2025-12-09 17:51:05 +00:00
---
summary: "Telegram bot support status, capabilities, and configuration"
read_when:
- Working on Telegram features or webhooks
---
2025-12-07 22:46:02 +01:00
# Telegram (Bot API)
Updated: 2025-12-07
2025-12-14 00:49:18 +00:00
Status: ready for bot-mode use with grammY (long-polling by default; webhook supported when configured). Text + media send, mention-gated group replies, and optional proxy support are implemented.
2025-12-07 22:46:02 +01:00
## Goals
- Let you talk to Clawdis via a Telegram bot in DMs and groups.
- Share the same `main` session used by WhatsApp/WebChat; groups stay isolated as `group:<chatId>` .
- Keep transport routing deterministic: replies always go back to the surface they arrived on.
## How it will work (Bot API)
1) Create a bot with @BotFather and grab the token.
2) Configure Clawdis with `TELEGRAM_BOT_TOKEN` (or `telegram.botToken` in `~/.clawdis/clawdis.json` ).
2025-12-26 16:54:53 +00:00
3) Run the gateway; it auto-starts Telegram when the bot token is set (unless `telegram.enabled = false` ).
2025-12-14 00:49:18 +00:00
- **Long-polling** is the default.
- **Webhook mode** is enabled by setting `telegram.webhookUrl` (optionally `telegram.webhookSecret` / `telegram.webhookPath` ).
- The webhook listener currently binds to `0.0.0.0:8787` and serves `POST /telegram-webhook` by default.
- If you need a different public port/host, set `telegram.webhookUrl` to the externally reachable URL and use a reverse proxy to forward to `:8787` .
2025-12-07 22:46:02 +01:00
4) Direct chats: user sends the first message; all subsequent turns land in the shared `main` session (default, no extra config).
5) Groups: add the bot, disable privacy mode (or make it admin) so it can read messages; group threads stay on `group:<chatId>` and require mention/command to trigger replies.
2025-12-24 00:22:57 +00:00
6) Optional allowlist: reuse `routing.allowFrom` for direct chats by chat id (`123456789` or `telegram:123456789` ).
2025-12-07 22:46:02 +01:00
## Capabilities & limits (Bot API)
- Sees only messages sent after it’ s added to a chat; no pre-history access.
- Cannot DM users first; they must initiate. Channels are receive-only unless the bot is an admin poster.
- File size caps follow Telegram Bot API (up to 2 GB for documents; smaller for some media types).
2025-12-23 02:26:11 +01:00
- Typing indicators (`sendChatAction` ) supported; outbound replies are sent as native replies to the triggering message (threaded where Telegram allows).
2025-12-07 22:46:02 +01:00
## Planned implementation details
2025-12-09 17:51:05 +00:00
- Library: grammY is the only client for send + gateway (fetch fallback removed); grammY throttler is enabled by default to stay under Bot API limits.
2025-12-23 02:44:38 +01:00
- Inbound normalization: maps Bot API updates to `MsgContext` with `Surface: "telegram"` , `ChatType: direct|group` , `SenderName` , `MediaPath` /`MediaType` when attachments arrive, `Timestamp` , and reply-to metadata (`ReplyToId` , `ReplyToBody` , `ReplyToSender` ) when the user replies; reply context is appended to `Body` as a `[Replying to ...]` block; groups require @bot mention by default.
2025-12-07 22:46:02 +01:00
- Outbound: text and media (photo/video/audio/document) with optional caption; chunked to limits. Typing cue sent best-effort.
2025-12-14 00:49:18 +00:00
- Config: `TELEGRAM_BOT_TOKEN` env or `telegram.botToken` required; `telegram.requireMention` , `telegram.allowFrom` , `telegram.mediaMaxMb` , `telegram.proxy` , `telegram.webhookSecret` , `telegram.webhookUrl` , `telegram.webhookPath` supported.
2025-12-07 22:46:02 +01:00
Example config:
```json5
{
telegram: {
2025-12-26 16:54:53 +00:00
enabled: true,
2025-12-07 22:46:02 +01:00
botToken: "123:abc",
requireMention: true,
allowFrom: ["123456789"], // direct chat ids allowed (or "*")
mediaMaxMb: 5,
proxy: "socks5://localhost:9050",
webhookSecret: "mysecret",
2025-12-14 00:49:18 +00:00
webhookPath: "/telegram-webhook",
2025-12-07 22:46:02 +01:00
webhookUrl: "https://yourdomain.com/telegram-webhook"
}
}
```
- Tests: grammY-based paths in `src/telegram/*.test.ts` cover DM + group gating; add more media and webhook cases as needed.
## Group etiquette
- Keep privacy mode off if you expect the bot to read all messages; with privacy on, it only sees commands/mentions.
- Make the bot an admin if you need it to send in restricted groups or channels.
- Mention the bot (`@yourbot` ) or use commands to trigger; we’ ll honor `group.requireMention` by default to avoid noise.
## Roadmap
- ✅ Design and defaults (this doc)
2025-12-09 17:51:05 +00:00
- ✅ grammY long-poll gateway + text/media send
2025-12-07 22:46:02 +01:00
- ✅ Proxy + webhook helpers (setWebhook/deleteWebhook, health endpoint, optional public URL)
- ⏳ Add more grammY coverage (webhook payloads, media edge cases)
## Safety & ops
2025-12-14 00:49:18 +00:00
- Treat the bot token as a secret (equivalent to account control); prefer `TELEGRAM_BOT_TOKEN` or a locked-down config file (`chmod 600 ~/.clawdis/clawdis.json` ).
- Respect Telegram rate limits (429s); grammY throttling is enabled by default.
2025-12-07 22:46:02 +01:00
- Use a test bot for development to avoid hitting production chats.