imessage-mcp-server
Allows reading and sending iMessages on macOS, including listing conversations, reading messages, and polling for new messages.
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-mcp-serverlist my recent conversations"
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-mcp-server
MCP server + AI bridge for iMessage on macOS
Expose your iMessage history and send capabilities via the Model Context Protocol, or turn your Mac into a 24/7 AI assistant that auto-replies to your iMessages.
⚠️ macOS only — requires the Messages app and its SQLite database (~/Library/Messages/chat.db).
Features
MCP Server mode
Four standard MCP tools for reading and sending iMessages:
Tool | Description |
| Send an iMessage to a recipient's email or phone number |
| List recent conversations with latest message preview and unread count |
| Read paginated messages from a specific conversation |
| Poll for new incoming messages since a timestamp |
Bridge mode
Run an autonomous AI agent in the background:
Polls for new iMessages from your configured
masterHandleSends them to Claude, OpenAI, DeepSeek, Kimi, or any OpenAI-compatible model
Connects any MCP Servers as tools (filesystem, shell, git, etc.)
Auto-replies with results
Remembers conversation context
Supports macOS LaunchAgent for auto-start on login
Related MCP server: iMessage MCP
Prerequisites
macOS (Ventura or later recommended)
Node.js >= 18
iMessage signed in via the Messages app
Full Disk Access for your terminal / IDE
Go to System Settings → Privacy & Security → Full Disk Access
Add your terminal app (Terminal, iTerm2, VS Code, etc.)
Xcode Command Line Tools (needed to compile the native
better-sqlite3module)
xcode-select --installQuick Start
MCP Server mode
Add to your MCP configuration:
Claude Code (.claude/settings.json):
{
"mcpServers": {
"imessage": {
"command": "npx",
"args": ["-y", "imessage-mcp-server", "--server"]
}
}
}Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"imessage": {
"command": "npx",
"args": ["-y", "imessage-mcp-server", "--server"]
}
}
}Cursor (.cursor/mcp.json):
{
"mcpServers": {
"imessage": {
"command": "npx",
"args": ["-y", "imessage-mcp-server", "--server"]
}
}
}VS Code + GitHub Copilot (.vscode/mcp.json):
{
"servers": {
"imessage": {
"command": "npx",
"args": ["-y", "imessage-mcp-server", "--server"]
}
}
}Bridge mode
Create a bridge-config.json:
{
"masterHandle": "your-email@icloud.com",
"provider": "anthropic",
"apiKey": "${ANTHROPIC_API_KEY}",
"model": "claude-3-5-sonnet-20241022",
"mcpServers": {
"filesystem": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-filesystem", "/Users/YOU"]
}
}
}Run in foreground for testing:
npx imessage-mcp-server --bridge --config ./bridge-config.json --foregroundInstall as a macOS LaunchAgent (auto-start on login):
npx imessage-mcp-server --bridge --install-service --config ./bridge-config.json
npx imessage-mcp-server --bridge --status
npx imessage-mcp-server --bridge --uninstallNote: When running as a LaunchAgent, the bridge does not inherit environment variables from your shell. If your
apiKeyuses${ANTHROPIC_API_KEY}env substitution, the service won't be able to resolve it. Put the API key directly in the config file instead.
CLI Reference
# Show help / version
npx imessage-mcp-server --help
npx imessage-mcp-server --version
# MCP Server mode
npx imessage-mcp-server --server
# Bridge mode
npx imessage-mcp-server --bridge --config ./bridge-config.json
npx imessage-mcp-server --bridge --foreground
npx imessage-mcp-server --bridge --test-config
npx imessage-mcp-server --bridge --install-service --config ./bridge-config.json
npx imessage-mcp-server --bridge --status
npx imessage-mcp-server --bridge --uninstallBridge Configuration
Full schema
{
"masterHandle": "your-email@icloud.com",
"provider": "anthropic",
"apiKey": "${ANTHROPIC_API_KEY}",
"baseUrl": null,
"model": "claude-3-5-sonnet-20241022",
"maxTokens": 4096,
"pollIntervalMs": 3000,
"maxHistoryPerConversation": 20,
"maxToolIterations": 10,
"sendProcessingIndicator": true,
"systemPrompt": "Optional custom system prompt",
"projectDir": "/Users/YOU/project",
"mcpServers": {
"filesystem": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-filesystem", "/Users/YOU"]
},
"shell": {
"command": "npx",
"args": ["-y", "mcp-shell-server"]
}
},
"safety": {
"requireConfirmation": false,
"allowedTools": null,
"blockedTools": [],
"blockedCommands": ["rm -rf /", "sudo"],
"readOnly": false
}
}Supported providers
Provider |
| Notes |
Anthropic / Claude |
| Native thinking blocks |
OpenAI |
| Official API |
DeepSeek |
| OpenAI-compatible endpoint |
Kimi |
| OpenAI-compatible endpoint |
Any OpenAI-compatible |
| Set |
Environment variables
Variable | Description |
| Override the path to |
| Your iMessage handle for bridge mode |
| Default LLM provider |
| API keys |
| Custom API endpoints |
Config files support ${VAR_NAME} syntax for env substitution.
MCP Tools (Server mode)
send_imessage
Send an iMessage to a recipient.
{ "recipient": "example@icloud.com", "text": "Hello from MCP!" }list_conversations
List recent iMessage conversations.
Param | Type | Default | Description |
| number | 20 | Max conversations (max 100) |
read_conversation
Read messages from a specific conversation.
Param | Type | Default | Description |
| string | — | Filter by email/phone |
| number | — | Filter by chat ROWID |
| number | 30 | Max messages (max 200) |
| number | — | Paginate before ROWID |
| boolean | true | Include read messages |
| boolean | false | Only unread |
get_new_messages
Poll for recently received messages.
Param | Type | Default | Description |
| string | — | ISO timestamp |
| number | 10 | Max messages (max 100) |
| boolean | false | Only unread |
Bridge Tools
In bridge mode, the AI can use any tools exposed by the configured MCP servers, plus two built-in local tools:
send_imessage— send a message to any recipientsend_long_reply— split a long response into multiple iMessages
Security Notes
The iMessage database is opened in read-only mode for all read operations.
Bridge mode only processes messages from the configured
masterHandle; all other senders are ignored.Use
safety.readOnly: trueto prevent write tools.Use
safety.allowedToolsto whitelist allowed tools.Use
safety.blockedCommandsto blacklist dangerous shell patterns.All chat data stays on your Mac; only API calls to your chosen LLM provider leave the machine.
Troubleshooting
Problem | Solution |
❌ iMessage database not found | Sign into Messages app or set |
🔒 Permission denied | Grant Full Disk Access to your terminal/IDE. |
🔐 "Database is locked" | Quit Messages app or wait for sync. |
💻 osascript failed | Make sure Messages.app is running and signed in. |
⚠️ better-sqlite3 compile errors | Run |
🐢 First | Native modules compile on first run; later runs are cached. |
License
MIT © 2026 tinyxia
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/tinyxia/imessage-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server