A community-driven registry for the Claude Code ecosystem. Not affiliated with Anthropic.
Are you the author? Sign in to claim
Let your AI agent call your phone and talk to you — MCP servers for live, interruptible voice calls + tiered alerts, usi
Your AI agent can call your phone — and actually talk to you.
ringback gives an LLM (Claude, or any MCP client) tools to reach you on your phone — from a one-way "fierce" alert all the way to a live, interruptible voice conversation — using only free, self-hosted pieces. No paid telephony. No extra API key for the conversation: the model already driving the MCP is the voice on the line.
Highlights
It ships two MCP servers, ringback-alert and ringback-voice:
Platform: macOS, Linux, and Windows (via WSL2 or Docker). TTS is Piper by default (same voice everywhere), falling back to the OS-native voice (
sayon macOS). The engine is headless — it never opens a local mic/speaker (all audio is WAV ↔ SIP/RTP), so no sound card is required. Setup guides: macOS · Linux · Windows · Docker.
| Server | Tools | What it does |
|---|---|---|
| ringback-alert | alert_me, alert_test, alert_status | Fire-and-forget notification: a loud push (ntfy / Pushover) and/or a SIP ring + chat message. |
| ringback-voice | call_start, converse, get_conversation, call_end, … | A real two-way phone conversation. Rings your phone; you talk, it transcribes you, the LLM replies in speech. Supports barge-in (talk over it and it stops). |
The criteria for when to contact you live in the tool descriptions — the calling LLM decides. These servers are just the mechanism.
agent → call_start("Your nightly deploy failed — want me to walk you through it?")
📞 your phone rings; you pick up and hear the line
you → "yeah, which step broke?"
agent → "The database migration. I can roll it back and retry — want that?"
you → "yes, do it" ← you can also just talk over the agent to interrupt
agent → call_end()
The LLM calls call_start once, then converse(...) for each turn. Plain alerts are even simpler: one alert_me(...) call.
🤖 Easiest path: copy the prompt below and paste it into Claude Code — it'll clone, build, configure, and register everything, asking you only for what it needs (a free SIP account + your phone to answer a test call).
Set up the ringback MCP server for me — it lets you (the agent) call my phone when you
need a decision while I'm away. Repo: https://github.com/mohitbadwal/ringback
(runs on macOS, Linux, or Windows via WSL2/Docker).
Please:
1. Detect my OS and pick the path:
- macOS → ./setup.sh (Homebrew); read docs/SETUP_MACOS.md
- Linux or Windows-WSL2 → ./setup-linux.sh; read docs/SETUP_LINUX.md
- Windows without WSL2 → use Docker; read docs/SETUP_DOCKER.md
2. Clone https://github.com/mohitbadwal/ringback, cd in, and read the README + the doc above.
3. Run the setup for my OS (compiles pjsua2 from source — ~20–30 min — installs whisper +
Piper TTS, downloads models, and creates voice.env).
4. I need a free Linphone SIP account (the phone line): walk me through signing up at
https://subscribe.linphone.org and installing the Linphone app on my phone, then put my
SIP id/username/password into voice.env (and set VOICE_DISPLAY_NAME to a caller-ID name).
5. Register it (per OS):
- macOS: claude mcp add ringback-voice --scope user -- "$PWD/run_voice_mcp.sh"
- Linux/WSL2: claude mcp add ringback-voice --scope user -- python3 "$PWD/run_voice_mcp.py"
- Docker: see docs/SETUP_DOCKER.md (build image, convert creds to voice.docker.env, then register a `docker run -i` command)
6. macOS only: if a test call fails with error -32000 or a segfault, run ./fix_macos_twolevel.sh.
7. Tell me to start a fresh session, then call me to confirm two-way voice works.
Ask me whenever you need input (SIP credentials, my phone to answer the test call, etc.).
Prefer to do it by hand? Quick start and the full walkthrough are below.
git clone https://github.com/mohitbadwal/ringback && cd ringback
./setup.sh # installs EVERYTHING (toolchain, pjsua2, whisper model, deps) + creates voice.env
# edit voice.env → add your 3 SIP vars (free account: https://subscribe.linphone.org), then:
claude mcp add ringback-voice --scope user -- "$PWD/run_voice_mcp.sh"
Full walkthrough + env-var reference: Set up ringback-voice below.
NOTICE. The ringback-alert server is unaffected. LLM (Claude) ──MCP tools──▶ ringback-voice server (Python)
│ call_start / converse / listen / speak
▼
pjsua2 (SIP+SRTP, built from source) ──▶ Linphone SIP server
│ Piper/say → ffmpeg → WAV (speak) │ APNs VoIP push
│ record → whisper.cpp (listen) ▼
└───────────────────────────────────▶ your iPhone rings
ringback-alert is simpler: it shells out to ntfy/Pushover HTTP and/or baresip for a SIP ring + chat message.
./setup.sh./setup-linux.sh (see docs/SETUP_LINUX.md)./setup-linux.sh inside it) or Docker Desktop (see docs/SETUP_WINDOWS.md)docker build -t ringback . (see docs/SETUP_DOCKER.md)sip.linphone.org) and the Linphone iOS/Android app (for the ring/voice features)python3 you point at)1. Clone + install everything:
git clone https://github.com/mohitbadwal/ringback && cd ringback
./setup.sh
setup.sh installs the toolchain, compiles pjsua2 from source (~20–30 min — no Homebrew formula exists for the bindings), relinks the pjproject dylibs to a two-level OpenSSL namespace (the macOS fix that makes SIP/SRTP work), downloads the whisper model, installs Piper + a voice, installs deps, and creates voice.env for you. Safe to re-run. (Override PYTHON_BIN / PJPROJECT_DIR / WHISPER_MODEL_NAME if your layout differs.)
On Linux? Use
./setup-linux.shinstead — it does the same build with apt/dnf and needs no OpenSSL relink. On Windows? Use WSL2 (docs/SETUP_WINDOWS.md) or Docker. Register the server with the cross-platform launcherpython3 run_voice_mcp.py(the.shis macOS-only).
Hit a snag on macOS?
docs/SETUP_MACOS.mdis a field-tested root-cause + troubleshooting guide (build target, the OpenSSL flat-namespace fix, whisper model, symptom→fix table).
2. Get a free SIP account (this is the phone that rings):
sip:<username>@sip.linphone.org.3. Fill in voice.env (already created by setup.sh — just edit it). Only three vars are required:
export VOICE_SIP_ID="sip:yourname@sip.linphone.org"
export VOICE_SIP_USER="yourname"
export VOICE_SIP_PASS="your-password"
Full variable reference:
| Variable | Required | Default | What it is |
|---|---|---|---|
VOICE_SIP_ID | ✅ | — | Your SIP address, e.g. sip:you@sip.linphone.org |
VOICE_SIP_USER | ✅ | — | SIP username (the part before @) |
VOICE_SIP_PASS | ✅ | — | Your SIP password |
VOICE_SIP_CALLEE | — | = VOICE_SIP_ID | Address to call (normally yourself) |
VOICE_SIP_PROXY | — | sip:sip.linphone.org;transport=tls | SIP registrar/proxy |
WHISPER_MODEL | — | ~/.whisper-models/ggml-small.en.bin | STT model: base.en (fast) · small.en (default) · medium.en (accurate) |
VOICE_TTS | — | auto | TTS engine: auto (Piper if installed, else OS voice) · piper · say · espeak · sapi |
VOICE_PIPER_MODEL | — | ~/.piper-voices/en_US-lessac-medium.onnx | Piper voice (.onnx; needs the matching .onnx.json beside it) |
VOICE_TTS_CMD | — | — | Custom TTS command template with {text}/{out} (overrides VOICE_TTS) |
VOICE_NULL_AUDIO | — | auto | Force pjsua2 null audio device (auto = on except macOS; 1/0 to force) |
RINGBACK_PRESENCE | — | — | Override watchdog idle/presence: present or absent (for Wayland/headless) |
PJPROJECT_DIR | — | ~/build/pjproject-2.17 | pjsua2 build dir (auto-detected) |
PYTHON_BIN | — | $(command -v python3) | Python that has pjsua2 (auto-detected) |
OPENSSL_PREFIX | — | $(brew --prefix openssl@3) | OpenSSL libs (macOS; auto-detected) |
4. Register + test:
# macOS:
claude mcp add ringback-voice --scope user -- "$PWD/run_voice_mcp.sh"
# Linux / Windows-WSL2 (cross-platform launcher):
claude mcp add ringback-voice --scope user -- python3 "$PWD/run_voice_mcp.py"
# Any OS via Docker (convert creds to voice.docker.env first — see docs/SETUP_DOCKER.md):
claude mcp add ringback-voice --scope user -- docker run -i --rm --network host --env-file voice.docker.env ringback
Then in a fresh Claude session say: "Use ringback-voice to call me and say hello." Your phone should ring.
Claude Desktop instead of Code? Add this to
~/Library/Application Support/Claude/claude_desktop_config.json(absolute path required; restart the app):hljs language-json{ "mcpServers": { "ringback-voice": { "command": "/absolute/path/to/ringback/run_voice_mcp.sh" } } }
ringback-alert reads its config from the MCP client's env block (no file to source). Register it with the channels you want:
# Claude Code
claude mcp add ringback-alert --scope user \
--env ALERT_CHANNEL=ntfy \
--env NTFY_URL=https://ntfy.sh/your-long-random-topic \
-- /opt/homebrew/bin/uv --directory "$PWD" run server.py
See alert.env.example for all variables (ntfy / Pushover / SIP ring). Use a long random ntfy topic — anyone who knows it can read/publish.
The LLM drives a simple loop:
reply = call_start("Hi, it's your assistant — your deploy failed. Want details?")
# rings the phone, speaks the line, returns the user's first words
reply = converse("It failed on the database migration step. Want me to retry it?")
# speaks AND listens in one interruptible turn
... repeat converse() each turn ...
call_end() # when the user says "bye" / hangs up
converse(text) speaks while listening. If you talk over it, it stops immediately and tells the LLM how far it got and what you said (barge-in).get_conversation() returns the full transcript so far — both sides, plus where it got interrupted.alert_me as text instead.Whisper model accuracy/speed trade-off (set WHISPER_MODEL): base.en (fast/rough) → small.en (balanced, default) → medium.en (most accurate/slow).
alert_me(message, severity, title) with severity = info | warn | critical. Channels via ALERT_CHANNEL (comma list of ntfy, pushover, call):
critical.critical by default.A built-in rate-limit guard (default 5/60s, per-process) stops a misfiring caller from spamming you.
skills/watchdog/ is a ready-to-use Claude skill built on these servers. It watches a condition you give it (a CI run, a deploy, a pod, a file) and escalates only when you're actually away from the laptop — chat status → chat warning → ringback-alert push → ringback-voice call — judged by input-idle time (macOS, Linux, or Windows; see platform_compat.hid_idle_seconds). It never interrupts you while you're typing, and de-escalates the moment you touch the keyboard.
cp -r skills/watchdog ~/.claude/skills/watchdog # install for Claude Code
Then: /watchdog <what to watch> | priority=<low|medium|critical> — low = chat only, medium = may send a phone alert, critical = may place a call. Full design in skills/watchdog/SKILL.md.
voice.env (and the baresip accounts file for ringback-alert) — never in the repo or the MCP client config when you can avoid it.NOTICE for the GPL/pjproject licensing caveat before redistributing.Apache-2.0 (see LICENSE), with an important GPL caveat for the voice
component's pjproject dependency — see NOTICE.
Built on pjproject/pjsua2, whisper.cpp, baresip, ntfy, and Linphone.
Run Claude Code as an MCP server so any agent can delegate coding tasks to it
Browser automation using accessibility snapshots instead of screenshots
Secure MCP server for MySQL database interaction, queries, and schema management
English-first Korean equity intelligence MCP — DART filings, foreign-holder 5%-rule flows, activist filings, KRX news. F