Production-grade MCP server for Telegram — dual-mode Bot API + MTProto, mega-tool pattern
Project description
better-telegram-mcp
Production-grade MCP server for Telegram with dual-mode support: Bot API (via httpx) for quick bot integrations and MTProto (via Telethon) for full user-account access including message search, history browsing, contact management, and group creation.
Features
- 6 mega-tools with action dispatch:
messages,chats,media,contacts,config,help - Dual mode: Bot API (httpx) for bots, MTProto (Telethon) for user accounts
- 3-tier token optimization: Only 6 tools registered instead of 30+ individual endpoints
- Tool annotations: Each tool declares
readOnlyHint,destructiveHint,idempotentHint,openWorldHint - MCP Resources: Documentation available as
telegram://docs/*resources - Auto-detect mode: Set bot token for bot mode, or API credentials for user mode
Quick Start
Bot Mode
- Open Telegram, search for @BotFather
- Send
/newbot, follow prompts to name your bot - Copy the token (format:
123456789:ABCdefGHI-JKLmnoPQRstUVwxyz) - Run:
TELEGRAM_BOT_TOKEN=123456:ABC-DEF uvx --python 3.13 better-telegram-mcp
User Mode
- Go to https://my.telegram.org
- Login with your phone number (OTP sent via Telegram, not SMS)
- Click "API development tools"
- Create an app, note
api_id(integer) andapi_hash(32-char hex) - Authenticate once, then run:
export TELEGRAM_API_ID=12345
export TELEGRAM_API_HASH=a1b2c3d4e5f6a1b2c3d4e5f6a1b2c3d4
# Step 1: Authenticate (interactive, one-time)
uvx --python 3.13 better-telegram-mcp auth
# Step 2: Run the server
uvx --python 3.13 better-telegram-mcp
Auth CLI
The auth command creates a Telethon session file for user mode. This must be done once before using user mode.
# Basic auth (prompts for phone + OTP)
TELEGRAM_API_ID=... TELEGRAM_API_HASH=... uvx --python 3.13 better-telegram-mcp auth
# With phone number pre-set (only prompts for OTP)
TELEGRAM_API_ID=... TELEGRAM_API_HASH=... TELEGRAM_PHONE=+84912345678 \
uvx --python 3.13 better-telegram-mcp auth
# With 2FA password pre-set
TELEGRAM_API_ID=... TELEGRAM_API_HASH=... TELEGRAM_PASSWORD=my2fapass \
uvx --python 3.13 better-telegram-mcp auth
# Named session (for multiple accounts)
TELEGRAM_API_ID=... TELEGRAM_API_HASH=... \
uvx --python 3.13 better-telegram-mcp auth --session-name work
Session file: Stored at ~/.better-telegram-mcp/<name>.session with 600 permissions (owner-only). Treat this file like a password.
2FA handling: If your account has Two-Step Verification enabled, set TELEGRAM_PASSWORD env var or enter it interactively when prompted.
Configuration
All configuration is via environment variables with TELEGRAM_ prefix:
| Variable | Required | Default | Description |
|---|---|---|---|
TELEGRAM_BOT_TOKEN |
Bot mode | - | Bot token from @BotFather |
TELEGRAM_API_ID |
User mode | - | API ID from my.telegram.org |
TELEGRAM_API_HASH |
User mode | - | API hash from my.telegram.org |
TELEGRAM_PHONE |
No | Interactive prompt | Phone number for auth (e.g., +84912345678) |
TELEGRAM_PASSWORD |
No | Interactive prompt | 2FA password (if enabled) |
TELEGRAM_SESSION_NAME |
No | default |
Session file name (for multiple accounts) |
TELEGRAM_DATA_DIR |
No | ~/.better-telegram-mcp |
Data directory for session files |
Mode detection: If TELEGRAM_API_ID + TELEGRAM_API_HASH are set, user mode is used (priority). Otherwise, TELEGRAM_BOT_TOKEN is used for bot mode. No silent fallback between modes.
MCP Config Examples
Claude Code
# Bot mode
claude mcp add telegram -e TELEGRAM_BOT_TOKEN=123456:ABC-DEF -- uvx --python 3.13 better-telegram-mcp
# User mode (after running auth)
claude mcp add telegram -e TELEGRAM_API_ID=12345 -e TELEGRAM_API_HASH=abc123 -- uvx --python 3.13 better-telegram-mcp
Claude Desktop / Cursor
{
"mcpServers": {
"telegram": {
"command": "uvx",
"args": ["--python", "3.13", "better-telegram-mcp"],
"env": {
"TELEGRAM_BOT_TOKEN": "123456:ABC-DEF"
}
}
}
}
VS Code Copilot
Add to .vscode/mcp.json:
{
"servers": {
"telegram": {
"command": "uvx",
"args": ["--python", "3.13", "better-telegram-mcp"],
"env": {
"TELEGRAM_BOT_TOKEN": "123456:ABC-DEF"
}
}
}
}
Docker
# Bot mode
docker run -i --rm -e TELEGRAM_BOT_TOKEN=123456:ABC-DEF n24q02m/better-telegram-mcp
# User mode (auth must be done on host first, then mount session)
docker run -i --rm \
-e TELEGRAM_API_ID=12345 \
-e TELEGRAM_API_HASH=abcdef123456 \
-v ~/.better-telegram-mcp:/data \
n24q02m/better-telegram-mcp
Docker config for MCP clients:
{
"mcpServers": {
"telegram": {
"command": "docker",
"args": [
"run", "-i", "--rm",
"-e", "TELEGRAM_BOT_TOKEN",
"n24q02m/better-telegram-mcp"
],
"env": {
"TELEGRAM_BOT_TOKEN": "123456:ABC-DEF"
}
}
}
}
Note: For user mode in Docker, authenticate on the host first (uvx better-telegram-mcp auth), then mount the session directory with -v ~/.better-telegram-mcp:/data.
Mode Capabilities
| Feature | Bot Mode | User Mode |
|---|---|---|
| Send messages | Y | Y |
| Edit messages | Y | Y |
| Delete messages | Y | Y |
| Forward messages | Y | Y |
| Pin messages | Y | Y |
| React to messages | Y | Y |
| Search messages | - | Y |
| Browse history | - | Y |
| List chats | - | Y |
| Get chat info | Y | Y |
| Create groups/channels | - | Y |
| Join/Leave chats | Partial | Y |
| Manage members | Y | Y |
| Admin promotion | Y | Y |
| Chat settings | Y | Y |
| Forum topics | Partial | Y |
| Send media (photo/file/voice/video) | Y | Y |
| Download media | - | Y |
| List contacts | - | Y |
| Search contacts | - | Y |
| Add contacts | - | Y |
| Block/Unblock users | - | Y |
Tool Reference
Use the help tool for full documentation:
help(topic="messages") # Message operations
help(topic="chats") # Chat management
help(topic="media") # Media send/download
help(topic="contacts") # Contact management
help(topic="all") # Everything
Troubleshooting
| Error | Cause | Fix |
|---|---|---|
No Telegram credentials found |
Neither bot token nor API credentials set | Set TELEGRAM_BOT_TOKEN or TELEGRAM_API_ID + TELEGRAM_API_HASH |
Invalid bot token |
Token revoked or wrong | Regenerate via /token in @BotFather |
Session not authorized |
Session file missing or expired | Run uvx better-telegram-mcp auth |
PhoneNumberInvalidError |
Wrong phone format | Include country code with + (e.g., +84912345678) |
SessionPasswordNeededError |
2FA enabled | Set TELEGRAM_PASSWORD env or enter interactively |
FloodWaitError |
Too many auth attempts | Wait the indicated seconds |
requires user mode |
Action not available in bot mode | Switch to user mode (API ID + Hash) |
| Session lost after Docker restart | Data volume not mounted | Add -v ~/.better-telegram-mcp:/data |
Compatible With
Also by n24q02m
| Server | Description | Install |
|---|---|---|
| better-notion-mcp | Notion API for AI agents | npx -y @n24q02m/better-notion-mcp@latest |
| better-email-mcp | Email (IMAP/SMTP) for AI agents | npx -y @n24q02m/better-email-mcp@latest |
| wet-mcp | Web search, extraction, library docs | uvx --python 3.13 wet-mcp@latest |
| mnemo-mcp | Persistent AI memory | uvx mnemo-mcp@latest |
| better-godot-mcp | Godot Engine for AI agents | npx -y @n24q02m/better-godot-mcp@latest |
Contributing
See CONTRIBUTING.md.
License
MIT - See LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file better_telegram_mcp-1.0.5.tar.gz.
File metadata
- Download URL: better_telegram_mcp-1.0.5.tar.gz
- Upload date:
- Size: 69.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.10 {"installer":{"name":"uv","version":"0.10.10","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f6c4ff535d3fab8f9a3fcf7dcd88f2083d1e71875dfa6b881141113a15d49658
|
|
| MD5 |
21b6ce31b7159acec30d3728e0c4c8df
|
|
| BLAKE2b-256 |
9fde52725eeb9a9c8783d559fd3dcdb2828346c5feabd1217fa2aa921602d6cb
|
File details
Details for the file better_telegram_mcp-1.0.5-py3-none-any.whl.
File metadata
- Download URL: better_telegram_mcp-1.0.5-py3-none-any.whl
- Upload date:
- Size: 26.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.10 {"installer":{"name":"uv","version":"0.10.10","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6a9c69451c644cd3cd44e54f2c57a7d4e93ea6da02fa689dc2b35e574618b6ee
|
|
| MD5 |
702574dad66ced8632ceb07b0b87ab4a
|
|
| BLAKE2b-256 |
eb2829bfaa2cf1ff237f7e5c027ab4e500e4fa44245e8890291c1e7008409660
|