manuelcecchetto/atp-mcp-server
If you are the rightful owner of atp-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
The ATP Librarian MCP Server is designed to manage task dependencies and ensure the integrity of task execution within a project by enforcing the Agent Task Protocol.
ATP Librarian MCP Server
This server enforces the Agent Task Protocol (.atp.json) contract so worker agents can claim, finish, and decompose tasks without corrupting the dependency graph. It exposes MCP tools that wrap deterministic updates to the plan file on disk.
Quick start (no clone, uvx)
Add to your MCP client config and update the plan path:
[mcp_servers.atp]
command = "uvx"
args = ["--from", "git+https://github.com/Edgeworthless/atp-mcp-server", "atp-server"]
env = { "ATP_FILE" = "/path/to/your/.atp.json", "ATP_LEASE_SECONDS" = "600" }
uvx downloads/builds on the fly. Tools still require plan_path per call; ATP_FILE is just a default.
Local install
pip install -e .- Run:
python3 main.py - Configure your MCP client to call that command, and pass
plan_pathon every tool call.
Docker (optional)
Build or pull, then mount your plan file:
docker build -t atp-librarian .
docker run --rm -v /path/to/.atp.json:/data/.atp.json -e ATP_FILE=/data/.atp.json atp-librarian
Environment knobs
ATP_FILE: path to the ATP plan file (default.atp.json).ATP_LOCK_FILE: override the lock file path (defaults to<ATP_FILE>.lock).ATP_LEASE_SECONDS: duration before a claimed task is released (default 600s).- Tools accept
plan_pathdirectly; the env vars mainly backstop the status resource or when clients omit the argument.
Available tools
atp_claim_task(plan_path, agent_id): Assigns the highest-priority READY node, recovers zombies, and returns dependency context. Re-enters an existing claim for the same agent.atp_complete_task(plan_path, node_id, report, artifacts=[], status="DONE"): Marks a task DONE or FAILED, clears the lease, and unlocks children whose dependencies are satisfied.atp_decompose_task(plan_path, parent_id, subtasks): Converts a task into a SCOPE with a new subgraph. Subtasks must form a DAG; start nodes inherit the parent’s original dependencies. The parent closes automatically once all new tasks complete.atp_read_graph(plan_path, view_mode="full" | "local", node_id=None): Returns the full JSON graph or a neighborhood view aroundnode_id.
Resource
atp://status/summary: Plaintext dashboard with project status, live claims, and ready tasks for the default plan (ATP_FILEor.atp.jsonin the current working directory).
Graph contract
- Keep the plan as a valid task DAG: each node has
title,instruction,dependencies,status(LOCKED|READY|CLAIMED|COMPLETED|FAILED), plus optionalcontext,artifacts,report, timestamps. - Node statuses:
LOCKED(waiting),READY,CLAIMED,COMPLETED,FAILED. The server will auto-release CLAIMED tasks after the lease window and auto-complete SCOPE nodes produced byatp_decompose_taskonce allscope_childrenfinish. - Dependency integrity is checked on every read/write; missing node references will raise errors instead of silently mutating the file.
Testing
python3 -m compileall main.py
MCP client config example
Example JSON config (Codex-compatible):
{
"mcpServers": {
"atp-librarian": {
"command": "python3",
"args": ["/path/to/atp-mcp-server/main.py"],
"cwd": "/path/to/atp-mcp-server",
"env": {
"ATP_FILE": "/path/to/your/project/.atp.json",
"ATP_LEASE_SECONDS": "600"
}
}
}
}
Tool calls should still provide plan_path (e.g., /path/to/your/project/.atp.json); ATP_FILE just sets a default for the status resource or when a client omits the argument.