Telegram Userbot
Connect your personal Telegram account to OpenClaw via MTProto. Your AI assistant responds as you.
Audits
PassInstall
openclaw plugins install clawhub:telegram-userbotTelegram Userbot
Telegram Userbot plugin for OpenClaw — connects as a regular Telegram user account (not a bot) via MTProto using GramJS
WARNING: Using a user account for automated messaging may violate Telegram's Terms of Service. Use a dedicated secondary account. Your account could be banned or restricted.
Features
- MTProto Client API — operates as a user account, not a bot
- DM & Group support — private chats, groups, supergroups, forum topics
- Forum topic routing — correctly routes replies to the right forum topic thread
- @Mention detection — respond only when mentioned in groups (text, caption, and ID-based mentions)
- Read receipts — mark messages as read
- User allowlist — control which user has access to send messages for direct
- Chat allowlist — control which chats the assistant can access
- Multi-account — run multiple Telegram accounts simultaneously
- Per-group settings — different behavior for different groups
- Slash commands — slash commands are available in DM to the connected account (
/status,/reset,/new, etc.)
Requirements
- OpenClaw >= 2026.5.7
- Telegram API credentials from my.telegram.org
- Node.js >= 22
Installation
openclaw plugins install clawhub:telegram-userbot
Setup
1. Get Telegram API credentials
- Go to https://my.telegram.org
- Log in with your phone number
- Go to "API development tools"
- Create a new application
- Copy the
api_idandapi_hash
2. Log in to your telegram account
Log in to your telegram account via cli using API credentials and phone number
openclaw telegram-userbot --auth
If the custom OpenClaw cli command hangs, run the standalone authorization script directly:
node ~/.openclaw/extensions/telegram-userbot/dist/telegram-userbot-cli.js --auth
NOTES: Starting with OpenClaw
2026.5.12, hangs have been observed in some environments when running custom plugin cli commands throughopenclaw <plugin command> .... If that happens, use the standalone command above. It runs the same authorization flow, but bypasses the custom cli entrypoint inside OpenClaw.
Follow the steps in the console
Starting Telegram Userbot authorization...
Please enter your apiId: 12345678
Please enter your apiHash: c4b9c0fde16342afe52907847df27596
[2026-05-10T16:01:24.570] [INFO] - [Running gramJS version 2.26.21]
[2026-05-10T16:01:24.578] [INFO] - [Connecting to x.x.x.x:80/TCPFull...]
[2026-05-10T16:01:25.804] [INFO] - [Connection to x.x.x.x:80/TCPFull complete!]
[2026-05-10T16:01:25.808] [INFO] - [Using LAYER 198 for initial connect]
Please enter your number: +1 XXX XXX XXXX
Please enter the code you received: 12345
[2026-05-10T16:01:56.384] [INFO] - [Signed in successfully as <USER>]
[2026-05-10T16:01:56.388] [WARN] - [Disconnecting...]
[2026-05-10T16:01:56.390] [INFO] - [Disconnecting from x.x.x.x:80/TCPFull...]
Telegram authorization completed successfully.
Session string:
1BAAOMTQ5LjE1NC4xNjcuOTEAUQZ1aeNwM6O5lSD+kX/irkoUFMj+nUy5hRhpVqbkuOhEP+JOT4FEobUVnUKPnpKPxXdwQ9e
js+tWQTto86Heab4XSfyOoWK5WDA/dMhFYBuFxms/FF946HerCM+i5nh0gu//YGmIEntw7gY8JQQNYuvLB5SGdsDpa50LcJ5fK
686qqUsnlqmRTONdVG3EOdnV8RbTFTHg5BWLztfD5uLt1lIr/bG+BWCPCLAaA85yPL8SgGRLtX4QYXrnaEVmKui8SWq5J/
Ol86oZGlrMcnj5DRQ/VeYY7yGcESwnoTSx44irCyk9GelCavzs/dfN6sAYfoZb6cN/L9jxEYXkkCQdig=
Since the plugin supports connecting multiple accounts, at this step the cli will ask you for the account ID, if you do not enter anything, the [default] key will be applied. You can also enter your own value.
Enter account id for config [default]: [2026-05-10T16:01:56.402] [INFO] - [connection closed]
[2026-05-10T16:02:02.096] [WARN] - [Disconnecting...]
[2026-05-10T16:02:02.103] [INFO] - [Disconnecting from x.x.x.x:80/TCPFull...]
In the next step, you must confirm or reject the automatic update of the openclaw.json configuration file. If you reject it or receive an error updating the file, the cli will display an openclaw.json configuration fragment that you must add manually.
The automatic config update keeps the rest of openclaw.json intact and only updates the channels.telegram-userbot section for the selected account. A timestamped backup of the config file is created before any write attempt.
Update yes
Update OpenClaw config automatically? [y/N]: y
Config overwrite: /root/.openclaw/openclaw.json (sha256 97c4b55e61901aa71ff40898b5ebfbadd0f8fb9cd0145f3a08a5e5163783258a -> 6447683c687ceeb0dba09b2ca5187967e979ad2663d901977c608b6a09c9c432, backup=/root/.openclaw/openclaw.json.bak)
OpenClaw config updated: /root/.openclaw/openclaw.json
Configured account id: default
Config backup created: /root/.openclaw/openclaw.json.bak-20260512-084914-telegram-userbot-auth
After applying config changes, restart OpenClaw:
openclaw gateway restart
Update no
Update OpenClaw config automatically? [y/N]: n
JSON fragment for manual insertion:
{
"channels": {
"telegram-userbot": {
"accounts": {
"default": {
"enabled": true,
"apiId": 12345678,
"apiHash": "apiHash",
"sessionString": "sessionString",
"allowFrom": [
"*"
],
"groups": {
"*": {
"enabled": true,
"groupPolicy": "mention",
"allowFrom": [
"*"
]
}
}
}
}
}
}
}
After applying config changes, restart OpenClaw:
openclaw gateway restart
3. Restart OpenClaw gateway
openclaw gateway restart
Configuration Reference
JSON Reference
{
"channels": {
"telegram-userbot": {
"accounts": {
"default": {
"enabled": true,
"apiId": 12345678,
"apiHash": "apiHash",
"sessionString": "sessionString",
"allowFrom": [
"*"
],
"groups": {
"*": {
"enabled": true,
"groupPolicy": "mention",
"allowFrom": [
"*"
]
}
}
}
}
}
}
}
Mention fields
| Field | Type | Default | Description |
|---|---|---|---|
apiId | number | required | Telegram API ID |
apiHash | string | required | Telegram API hash |
sessionString | string | "" | Authenticated StringSession |
allowFrom | string[] | ["*"] | Allowed sender IDs/usernames for direct messages only |
groups | object | {} | Allowed groups map keyed by explicit group id or * |
Group config fields:
| Field | Type | Default | Description |
|---|---|---|---|
enabled | boolean | true | Enables or disables replies in the group |
groupPolicy | "open" | "mention" | "mention" | open replies to any group message, mention only on @mention or reply-to-self |
allowFrom | string[] | ["*"] | Allowed sender IDs/usernames inside that group |
Configuration variant for example
{
"channels": {
"telegram-userbot": {
"accounts": {
"default": {
"enabled": true,
"apiId": 12345678,
"apiHash": "apiHash",
"sessionString": "sessionString",
"allowFrom": [
"@nickname1",
"@nickname2"
],
"groups": {
"-1001234567899": {
"enabled": true,
"groupPolicy": "mention",
"allowFrom": [
"@nickname1"
]
},
"-1009876543219": {
"enabled": true,
"groupPolicy": "mention",
"allowFrom": [
"*"
]
},
"-1001234567891": {
"enabled": true,
"groupPolicy": "open",
"allowFrom": [
"*"
]
}
}
}
}
}
}
}
Slash commands
OpenClaw provides a robust set of native commands. Just like in a regular Telegram bot, slash commands are also available for a user Telegram account connected via the Telegram userbot plugin. Send the slash command in DM to the connected account.
Use commands like /status, /reset, /new and others.
You can read more about slash commands in the OpenClaw official documentation.
Multi-Account
The plugin also supports adding multiple accounts. You can run the cli command many times
openclaw telegram-userbot --auth
If the custom cli command hangs on your OpenClaw version, use the standalone command instead:
node ~/.openclaw/extensions/telegram-userbot/dist/telegram-userbot-cli.js --auth
And in the account ID step, enter a value other than the first [default] or your previously entered one. account ID must be unique
Enter account id for config [default]: [2026-05-10T16:01:56.402] [INFO] - [connection closed]
[2026-05-10T16:02:02.096] [WARN] - [Disconnecting...]
[2026-05-10T16:02:02.103] [INFO] - [Disconnecting from x.x.x.x:80/TCPFull...]
second
{
"channels": {
"telegram-userbot": {
"accounts": {
"default": {
"enabled": true,
"apiId": 12345678,
"apiHash": "apiHash",
"sessionString": "sessionString",
"allowFrom": [
"*"
],
"groups": {
"*": {
"enabled": true,
"groupPolicy": "mention",
"allowFrom": [
"*"
]
}
}
},
"second": {
"enabled": true,
"apiId": 12345678,
"apiHash": "apiHash",
"sessionString": "sessionString",
"allowFrom": [
"*"
],
"groups": {
"*": {
"enabled": true,
"groupPolicy": "mention",
"allowFrom": [
"*"
]
}
}
}
}
}
}
}
Multi-agent routing
The Telegram Userbot channel can also be used alongside the regular Telegram channel for configuring OpenClaw multi-agent routing. In that case, accounts connected via the Telegram Userbot channel will have independent agents.
Here is an example of how to configure OpenClaw multi-agent routing using telegram-userbot channel in parallel with main telegram channel.
You can read more about how to set up multi-agent routing in the official OpenClaw documentation
List model
"list": [
{
"id": "main",
"default": true,
"workspace": "/root/.openclaw/workspace"
},
{
"id": "second",
"workspace": "/root/.openclaw/workspace-second",
},
{
"id": "userbot-main",
"workspace": "/root/.openclaw/workspace-userbot-main",
},
{
"id": "userbot-second",
"workspace": "/root/.openclaw/workspace-userbot-second",
}
]
Bindings
"bindings": [
{
"agentId": "main",
"match": {
"channel": "telegram",
"accountId": "default"
}
},
{
"agentId": "second",
"match": {
"channel": "telegram",
"accountId": "second"
}
},
{
"agentId": "userbot-main",
"match": {
"channel": "telegram-userbot",
"accountId": "default"
}
},
{
"agentId": "userbot-second",
"match": {
"channel": "telegram-userbot",
"accountId": "second"
}
}
]
Development
npm install # install dependencies
npm run build # run build script
For local authorization testing during development, you can also run the standalone cli directly:
npm run telegram-userbot-cli -- --auth
or
npm run telegram-userbot-cli:auth
License
MIT
