telegram-mcp-server
Enables Claude to interact with Telegram, including listing chats, reading messages, sending messages, searching, and managing contacts.
README
Telegram MCP Server for Claude Cowork
This project exposes a Telegram account to Claude Cowork through MCP. It uses
Telethon to connect to Telegram and
FastMCP to expose tools that Claude can
call over stdio, which is the most reliable way to connect local MCP servers
to Claude Desktop and Cowork.
Features
- List recent chats and unread counts
- Look up chat metadata
- Search chats by name
- Read recent messages
- Send a message or reply
- Search messages globally or inside a chat
- List contacts
- Mark chats as read
Files
telegram_mcp_server.py: the MCP servertelegram_login.py: one-time login helperrequirements.txt: Python dependencies
Prerequisites
- Python 3.11+ or 3.12+
- A Telegram API ID and API hash from my.telegram.org
- Claude Desktop / Claude Cowork with local MCP enabled
Install
cd telegram-mcp-server
python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
Configure Telegram credentials
Create ~/.telegram-mcp/config.json:
{
"api_id": "123456",
"api_hash": "your_api_hash",
"phone": "+15551234567"
}
You can also provide the same values through environment variables:
TELEGRAM_API_IDTELEGRAM_API_HASHTELEGRAM_PHONE
One-time login
Run:
~/.telegram-mcp/venv/bin/python3 telegram_login.py
If you are using the repo-local virtualenv instead:
.venv/bin/python3 telegram_login.py
Telegram will prompt for your login code and any 2FA password. On success it
stores the session at ~/.telegram-mcp/session.session and also exports a
lock-free runtime session to ~/.telegram-mcp/session.string. The MCP server
prefers the string session so Claude, Codex, and automations can use Telegram
at the same time without SQLite lock errors.
Connect it to Claude Cowork
Add this entry to:
~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"telegram": {
"command": "/ABSOLUTE/PATH/TO/.venv/bin/python3",
"args": [
"/ABSOLUTE/PATH/TO/telegram_mcp_server.py"
]
}
}
}
If you are using the shared environment from ~/.telegram-mcp/venv, the entry
would look like:
{
"mcpServers": {
"telegram": {
"command": "/Users/you/.telegram-mcp/venv/bin/python3",
"args": [
"/path/to/telegram-mcp-server/telegram_mcp_server.py"
]
}
}
}
Then fully restart Claude Desktop. Cowork should discover the Telegram tools on startup.
Available tools
list_chats(limit=30)get_chat_info(chat_id)search_chats(query, limit=10)read_messages(chat_id, limit=20)send_message(chat_id, text, reply_to_message_id=0)search_messages(query, chat_id=0, limit=20, sender_name="")get_contacts(limit=50)mark_as_read(chat_id)
Optional SSE debugging mode
For local debugging only, you can run the server over SSE:
TELEGRAM_MCP_TRANSPORT=sse \
TELEGRAM_MCP_HOST=127.0.0.1 \
TELEGRAM_MCP_PORT=8457 \
.venv/bin/python3 telegram_mcp_server.py
This is useful for testing transport behavior, but Claude Cowork should use the
stdio setup above.
Troubleshooting
If Claude does not show the tools:
- Verify the paths in
claude_desktop_config.jsonare absolute - Restart Claude Desktop completely
- Re-run
telegram_login.pyif the Telegram session expired - Confirm your config file or environment variables contain
api_idandapi_hash
If you see database is locked:
- Re-run
telegram_login.pyto refresh~/.telegram-mcp/session.string - Restart Claude Desktop or open a fresh Codex session so new MCP processes use the string session
If authentication fails:
- Make sure your phone number includes the country code
- Make sure you are using credentials from
my.telegram.org, not a bot token
Security notes
Do not commit:
~/.telegram-mcp/config.json~/.telegram-mcp/session.session~/.telegram-mcp/session.string- any exported logs containing message content
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.