MCP-Telegram
MCP-Telegram connects AI assistants to Telegram as a userbot, enabling full access to your personal Telegram account for messaging, chat management, media handling, and contact management.
Connection & Authentication
Check connection status and account info
Authenticate via QR code login with session persistence across restarts
Messaging
Send text messages (with optional reply, Markdown/HTML formatting) and files (photos, documents, videos)
Edit, delete, forward, pin, and unpin messages
Reading & Searching
List recent chats with unread counts (filterable by type: private/group/channel)
Read messages from a specific chat with date range filtering
Search chats/users/channels by name or username
Search messages within a chat by text
Get unread chats at a glance
Chat Management
Mark chats as read
Get detailed chat info (name, type, member count, description)
List members of a group or channel
User & Contact Info
Retrieve your contacts list with phone numbers
View detailed user profiles (bio, photo, last seen)
Media
Download media from messages to local files
Chats can be targeted by numeric ID or @username. Compatible with Claude Desktop, Cursor, VS Code, Mastra, and other MCP clients.
Connects to Telegram via the MTProto protocol as a userbot, enabling AI assistants to manage chats, send and edit messages, list contacts, search message history, and download media.
MCP Telegram
๐ Documentation ยท โ๏ธ Cloud version โ connect Telegram to Claude.ai or ChatGPT in 30 seconds with QR code, no API keys needed.
An MCP (Model Context Protocol) server that connects AI assistants like Claude to Telegram via the MTProto protocol. Unlike bots, this runs as a userbot -- it operates under your personal Telegram account using GramJS, giving full access to your chats, contacts, and message history.
Features
Comprehensive tool coverage -- the most full-featured Telegram MCP server available (80+ tools)
MTProto protocol -- direct Telegram API access, not the limited Bot API
Userbot -- operates as your personal account, not a bot
Full-featured -- messaging, reactions, polls, scheduled messages, stickers, media, contacts, and more
Forum Topics -- list topics, read per-topic messages, send to specific topics, per-topic unread counts
Stickers -- search sticker sets, browse installed/recent stickers, send stickers to any chat
Account management -- update profile, manage privacy settings, sessions, auto-delete timers
Global search -- search messages across all chats at once
Real-time polling -- fetch updates via stateless cursors; agent owns
{pts, qts, date}stateInline bots & buttons -- query inline bots, send results, press callback buttons
Stories -- read stories from peers, get story view stats
Admin controls -- toggle channel signatures, anti-spam, forum mode, prehistory; approve join requests
Stats -- channel and supergroup analytics (GetBroadcastStats / GetMegagroupStats)
Boosts & Business -- boost status, boosters list, Telegram Business chat links
QR code login -- authenticate by scanning a QR code in the Telegram app
Session persistence -- login once, stay connected across restarts
Human-readable output -- sender names are resolved, not just numeric IDs
Works with any MCP client -- Claude Code, Claude Desktop, ChatGPT, Cursor, VS Code, Mastra, etc.
Prerequisites
Node.js 18 or later
Telegram API credentials --
API_IDandAPI_HASHfrom my.telegram.org
Quick Start
1. Get Telegram API credentials
Go to my.telegram.org and log in with your phone number.
Navigate to API development tools.
Create a new application (any name and platform).
Copy the App api_id and App api_hash.
2. Login
TELEGRAM_API_ID=YOUR_ID TELEGRAM_API_HASH=YOUR_HASH npx @overpod/mcp-telegram loginA QR code will appear in the terminal. Open Telegram on your phone, go to Settings > Devices > Link Desktop Device, and scan the code. The session is saved to ~/.mcp-telegram/session and reused automatically.
Custom session path: set
TELEGRAM_SESSION_PATH=/path/to/sessionto store the session file elsewhere.
3. Add to Claude
claude mcp add telegram -s user \
-e TELEGRAM_API_ID=YOUR_ID \
-e TELEGRAM_API_HASH=YOUR_HASH \
-- npx @overpod/mcp-telegramThat's it! Ask Claude to run telegram-status to verify.
Multiple Accounts
Use TELEGRAM_SESSION_PATH to run separate Telegram accounts side by side:
# Login each account with a unique session path
TELEGRAM_API_ID=ID1 TELEGRAM_API_HASH=HASH1 TELEGRAM_SESSION_PATH=~/.mcp-telegram/session-work npx @overpod/mcp-telegram login
TELEGRAM_API_ID=ID2 TELEGRAM_API_HASH=HASH2 TELEGRAM_SESSION_PATH=~/.mcp-telegram/session-personal npx @overpod/mcp-telegram loginThen add each as a separate MCP server:
claude mcp add telegram-work -s user \
-e TELEGRAM_API_ID=ID1 \
-e TELEGRAM_API_HASH=HASH1 \
-e TELEGRAM_SESSION_PATH=~/.mcp-telegram/session-work \
-- npx @overpod/mcp-telegram
claude mcp add telegram-personal -s user \
-e TELEGRAM_API_ID=ID2 \
-e TELEGRAM_API_HASH=HASH2 \
-e TELEGRAM_SESSION_PATH=~/.mcp-telegram/session-personal \
-- npx @overpod/mcp-telegramEach account gets its own session file โ no conflicts.
Proxy Support
If Telegram is blocked or you're running in a containerized environment (Docker, K3s), use a SOCKS5 or MTProxy:
# SOCKS5 proxy
TELEGRAM_PROXY_IP=127.0.0.1 \
TELEGRAM_PROXY_PORT=10808 \
npx @overpod/mcp-telegram
# MTProxy
TELEGRAM_PROXY_IP=proxy.example.com \
TELEGRAM_PROXY_PORT=443 \
TELEGRAM_PROXY_SECRET=ee00000000000000000000000000000000 \
npx @overpod/mcp-telegramVariable | Description |
| Proxy server address |
| Proxy server port |
|
|
| MTProxy secret (enables MTProxy mode) |
| Optional proxy auth |
| Optional proxy auth |
Installation Options
npx (recommended, zero install)
No need to clone or install anything. Just use npx @overpod/mcp-telegram.
Global install
npm install -g @overpod/mcp-telegram
mcp-telegram # run server
mcp-telegram login # QR loginPre-built binary (no runtime needed)
Download from Releases โ standalone single-file binaries, zero dependencies:
Platform | Server | Login CLI |
Linux x64 |
|
|
Linux ARM64 |
|
|
macOS x64 |
|
|
macOS ARM64 |
|
|
Windows x64 |
|
|
# Download (example for Linux x64)
curl -L -o mcp-telegram https://github.com/mcp-telegram/mcp-telegram/releases/latest/download/mcp-telegram-linux-x64
curl -L -o mcp-telegram-login https://github.com/mcp-telegram/mcp-telegram/releases/latest/download/mcp-telegram-login-linux-x64
chmod +x mcp-telegram mcp-telegram-login
# Login
TELEGRAM_API_ID=YOUR_ID TELEGRAM_API_HASH=YOUR_HASH ./mcp-telegram-login
# Run
./mcp-telegramFrom source
git clone https://github.com/mcp-telegram/mcp-telegram.git
cd mcp-telegram
npm install && npm run buildDocker
docker build -t mcp-telegram https://github.com/mcp-telegram/mcp-telegram.gitLogin (interactive terminal required):
docker run -it --rm \
-e TELEGRAM_API_ID=YOUR_ID \
-e TELEGRAM_API_HASH=YOUR_HASH \
-v ~/.mcp-telegram:/root/.mcp-telegram \
--entrypoint node mcp-telegram dist/qr-login-cli.jsRun the MCP server:
docker run -i --rm \
-e TELEGRAM_API_ID=YOUR_ID \
-e TELEGRAM_API_HASH=YOUR_HASH \
-v ~/.mcp-telegram:/root/.mcp-telegram \
mcp-telegramNote: Login must be done once via terminal. After that, the session is persisted in
~/.mcp-telegramand reused automatically.
Usage with MCP Clients
Claude Code (CLI)
claude mcp add telegram -s user \
-e TELEGRAM_API_ID=YOUR_ID \
-e TELEGRAM_API_HASH=YOUR_HASH \
-- npx @overpod/mcp-telegramClaude Desktop
Open your config file:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.json
Add the Telegram server:
{
"mcpServers": {
"telegram": {
"command": "npx",
"args": ["@overpod/mcp-telegram"],
"env": {
"TELEGRAM_API_ID": "YOUR_ID",
"TELEGRAM_API_HASH": "YOUR_HASH"
}
}
}
}Restart Claude Desktop.
Ask Claude: "Run telegram-login" -- a QR code will appear. If the image is not visible, it's also saved to
~/.mcp-telegram/qr-login.png. Scan it in Telegram (Settings > Devices > Link Desktop Device).Ask Claude: "Run telegram-status" to verify the connection.
Note: No terminal required! Login works entirely through Claude Desktop.
Claude Desktop (Binary)
Same setup, but using the pre-built binary instead of npx:
{
"mcpServers": {
"telegram": {
"command": "/path/to/mcp-telegram",
"env": {
"TELEGRAM_API_ID": "YOUR_ID",
"TELEGRAM_API_HASH": "YOUR_HASH"
}
}
}
}Claude Desktop (Docker)
Login via terminal first (see Docker section above).
Add to your config file:
{
"mcpServers": {
"telegram": {
"command": "docker",
"args": [
"run", "-i", "--rm",
"-e", "TELEGRAM_API_ID=YOUR_ID",
"-e", "TELEGRAM_API_HASH=YOUR_HASH",
"-v", "~/.mcp-telegram:/root/.mcp-telegram",
"mcp-telegram"
]
}
}
}Restart Claude Desktop. Ask Claude: "Run telegram-status" to verify.
Cursor / VS Code
Add the same JSON config above to your MCP settings (Cursor Settings > MCP, or VS Code MCP config).
Mastra
import { MCPClient } from "@mastra/mcp";
const telegramMcp = new MCPClient({
id: "telegram-mcp",
servers: {
telegram: {
command: "npx",
args: ["@overpod/mcp-telegram"],
env: {
TELEGRAM_API_ID: process.env.TELEGRAM_API_ID!,
TELEGRAM_API_HASH: process.env.TELEGRAM_API_HASH!,
},
},
},
});Tools
All tools are auto-discoverable via MCP โ your AI client will see the full list with parameters and descriptions when connected.
Category | Tools |
Auth |
|
Messaging |
|
Scheduled |
|
Reading |
|
Drafts |
|
Forum Topics |
|
Polls |
|
Reactions |
|
Stickers |
|
Media |
|
Groups |
|
Chat Info |
|
Invite Links |
|
Contacts |
|
Moderation |
|
Profiles |
|
Account |
|
Pinning |
|
Chat Settings |
|
Admin Toggles |
|
Stats |
|
Inline Bots & Buttons |
|
Real-Time Polling |
|
Stories |
|
Boosts & Business |
|
Opt-in (env-gated) |
|
Tip: Ask your AI assistant "What Telegram tools are available?" to get the full list with parameters and descriptions.
Optional Features
Some tools are disabled by default and must be opted in via environment variables:
Variable | Value | Tools enabled |
|
|
|
|
|
|
|
|
|
Add these to your .env file or MCP client config to enable them.
Development
npm run dev # Start with file watching (tsx)
npm start # Start the MCP server
npm run login # QR code login in terminal
npm run build # Compile TypeScript
npm run lint # Check code with Biome
npm run lint:fix # Auto-fix lint issues
npm run format # Format code with BiomeProject Structure
src/
index.ts -- MCP server entry point
telegram-client.ts -- TelegramService class (GramJS wrapper)
qr-login-cli.ts -- CLI utility for QR code login
tools/ -- Modular tool definitions
auth.ts -- Connection & login
messages.ts -- Send, read, search, edit, delete, forward; inline bots; real-time polling
chats.ts -- Chat listing, group management, admin toggles, stats
contacts.ts -- Contacts, profiles, moderation
media.ts -- Files, photos, downloads
reactions.ts -- Reactions, set-chat-reactions
extras.ts -- Pin, schedule, polls, topics
stickers.ts -- Sticker sets, send, search, browse
account.ts -- Sessions, privacy, auto-delete, profile, chat mute/folders, invite links, business chat links
boosts.ts -- Boost status, my boosts, boosters list
stories.ts -- Stories: list all, peer, by-id, view stats
group-calls.ts -- Group call info and participants (opt-in: MCP_TELEGRAM_ENABLE_GROUP_CALLS)
stars.ts -- Stars wallet status and transactions (opt-in: MCP_TELEGRAM_ENABLE_STARS)
quick-replies.ts -- Quick replies and messages (opt-in: MCP_TELEGRAM_ENABLE_QUICK_REPLIES)
shared.ts -- Shared utilitiesTech Stack
TypeScript -- ES2022, ESM modules
GramJS (
telegram) -- Telegram MTProto client@modelcontextprotocol/sdk -- MCP server framework
Zod -- Runtime schema validation for tool parameters
Biome -- Linter and formatter
tsx -- TypeScript execution without a build step
dotenv -- Environment variable management
Troubleshooting
AUTH_KEY_DUPLICATED
A Telegram session can only be used by one process at a time. If you get AUTH_KEY_DUPLICATED, it means another process is already using the same session file.
Solution: Create separate sessions for each environment:
# Local development
TELEGRAM_SESSION_PATH=~/.mcp-telegram/session-local npx @overpod/mcp-telegram login
# Production server
TELEGRAM_SESSION_PATH=~/.mcp-telegram/session-prod npx @overpod/mcp-telegram loginThen set TELEGRAM_SESSION_PATH in each environment's MCP config accordingly.
Security
API credentials are stored in
.env(gitignored)Session is stored in
~/.mcp-telegram/sessionwith0600permissions (owner-only access)Session directory is created with
0700permissionsPhone number is not required -- QR-only authentication
No data is sent to third-party services -- all communication goes directly to Telegram servers via MTProto
QR login codes are generated locally and never leave your machine
One session per process -- using the same session in multiple processes simultaneously causes
AUTH_KEY_DUPLICATEDerrors (see Troubleshooting)This is a userbot (personal account), not a bot -- respect the Telegram Terms of Service
License
MIT
Maintenance
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/mcp-telegram/mcp-telegram'
If you have feedback or need assistance with the MCP directory API, please join our Discord server