# MCP (Model Context Protocol) ADR (Architectural Decision Record) Analysis Server
[](https://github.com/tosin2013/mcp-adr-analysis-server)
[](LICENSE)
[](https://www.npmjs.com/package/mcp-adr-analysis-server)
[](https://nodejs.org/)
[](https://www.typescriptlang.org/)
[](https://github.com/tosin2013/mcp-adr-analysis-server/issues?q=is%3Aissue+is%3Aopen+label%3A%22good+first+issue%22)
> **AI-powered architectural analysis for intelligent development workflows.** Returns actual analysis results, not prompts to submit elsewhere.
## What is MCP?
The **Model Context Protocol (MCP)** is an open standard that enables seamless integration between AI assistants and external tools and data sources. Think of it as a universal adapter that lets AI assistants like Claude, Cline, and Cursor connect to specialized analysis servers. This server enhances AI assistants with deep architectural analysis capabilities, enabling intelligent code generation, decision tracking, and development workflow automation.
## TL;DR
**What:** MCP server that provides AI-powered architectural decision analysis and ADR management
**Who:** AI coding assistants (Claude, Cline, Cursor), enterprise architects, development teams
**Why:** Get immediate architectural insights instead of prompts, with 95% confidence scoring
**How:** `npm install -g mcp-adr-analysis-server` → Configure with OpenRouter API → Start analyzing
**Key Features:** Tree-sitter AST analysis • Security content masking • Test-driven development • Deployment readiness validation
<details>
<summary><b>Key Terms</b></summary>
| Term | Definition |
| ---------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| **ADR** | **Architectural Decision Record** — A document that captures an important architectural decision along with its context, alternatives considered, and consequences. |
| **MCP** | **Model Context Protocol** — An open standard enabling AI assistants to connect to external tools and data sources. |
| **Tree-sitter** | An incremental parsing library that provides AST (Abstract Syntax Tree) analysis for 50+ languages. Used for semantic code understanding, extracting function signatures, and identifying architectural patterns. |
| **Knowledge Graph** | A graph database maintained by the server that tracks relationships between ADRs, code implementations, and architectural decisions. Enables intelligent code linking and impact analysis. |
| **Smart Code Linking** | AI-powered discovery of code files related to ADRs and architectural decisions, using keyword extraction and semantic search. |
</details>
---
**Author**: [Tosin Akinosho](https://github.com/tosin2013) | **Repository**: [GitHub](https://github.com/tosin2013/mcp-adr-analysis-server.git)
## ✨ Core Capabilities
🤖 **AI-Powered Analysis** - Immediate architectural insights with OpenRouter.ai integration
🏗️ **Technology Detection** - Identify any tech stack and architectural patterns
📋 **ADR Management** - Generate, suggest, and maintain Architectural Decision Records
🔗 **Smart Code Linking** - AI-powered discovery of code files related to ADRs and decisions
🛡️ **Security & Compliance** - Detect and mask sensitive content automatically
🧪 **TDD Integration** - Two-phase Test-Driven Development with validation
🚀 **Deployment Readiness** - Zero-tolerance test validation with hard blocking
📖 **[View Full Capabilities →](docs/explanation/)**
## Prerequisites
Before installing, verify you have:
```bash
node --version # Should show v20.0.0 or higher
npm --version # Should show 9.0.0 or higher (included with Node.js 20+)
```
**Required:**
- **Node.js 20.0.0 or higher** — [Download](https://nodejs.org/) or use [nvm](https://github.com/nvm-sh/nvm)/[fnm](https://github.com/Schniz/fnm)
- **npm 9.0.0 or higher** (included with Node.js 20+)
- **An MCP-compatible client** — [Claude Desktop](https://claude.ai/download), [Cline](https://marketplace.visualstudio.com/items?itemName=saoudrizwan.claude-dev), [Cursor](https://cursor.sh/), or [Windsurf](https://codeium.com/windsurf)
### Network Requirements
- **Internet access required** during `npm install` for native module compilation (tree-sitter-yaml, tree-sitter-typescript)
- If behind a corporate proxy, set `HTTP_PROXY` and `HTTPS_PROXY` environment variables
- **Offline fallback**: If native builds fail, the server operates in reduced mode without tree-sitter code analysis
## 📦 Quick Installation
```bash
# Option 1: Global installation (recommended for frequent use)
npm install -g mcp-adr-analysis-server
# Option 2: Use npx (no installation required)
npx mcp-adr-analysis-server
# Option 3: From source (for development or customization)
git clone https://github.com/tosin2013/mcp-adr-analysis-server.git
cd mcp-adr-analysis-server && npm install && npm run build
# Option 4: RHEL 9/10 systems (special installer)
curl -sSL https://raw.githubusercontent.com/tosin2013/mcp-adr-analysis-server/main/scripts/install-rhel.sh | bash
```
> **Note:** When installing from source, `npm run build` is required before running the server since the `bin` entry points to `./dist/src/index.js`.
📖 **[Detailed Installation Guide →](docs/tutorials/01-first-steps.md)** | **[RHEL Setup →](scripts/install-rhel.sh)**
## ⚡ Quick Setup (3 Steps)
1. **Get API Key**: Sign up at [OpenRouter.ai/keys](https://openrouter.ai/keys) — OpenRouter is an API gateway that provides access to multiple AI models (Claude, GPT, etc.) through a single key. _No API key? The server still works in prompt-only mode — see [Execution Modes](#execution-modes) below._
2. **Set Environment**: `OPENROUTER_API_KEY=your_key` + `EXECUTION_MODE=full`
3. **Configure Client**: Add to Claude Desktop, Cline, Cursor, or Windsurf
```json
{
"mcpServers": {
"adr-analysis": {
"command": "mcp-adr-analysis-server",
"env": {
"PROJECT_PATH": "/path/to/your/project",
"OPENROUTER_API_KEY": "your_key_here",
"EXECUTION_MODE": "full"
}
}
}
}
```
> **Claude Desktop users:** Save this JSON to `~/Library/Application Support/Claude/claude_desktop_config.json` (macOS) or `%APPDATA%\Claude\claude_desktop_config.json` (Windows).
<details>
<summary><b>Config locations for other clients</b></summary>
| Client | Config file location |
| ---------------------------- | ----------------------------------------------------------------------------- |
| **Claude Desktop (macOS)** | `~/Library/Application Support/Claude/claude_desktop_config.json` |
| **Claude Desktop (Windows)** | `%APPDATA%\Claude\claude_desktop_config.json` |
| **Cline (VS Code)** | VS Code Settings → Cline → MCP Servers (or `.vscode/cline_mcp_settings.json`) |
| **Cursor** | Cursor Settings → MCP → Add Server |
</details>
<details>
<summary><b>With ADR Aggregator (Optional)</b></summary>
```json
{
"mcpServers": {
"adr-analysis": {
"command": "mcp-adr-analysis-server",
"env": {
"PROJECT_PATH": "/path/to/your/project",
"OPENROUTER_API_KEY": "your_key_here",
"EXECUTION_MODE": "full",
"ADR_AGGREGATOR_API_KEY": "agg_your_key_here"
}
}
}
}
```
Get your API key at [adraggregator.com](https://adraggregator.com)
</details>
📖 **[Full Configuration Guide →](docs/reference/mcp-client-config.md)** | **[Client Setup →](docs/reference/environment-config.md)**
### Execution Modes
| | **Full Mode** | **Prompt-Only Mode** |
| ------------------------ | ---------------------------------------------------------------------------------- | ----------------------------------------------------------------- |
| **Requires API key?** | Yes (`OPENROUTER_API_KEY`) | No |
| **Returns** | Actual analysis results with confidence scores | Prompts you can paste into any AI chat |
| **Set via** | `EXECUTION_MODE=full` | `EXECUTION_MODE=prompt-only` (default) |
| **Best for** | Production use, automation | Trying it out, no-cost exploration |
| **Available Features** | All 73 tools, AI analysis, confidence scoring, Smart Code Linking, Knowledge Graph | Analysis prompts, templates, local file operations, ADR discovery |
| **Unavailable Features** | — | AI execution, confidence scores, Smart Code Linking, web research |
**Tip:** Start with prompt-only mode to explore the tool catalog — you can analyze projects, discover ADRs, and generate templates without an API key. Add an API key when you're ready for AI-powered analysis with confidence scoring.
## 🚀 Usage Examples
Just ask your MCP client in natural language — no code required:
> "Analyze this React project's architecture and suggest ADRs for any implicit decisions"
> "Generate ADRs from the PRD.md file and create a todo.md with implementation tasks"
> "Check this codebase for security issues and provide masking recommendations"
**The server returns actual analysis results** instead of prompts to submit elsewhere!
<details>
<summary><b>Programmatic Usage (Advanced)</b></summary>
If you're integrating the server into your own tooling via the MCP SDK:
```typescript
// Basic project analysis
const analysis = await analyzeProjectEcosystem({
projectPath: '/path/to/project',
analysisType: 'comprehensive',
});
// Generate ADRs from requirements
const adrs = await generateAdrsFromPrd({
prdPath: 'docs/PRD.md',
outputDirectory: 'docs/adrs',
});
// Smart Code Linking - Find code related to ADR decisions
const relatedCode = await findRelatedCode(
'docs/adrs/001-auth-system.md',
'We will implement JWT authentication with Express middleware',
'/path/to/project',
{
useAI: true, // AI-powered keyword extraction
useRipgrep: true, // Fast text search
maxFiles: 10, // Limit results
includeContent: true, // Include file contents
}
);
```
</details>
📖 **[Complete Usage Guide →](docs/tutorials/)** | **[API Reference →](docs/reference/)**
> **Try it out:** This repo includes a [`sample-project/`](sample-project/) directory with example ADRs and source code. Point `PROJECT_PATH` at it to experiment without affecting your own codebase.
>
> **Note:** The sample project is only available when **cloning from source** (Option 3 above). If you installed via npm (Option 1 or 2), create your own test project or clone the repo separately to access the sample: `git clone --depth 1 https://github.com/tosin2013/mcp-adr-analysis-server.git sample-test`
## 🎯 Use Cases
👨💻 **AI Coding Assistants** - Enhance Claude, Cline, Cursor with architectural intelligence
💬 **Conversational AI** - Answer architecture questions with confidence scoring
🤖 **Autonomous Agents** - Continuous analysis and rule enforcement
🏢 **Enterprise Teams** - Portfolio analysis and migration planning
📖 **[Detailed Use Cases →](docs/explanation/mcp-concepts.md)**
## 🛠️ Technology Stack
**Runtime:** Node.js 20+ • **Language:** TypeScript • **Framework:** MCP SDK • **Testing:** Jest (>80% coverage)
**Search:** ripgrep (fast text search) + fast-glob (file matching) • **AI Integration:** OpenRouter.ai • **Web Research:** Firecrawl • **Code Analysis:** tree-sitter (code parser) + Smart Code Linking
📖 **[Technical Details →](docs/explanation/server-architecture.md)**
## 📁 Project Structure
```
src/tools/ # 73 MCP tools for analysis
docs/adrs/ # Architectural Decision Records
tests/ # >80% test coverage
.github/ # CI/CD automation
```
📖 **[Full Structure →](docs/tutorials/)**
## 🧪 Testing
```bash
npm test # Run all tests (>80% coverage)
npm run test:coverage # Coverage report
```
📖 **[Testing Guide →](docs/how-to-guides/troubleshooting.md)**
## 🔥 Firecrawl Integration (Optional — Skip for Getting Started)
**Enhanced web research capabilities for comprehensive architectural analysis.**
> **Note:** You don't need Firecrawl for basic ADR analysis. The server works fully without it. Only configure Firecrawl if you need web research features like the `perform_research` tool with external sources.
<details>
<summary><b>When is Firecrawl useful?</b></summary>
- **ADR research** — automatically pull best practices from official docs when generating ADRs
- **Technology evaluation** — compare frameworks by crawling their documentation and changelogs
- **Security audits** — check CVE databases and security advisories for your dependencies
- **Migration planning** — gather migration guides and breaking-change notes from upstream projects
</details>
```bash
# Option 1: Cloud service (recommended)
export FIRECRAWL_ENABLED="true"
export FIRECRAWL_API_KEY="fc-your-api-key-here"
# Option 2: Self-hosted
export FIRECRAWL_ENABLED="true"
export FIRECRAWL_BASE_URL="http://localhost:3000"
# Option 3: Disabled (default - server works without web search)
```
📖 **[Firecrawl Setup Guide →](docs/reference/environment-config.md#firecrawl-configuration)**
## 🌐 ADR Aggregator Integration (Optional)
[ADR Aggregator](https://adraggregator.com) is a platform for cross-team ADR visibility and governance. It provides:
- **Cross-repository knowledge graphs** — See how architectural decisions relate across projects
- **Governance dashboards** — Track ADR compliance, staleness, and review cycles
- **Template library** — Access domain-specific ADR templates (security, API, database, etc.)
- **Team collaboration** — Share architectural decisions organization-wide
> **Note:** ADR Aggregator is optional. All core analysis features work without it.
```bash
# Set your API key (get one at adraggregator.com)
export ADR_AGGREGATOR_API_KEY="agg_your_key_here"
```
### Available Tools
| Tool | Description | Free | Pro+ | Team |
| ------------------------- | ---------------------------------- | ---- | ---- | ---- |
| `sync_to_aggregator` | Push local ADRs to platform | ✅ | ✅ | ✅ |
| `get_adr_context` | Pull ADR context from platform | ✅ | ✅ | ✅ |
| `get_staleness_report` | Get ADR governance/health reports | ✅ | ✅ | ✅ |
| `get_adr_templates` | Retrieve domain-specific templates | ✅ | ✅ | ✅ |
| `get_adr_diagrams` | Get Mermaid diagrams for ADRs | — | ✅ | ✅ |
| `validate_adr_compliance` | Validate ADR implementation | — | ✅ | ✅ |
| `get_knowledge_graph` | Cross-repository knowledge graph | — | — | ✅ |
### Workflow for New Repos
```bash
# 1. Analyze codebase for implicit architectural decisions
suggest_adrs(analysisType: 'implicit_decisions')
# 2. Generate ADR files from suggestions
generate_adr_from_decision(decisionData)
# 3. Save ADRs to docs/adrs/
# 4. (Optional) Sync to adraggregator.com
sync_to_aggregator(full_sync: true)
```
**Benefits:** Cross-team visibility • Staleness alerts • Compliance tracking • Organization-wide knowledge graph
📖 **[ADR Aggregator Guide →](https://adraggregator.com/docs)**
## 🔧 Development
```bash
git clone https://github.com/tosin2013/mcp-adr-analysis-server.git
cd mcp-adr-analysis-server
npm install && npm run build && npm test
```
**Quality Standards:** TypeScript strict mode • ESLint • >80% test coverage • Pre-commit hooks
### Viewing Documentation Locally
The documentation site is built with [Docusaurus](https://docusaurus.io/):
```bash
cd docs
npm install
npm run build
npm run serve
```
Then open `http://localhost:3000/mcp-adr-analysis-server/` in your browser.
📖 **[Development Guide →](docs/how-to-guides/getting-started-workflow-guidance.md)** | **[Contributing →](CONTRIBUTING.md)**
## 🔧 Troubleshooting
**Common Issues:**
- **RHEL Systems**: Use special installer script
- **Tools return prompts**: Set `EXECUTION_MODE=full` + API key
- **Module not found**: Run `npm install && npm run build`
- **Permission denied**: Check file permissions and project path
📖 **[Complete Troubleshooting Guide →](docs/how-to-guides/troubleshooting.md)**
## 🔒 Security & Performance
**Security:** Automatic secret detection • Content masking • Local processing • Zero trust
**Performance:** Multi-level caching • Incremental analysis • Parallel processing • Memory optimization
📖 **[Security Guide →](docs/explanation/security-philosophy.md)** | **[Performance →](docs/explanation/performance-design.md)**
### 🔐 Security Vulnerability Reporting
Found a security issue? Please read our [Security Policy](SECURITY.md) for responsible disclosure procedures. **Do not** create public issues for security vulnerabilities.
## 🤝 Contributing
We welcome contributions! Whether you're fixing bugs, adding features, or improving documentation, your help is appreciated.
### 🌟 Quick Start for Contributors
1. **Fork** the repository
2. **Clone** your fork: `git clone https://github.com/YOUR_USERNAME/mcp-adr-analysis-server.git`
3. **Create** a branch: `git checkout -b feature/your-feature-name`
4. **Make** your changes with tests
5. **Test**: `npm test` (maintain >80% coverage)
6. **Submit** a Pull Request
### 👶 First Time Contributing?
Looking for a good first issue? Check out our [**good first issues**](https://github.com/tosin2013/mcp-adr-analysis-server/issues?q=is%3Aissue+is%3Aopen+label%3A%22good+first+issue%22) - these are beginner-friendly tasks perfect for getting started!
**New to open source?** Our [Contributing Guide](CONTRIBUTING.md) walks you through the entire process step-by-step.
### 📝 Reporting Issues
Use our [**issue templates**](https://github.com/tosin2013/mcp-adr-analysis-server/issues/new/choose) when reporting bugs or requesting features. Templates help us understand and resolve issues faster.
**Standards:** TypeScript strict • >80% coverage • ESLint • Security validation • MCP compliance
📖 **[Full Contributing Guide →](CONTRIBUTING.md)** | **[Code of Conduct →](docs/community/CODE_OF_CONDUCT.md)**
## 🔗 Resources
**Official:** [MCP Specification](https://modelcontextprotocol.io/) • [MCP SDK](https://github.com/modelcontextprotocol/typescript-sdk)
**Community:** [MCP Registry](https://github.com/modelcontextprotocol/servers) • [Discord](https://discord.gg/modelcontextprotocol)
**Project:** [ADRs](./docs/adrs/) • [Progress](./docs/release-dashboard.md) • [Publishing Guide](./docs/how-to-guides/NPM_PUBLISHING.md)
## 📄 License
MIT License - see [LICENSE](LICENSE) file for details.
## 🙏 Acknowledgments
- **Anthropic** for creating the Model Context Protocol
- **The MCP Community** for inspiration and best practices
- **Contributors** who help make this project better
---
**Built with ❤️ by [Tosin Akinosho](https://github.com/tosin2013) for AI-driven architectural analysis**
_Empowering AI assistants with deep architectural intelligence and decision-making capabilities._