MCP Telegram
Supports chat summarization using Google's Gemini API as one of the available LLM providers for analyzing and summarizing Telegram conversations.
Supports chat summarization using Ollama's local LLM as one of the available LLM providers for analyzing and summarizing Telegram conversations without requiring external API keys.
Provides comprehensive Telegram integration, enabling AI assistants to manage chats, send/receive messages, search conversations, schedule messages, resolve links, backup messages, and summarize chats using Telegram's API.
mcp-telegram
MCP server for Telegram — let AI assistants interact with your Telegram account
Features
Chat Management: List, search, mute/unmute chats
Messages: Read, search, inspect context, send, draft, schedule, link-resolve, and backup messages
AI Summarization: Summarize chat conversations using multiple LLM providers
Secure: Session stored in macOS Keychain (file-based storage on Linux/Windows)
Installation
go install github.com/tolmachov/mcp-telegram@latestOr build from source:
git clone https://github.com/tolmachov/mcp-telegram.git
cd mcp-telegram
makeSetup
1. Get Telegram API Credentials
Go to my.telegram.org/apps
Create an application
Copy
api_idandapi_hash
2. Configure Environment
Store credentials (macOS Keychain; plaintext JSON at ~/.local/state/mcp-telegram/config.json with 0600 perms on Linux/Windows):
mcp-telegram config set TELEGRAM_API_ID 123456789
mcp-telegram config set TELEGRAM_API_HASH abcd1234efgh5678Or use a .env file:
cp .env.example .env
# Edit .env with your credentials3. Login to Telegram
mcp-telegram login --phone +1234567890You'll be prompted for a verification code sent to your Telegram.
4. Configure MCP Client
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"telegram": {
"command": "mcp-telegram",
"args": ["run"],
"env": {
"TELEGRAM_API_ID": "your_api_id",
"TELEGRAM_API_HASH": "your_api_hash"
}
}
}
}Claude Code
claude mcp add telegram -- /path/to/mcp-telegram runSet environment variables in your .env file or pass them via --env.
Available Tools
19 tools exposed to MCP clients. Messages are identified by opaque string
handles ("42" for regular, "s:42" for scheduled) — copy them back
verbatim from tool outputs to follow-up calls, never parse or construct
them manually.
Tool | Description |
| Get current user information |
| List all chats, groups, and channels |
| Fuzzy search for chats by name |
| Get detailed information about a chat |
| Get messages from a chat (set |
| Search within one chat by substring, with optional date / sender / media / thread filters |
| Search by substring across all chats with opaque cursor-based pagination |
| Get messages around a specific anchor message in chronological order |
| Send, reply, schedule, or draft a message. |
| Edit a message; for scheduled handles, |
| Delete a message; |
| Forward a delivered message (scheduled handles are rejected) |
| Parse |
| Mark one or more chats as read |
| Export messages to a text file (idempotent; overwrites target) |
| Resolve @username to user/chat info |
| Mute or unmute chat notifications ( |
| AI-powered chat summarization via sampling / Gemini / Ollama / Anthropic |
| Download photo media from a message resource URI; returns MCP image content |
Available Resources
URI | Description |
| Current user info |
| All chats list |
| Detailed info for any chat ID via resource template |
| Last 100 messages from a pinned chat (dynamic resource, only for currently pinned chats) |
Pinned chat resources are created dynamically for each pinned chat and refreshed in the background; clients will receive resources/list_changed when the set changes.
Available Prompts
3 parameterized prompts that MCP clients expose as slash-commands or quick actions.
Prompt | Arguments | Description |
|
| Walks active chats and produces a per-chat digest of key updates and action items. Read-only. |
|
| Summarizes a specific chat and lists messages that look like they need a reply. Read-only. |
|
| Searches for a message, shows a draft reply, and sends only after explicit user confirmation. |
Prompt Examples
Here are some example prompts you can use with AI assistants:
Message Management
"Check for any unread important messages in my Telegram"
"Summarize all my unread Telegram messages"
"Read and analyze my unread messages, prepare draft responses where needed"
"Check non-critical unread messages and give me a brief overview"
"Find messages mentioning 'invoice' in my work chat from last week"
"Open the context around this Telegram link: https://t.me/example/123"
Organization
"Analyze my Telegram dialogs and suggest a folder structure"
"Help me categorize my Telegram chats by importance"
"Find all work-related conversations and suggest how to organize them"
Communication
"Monitor specific chat for updates about [topic]"
"Draft a polite response to the last message in [chat]"
"Check if there are any unanswered questions in my chats"
"Resolve this Telegram message link and show me the thread context"
Backup & Export
"Backup my conversation with [contact] to a file"
"Export the last week of messages from [group]"
"Backup media-only updates too so nothing is silently skipped"
Chat Summarization
The SummarizeChat tool supports multiple LLM providers:
sampling (experimental): Uses the MCP client's LLM via MCP Sampling. Only works with clients that support sampling: VS Code, fast-agent, Continue. Does NOT work with Claude Desktop or Claude Code.
ollama: Local LLM via Ollama - no API key required
gemini: Google Gemini API
anthropic: Anthropic Claude API
Configure via environment variables:
SUMMARIZE_PROVIDER=ollama # or: sampling, gemini, anthropic
SUMMARIZE_MODEL= # provider-specific model nameCommands
# Run MCP server (used by MCP clients)
mcp-telegram run
# Login to Telegram
mcp-telegram login --phone +1234567890
# Logout and delete session
mcp-telegram logout
# Securely store config values (macOS Keychain / file on Linux)
mcp-telegram config set TELEGRAM_API_ID 123456789
mcp-telegram config set TELEGRAM_API_HASH abcd1234
# List stored keys
mcp-telegram config list
# Delete a stored value
mcp-telegram config delete TELEGRAM_API_IDAllowed keys: TELEGRAM_API_ID, TELEGRAM_API_HASH, ANTHROPIC_API_KEY, GEMINI_API_KEY.
Configuration Options
Environment Variable | Description | Default |
| Telegram API ID | Required |
| Telegram API Hash | Required |
| Allowed directories for backups | OS app data dir |
| LLM provider for summarization |
|
| Model name | Provider default |
| Tokens per summarization batch |
|
| Ollama API URL |
|
| Google Gemini API key | - |
| Anthropic API key | - |
| Max bytes |
|
| RPS ceiling for history-fetching calls to Telegram. Exceeding Telegram's FLOOD_WAIT thresholds pauses all tools. |
|
| Polling interval (seconds) for the pinned-chat resource watcher. |
|
Destructive Actions
Tools like DeleteMessage request user confirmation via MCP elicitation before proceeding. If your MCP client does not support elicitation, the server relies on the LLM's instructions to confirm verbally before executing destructive operations.
Session Storage
macOS: Stored securely in Keychain.
Linux/Windows: Stored in
~/.local/state/mcp-telegram/session.jsonwith0600file permissions. The file is plaintext — keep the containing user account trusted, and prefer running on macOS when handling sensitive accounts.
Config values set via mcp-telegram config set (API keys, Telegram credentials) follow the same backend: Keychain on macOS, plaintext JSON on Linux/Windows.
License
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/tolmachov/mcp-telegram'
If you have feedback or need assistance with the MCP directory API, please join our Discord server