Orcho — Model Context Protocol server for Claude Code, Cursor, Zed, and other MCP-speaking clients
Project description
orcho-mcp
Model Context Protocol server for Orcho.
Exposes orcho's runtime to MCP-aware clients (Claude Code, Cursor, Zed, and other MCP-speaking tools) over stdio. Full async control loop — act, observe, decide, inspect — without raw log scraping.
📖 Documentation: docs.orcho.dev
An AI client (here Claude Code) driving a run through this server —
orcho_run_start → orcho_run_watch → orcho_run_evidence → verdict, all
typed, no log scraping. Real session; the run is mock=True. Interactive
version: docs.orcho.dev.
Status:
v0.1.0public release line. Core control loop surfaces are available:
- Act:
orcho_run_start/orcho_run_resume/orcho_run_cancelwith L4-test-pinned semantics (process-group signal handling, supervisor-owned restart-recovery, race-aware cancel).- Observe:
orcho_run_status/orcho_run_history/orcho_run_metrics/orcho_run_events_tail— read-only, polling-friendly.- Decide:
orcho_phase_handoff_decide— generic phase-handoff state transition for paused runs. The pipeline pauses withstatus=awaiting_phase_handoffwhen a phase's declaredhandoffpolicy fires;continue/retry_feedback/haltwrite a decision artifact (haltflipsmeta.statustohaltedsynchronously). Pure state transition; never spawns.- Inspect:
orcho_run_evidence— typed inspection slices (plan/findings/commands/artifacts/errors/sub_runs/all) with severity filter (P0..P3).Live progress:
orcho_run_watchemits orderednotifications/progresswhen the MCP request carries aprogressToken. Clients that don't carry one pollorcho_run_status/orcho_run_events_tailagainst the same run state.
Install
Choose an install path:
| Path | Use when | Command |
|---|---|---|
Native CLI with pipx |
You want orcho and orcho-mcp available from the shell. |
pipx install orcho |
| Docker | You want the MCP server and agent CLIs isolated inside a container. | docker pull ghcr.io/symphos-ai/orcho |
| Direct MCP dependency | You intentionally want only this package in a virtualenv, CI image, devcontainer, or custom image. | python -m pip install orcho-mcp |
If pipx is missing, install it first. On macOS with Homebrew:
brew install pipx
pipx ensurepath
exec zsh -l
For Linux or Windows, use the official pipx installation guide.
Recommended CLI install
Use the orcho distribution when you want both the Orcho commands and the MCP
server available from your shell. Since orcho 0.1.1 the server ships by
default — no extra needed. pipx keeps the command set isolated from the
current project or Python environment.
pipx install orcho
orcho-mcp --help
Since orcho 0.1.1 this includes the MCP server by default. The [mcp] and
[all] extras remain as no-op aliases.
Containerized MCP server
Use Docker when an MCP client should start an isolated server over stdio:
docker run --rm -i \
-v /path/to/my-workspace:/workspace \
-v ~/.orcho-auth:/agent-auth:ro \
-e ORCHO_WORKSPACE=/workspace/workspace-orchestrator \
ghcr.io/symphos-ai/orcho \
orcho-mcp
Inside that server, projects live under /workspace/<project-name>. The
orcho Docker docs
cover one-time credential bootstrap and custom project toolchains.
Direct MCP package install
Use pip when you intentionally want orcho-mcp in the active virtual
environment, CI image, devcontainer, or Docker image.
python -m pip install orcho-mcp
This pulls orcho-core (the engine), the official mcp Python SDK, and the runtime pieces orcho-mcp depends on.
Create a workspace
Orcho writes run state into an Orcho workspace. Start by pointing it at the folder that groups your project repos:
orcho workspace init ~/www/my-workspace
The command creates ~/www/my-workspace/workspace-orchestrator/,
including .orcho/ settings and extension-point guides, and prints the
MCP config snippet for that workspace. To write the snippet directly
into a project-local MCP config:
ORCHO_MCP_COMMAND="$(command -v orcho-mcp)"
orcho workspace init ~/www/my-workspace \
--mcp-config ~/www/my-workspace/.mcp.json \
--mcp-server-name orcho-my-workspace \
--orcho-mcp-command "$ORCHO_MCP_COMMAND"
ORCHO_MCP_COMMAND must point to the command your MCP client can run.
For packaged installs this is normally orcho-mcp. For source installs,
use the absolute path inside the Orcho environment, for example
/Users/me/orcho-preview/orcho-core/.venv/bin/orcho-mcp.
Each MCP server process owns one workspace through ORCHO_WORKSPACE.
For multiple workspaces, add multiple MCP server entries.
Register with an MCP-aware client
Each client has its own MCP registry/config format. Use
docs/mcp_client_setup.md for copy-paste
instructions for Codex CLI/app, Claude Code, Gemini CLI, the Claude app,
and Antigravity.
What's inside
npx @modelcontextprotocol/inspector orcho-mcp
Opens a web UI on localhost showing every registered tool, resource, and prompt with full JSON schemas — Anthropic's official Inspector ≈ Swagger UI for MCP.
A static catalogue is also committed at docs/mcp_schema.json — the same shape, snapshotted in CI.
Control loop
The full contract — starting, observing, resuming, cancelling, deciding (QA gate), and inspecting runs through the MCP wire — lives in docs/run_lifecycle.md. Tool docstrings stay terse; that file is the long-form reference.
Tool naming is consistent: every run-lifecycle tool is orcho_run_<verb>. State-transition and inspection tools sit beside that group with their own names:
| Group | Tools |
|---|---|
| Act | orcho_run_start, orcho_run_resume, orcho_run_cancel |
| Observe | orcho_run_status, orcho_run_history, orcho_run_metrics, orcho_run_events_tail |
| Decide | orcho_phase_handoff_decide |
| Inspect | orcho_run_evidence, orcho_run_diff |
For an end-to-end walkthrough of the full control loop with code, see docs/control_loop_walkthrough.md.
Architecture
orcho-mcp is one of the public Orcho runtime packages:
orcho-core— pipeline runtime + CLI (Apache-2.0).orcho-mcp— MCP server, this repo (Apache-2.0).
The post-v1 cross-MCP consumer roadmap (orcho-as-MCP-client — pipeline agents calling external GitHub / Linear / Slack MCP servers) is documented in orcho-core/docs/plans/2026-05-06-cross-mcp-orchestration.md.
For contributor-facing architecture and test guidance:
docs/architecture/mcp_boundaries.mddescribes the package boundaries enforced by the architecture tests.docs/architecture/observation_delivery.mddefines the durable replay contract for MCP observation and notification use.docs/testing.mdexplains the test philosophy, layer model, fixture style, and verification commands.
License
Apache-2.0. See LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file orcho_mcp-0.2.0.tar.gz.
File metadata
- Download URL: orcho_mcp-0.2.0.tar.gz
- Upload date:
- Size: 261.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eea85b27b1c2f7f3f5b78227d630475461559c8818415145a087ee4206f1306f
|
|
| MD5 |
6101e91fc5b674380f70b1b9aa9fc126
|
|
| BLAKE2b-256 |
368083a990e4fa713fb4027f38c338e5b5b2afe80c2bb512f448527726fa4fa4
|
Provenance
The following attestation bundles were made for orcho_mcp-0.2.0.tar.gz:
Publisher:
release.yml on symphos-ai/orcho-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
orcho_mcp-0.2.0.tar.gz -
Subject digest:
eea85b27b1c2f7f3f5b78227d630475461559c8818415145a087ee4206f1306f - Sigstore transparency entry: 2073880408
- Sigstore integration time:
-
Permalink:
symphos-ai/orcho-mcp@2defbb46bf676bec337dc325c2620af885b0f5dd -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/symphos-ai
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@2defbb46bf676bec337dc325c2620af885b0f5dd -
Trigger Event:
push
-
Statement type:
File details
Details for the file orcho_mcp-0.2.0-py3-none-any.whl.
File metadata
- Download URL: orcho_mcp-0.2.0-py3-none-any.whl
- Upload date:
- Size: 301.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0740e5557cbb4245cc5d8923a459916ccd5fd6dca0c72df350b5395b57059bd2
|
|
| MD5 |
b12f361c432a453d4620bf94e8457643
|
|
| BLAKE2b-256 |
46b9728bc04700467f5acea3808238470d1b4c451162f57ccb8b721a63f20489
|
Provenance
The following attestation bundles were made for orcho_mcp-0.2.0-py3-none-any.whl:
Publisher:
release.yml on symphos-ai/orcho-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
orcho_mcp-0.2.0-py3-none-any.whl -
Subject digest:
0740e5557cbb4245cc5d8923a459916ccd5fd6dca0c72df350b5395b57059bd2 - Sigstore transparency entry: 2073880492
- Sigstore integration time:
-
Permalink:
symphos-ai/orcho-mcp@2defbb46bf676bec337dc325c2620af885b0f5dd -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/symphos-ai
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@2defbb46bf676bec337dc325c2620af885b0f5dd -
Trigger Event:
push
-
Statement type: