Skip to main content

MCP bridge for MPAC: coordinate coding agents working on the same repository

Project description

mpac-mcp

arXiv PyPI

📄 Paper: MPAC: A Multi-Principal Agent Coordination Protocol for Interoperable Multi-Agent Collaboration (arXiv:2604.09744)

mpac-mcp is the MCP-facing bridge for MPAC — it lets MCP-aware coding clients (Claude Code, Cursor, any MCP host) participate in an MPAC coordination session without re-implementing the protocol themselves. The underlying protocol and reference runtime live in mpac-protocol / the mpac package.

It does not re-implement the coordination protocol. Instead it:

  • detects the current repository context
  • ensures a local MPAC sidecar is running
  • queries the sidecar for shared coordination state
  • exposes high-level tools to MCP-compatible coding clients

All bundled smoke scripts now run against an isolated scratch workspace copied from the requested repo path, so repeated runs do not inherit stale conflicts or frozen scope from a long-lived sidecar session.

Current scope

This initial scaffold focuses on the shortest end-to-end path:

  • local sidecar auto-discovery / auto-start
  • repository-root detection
  • session summary query
  • first MCP tools:
    • who_is_working
    • begin_task
    • check_overlap
    • get_file_state
    • ack_conflict
    • submit_change
    • yield_task
    • escalate_conflict
    • resolve_conflict
    • take_over_task
  • a Milestone 0 validation script for "two processes share one local coordinator"
  • an end-to-end smoke script for "one external client + one MCP-owned task"
  • an end-to-end smoke script for "begin task -> submit change -> yield task"
  • an end-to-end smoke script for "ack -> escalate -> resolve"
  • an end-to-end smoke script for "suspend -> claim -> take over"

Multi-tenant Hosted Mode (Authenticated Profile)

When deploying a hosted coordinator for multiple projects/teams:

  1. Set MPAC_TOKEN_TABLE as a JSON env var mapping bearer tokens to allowed sessions:

    {
      "<token-for-alice>": {"allowed_sessions": ["proj-alpha"], "roles": ["contributor"]},
      "<token-for-bob>":   {"allowed_sessions": ["proj-beta"],  "roles": ["contributor"]}
    }
    
  2. Start the sidecar in multi-session mode:

    mpac-mcp-sidecar --multi-session --host 0.0.0.0 --port 8766 --tls
    

    The sidecar auto-detects MPAC_TOKEN_TABLE and switches to security_profile=authenticated.

  3. Clients connect with their token in the HELLO credential field:

    wss://your-host/session/proj-alpha
    

    Tokens bound to proj-alpha can only join proj-alpha — cross-session access returns CREDENTIAL_REJECTED.

See deploy/fly-coordinator/ for a complete Docker + Caddy + fly.io deployment recipe.

Development status

This directory is the start of the mpac-mcp product entry point. It is intentionally thin: MPAC remains the runtime and coordination engine; mpac-mcp is the integration layer.

Running the Milestone 0 smoke check

From this repository root:

python3 mpac-mcp/src/mpac_mcp/milestone0.py --workspace .

This will:

  • derive a deterministic local sidecar port from the repo path
  • start the local sidecar if it is not already running
  • launch two independent demo clients
  • announce two overlapping intents
  • query the sidecar summary and print the result

Running the tool smoke check

From this repository root:

python3 mpac-mcp/src/mpac_mcp/smoke_tools.py --workspace .

This will:

  • ensure the local sidecar is running
  • launch one independent demo client
  • call begin_task(...) through the bridge
  • call check_overlap(...)
  • confirm that overlap is visible through shared sidecar state

Running the commit smoke check

From this repository root:

python3 mpac-mcp/src/mpac_mcp/smoke_commit.py --workspace .

This will:

  • ensure the local sidecar is running
  • call begin_task(...)
  • call submit_change(...) once with a derived state_ref_before
  • verify the sidecar state changed
  • call yield_task(...)

Running the governance smoke check

From this repository root:

python3 mpac-mcp/src/mpac_mcp/smoke_governance.py --workspace .

This will:

  • ensure the local sidecar is running
  • launch one contributor client and one arbiter client
  • call begin_task(...) to create a real overlap
  • call ack_conflict(...)
  • call escalate_conflict(...)
  • call resolve_conflict(...)

Running the takeover smoke check

From this repository root:

python3 mpac-mcp/src/mpac_mcp/smoke_takeover.py --workspace .

This will:

  • ensure the local sidecar is running
  • launch one client that leaves with GOODBYE(intent_disposition="transfer")
  • verify the sidecar exposes a suspended intent
  • call take_over_task(...)
  • verify the replacement intent becomes active

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mpac_mcp-0.2.3.tar.gz (38.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mpac_mcp-0.2.3-py3-none-any.whl (43.7 kB view details)

Uploaded Python 3

File details

Details for the file mpac_mcp-0.2.3.tar.gz.

File metadata

  • Download URL: mpac_mcp-0.2.3.tar.gz
  • Upload date:
  • Size: 38.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for mpac_mcp-0.2.3.tar.gz
Algorithm Hash digest
SHA256 2da51af7f08849619bb3172a22dfd79ccde9601848b0752d668c95e2a002535c
MD5 09aaaf45e0bd8cd38dd895be55b4e86e
BLAKE2b-256 2796ecec2c8577760615eea16d34458021082c54100aac53cdfc07546b970129

See more details on using hashes here.

File details

Details for the file mpac_mcp-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: mpac_mcp-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 43.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for mpac_mcp-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 b43dbf71e4652398fbd4a8b780c692f708997541eb1966599b91a6f46c5399d9
MD5 e5bdb19c56b0790fd65c300729818a9b
BLAKE2b-256 453c0303d7e0fdd28084a922bded804a5adf8058fd385a9eeb6dd215f8bb8187

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page