Mainstream messaging
Telegram
Prêt pour la production pour les MP de bots et les groupes via grammY. La scrutation longue est le mode par défaut ; le mode Webhook est facultatif.
La politique de MP par défaut pour Telegram est l’appairage.
Diagnostics intercanaux et guides de réparation.
Modèles et exemples complets de configuration des canaux.
Configuration rapide
Créer le jeton du bot dans BotFather
Ouvrez Telegram et discutez avec @BotFather (vérifiez que l’identifiant est exactement @BotFather).
Exécutez /newbot, suivez les invites, puis enregistrez le jeton.
Configurer le jeton et la politique de MP
{
channels: {
telegram: {
enabled: true,
botToken: "123:abc",
dmPolicy: "pairing",
groups: { "*": { requireMention: true } },
},
},
}
Repli par variable d’environnement : TELEGRAM_BOT_TOKEN=... (compte par défaut uniquement).
Telegram n’utilise pas openclaw channels login telegram ; configurez le jeton dans la configuration ou l’environnement, puis démarrez le gateway.
Démarrer le gateway et approuver le premier MP
openclaw gateway
openclaw pairing list telegram
openclaw pairing approve telegram <CODE>
Les codes d’appairage expirent après 1 heure.
Ajouter le bot à un groupe
Ajoutez le bot à votre groupe, puis définissez channels.telegram.groups et groupPolicy pour correspondre à votre modèle d’accès.
Paramètres côté Telegram
Mode confidentialité et visibilité des groupes
Les bots Telegram utilisent par défaut le Mode confidentialité, qui limite les messages de groupe qu’ils reçoivent.
Si le bot doit voir tous les messages de groupe, soit :
- désactivez le mode confidentialité via
/setprivacy, soit - faites du bot un administrateur du groupe.
Lorsque vous modifiez le mode confidentialité, supprimez puis rajoutez le bot dans chaque groupe afin que Telegram applique la modification.
Autorisations de groupe
Le statut d’administrateur se contrôle dans les paramètres du groupe Telegram.
Les bots administrateurs reçoivent tous les messages de groupe, ce qui est utile pour un comportement de groupe toujours actif.
Bascules BotFather utiles
/setjoingroupspour autoriser/refuser les ajouts à des groupes/setprivacypour le comportement de visibilité dans les groupes
Contrôle d’accès et activation
Politique de MP
channels.telegram.dmPolicy contrôle l’accès aux messages directs :
pairing(par défaut)allowlist(nécessite au moins un ID d’expéditeur dansallowFrom)open(nécessite queallowFrominclue"*")disabled
dmPolicy: "open" avec allowFrom: ["*"] permet à n’importe quel compte Telegram qui trouve ou devine le nom d’utilisateur du bot de commander le bot. Utilisez-le seulement pour des bots volontairement publics avec des outils strictement limités ; les bots à propriétaire unique doivent utiliser allowlist avec des ID utilisateur numériques.
channels.telegram.allowFrom accepte les ID utilisateur Telegram numériques. Les préfixes telegram: / tg: sont acceptés et normalisés.
Dans les configurations multicomptes, un channels.telegram.allowFrom restrictif au niveau supérieur est traité comme une limite de sécurité : les entrées allowFrom: ["*"] au niveau du compte ne rendent pas ce compte public sauf si la liste d’autorisation effective du compte contient toujours un joker explicite après fusion.
dmPolicy: "allowlist" avec allowFrom vide bloque tous les MP et est rejeté par la validation de configuration.
La configuration ne demande que des ID utilisateur numériques.
Si vous avez effectué une mise à niveau et que votre configuration contient des entrées de liste d’autorisation @username, exécutez openclaw doctor --fix pour les résoudre (au mieux ; nécessite un jeton de bot Telegram).
Si vous dépendiez auparavant de fichiers de liste d’autorisation du magasin d’appairage, openclaw doctor --fix peut récupérer les entrées dans channels.telegram.allowFrom dans les flux de liste d’autorisation (par exemple lorsque dmPolicy: "allowlist" n’a encore aucun ID explicite).
Pour les bots à propriétaire unique, préférez dmPolicy: "allowlist" avec des ID numériques allowFrom explicites afin de conserver une politique d’accès durable dans la configuration (au lieu de dépendre d’approbations d’appairage précédentes).
Confusion fréquente : l’approbation d’appairage des MP ne signifie pas « cet expéditeur est autorisé partout ».
L’appairage accorde l’accès aux MP. Si aucun propriétaire de commandes n’existe encore, le premier appairage approuvé définit aussi commands.ownerAllowFrom afin que les commandes réservées au propriétaire et les approbations d’exécution aient un compte opérateur explicite.
L’autorisation des expéditeurs en groupe provient toujours de listes d’autorisation explicites dans la configuration.
Si vous voulez « je suis autorisé une fois et les MP comme les commandes de groupe fonctionnent », mettez votre ID utilisateur Telegram numérique dans channels.telegram.allowFrom ; pour les commandes réservées au propriétaire, assurez-vous que commands.ownerAllowFrom contient telegram:<your user id>.
Trouver votre ID utilisateur Telegram
Plus sûr (sans bot tiers) :
- Envoyez un MP à votre bot.
- Exécutez
openclaw logs --follow. - Lisez
from.id.
Méthode officielle de la Bot API :
curl "https://api.telegram.org/bot<bot_token>/getUpdates"
Méthode tierce (moins privée) : @userinfobot ou @getidsbot.
Politique de groupe et listes d’autorisation
Deux contrôles s’appliquent ensemble :
-
Quels groupes sont autorisés (
channels.telegram.groups)- aucune configuration
groups:- avec
groupPolicy: "open": n’importe quel groupe peut passer les vérifications d’ID de groupe - avec
groupPolicy: "allowlist"(par défaut) : les groupes sont bloqués jusqu’à ce que vous ajoutiez des entréesgroups(ou"*")
- avec
groupsconfiguré : agit comme une liste d’autorisation (ID explicites ou"*")
- aucune configuration
-
Quels expéditeurs sont autorisés dans les groupes (
channels.telegram.groupPolicy)openallowlist(par défaut)disabled
groupAllowFrom est utilisé pour le filtrage des expéditeurs en groupe. S’il n’est pas défini, Telegram se rabat sur allowFrom.
Les entrées groupAllowFrom doivent être des ID utilisateur Telegram numériques (les préfixes telegram: / tg: sont normalisés).
Ne mettez pas d’ID de chat de groupe ou de supergroupe Telegram dans groupAllowFrom. Les ID de chat négatifs doivent être placés sous channels.telegram.groups.
Les entrées non numériques sont ignorées pour l’autorisation des expéditeurs.
Limite de sécurité (2026.2.25+) : l’authentification des expéditeurs en groupe n’hérite pas des approbations du magasin d’appairage des MP.
L’appairage reste limité aux MP. Pour les groupes, définissez groupAllowFrom ou allowFrom par groupe/par sujet.
Si groupAllowFrom n’est pas défini, Telegram se rabat sur allowFrom dans la configuration, pas sur le magasin d’appairage.
Modèle pratique pour les bots à propriétaire unique : définissez votre ID utilisateur dans channels.telegram.allowFrom, laissez groupAllowFrom non défini et autorisez les groupes cibles sous channels.telegram.groups.
Note d’exécution : si channels.telegram est complètement absent, l’exécution utilise par défaut groupPolicy="allowlist" avec fermeture en cas d’échec, sauf si channels.defaults.groupPolicy est défini explicitement.
Exemple : autoriser n’importe quel membre dans un groupe spécifique :
{
channels: {
telegram: {
groups: {
"-1001234567890": {
groupPolicy: "open",
requireMention: false,
},
},
},
},
}
Exemple : autoriser uniquement des utilisateurs spécifiques dans un groupe spécifique :
{
channels: {
telegram: {
groups: {
"-1001234567890": {
requireMention: true,
allowFrom: ["8734062810", "745123456"],
},
},
},
},
}
Comportement des mentions
Les réponses de groupe nécessitent une mention par défaut.
La mention peut provenir :
- d’une mention native
@botusername, ou - de motifs de mention dans :
agents.list[].groupChat.mentionPatternsmessages.groupChat.mentionPatterns
Bascules de commande au niveau de la session :
/activation always/activation mention
Celles-ci mettent uniquement à jour l’état de session. Utilisez la configuration pour la persistance.
Exemple de configuration persistante :
{
channels: {
telegram: {
groups: {
"*": { requireMention: false },
},
},
},
}
Obtenir l’ID du chat de groupe :
- transférez un message de groupe à
@userinfobot/@getidsbot - ou lisez
chat.iddepuisopenclaw logs --follow - ou inspectez
getUpdatesde la Bot API
Comportement à l’exécution
- Telegram est détenu par le processus gateway.
- Le routage est déterministe : les messages entrants Telegram répondent vers Telegram (le modèle ne choisit pas les canaux).
- Les messages entrants sont normalisés dans l’enveloppe de canal partagée avec les métadonnées de réponse et les espaces réservés de médias.
- Les sessions de groupe sont isolées par ID de groupe. Les sujets de forum ajoutent
:topic:<threadId>pour maintenir l’isolement des sujets. - Les messages MP peuvent porter
message_thread_id; OpenClaw conserve l’ID de fil pour les réponses, mais maintient par défaut les MP sur la session plate. Configurezchannels.telegram.dm.threadReplies: "inbound",channels.telegram.direct.<chatId>.threadReplies: "inbound",requireTopic: trueou une configuration de sujet correspondante lorsque vous voulez intentionnellement isoler les sessions de sujets de MP. - La scrutation longue utilise le runner grammY avec un séquençage par chat/par fil. La concurrence globale du récepteur du runner utilise
agents.defaults.maxConcurrent. - La scrutation longue est protégée dans chaque processus gateway afin qu’un seul scrutateur actif puisse utiliser un jeton de bot à la fois. Si vous voyez encore des conflits
getUpdates409, un autre gateway OpenClaw, script ou scrutateur externe utilise probablement le même jeton. - Les redémarrages du watchdog de scrutation longue se déclenchent par défaut après 120 secondes sans vivacité
getUpdatesterminée. Augmentezchannels.telegram.pollingStallThresholdMsuniquement si votre déploiement voit encore de faux redémarrages pour blocage de scrutation pendant des travaux de longue durée. La valeur est en millisecondes et est autorisée de30000à600000; les remplacements par compte sont pris en charge. - La Bot API Telegram ne prend pas en charge les accusés de lecture (
sendReadReceiptsne s’applique pas).
Référence des fonctionnalités
Aperçu de flux en direct (modifications de message)
OpenClaw peut diffuser des réponses partielles en temps réel :
- chats directs : message d’aperçu +
editMessageText - groupes/sujets : message d’aperçu +
editMessageText
Exigence :
channels.telegram.streamingvautoff | partial | block | progress(par défaut :partial)progressconserve un brouillon de statut modifiable pour la progression des outils, l’efface à la fin et envoie la réponse finale comme message normalstreaming.preview.toolProgresscontrôle si les mises à jour d’outil/de progression réutilisent le même message d’aperçu modifié (par défaut :truelorsque le streaming d’aperçu est actif)streaming.preview.commandTextcontrôle les détails de commande/d’exécution dans ces lignes de progression d’outil :raw(par défaut, conserve le comportement publié) oustatus(libellé de l’outil uniquement)- les anciens
channels.telegram.streamModeet valeurs booléennesstreamingsont détectés ; exécutezopenclaw doctor --fixpour les migrer verschannels.telegram.streaming.mode
Les mises à jour d’aperçu de progression d’outil sont les courtes lignes de statut affichées pendant l’exécution des outils, par exemple l’exécution de commandes, les lectures de fichiers, les mises à jour de planification ou les résumés de correctifs. Telegram les laisse activées par défaut afin de correspondre au comportement publié d’OpenClaw à partir de v2026.4.22. Pour conserver l’aperçu modifié pour le texte de réponse mais masquer les lignes de progression d’outil, définissez :
{
"channels": {
"telegram": {
"streaming": {
"mode": "partial",
"preview": {
"toolProgress": false
}
}
}
}
}
Pour garder la progression d’outil visible mais masquer le texte de commande/d’exécution, définissez :
{
"channels": {
"telegram": {
"streaming": {
"mode": "partial",
"preview": {
"commandText": "status"
}
}
}
}
}
Utilisez le mode progress lorsque vous voulez une progression d’outil visible sans modifier la réponse finale dans ce même message. Placez la politique du texte de commande sous streaming.progress :
{
"channels": {
"telegram": {
"streaming": {
"mode": "progress",
"progress": {
"toolProgress": true,
"commandText": "status"
}
}
}
}
}
Utilisez streaming.mode: "off" uniquement lorsque vous voulez une livraison finale seulement : les modifications d’aperçu Telegram sont désactivées et le bavardage générique d’outil/progression est supprimé au lieu d’être envoyé comme messages d’état autonomes. Les invites d’approbation, les charges utiles multimédias et les erreurs passent toujours par la livraison finale normale. Utilisez streaming.preview.toolProgress: false lorsque vous voulez seulement conserver les modifications d’aperçu de réponse tout en masquant les lignes d’état de progression d’outil.
Pour les réponses uniquement textuelles :
- aperçus courts en DM/groupe/sujet : OpenClaw conserve le même message d’aperçu et effectue la modification finale sur place
- les réponses finales longues qui se divisent en plusieurs messages Telegram réutilisent l’aperçu existant comme premier fragment final lorsque c’est possible, puis envoient uniquement les fragments restants
- les réponses finales en mode progression effacent le brouillon d’état et utilisent la livraison finale normale au lieu de transformer le brouillon en réponse
- si la modification finale échoue avant que le texte terminé soit confirmé, OpenClaw utilise la livraison finale normale et nettoie l’aperçu obsolète
Pour les réponses complexes (par exemple les charges utiles multimédias), OpenClaw revient à la livraison finale normale puis nettoie le message d’aperçu.
Le streaming d’aperçu est distinct du streaming par blocs. Lorsque le streaming par blocs est explicitement activé pour Telegram, OpenClaw ignore le flux d’aperçu pour éviter un double streaming.
Flux de raisonnement propre à Telegram :
/reasoning streamenvoie le raisonnement à l’aperçu en direct pendant la génération- l’aperçu de raisonnement est supprimé après la livraison finale ; utilisez
/reasoning onlorsque le raisonnement doit rester visible - la réponse finale est envoyée sans texte de raisonnement
Mise en forme et solution de repli HTML
Le texte sortant utilise Telegram parse_mode: "HTML".
- Le texte de type Markdown est rendu en HTML compatible avec Telegram.
- Le HTML brut du modèle est échappé pour réduire les échecs d’analyse Telegram.
- Si Telegram rejette le HTML analysé, OpenClaw réessaie en texte brut.
Les aperçus de liens sont activés par défaut et peuvent être désactivés avec channels.telegram.linkPreview: false.
Commandes natives et commandes personnalisées
L’enregistrement du menu de commandes Telegram est géré au démarrage avec setMyCommands.
Valeurs par défaut des commandes natives :
commands.native: "auto"active les commandes natives pour Telegram
Ajouter des entrées de menu de commandes personnalisées :
{
channels: {
telegram: {
customCommands: [
{ command: "backup", description: "Git backup" },
{ command: "generate", description: "Create an image" },
],
},
},
}
Règles :
- les noms sont normalisés (suppression du
/initial, minuscules) - motif valide :
a-z,0-9,_, longueur1..32 - les commandes personnalisées ne peuvent pas remplacer les commandes natives
- les conflits/doublons sont ignorés et journalisés
Notes :
- les commandes personnalisées sont uniquement des entrées de menu ; elles n’implémentent pas automatiquement un comportement
- les commandes de Plugin/Skill peuvent toujours fonctionner lorsqu’elles sont saisies, même si elles ne sont pas affichées dans le menu Telegram
Si les commandes natives sont désactivées, les commandes intégrées sont supprimées. Les commandes personnalisées/de Plugin peuvent toujours s’enregistrer si elles sont configurées.
Échecs de configuration courants :
setMyCommands failedavecBOT_COMMANDS_TOO_MUCHsignifie que le menu Telegram déborde encore après réduction ; réduisez les commandes de Plugin/Skill/personnalisées ou désactivezchannels.telegram.commands.native.- l’échec de
deleteWebhook,deleteMyCommandsousetMyCommandsavec404: Not Foundalors que les commandes directes curl de la Bot API fonctionnent peut signifier quechannels.telegram.apiRoota été défini sur le point de terminaison complet/bot<TOKEN>.apiRootdoit être uniquement la racine de la Bot API, etopenclaw doctor --fixsupprime un suffixe accidentel/bot<TOKEN>. getMe returned 401signifie que Telegram a rejeté le jeton de bot configuré. Mettez à jourbotToken,tokenFileouTELEGRAM_BOT_TOKENavec le jeton BotFather actuel ; OpenClaw s’arrête avant l’interrogation, donc cela n’est pas signalé comme un échec de nettoyage de Webhook.setMyCommands failedavec des erreurs réseau/fetch signifie généralement que le DNS/HTTPS sortant versapi.telegram.orgest bloqué.
Commandes d’appairage d’appareil (Plugin device-pair)
Lorsque le Plugin device-pair est installé :
/pairgénère un code de configuration- collez le code dans l’application iOS
/pair pendingliste les demandes en attente (y compris rôle/portées)- approuvez la demande :
/pair approve <requestId>pour une approbation explicite/pair approvelorsqu’il n’y a qu’une seule demande en attente/pair approve latestpour la plus récente
Le code de configuration transporte un jeton d’amorçage à courte durée de vie. Le transfert d’amorçage intégré conserve le jeton du nœud principal à scopes: [] ; tout jeton opérateur transféré reste limité à operator.approvals, operator.read, operator.talk.secrets et operator.write. Les vérifications de portée d’amorçage sont préfixées par rôle, donc cette liste d’autorisation d’opérateur ne satisfait que les demandes opérateur ; les rôles non opérateur ont toujours besoin de portées sous leur propre préfixe de rôle.
Si un appareil réessaie avec des détails d’authentification modifiés (par exemple rôle/portées/clé publique), la demande en attente précédente est remplacée et la nouvelle demande utilise un requestId différent. Relancez /pair pending avant d’approuver.
Plus de détails : Appairage.
Boutons en ligne
Configurer la portée du clavier en ligne :
{
channels: {
telegram: {
capabilities: {
inlineButtons: "allowlist",
},
},
},
}
Remplacement par compte :
{
channels: {
telegram: {
accounts: {
main: {
capabilities: {
inlineButtons: "allowlist",
},
},
},
},
},
}
Portées :
offdmgroupallallowlist(par défaut)
L’ancien capabilities: ["inlineButtons"] correspond à inlineButtons: "all".
Exemple d’action de message :
{
action: "send",
channel: "telegram",
to: "123456789",
message: "Choose an option:",
buttons: [
[
{ text: "Yes", callback_data: "yes" },
{ text: "No", callback_data: "no" },
],
[{ text: "Cancel", callback_data: "cancel" }],
],
}
Les clics de rappel sont transmis à l’agent comme texte :
callback_data: <value>
Actions de message Telegram pour agents et automatisation
Les actions d’outil Telegram incluent :
sendMessage(to,content, optionnelmediaUrl,replyToMessageId,messageThreadId)react(chatId,messageId,emoji)deleteMessage(chatId,messageId)editMessage(chatId,messageId,content)createForumTopic(chatId,name, optionneliconColor,iconCustomEmojiId)
Les actions de message de canal exposent des alias ergonomiques (send, react, delete, edit, sticker, sticker-search, topic-create).
Contrôles de verrouillage :
channels.telegram.actions.sendMessagechannels.telegram.actions.deleteMessagechannels.telegram.actions.reactionschannels.telegram.actions.sticker(par défaut : désactivé)
Note : edit et topic-create sont actuellement activés par défaut et n’ont pas de bascules channels.telegram.actions.* séparées.
Les envois au runtime utilisent l’instantané actif de configuration/secrets (démarrage/rechargement), donc les chemins d’action ne réévaluent pas ponctuellement SecretRef à chaque envoi.
Sémantique de suppression des réactions : /tools/reactions
Balises de fils de réponse
Telegram prend en charge les balises explicites de fil de réponse dans la sortie générée :
[[reply_to_current]]répond au message déclencheur[[reply_to:<id>]]répond à un ID de message Telegram spécifique
channels.telegram.replyToMode contrôle la gestion :
off(par défaut)firstall
Lorsque le fil de réponse est activé et que le texte ou la légende Telegram d’origine est disponible, OpenClaw inclut automatiquement un extrait de citation Telegram natif. Telegram limite le texte de citation natif à 1024 unités de code UTF-16 ; les messages plus longs sont donc cités depuis le début et reviennent à une réponse simple si Telegram rejette la citation.
Note : off désactive le fil de réponse implicite. Les balises explicites [[reply_to_*]] restent honorées.
Sujets de forum et comportement des fils
Supergroupes de forum :
- les clés de session de sujet ajoutent
:topic:<threadId> - les réponses et la saisie ciblent le fil du sujet
- chemin de configuration du sujet :
channels.telegram.groups.<chatId>.topics.<threadId>
Cas particulier du sujet général (threadId=1) :
- les envois de message omettent
message_thread_id(Telegram rejettesendMessage(...thread_id=1)) - les actions de saisie incluent toujours
message_thread_id
Héritage des sujets : les entrées de sujet héritent des paramètres du groupe sauf remplacement (requireMention, allowFrom, skills, systemPrompt, enabled, groupPolicy).
agentId est propre au sujet et n’hérite pas des valeurs par défaut du groupe.
Routage d’agent par sujet : Chaque sujet peut être routé vers un agent différent en définissant agentId dans la configuration du sujet. Cela donne à chaque sujet son propre espace de travail, sa mémoire et sa session isolés. Exemple :
{
channels: {
telegram: {
groups: {
"-1001234567890": {
topics: {
"1": { agentId: "main" }, // General topic → main agent
"3": { agentId: "zu" }, // Dev topic → zu agent
"5": { agentId: "coder" } // Code review → coder agent
}
}
}
}
}
}
Chaque sujet a ensuite sa propre clé de session : agent:zu:telegram:group:-1001234567890:topic:3
Liaison de sujet ACP persistante : Les sujets de forum peuvent épingler les sessions de harnais ACP via des liaisons ACP typées de premier niveau (bindings[] avec type: "acp" et match.channel: "telegram", peer.kind: "group" et un identifiant qualifié par sujet comme -1001234567890:topic:42). Actuellement limité aux sujets de forum dans les groupes/supergroupes. Voir Agents ACP.
Lancement ACP lié au fil depuis le chat : /acp spawn <agent> --thread here|auto lie le sujet actuel à une nouvelle session ACP ; les suivis y sont routés directement. OpenClaw épingle la confirmation de lancement dans le sujet. Nécessite que channels.telegram.threadBindings.spawnSessions reste activé (par défaut : true).
Le contexte de modèle expose MessageThreadId et IsForum. Les discussions DM avec message_thread_id conservent par défaut le routage DM et les métadonnées de réponse sur des sessions plates ; elles n’utilisent des clés de session tenant compte des fils que lorsqu’elles sont configurées avec threadReplies: "inbound", threadReplies: "always", requireTopic: true ou une configuration de sujet correspondante. Utilisez channels.telegram.dm.threadReplies de premier niveau pour la valeur par défaut du compte, ou direct.<chatId>.threadReplies pour un DM.
Audio, vidéo et stickers
Messages audio
Telegram distingue les notes vocales des fichiers audio.
- par défaut : comportement de fichier audio
- balise
[[audio_as_voice]]dans la réponse de l’agent pour forcer l’envoi en note vocale - les transcriptions de notes vocales entrantes sont encadrées comme du texte généré par machine, non fiable dans le contexte de l’agent ; la détection des mentions utilise toujours la transcription brute, donc les messages vocaux soumis à une mention continuent de fonctionner.
Exemple d’action de message :
{
action: "send",
channel: "telegram",
to: "123456789",
media: "https://example.com/voice.ogg",
asVoice: true,
}
Messages vidéo
Telegram distingue les fichiers vidéo des notes vidéo.
Exemple d’action de message :
{
action: "send",
channel: "telegram",
to: "123456789",
media: "https://example.com/video.mp4",
asVideoNote: true,
}
Les notes vidéo ne prennent pas en charge les légendes ; le texte de message fourni est envoyé séparément.
Stickers
Gestion des stickers entrants :
- WEBP statique : téléchargé et traité (espace réservé
<media:sticker>) - TGS animé : ignoré
- WEBM vidéo : ignoré
Champs de contexte des stickers :
Sticker.emojiSticker.setNameSticker.fileIdSticker.fileUniqueIdSticker.cachedDescription
Fichier de cache des stickers :
~/.openclaw/telegram/sticker-cache.json
Les stickers sont décrits une fois (quand c’est possible) et mis en cache pour réduire les appels de vision répétés.
Activer les actions de sticker :
{
channels: {
telegram: {
actions: {
sticker: true,
},
},
},
}
Envoyer une action de sticker :
{
action: "sticker",
channel: "telegram",
to: "123456789",
fileId: "CAACAgIAAxkBAAI...",
}
Rechercher des stickers mis en cache :
{
action: "sticker-search",
channel: "telegram",
query: "cat waving",
limit: 5,
}
Notifications de réaction
Les réactions Telegram arrivent sous forme de mises à jour message_reaction (distinctes des charges utiles de message).
Lorsqu’elles sont activées, OpenClaw met en file d’attente des événements système comme :
Telegram reaction added: 👍 by Alice (@alice) on msg 42
Configuration :
channels.telegram.reactionNotifications:off | own | all(par défaut :own)channels.telegram.reactionLevel:off | ack | minimal | extensive(par défaut :minimal)
Notes :
ownsignifie uniquement les réactions des utilisateurs aux messages envoyés par le bot (au mieux, via le cache des messages envoyés).- Les événements de réaction respectent toujours les contrôles d’accès Telegram (
dmPolicy,allowFrom,groupPolicy,groupAllowFrom) ; les expéditeurs non autorisés sont ignorés. - Telegram ne fournit pas d’ID de fil dans les mises à jour de réaction.
- les groupes hors forum sont routés vers la session de discussion de groupe
- les groupes de forum sont routés vers la session du sujet général du groupe (
:topic:1), pas vers le sujet d’origine exact
allowed_updates pour le polling/webhook inclut automatiquement message_reaction.
Réactions d’accusé de réception
ackReaction envoie un emoji d’accusé de réception pendant qu’OpenClaw traite un message entrant.
Ordre de résolution :
channels.telegram.accounts.<accountId>.ackReactionchannels.telegram.ackReactionmessages.ackReaction- repli sur l’emoji d’identité de l’agent (
agents.list[].identity.emoji, sinon "👀")
Notes :
- Telegram attend un emoji Unicode (par exemple "👀").
- Utilisez
""pour désactiver la réaction pour un canal ou un compte.
Écritures de configuration depuis des événements et commandes Telegram
Les écritures de configuration de canal sont activées par défaut (configWrites !== false).
Les écritures déclenchées par Telegram incluent :
- événements de migration de groupe (
migrate_to_chat_id) pour mettre à jourchannels.telegram.groups /config setet/config unset(nécessite l’activation des commandes)
Désactiver :
{
channels: {
telegram: {
configWrites: false,
},
},
}
Long polling ou Webhook
La valeur par défaut est le long polling. Pour le mode Webhook, définissez channels.telegram.webhookUrl et channels.telegram.webhookSecret ; webhookPath, webhookHost, webhookPort sont facultatifs (valeurs par défaut /telegram-webhook, 127.0.0.1, 8787).
En mode long polling, OpenClaw conserve son repère de redémarrage uniquement après la distribution réussie d’une mise à jour. Si un gestionnaire échoue, cette mise à jour reste réessayable dans le même processus et n’est pas inscrite comme terminée pour la déduplication au redémarrage.
L’écouteur local se lie à 127.0.0.1:8787. Pour une entrée publique, placez un proxy inverse devant le port local ou définissez intentionnellement webhookHost: "0.0.0.0".
Le mode Webhook valide les garde-fous de requête, le jeton secret Telegram et le corps JSON avant de renvoyer 200 à Telegram.
OpenClaw traite ensuite la mise à jour de manière asynchrone au moyen des mêmes voies de bot par discussion/par sujet que le long polling, afin que les tours d’agent lents ne bloquent pas l’ACK de livraison de Telegram.
Limites, nouvelles tentatives et cibles CLI
- La valeur par défaut de
channels.telegram.textChunkLimitest 4000. channels.telegram.chunkMode="newline"privilégie les limites de paragraphe (lignes vides) avant le découpage par longueur.channels.telegram.mediaMaxMb(par défaut 100) limite la taille des médias Telegram entrants et sortants.channels.telegram.mediaGroupFlushMs(par défaut 500) contrôle la durée pendant laquelle les albums/groupes de médias Telegram sont mis en mémoire tampon avant qu’OpenClaw ne les distribue comme un seul message entrant. Augmentez-la si des parties d’album arrivent tard ; diminuez-la pour réduire la latence des réponses aux albums.channels.telegram.timeoutSecondsremplace le délai d’expiration du client API Telegram (s’il n’est pas défini, la valeur par défaut de grammY s’applique). Les clients bot bornent les valeurs configurées sous le garde-fou de requête texte/saisie sortante de 60 secondes afin que grammY n’abandonne pas la livraison visible de la réponse avant que le garde-fou de transport et le repli d’OpenClaw puissent s’exécuter. Le long polling utilise toujours un garde-fou de requêtegetUpdatesde 45 secondes afin que les sondages inactifs ne soient pas abandonnés indéfiniment.channels.telegram.pollingStallThresholdMsvaut120000par défaut ; ajustez entre30000et600000uniquement pour les redémarrages de polling bloqué faussement positifs.- l’historique de contexte de groupe utilise
channels.telegram.historyLimitoumessages.groupChat.historyLimit(par défaut 50) ;0le désactive. - le contexte supplémentaire de réponse/citation/transfert est actuellement transmis tel que reçu.
- les listes d’autorisation Telegram contrôlent principalement qui peut déclencher l’agent, et ne constituent pas une frontière complète de masquage du contexte supplémentaire.
- Contrôles de l’historique DM :
channels.telegram.dmHistoryLimitchannels.telegram.dms["<user_id>"].historyLimit
- La configuration
channels.telegram.retrys’applique aux assistants d’envoi Telegram (CLI/outils/actions) pour les erreurs d’API sortantes récupérables. La livraison de réponse finale entrante utilise aussi une nouvelle tentative d’envoi sûr bornée pour les échecs Telegram avant connexion, mais elle ne réessaie pas les enveloppes réseau ambiguës après envoi qui pourraient dupliquer les messages visibles.
Les cibles d’envoi CLI et de l’outil de message peuvent être un ID de discussion numérique, un nom d’utilisateur ou une cible de sujet de forum :
openclaw message send --channel telegram --target 123456789 --message "hi"
openclaw message send --channel telegram --target @name --message "hi"
openclaw message send --channel telegram --target -1001234567890:topic:42 --message "hi topic"
Les sondages Telegram utilisent openclaw message poll et prennent en charge les sujets de forum :
openclaw message poll --channel telegram --target 123456789 \
--poll-question "Ship it?" --poll-option "Yes" --poll-option "No"
openclaw message poll --channel telegram --target -1001234567890:topic:42 \
--poll-question "Pick a time" --poll-option "10am" --poll-option "2pm" \
--poll-duration-seconds 300 --poll-public
Indicateurs de sondage propres à Telegram :
--poll-duration-seconds(5-600)--poll-anonymous--poll-public--thread-idpour les sujets de forum (ou utilisez une cible:topic:)
L’envoi Telegram prend aussi en charge :
--presentationavec des blocsbuttonspour les claviers en ligne lorsquechannels.telegram.capabilities.inlineButtonsl’autorise--pinou--delivery '{"pin":true}'pour demander une livraison épinglée lorsque le bot peut épingler dans cette discussion--force-documentpour envoyer les images et GIF sortants comme documents au lieu de les téléverser comme photo compressée ou média animé
Contrôle des actions :
channels.telegram.actions.sendMessage=falsedésactive les messages Telegram sortants, y compris les sondageschannels.telegram.actions.poll=falsedésactive la création de sondages Telegram tout en laissant les envois classiques activés
Approbations exec dans Telegram
Telegram prend en charge les approbations exec dans les DM des approbateurs et peut éventuellement publier les invites dans la discussion ou le sujet d’origine. Les approbateurs doivent être des ID utilisateur Telegram numériques.
Chemin de configuration :
channels.telegram.execApprovals.enabled(s’active automatiquement lorsqu’au moins un approbateur peut être résolu)channels.telegram.execApprovals.approvers(se rabat sur les ID numériques des propriétaires depuiscommands.ownerAllowFrom)channels.telegram.execApprovals.target:dm(par défaut) |channel|bothagentFilter,sessionFilter
channels.telegram.allowFrom, groupAllowFrom et defaultTo contrôlent qui peut parler au bot et où il envoie les réponses normales. Ils ne font pas d’une personne un approbateur exec. Le premier appairage DM approuvé initialise commands.ownerAllowFrom lorsqu’aucun propriétaire de commande n’existe encore, de sorte que la configuration à un seul propriétaire fonctionne toujours sans dupliquer les ID sous execApprovals.approvers.
La livraison au canal affiche le texte de commande dans la discussion ; activez channel ou both uniquement dans des groupes/sujets de confiance. Lorsque l’invite arrive dans un sujet de forum, OpenClaw conserve le sujet pour l’invite d’approbation et le suivi. Les approbations exec expirent après 30 minutes par défaut.
Les boutons d’approbation en ligne nécessitent aussi que channels.telegram.capabilities.inlineButtons autorise la surface cible (dm, group ou all). Les ID d’approbation préfixés par plugin: sont résolus via les approbations Plugin ; les autres sont d’abord résolus via les approbations exec.
Voir Approbations exec.
Contrôles des réponses d’erreur
Lorsque l’agent rencontre une erreur de livraison ou de fournisseur, Telegram peut soit répondre avec le texte d’erreur, soit le supprimer. Deux clés de configuration contrôlent ce comportement :
| Clé | Valeurs | Par défaut | Description |
|---|---|---|---|
channels.telegram.errorPolicy |
reply, silent |
reply |
reply envoie un message d’erreur convivial à la discussion. silent supprime entièrement les réponses d’erreur. |
channels.telegram.errorCooldownMs |
nombre (ms) | 60000 |
Temps minimal entre les réponses d’erreur à la même discussion. Empêche le spam d’erreurs pendant les pannes. |
Les remplacements par compte, par groupe et par sujet sont pris en charge (même héritage que les autres clés de configuration Telegram).
{
channels: {
telegram: {
errorPolicy: "reply",
errorCooldownMs: 120000,
groups: {
"-1001234567890": {
errorPolicy: "silent", // suppress errors in this group
},
},
},
},
}
Dépannage
Le bot ne répond pas aux messages de groupe sans mention
- Si
requireMention=false, le mode de confidentialité Telegram doit autoriser une visibilité complète.- BotFather :
/setprivacy-> Disable - puis supprimez et rajoutez le bot au groupe
- BotFather :
openclaw channels statusavertit lorsque la configuration attend des messages de groupe sans mention.openclaw channels status --probepeut vérifier les ID numériques explicites de groupes ; le joker"*"ne permet pas de sonder l’appartenance.- test rapide de session :
/activation always.
Le bot ne voit aucun message de groupe
- lorsque
channels.telegram.groupsexiste, le groupe doit être listé (ou inclure"*") - vérifiez l’appartenance du bot au groupe
- consultez les journaux :
openclaw logs --followpour connaître les raisons des ignorances
Les commandes fonctionnent partiellement ou pas du tout
- autorisez votre identité d’expéditeur (appariement et/ou
allowFromnumérique) - l’autorisation des commandes s’applique toujours même lorsque la stratégie de groupe est
open setMyCommands failedavecBOT_COMMANDS_TOO_MUCHsignifie que le menu natif contient trop d’entrées ; réduisez les commandes de Plugin/Skills/personnalisées ou désactivez les menus natifs- les appels de démarrage
deleteMyCommands/setMyCommandset les appels de saisiesendChatActionsont bornés et réessayés une fois via le repli de transport de Telegram en cas d’expiration de requête. Des erreurs réseau/fetch persistantes indiquent généralement des problèmes d’accessibilité DNS/HTTPS versapi.telegram.org
Le démarrage signale un jeton non autorisé
getMe returned 401est un échec d’authentification Telegram pour le jeton de bot configuré.- Recopiez ou régénérez le jeton de bot dans BotFather, puis mettez à jour
channels.telegram.botToken,channels.telegram.tokenFile,channels.telegram.accounts.<id>.botTokenouTELEGRAM_BOT_TOKENpour le compte par défaut. deleteWebhook 401 Unauthorizedpendant le démarrage est également un échec d’authentification ; le traiter comme « aucun webhook n’existe » ne ferait que reporter le même échec de mauvais jeton aux appels d’API ultérieurs.
Instabilité du polling ou du réseau
- Node 22+ + un fetch/proxy personnalisé peuvent déclencher un comportement d’abandon immédiat si les types AbortSignal ne correspondent pas.
- Certains hôtes résolvent d’abord
api.telegram.orgen IPv6 ; une sortie IPv6 défaillante peut provoquer des échecs intermittents de l’API Telegram. - Si les journaux incluent
TypeError: fetch failedouNetwork request for 'getUpdates' failed!, OpenClaw réessaie désormais ces erreurs comme des erreurs réseau récupérables. - Pendant le démarrage du polling, OpenClaw réutilise la sonde de démarrage
getMeréussie pour grammY afin que l’exécuteur n’ait pas besoin d’un secondgetMeavant le premiergetUpdates. - Si
deleteWebhookéchoue avec une erreur réseau transitoire pendant le démarrage du polling, OpenClaw continue en long polling au lieu d’effectuer un autre appel de plan de contrôle avant polling. Un Webhook encore actif apparaît comme un conflitgetUpdates; OpenClaw reconstruit alors le transport Telegram et réessaie le nettoyage du Webhook. - Si les sockets Telegram se recyclent selon une cadence fixe courte, recherchez une valeur
channels.telegram.timeoutSecondsbasse ; les clients de bot plafonnent les valeurs configurées sous les gardes des requêtes sortantes etgetUpdates, mais les anciennes versions pouvaient abandonner chaque polling ou réponse lorsque ce paramètre était inférieur à ces gardes. - Si les journaux incluent
Polling stall detected, OpenClaw redémarre le polling et reconstruit le transport Telegram après 120 secondes sans vivacité de long polling terminée par défaut. openclaw channels status --probeetopenclaw doctoravertissent lorsqu’un compte de polling en cours d’exécution n’a pas terminégetUpdatesaprès la période de grâce du démarrage, lorsqu’un compte Webhook en cours d’exécution n’a pas terminésetWebhookaprès la période de grâce du démarrage, ou lorsque la dernière activité réussie du transport de polling est obsolète.- Augmentez
channels.telegram.pollingStallThresholdMsuniquement lorsque les appelsgetUpdateslongue durée sont sains mais que votre hôte signale encore de faux redémarrages pour blocage du polling. Des blocages persistants indiquent généralement des problèmes de proxy, DNS, IPv6 ou de sortie TLS entre l’hôte etapi.telegram.org. - Telegram respecte aussi les variables d’environnement de proxy du processus pour le transport Bot API, notamment
HTTP_PROXY,HTTPS_PROXY,ALL_PROXYet leurs variantes en minuscules.NO_PROXY/no_proxypeut toujours contournerapi.telegram.org. - Si le proxy géré par OpenClaw est configuré via
OPENCLAW_PROXY_URLpour un environnement de service et qu’aucune variable d’environnement de proxy standard n’est présente, Telegram utilise aussi cette URL pour le transport Bot API. - Sur les hôtes VPS avec sortie directe/TLS instable, routez les appels de l’API Telegram via
channels.telegram.proxy:
channels:
telegram:
proxy: socks5://<user>:<password>@proxy-host:1080
- Node 22+ utilise par défaut
autoSelectFamily=true(sauf WSL2). L’ordre des résultats DNS de Telegram respecteOPENCLAW_TELEGRAM_DNS_RESULT_ORDER, puischannels.telegram.network.dnsResultOrder, puis la valeur par défaut du processus commeNODE_OPTIONS=--dns-result-order=ipv4first; si rien ne s’applique, Node 22+ revient àipv4first. - Si votre hôte est WSL2 ou fonctionne explicitement mieux avec un comportement IPv4 uniquement, forcez la sélection de famille :
channels:
telegram:
network:
autoSelectFamily: false
- Les réponses de plage de benchmark RFC 2544 (
198.18.0.0/15) sont déjà autorisées par défaut pour les téléchargements de médias Telegram. Si un faux IP ou proxy transparent de confiance réécritapi.telegram.orgvers une autre adresse privée/interne/à usage spécial pendant les téléchargements de médias, vous pouvez activer le contournement propre à Telegram :
channels:
telegram:
network:
dangerouslyAllowPrivateNetwork: true
- La même option est disponible par compte à
channels.telegram.accounts.<accountId>.network.dangerouslyAllowPrivateNetwork. - Si votre proxy résout les hôtes de médias Telegram en
198.18.x.x, laissez d’abord le drapeau dangereux désactivé. Les médias Telegram autorisent déjà la plage de benchmark RFC 2544 par défaut.
- Remplacements d’environnement (temporaires) :
OPENCLAW_TELEGRAM_DISABLE_AUTO_SELECT_FAMILY=1OPENCLAW_TELEGRAM_ENABLE_AUTO_SELECT_FAMILY=1OPENCLAW_TELEGRAM_DNS_RESULT_ORDER=ipv4first
- Validez les réponses DNS :
dig +short api.telegram.org A
dig +short api.telegram.org AAAA
Aide supplémentaire : Dépannage des canaux.
Référence de configuration
Référence principale : Référence de configuration - Telegram.
Champs Telegram à fort signal
- démarrage/authentification :
enabled,botToken,tokenFile,accounts.*(tokenFiledoit pointer vers un fichier ordinaire ; les liens symboliques sont rejetés) - contrôle d’accès :
dmPolicy,allowFrom,groupPolicy,groupAllowFrom,groups,groups.*.topics.*,bindings[]de niveau supérieur (type: "acp") - approbations d’exécution :
execApprovals,accounts.*.execApprovals - commande/menu :
commands.native,commands.nativeSkills,customCommands - fils/réponses :
replyToMode,dm.threadReplies,direct.*.threadReplies - streaming :
streaming(aperçu),streaming.preview.toolProgress,blockStreaming - formatage/livraison :
textChunkLimit,chunkMode,linkPreview,responsePrefix - médias/réseau :
mediaMaxMb,mediaGroupFlushMs,timeoutSeconds,pollingStallThresholdMs,retry,network.autoSelectFamily,network.dangerouslyAllowPrivateNetwork,proxy - racine d’API personnalisée :
apiRoot(racine Bot API uniquement ; n’incluez pas/bot<TOKEN>) - Webhook :
webhookUrl,webhookSecret,webhookPath,webhookHost - actions/capacités :
capabilities.inlineButtons,actions.sendMessage|editMessage|deleteMessage|reactions|sticker - réactions :
reactionNotifications,reactionLevel - erreurs :
errorPolicy,errorCooldownMs - écritures/historique :
configWrites,historyLimit,dmHistoryLimit,dms.*.historyLimit
Associés
Associez un utilisateur Telegram au Gateway.
Comportement de liste d’autorisation des groupes et des sujets.
Routez les messages entrants vers les agents.
Modèle de menace et renforcement.
Associez les groupes et sujets aux agents.
Diagnostics intercanaux.