Telegram Notify MCP Server
Enables mobile notifications, approval workflows with inline keyboard buttons, remote prompt input from smartphones, and file sharing via Telegram Bot API
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Telegram Notify MCP Serverask for my approval before any destructive operations"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
telegram-copilot-bridge
Control GitHub Copilot CLI remotely from Telegram. Send prompts, manage sessions, and approve tool calls β all from your smartphone.
Architecture
π± Telegram
β (Bot API long-polling)
π telegram-copilot-bridge
β (stdin/stdout NDJSON β ACP)
π€ copilot --acp --stdioFeatures
Remote Prompting β Send Copilot prompts from Telegram, receive results on your phone
Multi-Session β Run multiple Copilot sessions in parallel, switch between them
Tool Approval β Approve or deny Copilot's tool calls via inline buttons
Autopilot Mode β Auto-approve all tool calls for hands-free operation
Session History β Resume past Copilot sessions with one tap
Folder Picker β
/newshows inline buttons for project directories
Installation
git clone https://github.com/NobufumiMurata/telegram-copilot-bridge.git
cd telegram-copilot-bridge
pip install -e .Prerequisites: Install Copilot CLI and authenticate:
winget install GitHub.Copilot # or: npm install -g @github/copilot
copilot # then /login to authenticateSetup
1. Create a Telegram Bot
Open Telegram and message @BotFather
Send
/newbotand follow the promptsCopy the bot token
2. Get Your Chat ID and User ID
Send any message to your bot, then:
curl "https://api.telegram.org/bot<YOUR_TOKEN>/getUpdates"From the response, note:
"chat": {"id": ...}β your Chat ID"from": {"id": ...}β your User ID (for the allowlist)
3. Configure
Copy the example file and fill in your values:
cp .env.example .env# .env
TELEGRAM_BOT_TOKEN=1234567890:AAXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
TELEGRAM_CHAT_ID=-100000000000
TELEGRAM_ALLOWED_USERS=123456789
# Default AI model
COPILOT_MODEL=claude-opus-4.6
# Root folder for /dirs and /new folder picker
COPILOT_DIRS_ROOT=/home/user/projectsThe .env file is loaded automatically on startup (from the current directory).
Use TELEGRAM_ENV_FILE=/path/to/.env to point to a different location.
Environment variables set in the shell always take priority over .env.
Usage
# Start (reads .env automatically)
python -m telegram_copilot_bridge
# With options
python -m telegram_copilot_bridge \
--cwd /path/to/project \
--model claude-opus-4.6 \
--timeout 120 \
-vCLI options:
Flag | Description | Default |
| Default working directory for sessions | current dir |
| AI model (e.g. |
|
| Auto-shutdown in minutes (0 = no timeout) |
|
| Auto-approve all tool calls | off (manual approval via Telegram) |
| Enable debug logging | off |
Telegram Commands
Command | Action |
| Start a new Copilot session (shows folder picker if |
| List past CLI sessions (default: 3) |
| Resume a past session |
| Browse directories |
| Show/set AI model |
| Toggle autopilot/manual approval |
| List active sessions |
| Switch active session |
| Session status |
| Stop a session |
| Stop all sessions & exit |
| Show commands |
(any text) | Send as prompt to active session |
Environment Variables
All variables can be set in .env or in the shell. Shell values take priority.
Telegram:
Variable | Description | Default |
| Bot API token | (required) |
| Target chat ID | (required) |
| Comma-separated allowed user IDs | (allow all) |
| Path to the |
|
| JSON credential file (fallback) | β |
Copilot:
Variable | Description | Default |
| Path to copilot executable |
|
| Default AI model |
|
| Auto-approve tool calls ( |
|
| Root directory for | (uses --cwd) |
| Comma-separated allowed working dirs | (any) |
| Comma-separated tools to allow |
|
| Permission approval timeout (seconds) |
|
| TCP port for singleton lock |
|
Security
User allowlist: Only messages from
TELEGRAM_ALLOWED_USERSare accepted. All other users are silently ignored.Timeouts: Configurable auto-shutdown timeout (default: no timeout). Permission requests timeout after 5 minutes (configurable via
COPILOT_PERMISSION_TIMEOUT_SECONDS).No secrets in repo: All credentials via
.envfile or environment variables.Tool allowlist: Uses
--allow-tool(not--allow-all-tools) to restrict what Copilot CLI can do.Directory restrictions: Restrict which directories Copilot sessions can operate in via
COPILOT_ALLOWED_DIRS.Singleton lock: Only one instance can run per machine (TCP port lock).
Limitations
VS Code local runs are not observable β There is no way to retrieve what Copilot is doing inside VS Code. MCP tools are one-way calls from VS Code β Bridge only.
Status of CLI sessions started outside the Bridge is unavailable β If you launch
copilotdirectly on the server, real-time execution status cannot be tracked. The Activity display in/status(estimated fromevents.jsonlmodification time) is the only alternative.Tool approval requests from CLI sessions started outside the Bridge cannot be relayed β Only sessions launched via the Hub can relay tool approval requests through Telegram inline buttons.
Single-instance restriction β Only one Hub process per machine (TCP port lock).
Telegram message length limit β Responses exceeding 4000 characters are split automatically.
License
MIT
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/NobufumiMurata/mcp-telegram-notify'
If you have feedback or need assistance with the MCP directory API, please join our Discord server