harness_to_mcp
Supports the OpenAI Chat Completions and Responses API protocols, enabling harnesses like Codex to be exposed as MCP servers.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@harness_to_mcplist available tools from the harness"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
harness_to_mcp: Expose harness internal tools as a standard MCP server
Contents: Features | Install | Demo | How it works | Notes
Turn any agent harness (Claude Code, Codex, OpenClaw, OpenCode, ...) into an MCP server.
How: harness_to_mcp sits between the harness and its LLM API, grabs the tool list from the hijacked request, and routes MCP tools/call back into the harness tool loop.
▮ Features
☑ One command to expose
claude/codex/openclaw/opencodeas an MCP server☑ Co-locates one MCP HTTP server and one hijack LLM API server on the same port
☑ Extracts the harness tool list automatically from intercepted LLM requests
☑ Mirrors captured harness system prompt into MCP
initialize.result.instructions☑ Forwards MCP
tools/callinto the harness tool loop and maps the tool result back☑ Compatible LLM API protocols:
OpenAI Chat Completions (
openclaw,opencode)OpenAI Responses (
codex)Anthropic Messages (
claude)
☑ Isolated harness config — will not pollute the user's own config and logs
☑ One harness process per MCP session, the harness process is stopped automatically on session close
☑ Plain server mode for bringing your own harness
☑ Pure-Python, clean dependencies — easy to hack and vibe-code on
▮ Install
pip install harness_to_mcpThe target harness CLI (claude, codex, openclaw, ...) needs to be installed separately and available on PATH.
▮ Demo
1. One-liner to expose a harness as MCP
harness_to_mcp claude
# or: harness_to_mcp codex / openclaw / opencodeEach command starts a server and launches one corresponding harness instance. The harness is started with an isolated config, so it will not touch the user's own config or logs.
The MCP endpoint is then ready at:
http://127.0.0.1:<port>/mcpPoint any MCP client (Claude Desktop, Cursor, your own script, ...) at it and the harness's internal tools show up as standard MCP tools.
You can inspect the exposed tools with python examples/list_tools.py.
2. Only run the server (plug in any harness)
harness_to_mcpThis mode starts only the server. It listens on MCP plus all hijack LLM API routes, but does not launch any harness by itself. Configure your harness's LLM API as the hijack API, send one request, and its internal tools are exposed on MCP. This is also how you plug in claude / codex / openclaw / opencode with your own custom config.
Exposed endpoints:
Purpose | Path |
MCP |
|
OpenAI Chat Completions |
|
OpenAI Responses |
|
Anthropic Messages |
|
3. Python API
We also provide a Python interface:
from harness_to_mcp import HarnessToMcp
with HarnessToMcp(port=9330) as server:
print(server.mcp_url) # e.g. http://127.0.0.1:9330/mcp
print(server.hijack_base_url) # e.g. http://127.0.0.1:9330/harness_to_mcp▮ How it works
sequenceDiagram
participant C as MCP Client
participant M as harness_to_mcp<br/>MCP Server
participant H as harness_to_mcp<br/>Hijack API Server
participant R as Harness
C->>M: initialize
M->>R: launch harness session
R->>H: send hijacked LLM API request
H-->>M: extract tool list from request
M-->>C: tools/list
C->>M: tools/call
M-->>H: resolve waiting request as tool call
H-->>R: return tool call payload
R->>R: execute internal tool
R->>H: send next request with tool result
H-->>M: match tool_call_id and deliver tool result
M-->>C: MCP tool responseIn short:
MCP client calls
initialize→ we spawn a harness.The harness fires off its first LLM request (with the tool schema in it) → we intercept the request, extract the tool list, and reply to the MCP client with
tools/list.MCP client calls
tools/call→ we complete the pending LLM response as a tool call, the harness executes its internal tool, and sends the result back in the next LLM request.We match the
tool_call_id, extract the tool result, and return it as the MCP tool response.
▮ Notes
The LLM API layer is split into reusable adapters:
chat completions,responses,messages.The harness launcher layer is split per-harness:
opencode,openclaw,codex,claude.Plain server mode (
harness_to_mcpwith no subcommand) never auto-launches a harness.Intercepted waiting requests are kept alive with periodic heartbeat bytes until MCP receives the next tool call.
▮ License
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/on-panda/harness_to_mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server