agentsync
Enables multiple AI agents to collaborate on the same git repository by coordinating work via a shared claims branch, detecting file conflicts before they happen.
README
agentsync
An MCP server that lets two (or more) AI agents collaborate on the same git repository without stepping on each other. Each agent declares what it's building before it builds, sees what its partner has claimed, and detects conflicts when work lands — all coordinated through the repo itself, with no lock server and no requirement that both agents be online at once.
How it works (one paragraph)
Coordination state is a single claims.json living on a dedicated agentsync
branch (kept out of main, so it never pollutes your code history and isn't
blocked by main's branch protection). Each agent's claim declares the work,
the files it will touch, what it requires, its branch, and a status.
Overlap is plain set intersection. Writes use a read-modify-write loop with
git push as a compare-and-swap: if the push is rejected, the server
re-fetches the latest claims and re-evaluates, so a colliding peer claim is
observed before this agent's claim is committed. All git work happens in a
private worktree under .git/, so your agent's actual code branch is never
disturbed.
See DESIGN.md for the architecture rationale and AGENTS.md for the playbook your agent follows to drive the tools.
Install
pip install -r requirements.txt # just `mcp`
For repo provisioning you also need the GitHub CLI,
authenticated with repo scope:
gh auth login # one-time; check with `gh auth status`
Configure
Both collaborators add the server to their MCP client, each with their own
agent id and their own local clone. See mcp.config.example.json:
{
"mcpServers": {
"agentsync": {
"command": "python3",
"args": ["/abs/path/to/agentsync_server.py"],
"env": {
"AGENTSYNC_REPO": "/abs/path/to/your/clone",
"AGENTSYNC_AGENT_ID": "jonny"
}
}
}
}
| env var | required | default | meaning |
|---|---|---|---|
AGENTSYNC_REPO |
yes | — | path to your local clone |
AGENTSYNC_AGENT_ID |
yes | — | your unique agent id |
AGENTSYNC_REMOTE |
no | origin |
git remote name |
AGENTSYNC_BRANCH |
no | agentsync |
coordination branch name |
AGENTSYNC_PARTNER_GITHUB |
no | — | partner's GitHub user, invited by provision() |
The agentsync branch is created automatically on the first survey() or
claim() call — no manual setup.
Starting from nothing (no repo yet)
If the shared repo doesn't exist on GitHub yet, one person runs provision()
once. Point AGENTSYNC_REPO at the folder you want the project in (it can be
empty or not yet created) and call:
provision(repo="you/our-project", partner_github="their-username")
This creates the GitHub repo (private by default), makes the first commit, seeds
the agentsync coordination branch, and invites your partner as a push
collaborator. It's idempotent — safe to re-run. Then send your partner the
clone_url it returns; once they accept the invite and clone, both of you point
the MCP server at your own clones and the normal protocol below takes over.
Tools
provision(repo="", partner_github="", private=True, description="") —
one-time bootstrap when the shared repo doesn't exist yet. Creates the GitHub
repo via gh, makes the first commit, seeds the agentsync branch, and invites
the partner as a push collaborator. Idempotent. Returns the clone_url to hand
your partner. (Needs the gh CLI authenticated with repo scope.)
add_collaborator(github_username, permission="push") — invite someone to
the existing shared repo so they can push (pull|triage|push|maintain
|admin). Use this when the repo already exists and you just want to grant a
partner access. They must accept the GitHub invite, then clone. Returns the
clone URL to hand them. (Needs gh with admin on the repo.)
survey() — pull the latest state and report what every other agent has
claimed: task, files, dependencies, branch, status, timestamp. Run it before
planning and again after finishing.
claim(task, touches, requires=None, branch="", force=False) — stake a
unit of work. Refuses with status: "blocked" if your touches hits a
partner's active files (you'd get in their way) or your requires hits their
in-progress files (you'd build on unstable ground), returning exactly what
overlaps and with whom. The overlap is checked against freshly-fetched state
immediately before the push. Pass force=True to claim anyway (e.g. same large
file, disjoint regions).
check_conflicts(against_branch="") — after building, diff your branch
against your partners' branches at two levels:
claim_overlap— declared-file intersection (intent).merge_conflict— a realgit merge-treedry-run merge (textual). Catches collisions the claims didn't predict.
Defaults to every branch named in an active peer claim; pass against_branch
to check one specific branch.
update_status(status, note="") — set your own claim's status
(planning | in-progress | done) and optionally leave a note for your
partner. Pushes immediately.
The workflow (what your agent does)
provision(...)— once, only if the repo doesn't exist yet (then both clone)survey()— what's my partner working on, if anything?- plan a slice that doesn't overlap their active work
claim(...)— if blocked, narrow the slice or wait- build on your branch
survey()again — where are they now?check_conflicts()— does their landed work collide with mine?- reconcile (rebase/merge or flag) →
update_status("done", note=...)
The full prompt your agent should run is in AGENTS.md.
Test
python3 test_agentsync.py # spins up real git repos and drives every path
The suite (19 cases, isolated per test) covers the protocol (claim/block on
shared files and dependency-on-WIP, force override, done-claims-don't-block,
status validation), conflict detection (textual conflict and clean-merge),
the compare-and-swap guarantee (a peer claim landing mid-flight both
survives our retry and is observed in time to block a collision), error paths,
provisioning (create + seed + invite, partner-from-env, existing-remote skip,
invite-failure reporting), and add_collaborator (invite + bad-permission +
no-remote) with the gh CLI stubbed so no real GitHub repo is touched. CI runs
it on every push via GitHub Actions.
Limitations
- Textual, not semantic.
check_conflictscatches files that won't merge; it does not catch "their API signature change breaks my caller." That reasoning is the agent's job (read both diffs) — the server gives it the signal, not the judgment. - Both sides must opt in. This only works fully if your partner's agent runs the same server and honors the same claim protocol. Without that, yours degrades to branch inspection: it sees what has landed, not what's planned.
- Advisory locks. Claims prevent collisions by convention, not enforcement;
force=Trueexists precisely because some overlaps are fine.
License
PolyForm Noncommercial License 1.0.0 — free to use, modify, and share for any noncommercial purpose. Commercial use requires a separate license.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.