Straight Connect
An MCP server for communication service connectors that currently provides multi-account Telegram integration with granular tool access and security controls. It allows AI models to manage messages, chats, and media across various accounts through a flexible, extensible routing architecture.
README
Straight Connect

MCP server for communication service connectors. Currently supports Telegram with multi-account configuration. Designed for extensibility — more services (Slack, Discord, email, etc.) can be added later.
Architecture
mcp/
├── server.py # FastMCP entry point + ASGI middleware
├── telegram.py # Telegram config, API client, tool definitions
├── requirements.txt # Server dependencies
└── Dockerfile
src/
├── config.py # Generates mcp.json from .env
└── chat.py # Gradio + LangChain ReAct chat app
docker-compose.yaml
pyproject.toml
.env # Your configuration (not committed)
.env.example # Configuration template
Setup
- Copy the environment template and fill in your values:
cp .env.example .env
-
Get bot tokens from @BotFather on Telegram and add them to
.env. -
Start the MCP server:
docker compose up --build -d
- Verify it's running:
docker compose logs mcp
Configuration
All configuration lives in .env. See .env.example for the full template.
Telegram Accounts
# Comma-separated account labels
TELEGRAM_ACCOUNTS=nietzsche,aurelia
# Per-account bot tokens (label uppercased)
TELEGRAM_NIETZSCHE_BOT_TOKEN=your-token-here
TELEGRAM_AURELIA_BOT_TOKEN=your-token-here
Tool Levels
Control which Telegram tools are available per account. Set a global default and optionally override per account:
# Global default
TELEGRAM_LEVEL=basic
# Per-account override
TELEGRAM_NIETZSCHE_LEVEL=standard
TELEGRAM_AURELIA_LEVEL=full
| Level | Tools (cumulative) |
|---|---|
| basic | get_me, send_message, get_updates |
| standard | + forward_message, edit_message_text, delete_message, send_photo, send_document |
| advanced | + get_chat, send_location, send_poll, pin_chat_message, unpin_chat_message, get_chat_member_count, get_chat_member |
| full | + send_audio, send_video, send_voice, send_sticker, copy_message, set_message_reaction, leave_chat, send_contact, send_venue |
Allowed Chats
Optionally restrict which chats a bot account can interact with. If set, any tool call targeting a chat not in the list will be rejected. If not set, all chats are allowed.
# Comma-separated chat IDs (user IDs, group IDs, @channel_usernames)
TELEGRAM_NIETZSCHE_ALLOWED_CHATS=123456789,-1001234567890
TELEGRAM_AURELIA_ALLOWED_CHATS=987654321,@mychannel
This applies to all tools that take a chat_id parameter. For forward_message and copy_message, both source and destination chats are checked.
Allowed User IDs
Restrict which Telegram users a bot account will interact with. Incoming updates from non-listed users are silently filtered out by get_updates. If not set, all users are allowed and a warning is logged at startup.
TELEGRAM_NIETZSCHE_ALLOWED_USER_IDS=123456789
TELEGRAM_AURELIA_ALLOWED_USER_IDS=5138099108,987654321
MCP Port
MCP_PORT=9831
Chat Model
Used by uv run chat for the Gradio test interface:
OPENAI_API_BASE=http://localhost:8000/v1
OPENAI_API_KEY=not-needed
CHAT_MODEL=openai:your-model-name
MCP Endpoints
Each account gets its own endpoint scoped by service and account label:
http://localhost:9831/mcp/telegram/<account>
Examples:
http://localhost:9831/mcp/telegram/nietzschehttp://localhost:9831/mcp/telegram/aurelia
There is no shared /mcp endpoint — each URL is exclusive to one account. This enables MCP clients to connect per-account with distinct tool namespaces.
Client Tools
Generate mcp.json
Print the MCP client configuration derived from your .env:
uv run config
Output:
{
"mcpServers": {
"nietzsche": {
"url": "http://localhost:9831/mcp/telegram/nietzsche"
},
"aurelia": {
"url": "http://localhost:9831/mcp/telegram/aurelia"
}
}
}
Chat Interface
Launch a Gradio web UI that connects to all configured MCP servers with a LangChain ReAct agent:
uv run chat
On startup it will:
- Connect to each configured MCP server
- List all available tools per account
- Test the configured chat model
- Launch the Gradio interface
Tool names are prefixed with the account label for disambiguation (e.g., nietzsche_telegram_send_message, aurelia_telegram_get_updates).
How It Works
- URL routing: ASGI middleware rewrites
/mcp/<service>/<account>to the internal FastMCP endpoint and sets the account context viacontextvars - Dynamic registration: Only configured services register their tools. If
TELEGRAM_ACCOUNTSis empty, no Telegram tools exist - Level gating: Tools are registered based on the maximum level across all accounts. Per-account level checks happen at call time, returning an error if the account's level is insufficient
- Chat whitelisting: Optional per-account
ALLOWED_CHATSrestricts which chats the bot can interact with - User filtering: Optional per-account
ALLOWED_USER_IDSfilters incoming updates to only include messages from specified users - Extensibility: New services follow the same pattern — add a config class, register tools conditionally, and the middleware routes automatically via
/mcp/<service>/<account>
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.