Enables AI agents to access Signal Desktop chat messages and attachments, providing tools to list chats, retrieve message history with pagination, and search for specific text within conversations from your local Signal database.
📱 signal-mcp-server
MCP Server for retrieving Signal messages using signal-export logic.
🎯 Overview
This MCP server enables AI agents and tools to access Signal Desktop chat messages and attachments via the Model Context Protocol (MCP).
🛠️ Features
Retrieve Signal messages from your local Signal Desktop database
List all Signal chats with contact details and message counts
Filter messages by chat/contact name
Paginate through message history with offset and limit
Support for multiple operating systems (Windows, macOS, Linux)
Handle encrypted Signal databases
📋 Prerequisites
Python 3.13 or higher
UV package manager
Signal Desktop installed with existing message database
Node.js and npm (for MCP inspector tools)
Windows, macOS, or Linux operating system
1. Signal Desktop
Official Download Page:
https://signal.org/download/Direct Download Links:
Note: Signal Desktop requires Signal to be installed on your phone for initial setup.
2. Python
Official Download Page:
https://www.python.org/downloads/Direct Download for Python 3.13.5:
Python 3.13.5 Release PageDownload the installer for your OS (Windows, macOS, Linux) and follow the setup instructions.
3. UV (Python Package Manager)
Official Documentation & Source:
https://github.com/astral-sh/uv
UV DocumentationInstallation (Windows):
irm https://astral.sh/uv/install.ps1 | iexOr, using pip (if you already have Python and pip installed):
pip install uvInstallation (macOS/Linux):
curl -LsSf https://astral.sh/uv/install.sh | shMore Info:
UV Installation Guide
4. Claude Desktop
Official Download Page:
https://claude.ai/downloadDownload the installer for your OS (Windows, macOS) and follow the setup instructions.
🚀 Installation Signal MCP Server
Clone the repository:
git clone https://github.com/stefanstranger/signal-mcp-server.git cd signal-mcp-serverCreate a virtual environment:
uv venv .venv --python 3.13Activate the virtual environment:
Windows PowerShell:
.\.venv\Scripts\Activate.ps1macOS/Linux:
source .venv/bin/activate
Install dependencies:
uv pip install fastmcp signal-export
⚙️ Configuration
🔧 Claude Desktop Setup
Usage with Claude Desktop Add the following to your claude_desktop_config.json file:
Signal Data Directory
The server automatically detects your Signal data directory based on your operating system:
Windows:
%APPDATA%\Signal
macOS:
~/Library/Application Support/Signal
Linux:
~/.config/Signal
(or Flatpak:~/.var/app/org.signal.Signal/config/Signal
)
Encryption
If your Signal database is encrypted, you may need to provide:
password
: Database password (if set)key
: Encryption key (if required)
🏃 Running the Server
Start MCP Server
Inspect MCP Server
Using the MCP Inspector:
Using mcptools:
📖 Available Tools
1. signal_list_chats
Lists all Signal chats with their details.
Parameters:
source_dir
(optional): Custom Signal data directory pathpassword
(optional): Database passwordkey
(optional): Encryption keyinclude_empty
(optional): Include chats with no messagesinclude_disappearing
(optional): Include disappearing messages
Example Response:
2. signal_get_chat_messages
Retrieves messages from a specific chat by name.
Parameters:
chat_name
(required): Name of the chat contactlimit
(optional): Maximum number of messages to returnoffset
(optional): Number of messages to skip (for pagination)Other parameters same as
signal_list_chats
Example Response:
3. signal_search_chat
Search for specific text within Signal chat messages.
Parameters:
chat_name
(required): Name of the chat to search withinquery
(required): Text to search for in message bodieslimit
(optional): Maximum number of matching messages to returnsource_dir
(optional): Custom Signal data directory pathpassword
(optional): Database passwordkey
(optional): Encryption keyinclude_empty
(optional): Include chats with no messagesinclude_disappearing
(optional): Include disappearing messages
Example Response:
🎯 Available Prompts
The server includes pre-built prompts for common analysis tasks:
1. signal_summarize_chat_prompt
Generate a summary prompt for recent messages in a specific chat.
2. signal_chat_topic_prompt
Generate a prompt to analyze discussion topics in a chat.
3. signal_chat_sentiment_prompt
Generate a prompt to analyze message sentiment in a chat.
4. signal_search_chat_prompt
Generate a search prompt for finding specific text in a chat.
💡 Usage Examples
List all chats
Get recent messages from a specific chat
Search for topics in a chat
Summarize conversations
Search within a chat
Analyze chat sentiment
🔒 Security & Privacy
⚠️ Important: This server provides access to your personal Signal messages. Please:
Only run this server locally
Never expose it to the internet
Be cautious about which AI agents you grant access
Consider the privacy of others in your conversations
Delete any exported data when no longer needed
🐛 Troubleshooting
Common Issues
"Signal database not found"
Ensure Signal Desktop is installed
Check if the data directory path is correct
Verify you have read permissions
"Database is encrypted"
Signal databases may be encrypted on some systems
You may need to provide encryption credentials
"No messages found"
Verify the chat name is spelled correctly
Check if the chat has any messages
Try using
include_empty=True
parameter
"Signal-MCP-Server does not want to start in Claude Desktop"
Check if there are no other Python versions installed besides the recommended version 3.13.
You may need to uninstall older Python versions installed.
📚 References
🙏 Credits
This project builds upon the excellent work of the signal-export project by Chris Arderne. The core logic for accessing and reading Signal Desktop databases is derived from and inspired by the signal-export library. I'm grateful for Chris his open-source contribution that made this MCP server possible.
📄 License
MIT License
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
⚖️ Disclaimer
This tool is not affiliated with or endorsed by Signal. Use at your own risk and respect the privacy of your conversations.
This server cannot be installed
local-only server
The server can only run on the client's local machine because it depends on local resources.
MCP Server for retrieving Signal messages using signal-export logic.
Related MCP Servers
- AsecurityAlicenseAqualityAn MCP server to run commands.Last updated -1403195MIT License
- AsecurityFlicenseAqualityA MCP Server used to collect MCP Servers over the internet.Last updated -319
- -securityAlicense-qualityA macOS app that provides an MCP server to your Messages, Contacts, and moreLast updated -820MIT License
- -securityFlicense-qualityRoot Signals MCP ServerLast updated -9