MCP server that bridges Claude Desktop to Claude Code sessions
Project description
cc-tap
Experimental MCP server that lets Claude Desktop see into and interact with Claude Code Remote Control sessions.
Example: Ask Claude Desktop "what's my Code session working on?" and get a real answer.
Why this exists
Claude Desktop and Claude Code are separate worlds. Both build up rich context on your project, but neither can see what the other is doing. A design idea on Desktop that should drive an implementation in Code, or an implementation detail in Code that the Desktop conversation needs; both require you to copy-paste between windows and re-explain context that already exists.
Claude Code's Remote Control lets you drive a session from another device, but that's still you driving the same session. cc-tap is for the other axis: letting a different agent (Claude Desktop, or another Claude Code instance) read and interact with a running CC session through MCP.
Who is this for
- Developers who use both Claude Desktop and Claude Code
- Anyone who wants to monitor or interact with CC sessions programmatically
- Multi-agent workflows where one Claude instance needs to coordinate with another
Quickstart
pip install cc-tap
Requires an active Claude Code login (claude /login) and Remote Control enabled.
Claude Code
claude mcp add cc-tap -- cc_tap
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"cc-tap": {
"command": "cc_tap",
"args": []
}
}
}
Tools
| Tool | Description |
|---|---|
list_sessions |
List all CC sessions (optionally filter by status) |
get_session_info |
Get details about a specific session |
read_session |
Read recent conversation from a session |
get_session_events |
Get raw events, optionally filtered by type |
send_message |
Send a message to a CC session (fire and forget) |
send_and_wait |
Send a message and wait for the full response |
How it works
cc-tap reads your Claude Code OAuth credentials (from macOS Keychain or ~/.claude/.credentials.json) and talks to the same API that Claude Code's Remote Control web UI uses. No additional authentication needed.
Sessions are accessed via HTTP polling (~1.5s latency). Messages you send appear in the target CC session as if typed by the user.
Limitations
- Tool approval — the session runtime only picks up approvals via WebSocket (behind Cloudflare bot protection). You can see pending tool requests via
send_and_wait, but must approve them in the CC terminal or claude.ai/code web UI. - Not real-time — uses HTTP polling, not WebSocket streaming. ~1.5s latency.
- Undocumented API — uses internal Anthropic endpoints that may change without notice.
- Local only — reads credentials from the local machine. Can't be deployed as a remote service.
Protocol
See PROTOCOL.md for the reverse-engineered Claude Code Remote session API documentation.
Development
git clone https://github.com/es617/cc-tap.git
cd cc-tap
pip install -e ".[dev,test]"
pre-commit install
pytest
Disclaimer
This project is an experimental research tool for personal and educational use. It interacts with undocumented, internal Anthropic APIs that are not part of any public or supported API surface. These endpoints may change, break, or be removed at any time without notice.
This project is not affiliated with, endorsed by, or supported by Anthropic. Use it at your own risk. The authors assume no responsibility for any consequences of using this tool, including but not limited to account restrictions, data loss, or service disruption.
By using this tool you acknowledge that you are responsible for compliance with Anthropic's Terms of Service and Acceptable Use Policy.
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 cc_tap-0.1.0.tar.gz.
File metadata
- Download URL: cc_tap-0.1.0.tar.gz
- Upload date:
- Size: 1.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1b9d929b15d3fd8f0ad00465a9787649ddb09c7aa9a9f8cc588214776b2825e4
|
|
| MD5 |
8a96370b1ce2c22179abb5829b5eb0aa
|
|
| BLAKE2b-256 |
bd0a7a5029b6a4322e230d8eef1a9bd1c258f935574cae484ce9fc59bfd4d80a
|
Provenance
The following attestation bundles were made for cc_tap-0.1.0.tar.gz:
Publisher:
cicd.yml on es617/cc-tap
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cc_tap-0.1.0.tar.gz -
Subject digest:
1b9d929b15d3fd8f0ad00465a9787649ddb09c7aa9a9f8cc588214776b2825e4 - Sigstore transparency entry: 1318542166
- Sigstore integration time:
-
Permalink:
es617/cc-tap@b18e9a2f448bc83b338f444262e4f19d96f6c0c8 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/es617
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
cicd.yml@b18e9a2f448bc83b338f444262e4f19d96f6c0c8 -
Trigger Event:
push
-
Statement type:
File details
Details for the file cc_tap-0.1.0-py3-none-any.whl.
File metadata
- Download URL: cc_tap-0.1.0-py3-none-any.whl
- Upload date:
- Size: 10.7 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 |
99207f0196dbf5d626ad6301550824fa90006992c24a4ea90a49d1b9d4b502d1
|
|
| MD5 |
89fda2d59e2a25a4d7bdc148d86876d6
|
|
| BLAKE2b-256 |
158306cb45f0d5bf0c7a7b6589de6d9dca19b717a2fe73d7392be3f145038399
|
Provenance
The following attestation bundles were made for cc_tap-0.1.0-py3-none-any.whl:
Publisher:
cicd.yml on es617/cc-tap
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cc_tap-0.1.0-py3-none-any.whl -
Subject digest:
99207f0196dbf5d626ad6301550824fa90006992c24a4ea90a49d1b9d4b502d1 - Sigstore transparency entry: 1318542220
- Sigstore integration time:
-
Permalink:
es617/cc-tap@b18e9a2f448bc83b338f444262e4f19d96f6c0c8 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/es617
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
cicd.yml@b18e9a2f448bc83b338f444262e4f19d96f6c0c8 -
Trigger Event:
push
-
Statement type: