mcacp
Bridges any MCP client (like Claude Code, Zed, VS Code) to any ACP coding agent, enabling multi-agent orchestration from a single chat interface.
README
MCACP
Bridge any MCP client to any ACP coding agent.
MCACP is an MCP server that speaks the Agent Client Protocol on behalf of your MCP host. It lets Claude Code, Zed, VS Code, or any MCP-compatible client spawn, manage, and interact with ACP coding agents — turning a single chat window into a multi-agent control plane.
MCP Client (Claude Code, Zed, VS Code, ...)
|
| MCP (stdio)
v
MCACP
|
| ACP (stdio, per agent)
v
Claude Code · Gemini CLI · Codex · Auggie · Copilot · ...
What can you do with this?
Run any ACP agent from any MCP client. You don't need a dedicated IDE plugin for each agent. Install Gemini from Claude Code. Run Codex from Zed. Mix and match.
Compare agents side by side. Give the same task to Claude Code ACP and Gemini CLI in parallel sessions and compare the results.
Build agent-driven pipelines. One agent writes code, another reviews it, a third runs the tests. MCACP handles the lifecycle and permission flow for all of them.
Control permissions interactively. On hosts that support MCP elicitation (Zed), permission requests pop up as interactive forms. On hosts that don't (Claude Code), they fall back to operator mode where the host agent decides.
Resume where you left off. Sessions persist to disk. Shut down, restart, load_session — the agent picks up where it stopped.
Discover and install agents from chat. Browse the ACP registry, install agents, check for upgrades — without leaving your conversation.
Quick start
Install
npm install -g mcacp
Or run directly:
npx mcacp
Add to your MCP client
Claude Code (~/.claude/settings.json):
{
"mcpServers": {
"mcacp": {
"command": "npx",
"args": ["-y", "mcacp"]
}
}
}
Zed (settings.json):
{
"context_servers": {
"mcacp": {
"command": { "path": "npx", "args": ["-y", "mcacp"] }
}
}
}
Then from chat:
"Search for available agents" → registry_search
"Install the Gemini agent" → agent_install
"Initialize it and start a session" → initialize + new_session
"Ask it to refactor auth" → prompt_start + prompt
MCP tools
MCACP exposes 22 tools organized into five groups.
Registry
| Tool | Description |
|---|---|
list_installed_agents |
List locally installed agents |
registry_search |
Search the ACP agent registry |
agent_install |
Install an agent from the registry |
agent_uninstall |
Remove an installed agent |
agent_check_upgrades |
Check for available upgrades |
discover_agents |
Scan editor configs (Zed, JetBrains) for agents |
reload_config |
Reload mcacp.json from disk |
Lifecycle
| Tool | Description |
|---|---|
initialize |
Spawn an agent process and perform the ACP handshake |
shutdown |
Gracefully shut down an agent |
Sessions
| Tool | Description |
|---|---|
new_session |
Create a session with working directory and permission policy |
load_session |
Resume a persisted session |
list_sessions |
List stored sessions for an agent |
close_session |
Close a session (preserved for later resume) |
Interaction
| Tool | Description |
|---|---|
prompt_start |
Send a prompt (returns immediately) |
prompt |
Block until events are available |
prompt_events |
Non-blocking poll for events |
grant_permission |
Resolve a pending permission request (operator mode) |
request_permission |
Send an MCP elicitation to the host for a permission decision |
cancel |
Cancel an in-progress prompt |
set_mode |
Switch agent operating mode |
Status
| Tool | Description |
|---|---|
list_running_agents |
List all agents with status and sessions |
get_agent_status |
Detailed status of a running agent |
set_agent_status |
Set status text for an agent |
Permission policies
Each session can use a different policy:
| Policy | Behavior |
|---|---|
allow_all |
Auto-approve all agent actions |
deny_all |
Block all tool use |
elicit |
Forward as MCP elicitations to the host; falls back to operator if unsupported |
operator |
Queue as events — the host agent decides via grant_permission |
Operator flow
Orchestrator MCACP ACP Agent
| | |
|-- prompt(sessionId, ...) ->| |
| |-- session/prompt --------->|
| |<- request_permission ------|
|<- {pendingPermission: ...} | |
| | |
|-- grant_permission ------->| |
| {toolCallId, optionId} |-- permission outcome ----->|
| |<- prompt result -----------|
|<- {stopReason, updates} | |
Configuration
MCACP looks for mcacp.json in these locations (first found wins):
--configflag orMCACP_CONFIGenv var.mcacp/mcacp.jsonin the current directory~/.config/mcacp/mcacp.json
{
"registries": ["https://cdn.agentclientprotocol.com/registry/v1/latest/registry.json"],
"defaultPermissionPolicy": "elicit",
"agent_servers": {
"my-custom-agent": {
"command": "node",
"args": ["my-agent.js"]
}
}
}
See docs/configuration.md for the full schema.
Building from source
git clone https://github.com/Oortonaut/mcacp.git
cd mcacp
npm install
npm run build
node dist/index.js
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.