better-telegram-mcp
Production-grade MCP server for Telegram with dual-mode Bot API + MTProto, 6 composite tools
Better Telegram MCP
mcp-name: io.github.n24q02m/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
- Web-based OTP auth: Browser-based authentication with remote relay support for headless environments
Why Better?
| Feature | better-telegram-mcp | Other Telegram MCP servers |
|---|---|---|
| Dual mode (Bot + User/MTProto) | Y | Bot only |
| Composite mega-tools (6 vs 30+) | Y | Individual tools |
| Tool annotations (read-only, destructive hints) | Y | N |
| MCP Resources (docs as resources) | Y | N |
| Web-based OTP auth (no CLI needed) | Y | CLI only |
| Remote auth relay (headless SSH/Docker) | Y | N |
| Security hardening (SSRF, path traversal) | Y | N |
| Docker multi-arch (amd64 + arm64) | Y | amd64 only |
Token Optimization
Instead of registering 30+ individual tools, Better Telegram MCP uses a 3-tier mega-tool pattern:
| Tier | Description | Example |
|---|---|---|
| 6 mega-tools | Action dispatch via action parameter | messages(action="send", ...) |
| Tool annotations | Hints for AI model behavior | readOnlyHint=False, destructiveHint=True |
| MCP Resources | Documentation as resources | telegram://docs/messages |
This reduces token overhead by ~80% compared to registering each action as a separate tool.
MCP Resources
| URI | Content |
|---|---|
telegram://docs/messages | Message operations reference |
telegram://docs/chats | Chat management reference |
telegram://docs/media | Media send/download reference |
telegram://docs/contacts | Contact management reference |
telegram://stats | All documentation combined |
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
- Click "API development tools", create an app
- Note your
api_id(integer) andapi_hash(32-char hex string) - Add to your MCP config with all required env vars (see examples below)
- Start using — on first run, a local web page opens in your browser for OTP authentication:
- Click "Send OTP Code" to receive a code in your Telegram app
- Enter the OTP code on the web page
- If 2FA is enabled, enter your password on the same page
- Headless (Docker/SSH): use
curlto hit the same endpoints (URL shown in logs/error messages)
- Done — session file persists at
~/.better-telegram-mcp/<name>.session, no more auth needed on subsequent runs
Security: The session file has
600permissions (owner-only). Treat it like a password — anyone with this file can access your Telegram account.
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 | User mode | - | Phone number with country code (e.g., +84912345678). Required for web auth UI. |
TELEGRAM_AUTH_URL | No | https://better-telegram-mcp.n24q02m.com | Auth server URL. Use local for localhost mode, or a custom URL for self-hosted relay. |
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 (auto-auth on first run)
claude mcp add telegram -e TELEGRAM_API_ID=12345 -e TELEGRAM_API_HASH=abc123 -e TELEGRAM_PHONE=+1234567890 -- uvx --python 3.13 better-telegram-mcp
Claude Desktop / Cursor
Bot mode:
{
"mcpServers": {
"telegram": {
"command": "uvx",
"args": ["--python", "3.13", "better-telegram-mcp"],
"env": {
"TELEGRAM_BOT_TOKEN": "123456:ABC-DEF"
}
}
}
}
User mode:
{
"mcpServers": {
"telegram": {
"command": "uvx",
"args": ["--python", "3.13", "better-telegram-mcp"],
"env": {
"TELEGRAM_API_ID": "12345678",
"TELEGRAM_API_HASH": "your-api-hash-from-my-telegram-org",
"TELEGRAM_PHONE": "+1234567890"
}
}
}
}
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 (auto-auth on first run, mount session dir for persistence)
docker run -i --rm \
-e TELEGRAM_API_ID=12345 \
-e TELEGRAM_API_HASH=abcdef123456 \
-e TELEGRAM_PHONE=+84912345678 \
-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, mount the session directory with -v ~/.better-telegram-mcp:/data so the session persists across container restarts. On first run, the auth web server starts on localhost — use port mapping (-p 8080:PORT) or curl to complete auth.
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 |
not authenticated | Session not yet authorized | Open the auth URL shown in error message (browser or curl) |
PhoneNumberInvalidError | Wrong phone format | Include country code with + (e.g., +84912345678) |
SessionPasswordNeededError | 2FA enabled | Enter 2FA password on the web auth page |
FloodWaitError | Too many auth attempts | Wait the indicated seconds before retrying |
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 |
| OTP sent but where? | Code goes to Telegram app | Check the Telegram app on your phone (not SMS). Look for a message from "Telegram" with a login code. |
| Headless auth? | No browser available | Use curl: curl -X POST http://127.0.0.1:PORT/send-code then curl -X POST http://127.0.0.1:PORT/verify -d '{"code":"12345"}' |
Self-Hosting Auth Relay
By default, OTP authentication uses the hosted relay at better-telegram-mcp.n24q02m.com. To self-host:
# Build and run the auth relay server
cd auth-relay
docker build -t telegram-auth-relay .
docker run -d -p 8080:8080 --name telegram-auth-relay telegram-auth-relay
Then set the MCP server to use your relay:
{
"env": {
"TELEGRAM_AUTH_URL": "https://your-domain.com"
}
}
Or use TELEGRAM_AUTH_URL=local for localhost-only mode (no remote relay).
| Mode | TELEGRAM_AUTH_URL | Use case |
|---|---|---|
| Remote (default) | https://better-telegram-mcp.n24q02m.com | Headless, SSH, any browser |
| Self-hosted | https://your-domain.com | Custom deployment |
| Local | local | Desktop, offline, no remote |
Build from Source
git clone https://github.com/n24q02m/better-telegram-mcp.git
cd better-telegram-mcp
uv sync --group dev
uv run ruff check .
uv run pytest
uv run better-telegram-mcp
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 with hybrid search | uvx mnemo-mcp@latest |
| better-godot-mcp | Godot Engine for AI agents | npx -y @n24q02m/better-godot-mcp@latest |
Contributing
See CONTRIBUTING.md.
Privacy
See PRIVACY.md.
Changelog
See CHANGELOG.md.
License
MIT - See LICENSE.
Verwandte Server
Google Meet MCP Server
An MCP server for interacting with Google Meet through the Google Calendar API.
KickMCP
An MCP server for seamless integration with the Kick.com API.
VoidMob MCP
Mobile proxies, SMS verifications, and global eSIM data plans for AI agents and MCP clients.
MCP Chat Desktop App
A cross-platform desktop app for interacting with various Large Language Models (LLMs) through the Model Context Protocol (MCP).
Hacker News
Fetch and interact with Hacker News content, including top stories, comments, and search functionality.
MyMCPSpace
Access and interact with MyMCPSpace posts, replies, likes, and feeds.
DingDing Bot
Send various types of messages, including text, markdown, images, and files, to a DingDing group robot.
LINE Bot MCP Server
Connects an AI agent to a LINE Official Account using the LINE Messaging API.
Discord MCP
An MCP server for the Discord API, enabling seamless integration of Discord bots with MCP-compatible applications.
MCP Notify Server
Sends desktop notifications with sound when agent tasks are completed.