iMessage Bridge for Poke
Allows reading and sending Apple iMessages on a Mac, including listing chats, reading history, searching messages, sending texts and attachments, and reacting with tapbacks.
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., "@iMessage Bridge for Poketell Sarah I'm running 10 min late"
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.
💬 iMessage Bridge for Poke
Text Poke to read and send your iMessages.
A tiny local server runs on your Mac, Poke reaches it over a private tunnel, and a menu bar switch turns it on and off. Your messages never leave your Mac unless you ask Poke to act on them.
What it feels like
You: what did the last person text me? Poke: Sarah said "running 10 late, order me a flat white" — want me to reply? You: yeah tell her got it 👍 Poke: Sent ✅
You're texting an assistant that can actually reach into your real iMessages — from your phone, from anywhere, as long as your Mac is awake.
Related MCP server: jons-mcp-imessage
How it works
your phone Poke cloud your Mac (awake)
┌──────────┐ ┌──────────┐ private tunnel ┌────────────────────────────┐
│ text │ ──────▶ │ Poke │ ─────────────────▶ │ FastMCP server :8765 │
│ "Poke…" │ │ (LLM) │ ◀───────────────── │ └▶ imsg CLI ▶ Messages.app │
└──────────┘ └──────────┘ └────────────────────────────┘Poke is an MCP host: it discovers the tools your server exposes and calls
them mid-conversation. The server wraps imsg,
a CLI that reads your local chat.db and drives Messages.app.
Each person runs their own copy. Recipe links are not shareable — a shared link would point Poke at your Mac and your texts. Share the repo, not your link.
Quick start
Prerequisites: macOS 12+, Homebrew, and a Poke account.
git clone https://github.com/ish-cs/imessage-poke-bridge.git
cd imessage-poke-bridge
./install.shThe installer handles everything: installs deps (imsg, Node, poke CLI, uv),
sets up the server + tunnel as background services, logs you into Poke, mints
your recipe link, and adds the iMessage Bridge menu bar app.
Two permissions you must grant
macOS requires these and no installer can do them for you:
Permission | Why | How |
Full Disk Access | read your Messages database | The installer prints a Python path and opens the pane — add it with |
Automation → Messages | send texts | A dialog pops up the first time it sends — click Allow |
Then click iMSG ● in your menu bar (○ = off) and start texting Poke.
Using it
Text Poke naturally:
"what did mom text me?"
"tell Sarah I'm running 10 min late"
"what did I miss today?"
"send the photo at ~/Desktop/ticket.png to the group"
Works whenever your Mac is awake. Lid closed / asleep = the bridge is dark until you wake it. (We deliberately don't keep your Mac awake — your battery thanks us.)
Tools
Tool | What it does |
| recent conversations + |
| messages in a chat (group senders resolved to names) |
| full-text search your history |
| name → phone/email, so "text Mom" works |
| is a handle reachable on iMessage |
| "what did I miss" across recent chats in one call |
| send a text |
| send an image/file (+ optional text) |
| tapback the latest message |
| self-diagnose: health, contacts, send count, recipe link |
Contact names come from your local AddressBook — covered by the Full Disk Access grant, so no extra Contacts permission.
Menu bar app
Item | Action |
Turn On / Off | start/stop the bridge ( |
Copy Recipe Link | your personal Poke link |
Open Logs Folder |
|
Auto-starts at login and self-restarts if it crashes.
Configuration
Set in the launchd plist or environment:
Variable | Default | Purpose |
|
| max sends per hour |
| (unset) | comma-separated handles; if set, only those can be texted |
| (unset) | bearer token — set this only if you expose the server on a public URL; leave unset for the private Poke tunnel |
Safety & privacy
Audit log — every send is appended to
~/.imsg-bridge/sends.jsonl. Review exactly what Poke did in your name.Rate limit + allowlist — guard rails on the send tools (see Configuration).
Local-first — messages stay on your Mac; only what Poke acts on is sent to it.
⚠️ Anything in your messages — secrets, 2FA codes, private notes — becomes readable by Poke (an LLM). Don't text yourself API keys, and rotate any that are already in your history.
Troubleshooting
Symptom | Fix |
Menu bar icon missing | It runs as a LaunchAgent; check |
Poke says "offline / no available upstreams" | The tunnel isn't running. Click the menu bar item → Turn On, or check |
"can't read messages" | Full Disk Access isn't granted to the Python binary the installer printed. |
Sends fail silently | Grant Automation → Messages (System Settings → Privacy & Security → Automation). |
Poke can't reach it | Your Mac is asleep. Wake it. |
Duplicate integrations in Poke | Delete extras at |
Logs live in ~/.imsg-bridge/ (server.log, tunnel.log, menubar.log).
Uninstall
./uninstall.shRemoves the services, menu bar app, and files. Revoke Full Disk Access manually
in System Settings, and remove the integration at poke.com/settings if you want.
Limitations
Your Mac must be awake. iMessage only exists on your Mac; there's no free cloud option (a cloud Mac costs $100+/mo).
SIP-on features only. Typing indicators, read receipts, edit/unsend, polls, and rich effects need SIP disabled and are intentionally not exposed.
Not notarized yet. MVP installs from source.
Contact matching is by last-10-digits, so some international numbers may mismatch.
Roadmap
Architecture
server.py FastMCP server wrapping imsg — 10 tools, stateless HTTP,
path-prefix shim for Poke's /<id>/mcp routing, optional bearer auth,
AddressBook contact resolution, send audit + rate limit.
menubar.py pyobjc menu bar controller for the launchd services.
install.sh per-user setup: deps, services, recipe capture, menu bar agent.
uninstall.sh teardown.License
MIT © Ishaan Pandey
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/ish-cs/imessage-poke-bridge'
If you have feedback or need assistance with the MCP directory API, please join our Discord server