wooxogh/adr-mcp-setup
Automatically generates Architecture Decision Records (ADRs) from Claude Code conversations using Claude Opus. Features AI quality review, duplicate detection, dependency graph, and stale ADR alerts.
Ask AI about wooxogh/adr-mcp-setup
Powered by Claude Β· Grounded in docs
I know everything about wooxogh/adr-mcp-setup. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
adr-skills
adr-skills is an MCP server for Claude Code that automatically captures development conversations and uses Claude Opus to generate, review, and manage Architecture Decision Records (ADRs).
TL;DR: Install once, and every Claude Code session ends with a structured ADR saved to
~/.adr-mcp/adrs/β no manual writing required.
What problem does this solve?
Engineering teams make dozens of architectural decisions every week β which database to use, how to handle auth, whether to go monolith or microservices β but rarely write them down. Months later, nobody remembers why Redis was chosen over Memcached, or why the team avoided GraphQL.
adr-skills solves this by turning your existing Claude Code conversations into permanent, searchable ADR documents automatically.
How it works
- You have a normal development conversation in Claude Code
- When the session ends, the Stop Hook captures the transcript
- Claude Opus analyzes the conversation and extracts the architectural decision
- A structured markdown ADR is saved to
~/.adr-mcp/adrs/ADR-0001-*.md - Use
review_adrto score quality,link_adrsto map dependencies,check_stale_adrsto surface outdated decisions
Features
- Auto session capture β Stop Hook saves conversations automatically on Claude Code exit; no manual steps
- AI-powered ADR generation β Claude Opus extracts context, decision, and consequences from raw conversation
- AI quality review β Scores ADR completeness 0β100 and flags missing context, unconsidered alternatives, or optimistic consequences
- Duplicate detection β Warns when a new decision overlaps with a past one before saving
- Markdown export β Every ADR exported as
ADR-NNNN-slug.md, ready to commit alongside your code - Status lifecycle β Track decisions through
Proposed β Accepted β Deprecated β Superseded - Dependency graph β Link ADRs with
related_to,conflicts_with,depends_onand visualize relationships - Stale ADR alerts β Surface
Accepteddecisions older than N months that may need revisiting - Keyword search β Find past decisions by technology name (e.g. Redis, JWT, PostgreSQL)
- Timeline view β Full decision history per project, correlated with git commits
How is this different from existing ADR tools?
| Tool | Auto-capture from chat | AI generation | Quality review | MCP server |
|---|---|---|---|---|
| adr-skills | β | β Claude Opus | β | β |
| adr-tools (CLI) | β | β | β | β |
| mcp-adr-analysis-server | β | β OpenRouter | β | β |
| claude-historian-mcp | β | β | β | β |
| log4brains | β | β | β | β |
No existing tool combines automatic conversation capture with AI-powered ADR generation in a single MCP server. There is an open feature request on the Anthropic repo for native ADR support β adr-skills fills that gap today.
Installation
git clone https://github.com/wooxogh/adr-mcp-setup.git
cd adr-mcp-setup
npm install
Register with Claude Code
claude mcp add adr-skills node /absolute/path/to/adr-mcp-setup/index.js
Environment setup
cp .env.example .env
# Add your ANTHROPIC_API_KEY to .env
Without the API key,
generate_adrfalls back to keyword-based extraction andreview_adris unavailable..envis in.gitignoreβ your key will never be committed.
Enable auto session capture (Stop Hook)
Add to ~/.claude/settings.json:
{
"hooks": {
"Stop": [{
"matcher": "",
"hooks": [{
"type": "command",
"command": "node /absolute/path/to/adr-mcp-setup/hook.js"
}]
}]
}
}
Tools (9 total)
| Tool | Description | Requires API key |
|---|---|---|
save_session | Save a conversation to the database | β |
generate_adr | Auto-generate an ADR from a session | β (AI mode: β ) |
review_adr | Score ADR quality and get improvement suggestions | β |
update_adr_status | Transition ADR through its lifecycle | β |
link_adrs | Create relationships between ADRs | β |
get_adr_graph | Visualize the ADR dependency graph | β |
check_stale_adrs | Find old Accepted ADRs that need revisiting | β |
search_decisions | Keyword search across all past decisions | β |
get_timeline | Decision history for a project | β |
generate_adr example output
# ADR-1: Adopt Redis as the caching layer
## Status
Accepted
## Context
We needed pub/sub support for real-time notifications.
Memcached only handles simple key-value caching and could not meet this requirement.
## Decision
We adopted Redis as both cache and message broker.
It supports pub/sub, TTL, and persistence, and the team already has operational experience with it.
## Consequences
Real-time features can now be implemented without a separate message broker.
We must account for Redis operational costs and treat it as a potential single point of failure.
review_adr example output
## ADR-1 Review β Score: 62/100
Good context, but decision rationale and risk coverage need work.
### Issues
π΄ [decision] No alternatives were considered before choosing Redis
π‘ [consequences] Risks are mentioned but mitigation strategies are missing
### Suggestions
1. Explicitly document why Memcached was rejected
2. Add a rollback plan if Redis becomes a bottleneck
get_adr_graph example output
## ADR Dependency Graph
### depends on
ADR-5 "Use JWT for auth" β ADR-2 "Adopt Redis as cache"
### conflicts with
ADR-7 "Move to stateless sessions" β ADR-2 "Adopt Redis as cache"
FAQ
Q: Do I need an Anthropic API key?
No. Without a key, generate_adr uses keyword extraction as a fallback. With a key, Claude Opus produces significantly more accurate ADRs and review_adr becomes available.
Q: Where are ADRs stored?
Two places: SQLite database at ~/.adr-mcp/sessions.db and markdown files at ~/.adr-mcp/adrs/. The markdown files are git-committable.
Q: Can I use this without the Stop Hook?
Yes. Call save_session manually with your conversation text, then generate_adr with the returned session ID.
Q: Does this work with other AI assistants besides Claude? The MCP server protocol is open, but the Stop Hook is Claude Code-specific. The database and markdown exports are tool-agnostic.
Q: How does duplicate detection work? When generating an ADR, adr-skills extracts significant keywords from the title and decision text and queries for overlapping past ADRs. Matches are shown as warnings β the new ADR is still saved.
Q: What ADR format does this use? The Michael Nygard ADR format (Title, Status, Context, Decision, Consequences), which is the most widely adopted format in the software industry.
Project structure
adr-mcp-setup/
βββ index.js β MCP server β 9 tool definitions and routing
βββ db.js β SQLite CRUD (sessions, adrs, adr_relations tables)
βββ adr.js β ADR extraction and AI review logic (Claude Opus)
βββ hook.js β Claude Code Stop Hook for automatic session capture
βββ .env.example β Environment variable template
βββ package.json
Database: ~/.adr-mcp/sessions.db
ADR files: ~/.adr-mcp/adrs/ADR-NNNN-slug.md
Requirements
- Node.js 18+
- Claude Code CLI
- Anthropic API Key (optional β required for AI generation and review)
