Skip to main content

Let your LLMs call each other — a local MCP switchboard for coding agents

Project description

TeLLMphone ☎️

Let your LLMs call each other.

Claude Code, asked for a second opinion, places a TeLLMphone call to codex on its own: codex (as grumpy-reviewer) delivers a verdict, and Claude relays it with its own take

TeLLMphone is a local MCP server that lets coding agents place calls to each other. Claude Code can ring Codex with a question about the current project and get an answer back, keep that conversation going across multiple turns, or leave a voicemail for the next Codex session to pick up. Conversations survive interruptions on both sides, and the callee can be given a saved personality and a specific model.

The second opinion you want is usually installed on the same machine, one terminal over — and you're tired of being the copy-paste layer between two AIs. Now they can just call each other.

Currently supports Claude Code and Codex; other agents can be added as plugins.

Requirements

  • macOS or Linux
  • Python 3.11+ and uv
  • The agent CLIs you want to connect (claude, codex), installed and logged in

Install

uv tool install tellmphone   # or: pipx install tellmphone
tellmphone install

install registers the MCP server with every agent CLI it finds — via claude mcp add and codex mcp add — and sets the codex config needed for non-interactive tool approval. It is idempotent; rerun it if you move the checkout. tellmphone uninstall removes the registrations (it does not delete ~/.tellmphone/).

Usage

You talk to your agent; your agent works the phone. In a Claude Code session:

Call codex and get a second opinion on this migration. Use the grumpy-reviewer personality.

Claude will place the call, relay the answer, and can keep the thread going with follow-ups. In the other direction, start a Codex session in the same project and ask it to check its messages.

That's what the demo above shows: Claude, asked for a second opinion, places the call itself and then argues with the answer. You can also work the phone yourself:

tellmphone call codex "Sanity-check the file locking in src/store.py." --personality grumpy-reviewer
tellmphone reply "Fair. Would any of it break on Windows?"

The tools the agents get:

Tool What it does
call Send a message to another agent about a project. Optional personality and model. Waits for the answer, or leaves it as voicemail.
reply Follow up on an existing call. The callee resumes with full context.
check_messages List unread messages and open calls for a project.
hang_up Close a call. The transcript is kept.
phonebook List available agents and personalities.

How it works

┌─────────────┐   MCP (stdio)   ┌──────────────────┐   headless CLI   ┌─────────────┐
│ Claude Code │ ──────────────► │   TeLLMphone     │ ───────────────► │ codex exec  │
│  (caller)   │  call/reply/…   │   switchboard    │  spawn / resume  │  (callee)   │
└─────────────┘                 └──────────────────┘                  └─────────────┘

There is no daemon. Each agent runs its own TeLLMphone instance over stdio; shared state lives under ~/.tellmphone/. A call spawns the callee's CLI headlessly (codex exec, claude -p) in the project directory, records the callee's native session id under a stable call id, and replies resume that exact session (codex exec resume, claude --resume). If a native session is lost, the stored transcript is replayed into a fresh one. Callees run in their CLI's read-only/sandboxed mode unless you allowlist a project for writes, and a hop limit keeps agents from chaining calls indefinitely.

The internals lean into the name: the switchboard routes calls, the phonebook lists who you can dial, a busy line means the callee is still thinking, voicemail holds messages for agents that aren't running, and the hop limit stops two agents from playing telephone forever.

Details, including the security model, are in docs/DESIGN.md.

Configuration

~/.tellmphone/config.toml:

[defaults]
timeout_s = 300   # wait this long before a live call rolls to voicemail
max_hops = 2      # agent-to-agent chain depth limit

# default model per callee; a call's explicit model argument wins.
# Use whatever model ids your CLI accepts.
[agents.codex]
model = "gpt-5.5"

# callees run read-only unless a project is allowlisted here
[permissions."/path/to/project"]
write = true

Personalities are Markdown files with a small frontmatter block (name, description) followed by the system prompt. Eight builtins ship with the package and update with it — critics (grumpy-reviewer, security-auditor, sycophancy-cop), thinking partners (rubber-duck, devils-advocate, architect), and builders (debugger, test-engineer); your own live in ~/.tellmphone/personalities/. A user file with the same name as a builtin replaces it, and one with disabled: true hides it. Callers select personalities by name and never send system prompts inline.

Data

Call records and transcripts live under ~/.tellmphone/projects/. Transcripts contain whatever flowed through the conversation, which for a coding agent usually includes your code. Everything is plain JSON owned by your user; delete a call directory (or all of ~/.tellmphone/) to purge.

Development

uv sync
uv run pytest

The test suite runs against fake claude/codex executables, so it needs neither CLI installed nor network. From a checkout, uv run tellmphone install registers your development version with your agents.


TeLLMphone is a project powered by The California Open Source Company. Licensed under Apache 2.0.

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

tellmphone-0.1.2.tar.gz (682.3 kB view details)

Uploaded Source

Built Distribution

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

tellmphone-0.1.2-py3-none-any.whl (35.2 kB view details)

Uploaded Python 3

File details

Details for the file tellmphone-0.1.2.tar.gz.

File metadata

  • Download URL: tellmphone-0.1.2.tar.gz
  • Upload date:
  • Size: 682.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tellmphone-0.1.2.tar.gz
Algorithm Hash digest
SHA256 aad69ae9e59b53b1bd5d4314ecda0a33a6e52dbf688d6dce9c1fd55caa59d55f
MD5 15c150464e77e0847c1f5f9d14540c32
BLAKE2b-256 85887752155cbfa45525359694f07cae0ea4882f4230b55944997eedd69e71c1

See more details on using hashes here.

Provenance

The following attestation bundles were made for tellmphone-0.1.2.tar.gz:

Publisher: publish.yml on CaliforniaOpenSource/tellmphone

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tellmphone-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: tellmphone-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 35.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tellmphone-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 5778ab5a59fcb6d73f0570f8cdd7fbf180fe8fae77edb6f8f3009baad99d448d
MD5 aaf63112f10d3d74fae02c7794a72d48
BLAKE2b-256 78354b07538d5aee2fbbcbb0d74e8fb98eae88f9b414cf70a04e4b3de5a5f1c3

See more details on using hashes here.

Provenance

The following attestation bundles were made for tellmphone-0.1.2-py3-none-any.whl:

Publisher: publish.yml on CaliforniaOpenSource/tellmphone

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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