backlog-mcp
backlog-mcp is an MCP server that gives AI agents structured read/write access to a story-based project backlog backed by plain markdown files in a requirements/ directory, with Git for versioning and collaboration.
Read operations:
list_stories— List stories with optional filtering by epic ID or status (draft,in-progress,done,blocked)get_story— Fetch full markdown content and metadata for a specific storyget_index_summary— High-level overview of all epics and story counts by status
Write operations:
set_story_status— Update a story's status in the index and backlog filesadd_story_note— Append a timestamped note to a story (for decisions, progress, or blockers)complete_story— Mark a story as done with a mandatory completion summarycreate_epic— Create a new epic with an auto-assignedEPIC-NNNID and optional descriptioncreate_story— Add a new story under an existing epic with an auto-assignedSTORY-NNNIDset_acceptance_criteria— Replace a story's acceptance criteria with a checklist (idempotent)
Deployment & collaboration:
Installable via Go or as a binary; configurable via
BACKLOG_ROOTandBACKLOG_TRANSPORT(stdioorhttp) environment variablesAll data lives in plain markdown files committable to Git, enabling multi-agent collaboration through standard Git workflows
Provides structured read/write access to story-based project backlogs stored as markdown files in git repositories, enabling AI agents to manage stories, update statuses, append notes, and handle collaboration through git's version control and merge capabilities.
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.
How collaboration works
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.
Related MCP server: Jira MCP
Install
Homebrew (tap)
brew tap corbym/backlog-mcp
brew install backlog-mcpYou can also install directly without an explicit tap step:
brew install corbym/backlog-mcp/backlog-mcpBinary release
Download the latest binary for your platform from the Releases page and put it somewhere on your $PATH.
Go install
If you have Go installed:
go install github.com/corbym/backlog-mcp@latestBuild from source
go mod tidy
go build -o backlog-mcp .Setup
Initialise a requirements/ folder in your project root:
./backlog-mcp init /path/to/your/project/requirementsThis 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 fileCommit the requirements/ folder to your repo. Edit the files to add your own epics and stories.
Running
./backlog-mcpThe 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.
Create a plan file
./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.
Configuring your MCP client
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.
Tools
Tool | Description |
| List stories, optionally filtered by |
| Get full markdown content and metadata for a story, including |
| High-level epic/story counts by status |
| Create a new epic — assigns next EPIC-NNN ID, writes epic file, registers in index |
| Create a new story under an epic — assigns next STORY-NNN ID, registers in index and backlog |
| Update epic lifecycle status with completion and regression guards (see below) |
| Update story status ( |
| Replace the acceptance criteria section of a story (idempotent) |
| Tick a single acceptance criterion |
| Append a timestamped note to a story file |
| Mark a story done with a mandatory completion summary and acceptance criteria validation |
| Reconcile an epic's |
| Update multiple acceptance-criteria checkbox states for one story in one call |
| Update multiple stories in one call (status, note, and/or acceptance criteria patches) |
| Update multiple epics in one call (status and/or note) |
set_epic_status guards
Setting status to done requires:
summary— a completion note, appended as a timestamped entry to the epic file.All stories done — if any stories are still open the call fails and lists them. Pass
override_incomplete=trueonly 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 guards
Acceptance 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.
Environment variables
Variable | Required | Default | Description |
| no |
| Override the path to the requirements directory |
File format
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
Automated PR backlog agent
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.
How it works
On every pull_request event (opened, synchronize) the workflow:
Installs the
backlog-mcpbinary viago install github.com/corbym/backlog-mcp@latest.Scans the PR title and branch name for
STORY-NNNIDs.For each matched story, sets status to
in-progress(if it wasdraftand the PR was just opened) and appends a timestamped note with the PR number and title.Commits any changed files under
requirements/back to the PR branch.
Setting it up in your repository
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 workflowThe files are in the corbym/backlog-mcp repository. No secrets or additional configuration are required beyond a requirements/ folder already being present.
Branch and PR naming
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 cleanlySee CONTRIBUTING.md for the full convention.
Using backlog-mcp with GitHub Copilot agent mode
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.
Notes
File writes are atomic (temp file + rename) — a crash mid-write cannot corrupt your files.
The filesystem is the source of truth. The MCP server never owns the data.
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/corbym/backlog-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server