Telegram MCP Server

Telegram MCP Server

An MCP server for interacting with Telegram bots and channels using the Telegraf library. It allows AI agents to send messages, manage channels, forward content, and intelligently respond to Telegram conversations.

Category
Visit Server

README

Telegram MCP Server

npm version License: MIT

Overview

An MCP (Model Context Protocol) server for interacting with Telegram bots and channels using the Telegraf library. This server enables AI agents to send messages, manage channels, forward content, and respond intelligently to Telegram conversations.

By implementing the Model Context Protocol (MCP), this server allows Large Language Models (LLMs) to interact with Telegram directly through their context window, bridging the gap between AI and messaging platforms.

Features

Core Tools

  • SEND_MESSAGE: Send messages to channels or chats with optional topic support
  • GET_CHANNEL_INFO: Get information about channels/chats
  • FORWARD_MESSAGE: Forward messages between chats
  • PIN_MESSAGE: Pin messages in channels
  • GET_CHANNEL_MEMBERS: Get list of channel administrators

AI Sampling (Enhanced)

  • Intelligent Responses: AI-powered responses using FastMCP sampling
  • Mention-Only Mode: Smart filtering - responds when mentioned in groups
  • Multi-Message Types: Supports text, photos, documents, voice, video, stickers, locations, contacts, polls
  • Access Control: Configurable user/chat allow/block lists
  • Rate Limiting: Per-user and per-chat rate limiting
  • Advanced Configuration: Highly customizable behavior and templates

Installation

Using npx (Recommended)

To use this server without installing it globally:

npx @iqai/mcp-telegram

Build from Source

git clone https://github.com/IQAIcom/mcp-telegram.git
cd mcp-telegram
pnpm install
pnpm run build

Running with an MCP Client

Add the following configuration to your MCP client settings (e.g., claude_desktop_config.json).

Minimal Configuration

{
  "mcpServers": {
    "telegram": {
      "command": "npx",
      "args": ["-y", "@iqai/mcp-telegram"],
      "env": {
        "TELEGRAM_BOT_TOKEN": "your_bot_token_here"
      }
    }
  }
}

Advanced Configuration (Local Build)

{
  "mcpServers": {
    "telegram": {
      "command": "node",
      "args": ["/absolute/path/to/mcp-telegram/dist/index.js"],
      "env": {
        "TELEGRAM_BOT_TOKEN": "your_bot_token_here",
        "SAMPLING_ENABLED": "true",
        "SAMPLING_MENTION_ONLY": "true"
      }
    }
  }
}

Configuration (Environment Variables)

Required

Variable Required Description
TELEGRAM_BOT_TOKEN Yes Your Telegram bot token from @BotFather

Sampling Configuration

Variable Default Description
SAMPLING_ENABLED true Enable/disable AI sampling entirely
SAMPLING_MENTION_ONLY true Only respond when mentioned in groups
SAMPLING_RESPOND_TO_DMS true Always respond in DMs
SAMPLING_MAX_TOKENS 1000 Max tokens per AI response
SAMPLING_SHOW_TYPING true Show typing indicator
SAMPLING_SILENT_MODE false Log but don't respond

Access Control

Variable Default Description
SAMPLING_ALLOWED_CHATS "" Comma-separated chat IDs/usernames to allow (empty = all)
SAMPLING_BLOCKED_CHATS "" Comma-separated chat IDs/usernames to ignore
SAMPLING_ALLOWED_USERS "" Comma-separated user IDs to allow (empty = all)
SAMPLING_BLOCKED_USERS "" Comma-separated user IDs to ignore
SAMPLING_ADMIN_USERS "" Comma-separated user IDs who can use admin commands

Rate Limiting

Variable Default Description
SAMPLING_RATE_LIMIT_USER 10 Max requests per user per minute
SAMPLING_RATE_LIMIT_CHAT 20 Max requests per chat per minute

Message Type Support

Variable Default Description
SAMPLING_ENABLE_TEXT true Enable text messages
SAMPLING_ENABLE_PHOTO true Enable photo messages
SAMPLING_ENABLE_DOCUMENT true Enable document uploads
SAMPLING_ENABLE_VOICE true Enable voice messages
SAMPLING_ENABLE_VIDEO true Enable video messages
SAMPLING_ENABLE_STICKER true Enable sticker messages
SAMPLING_ENABLE_LOCATION true Enable location sharing
SAMPLING_ENABLE_CONTACT true Enable contact sharing
SAMPLING_ENABLE_POLL true Enable poll messages

Content Filtering

Variable Default Description
SAMPLING_MIN_MESSAGE_LENGTH 1 Minimum message length
SAMPLING_MAX_MESSAGE_LENGTH 1000 Maximum message length
SAMPLING_KEYWORD_TRIGGERS "" Only respond to messages with these keywords
SAMPLING_IGNORE_COMMANDS true Ignore messages starting with /

Usage Examples

Market Discovery

  • "Send a message to @mychannel saying hello"
  • "Get information about @telegram channel"
  • "Forward message 123 from @source to @destination"

Bot Commands

  • /start: Initialize the bot and get a welcome message
  • /help: Get help information about available features
  • /config: View current configuration (admin users only)

MCP Tools

<!-- AUTO-GENERATED TOOLS START -->

FORWARD_MESSAGE

Forward a message from one chat to another

Parameter Type Required Description
fromChatId string number Yes
toChatId string number Yes
messageId number Yes ID of the message to forward
disableNotification boolean Forward message silently

GET_CHANNEL_INFO

Get information about a Telegram channel or chat

Parameter Type Required Description
channelId string number Yes

GET_CHANNEL_MEMBERS

Get a list of channel administrators and members

Parameter Type Required Default Description
channelId string number Yes
limit number 10 Maximum number of members to retrieve (1-50)

PIN_MESSAGE

Pin a message in a Telegram chat or channel

Parameter Type Required Description
chatId string number Yes
messageId number Yes ID of the message to pin
disableNotification boolean Pin message silently

SEND_MESSAGE

Send a message to a Telegram chat or channel

Parameter Type Required Description
chatId string number Yes
text string Yes The message text to send
topicId number The topic ID for forum channels (optional)
parseMode string Parse mode for Telegram rendering. Use Text for plain text without formatting.

<!-- AUTO-GENERATED TOOLS END -->

Development

Build Project

pnpm run build

Development Mode (Watch)

pnpm run watch

Linting & Formatting

pnpm run lint
pnpm run format

Project Structure

  • src/tools/: Individual tool definitions
  • src/services/: Telegram service and bot logic
  • src/sampling/: AI sampling feature implementation
  • src/config.ts: Configuration with Zod validation
  • src/index.ts: Server entry point

Getting Your Bot Token

  1. Message @BotFather on Telegram
  2. Use /newbot command
  3. Follow the prompts to create your bot
  4. Copy the bot token provided
  5. Set it as an environment variable

Resources

Disclaimer

This project is an unofficial tool. Users should ensure their bot usage complies with Telegram's Terms of Service and Bot API policies.

License

MIT

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured