A community-driven registry for the Claude Code ecosystem. Not affiliated with Anthropic.
Are you the author? Sign in to claim
backlog-mcp
An MCP server that gives AI agents structured read/write access to a story-based project backlog. Agents can list stories, read content, update status, and append notes — all backed by plain markdown files that live inside your project repository.
There is no shared server. The backlog files live in your repo under requirements/, committed and versioned alongside your code. Collaboration between agents, or between an agent and a human, works exactly the way the rest of your codebase does: through git. If two agents update different stories concurrently, git merges them. If they touch the same line, you resolve it like any other merge conflict.
The MCP server is a local process each agent runs for itself. It reads and writes files; git handles the rest.
brew tap corbym/backlog-mcp
brew install backlog-mcp
You can also install directly without an explicit tap step:
brew install corbym/backlog-mcp/backlog-mcp
Download the latest binary for your platform from the Releases page and put it somewhere on your $PATH.
If you have Go installed:
go install github.com/corbym/backlog-mcp@latest
go mod tidy
go build -o backlog-mcp .
Initialise a requirements/ folder in your project root:
./backlog-mcp init /path/to/your/project/requirements
This creates:
requirements/
requirements-index.md # master index — source of truth for epics and story status
backlog.md # priority-ordered list of not-done stories
epic-001-example/
story-001.md # example story file
Commit the requirements/ folder to your repo. Edit the files to add your own epics and stories.
./backlog-mcp
The server looks for a requirements/ directory relative to the working directory it is launched from. Claude Code sets the working directory to the project root, so no configuration is needed.
./backlog-mcp plan [name]
Creates a new plan scaffold in the requirements/ directory. Without a name the file is plan.md; with a name it is plan-<name>.md. If the file already exists a numeric suffix is added (plan-002.md, etc.). Open the file and work with your agent to fill it in before creating stories.
Prefer a local config file committed to your project root. This scopes the server to the project and means any agent cloning the repo gets the right setup automatically. Only use a global config if you want backlog-mcp available in every project without per-project configuration.
VS Code / GitHub Copilot — add .vscode/mcp.json to your project root:
{
"servers": {
"backlog-mcp": {
"command": "/path/to/backlog-mcp",
"type": "stdio"
}
}
}
Claude Code — add .claude/settings.json to your project root:
{
"mcpServers": {
"backlog-mcp": {
"command": "/path/to/backlog-mcp"
}
}
}
For a global fallback (applies to every project), place the same config in ~/.claude/settings.json (Claude Code) or add it to VS Code's user settings.json under the mcp.servers key (GitHub Copilot). Always prefer the local per-project file.
| Tool | Description |
|---|---|
list_stories | List stories, optionally filtered by epic_id, status, or story_type |
get_story | Get full markdown content and metadata for a story, including story_type |
get_index_summary | High-level epic/story counts by status |
create_epic | Create a new epic — assigns next EPIC-NNN ID, writes epic file, registers in index |
create_story | Create a new story under an epic — assigns next STORY-NNN ID, registers in index and backlog |
set_epic_status | Update epic lifecycle status with completion and regression guards (see below) |
set_story_status | Update story status (draft, in-progress, blocked, deferred) in index and backlog |
set_acceptance_criteria | Replace the acceptance criteria section of a story (idempotent) |
check_acceptance_criterion | Tick a single acceptance criterion [x] by index or text |
add_story_note | Append a timestamped note to a story file |
complete_story | Mark a story done with a mandatory completion summary and acceptance criteria validation |
groom_epic | Reconcile an epic's ## Stories section against story files and index data |
bulk_update_acceptance_criteria | Update multiple acceptance-criteria checkbox states for one story in one call |
bulk_update_stories | Update multiple stories in one call (status, note, and/or acceptance criteria patches) |
bulk_update_epics | Update multiple epics in one call (status and/or note) |
set_epic_status guardsSetting status to done requires:
summary — a completion note, appended as a timestamped entry to the epic file.override_incomplete=true only after the user explicitly confirms the incomplete stories are intentionally omitted.Moving backwards (e.g. done → in-progress, in-progress → draft) triggers a regression prompt: the agent should offer to create new stories before proceeding. Pass confirm_regression=true only if the user explicitly insists on skipping that step. blocked and deferred are lateral states and can be set freely.
complete_story guardsAcceptance criteria must be set (not the default placeholder) before a story can be completed. Unchecked criteria block completion unless incomplete_items is provided with one explanation per unchecked item. Tick done criteria [x] via set_acceptance_criteria first — do not use incomplete_items to confirm work that is actually finished.
| Variable | Required | Default | Description |
|---|---|---|---|
BACKLOG_ROOT | no | requirements | Override the path to the requirements directory |
requirements-index.md — one epic section per heading, one story per table row:
## EPIC-001: Combat System — `draft`
| Story | Title | Status | Type |
|-------|-------|--------|------|
| [STORY-001](./epic-001-combat-system/story-001.md) | Basic combat | draft | feature |
backlog.md — priority-ordered numbered list:
1. **STORY-001** — Basic combat
2. **STORY-002** — Enemy AI *(in-progress)*
Story files live at epic-NNN-slug/story-NNN.md under BACKLOG_ROOT.
Story types: feature, bug, chore, spike
Status values: draft, in-progress, done, blocked, deferred
A GitHub Actions workflow is included that automatically updates story statuses and appends notes when pull requests are opened or updated. It requires no API keys — only the standard GITHUB_TOKEN.
On every pull_request event (opened, synchronize) the workflow:
backlog-mcp binary via go install github.com/corbym/backlog-mcp@latest.STORY-NNN IDs.in-progress (if it was draft and the PR was just opened) and appends a timestamped note with the PR number and title.requirements/ back to the PR branch.Copy these three files into your repo:
.github/
actions/
install/
action.yml # composite action — installs the binary via go install
scripts/
backlog_agent.py # deterministic MCP client (Python 3, stdlib only)
workflows/
backlog-agent.yml # the workflow
The files are in the corbym/backlog-mcp repository. No secrets or additional configuration are required beyond a requirements/ folder already being present.
The agent matches stories by STORY-NNN ID. Include the ID in your branch name or PR title:
story-042-short-description # branch
STORY-042: Short description # PR title
STORY-042 STORY-043: Short desc # multiple stories
chore: bump goreleaser to v2 # no story — agent skips cleanly
See CONTRIBUTING.md for the full convention.
GitHub Copilot's agent mode in VS Code reads MCP servers from .vscode/mcp.json in your project root. Note the key is "servers", not "mcpServers" (which is the Claude Code convention):
{
"servers": {
"backlog-mcp": {
"command": "/path/to/backlog-mcp",
"type": "stdio"
}
}
}
MCP tools are only available in Agent mode — switch to it via the mode dropdown in Copilot Chat. Once configured, Copilot agent can call list_stories, get_story, add_story_note, and all other backlog tools during a chat session — the same tools the GitHub Actions workflow uses.
Run Claude Code as an MCP server so any agent can delegate coding tasks to it
Browser automation using accessibility snapshots instead of screenshots
English-first Korean equity intelligence MCP — DART filings, foreign-holder 5%-rule flows, activist filings, KRX news. F
Unity MCP acts as a bridge between AI assistants and your Unity Editor. Give your LLM tools to manage assets, control sc