Gateway
Configuration — canaux
Clés de configuration par canal sous channels.*. Couvre l’accès aux DM et aux groupes,
les configurations multi-comptes, le filtrage par mention, et les clés par canal pour Slack, Discord,
Telegram, WhatsApp, Matrix, iMessage et les autres plugins de canal fournis.
Pour les agents, les outils, le runtime Gateway et les autres clés de premier niveau, consultez la référence de configuration.
Canaux
Chaque canal démarre automatiquement lorsque sa section de configuration existe (sauf si enabled: false).
Accès aux DM et aux groupes
Tous les canaux prennent en charge les politiques de DM et les politiques de groupe :
| Politique de DM | Comportement |
|---|---|
pairing (défaut) |
Les expéditeurs inconnus reçoivent un code d’association unique ; le propriétaire doit approuver |
allowlist |
Uniquement les expéditeurs dans allowFrom (ou le magasin d’autorisations appairé) |
open |
Autorise tous les DM entrants (requiert allowFrom: ["*"]) |
disabled |
Ignore tous les DM entrants |
| Politique de groupe | Comportement |
|---|---|
allowlist (défaut) |
Uniquement les groupes correspondant à l’allowlist configurée |
open |
Ignore les allowlists de groupe (le filtrage par mention s’applique toujours) |
disabled |
Bloque tous les messages de groupe/salon |
Remplacements de modèle par canal
Utilisez channels.modelByChannel pour associer des ID de canal spécifiques à un modèle. Les valeurs acceptent provider/model ou des alias de modèle configurés. La correspondance de canal s’applique lorsqu’une session n’a pas déjà de remplacement de modèle (par exemple, défini via /model).
{
channels: {
modelByChannel: {
discord: {
"123456789012345678": "anthropic/claude-opus-4-6",
},
slack: {
C1234567890: "openai/gpt-4.1",
},
telegram: {
"-1001234567890": "openai/gpt-4.1-mini",
"-1001234567890:topic:99": "anthropic/claude-sonnet-4-6",
},
},
},
}
Valeurs par défaut des canaux et Heartbeat
Utilisez channels.defaults pour le comportement partagé de politique de groupe et de Heartbeat entre les fournisseurs :
{
channels: {
defaults: {
groupPolicy: "allowlist", // open | allowlist | disabled
contextVisibility: "all", // all | allowlist | allowlist_quote
heartbeat: {
showOk: false,
showAlerts: true,
useIndicator: true,
},
},
},
}
channels.defaults.groupPolicy: politique de groupe de secours lorsqu’ungroupPolicyau niveau du fournisseur n’est pas défini.channels.defaults.contextVisibility: mode de visibilité par défaut du contexte supplémentaire pour tous les canaux. Valeurs :all(par défaut, inclut tout le contexte cité/de fil/de l’historique),allowlist(inclut uniquement le contexte des expéditeurs en allowlist),allowlist_quote(identique à allowlist, mais conserve le contexte explicite de citation/réponse). Remplacement par canal :channels.<channel>.contextVisibility.channels.defaults.heartbeat.showOk: inclut les états sains des canaux dans la sortie Heartbeat.channels.defaults.heartbeat.showAlerts: inclut les états dégradés/en erreur dans la sortie Heartbeat.channels.defaults.heartbeat.useIndicator: affiche une sortie Heartbeat compacte sous forme d’indicateur.
WhatsApp fonctionne via le canal web du Gateway (Baileys Web). Il démarre automatiquement lorsqu’une session liée existe.
{
web: {
enabled: true,
heartbeatSeconds: 60,
whatsapp: {
keepAliveIntervalMs: 25000,
connectTimeoutMs: 60000,
defaultQueryTimeoutMs: 60000,
},
reconnect: {
initialMs: 2000,
maxMs: 120000,
factor: 1.4,
jitter: 0.2,
maxAttempts: 0,
},
},
channels: {
whatsapp: {
dmPolicy: "pairing", // pairing | allowlist | open | disabled
allowFrom: ["+15555550123", "+447700900123"],
textChunkLimit: 4000,
chunkMode: "length", // length | newline
mediaMaxMb: 50,
sendReadReceipts: true, // blue ticks (false in self-chat mode)
groups: {
"*": { requireMention: true },
},
groupPolicy: "allowlist",
groupAllowFrom: ["+15551234567"],
},
},
}
WhatsApp multi-comptes
{
channels: {
whatsapp: {
accounts: {
default: {},
personal: {},
biz: {
// authDir: "~/.openclaw/credentials/whatsapp/biz",
},
},
},
},
}
- Les commandes sortantes utilisent par défaut le compte
defaults’il existe ; sinon le premier ID de compte configuré (trié). - L’option facultative
channels.whatsapp.defaultAccountremplace cette sélection de compte par défaut de secours lorsqu’elle correspond à un ID de compte configuré. - Le répertoire d’authentification Baileys historique à compte unique est migré par
openclaw doctorverswhatsapp/default. - Remplacements par compte :
channels.whatsapp.accounts.<id>.sendReadReceipts,channels.whatsapp.accounts.<id>.dmPolicy,channels.whatsapp.accounts.<id>.allowFrom.
Telegram
{
channels: {
telegram: {
enabled: true,
botToken: "your-bot-token",
dmPolicy: "pairing",
allowFrom: ["tg:123456789"],
groups: {
"*": { requireMention: true },
"-1001234567890": {
allowFrom: ["@admin"],
systemPrompt: "Keep answers brief.",
topics: {
"99": {
requireMention: false,
skills: ["search"],
systemPrompt: "Stay on topic.",
},
},
},
},
customCommands: [
{ command: "backup", description: "Git backup" },
{ command: "generate", description: "Create an image" },
],
historyLimit: 50,
replyToMode: "first", // off | first | all | batched
linkPreview: true,
streaming: "partial", // off | partial | block | progress (default: off; opt in explicitly to avoid preview-edit rate limits)
actions: { reactions: true, sendMessage: true },
reactionNotifications: "own", // off | own | all
mediaMaxMb: 100,
retry: {
attempts: 3,
minDelayMs: 400,
maxDelayMs: 30000,
jitter: 0.1,
},
network: {
autoSelectFamily: true,
dnsResultOrder: "ipv4first",
},
apiRoot: "https://api.telegram.org",
proxy: "socks5://localhost:9050",
webhookUrl: "https://example.com/telegram-webhook",
webhookSecret: "secret",
webhookPath: "/telegram-webhook",
},
},
}
- Jeton du bot :
channels.telegram.botTokenouchannels.telegram.tokenFile(fichier standard uniquement ; les liens symboliques sont rejetés), avecTELEGRAM_BOT_TOKENcomme solution de secours pour le compte par défaut. apiRootest uniquement la racine de l’API Telegram Bot. Utilisezhttps://api.telegram.orgou votre racine auto-hébergée/proxy, pashttps://api.telegram.org/bot<TOKEN>;openclaw doctor --fixsupprime un suffixe accidentel final/bot<TOKEN>.- L’option facultative
channels.telegram.defaultAccountremplace la sélection de compte par défaut lorsqu’elle correspond à un ID de compte configuré. - Dans les configurations multi-comptes (2 ID de compte ou plus), définissez un compte par défaut explicite (
channels.telegram.defaultAccountouchannels.telegram.accounts.default) pour éviter le routage de secours ;openclaw doctoravertit lorsque celui-ci est manquant ou invalide. configWrites: falsebloque les écritures de configuration initiées par Telegram (migrations d’ID de supergroupe,/config set|unset).- Les entrées
bindings[]de premier niveau avectype: "acp"configurent des liaisons ACP persistantes pour les sujets de forum (utilisez le format canoniquechatId:topic:topicIddansmatch.peer.id). La sémantique des champs est partagée dans Agents ACP. - Les aperçus de flux Telegram utilisent
sendMessage+editMessageText(fonctionne dans les conversations directes et de groupe). - Politique de nouvelle tentative : consultez la politique de nouvelle tentative.
Discord
{
channels: {
discord: {
enabled: true,
token: "your-bot-token",
mediaMaxMb: 100,
allowBots: false,
actions: {
reactions: true,
stickers: true,
polls: true,
permissions: true,
messages: true,
threads: true,
pins: true,
search: true,
memberInfo: true,
roleInfo: true,
roles: false,
channelInfo: true,
voiceStatus: true,
events: true,
moderation: false,
},
replyToMode: "off", // off | first | all | batched
dmPolicy: "pairing",
allowFrom: ["1234567890", "123456789012345678"],
dm: { enabled: true, groupEnabled: false, groupChannels: ["openclaw-dm"] },
guilds: {
"123456789012345678": {
slug: "friends-of-openclaw",
requireMention: false,
ignoreOtherMentions: true,
reactionNotifications: "own",
users: ["987654321098765432"],
channels: {
general: { allow: true },
help: {
allow: true,
requireMention: true,
users: ["987654321098765432"],
skills: ["docs"],
systemPrompt: "Short answers only.",
},
},
},
},
historyLimit: 20,
textChunkLimit: 2000,
chunkMode: "length", // length | newline
streaming: {
mode: "progress", // off | partial | block | progress (Discord default: progress)
progress: {
label: "auto",
maxLines: 8,
toolProgress: true,
},
},
maxLinesPerMessage: 17,
ui: {
components: {
accentColor: "#5865F2",
},
},
threadBindings: {
enabled: true,
idleHours: 24,
maxAgeHours: 0,
spawnSessions: true,
defaultSpawnContext: "fork",
},
voice: {
enabled: true,
autoJoin: [
{
guildId: "123456789012345678",
channelId: "234567890123456789",
},
],
daveEncryption: true,
decryptionFailureTolerance: 24,
connectTimeoutMs: 30000,
reconnectGraceMs: 15000,
tts: {
provider: "openai",
openai: { voice: "alloy" },
},
},
execApprovals: {
enabled: "auto", // true | false | "auto"
approvers: ["987654321098765432"],
agentFilter: ["default"],
sessionFilter: ["discord:"],
target: "dm", // dm | channel | both
cleanupAfterResolve: false,
},
retry: {
attempts: 3,
minDelayMs: 500,
maxDelayMs: 30000,
jitter: 0.1,
},
},
},
}
- Jeton :
channels.discord.token, avecDISCORD_BOT_TOKENcomme solution de repli pour le compte par défaut. - Les appels sortants directs qui fournissent un
tokenDiscord explicite utilisent ce jeton pour l’appel ; les paramètres de nouvelle tentative et de stratégie du compte proviennent toujours du compte sélectionné dans l’instantané d’exécution actif. - Le paramètre facultatif
channels.discord.defaultAccountremplace la sélection du compte par défaut lorsqu’il correspond à un identifiant de compte configuré. - Utilisez
user:<id>(DM) ouchannel:<id>(canal de guilde) pour les cibles de livraison ; les identifiants numériques nus sont rejetés. - Les slugs de guilde sont en minuscules avec les espaces remplacés par
-; les clés de canal utilisent le nom converti en slug (sans#). Préférez les identifiants de guilde. - Les messages rédigés par des bots sont ignorés par défaut.
allowBots: trueles active ; utilisezallowBots: "mentions"pour n’accepter que les messages de bots qui mentionnent le bot (les propres messages restent filtrés). channels.discord.guilds.<id>.ignoreOtherMentions(et les remplacements de canal) supprime les messages qui mentionnent un autre utilisateur ou rôle mais pas le bot (à l’exclusion de @everyone/@here).channels.discord.mentionAliasesassocie un texte@handlesortant stable à des identifiants d’utilisateurs Discord avant l’envoi, afin que les coéquipiers connus puissent être mentionnés de manière déterministe même lorsque le cache de répertoire transitoire est vide. Les remplacements par compte se trouvent souschannels.discord.accounts.<accountId>.mentionAliases.maxLinesPerMessage(17 par défaut) divise les messages hauts même lorsqu’ils font moins de 2000 caractères.channels.discord.threadBindingscontrôle le routage lié aux fils Discord :enabled: remplacement Discord pour les fonctionnalités de session liées à un fil (/focus,/unfocus,/agents,/session idle,/session max-age, et livraison/routage liés)idleHours: remplacement Discord pour l’auto-unfocus après inactivité, en heures (0désactive)maxAgeHours: remplacement Discord pour l’âge maximal strict, en heures (0désactive)spawnSessions: commutateur poursessions_spawn({ thread: true })et la création/liaison automatique de fils lors du spawn de fils ACP (par défaut :true)defaultSpawnContext: contexte de sous-agent natif pour les spawns liés à un fil ("fork"par défaut)
- Les entrées
bindings[]de niveau supérieur avectype: "acp"configurent des liaisons ACP persistantes pour les canaux et les fils (utilisez l’identifiant de canal/fil dansmatch.peer.id). La sémantique des champs est partagée dans Agents ACP. channels.discord.ui.components.accentColordéfinit la couleur d’accentuation pour les conteneurs de composants Discord v2.channels.discord.voiceactive les conversations dans les canaux vocaux Discord ainsi que les remplacements facultatifs auto-join + LLM + TTS. Les configurations Discord en texte seul laissent la voix désactivée par défaut ; définissezchannels.discord.voice.enabled=truepour l’activer.channels.discord.voice.modelremplace facultativement le modèle LLM utilisé pour les réponses des canaux vocaux Discord.channels.discord.voice.daveEncryptionetchannels.discord.voice.decryptionFailureTolerancesont transmis aux options DAVE de@discordjs/voice(trueet24par défaut).channels.discord.voice.connectTimeoutMscontrôle l’attente Ready initiale de@discordjs/voicepour/vc joinet les tentatives d’auto-join (30000par défaut).channels.discord.voice.reconnectGraceMscontrôle le délai dont dispose une session vocale déconnectée pour entrer en signalisation de reconnexion avant qu’OpenClaw ne la détruise (15000par défaut).- La lecture vocale Discord n’est pas interrompue par l’événement de début de parole d’un autre utilisateur. Pour éviter les boucles de rétroaction, OpenClaw ignore la nouvelle capture vocale pendant la lecture TTS.
- OpenClaw tente en outre de récupérer la réception vocale en quittant/rejoignant une session vocale après des échecs de déchiffrement répétés.
channels.discord.streamingest la clé canonique du mode de flux. Discord utilise par défautstreaming.mode: "progress"afin que la progression des outils/du travail apparaisse dans un seul message d’aperçu modifié ; définissezstreaming.mode: "off"pour le désactiver. Les anciennes valeursstreamModeet booléennesstreamingrestent des alias d’exécution ; exécutezopenclaw doctor --fixpour réécrire la configuration persistante.channels.discord.autoPresenceassocie la disponibilité d’exécution à la présence du bot (healthy => online, degraded => idle, exhausted => dnd) et permet des remplacements facultatifs du texte de statut.channels.discord.dangerouslyAllowNameMatchingréactive la correspondance mutable par nom/étiquette (mode de compatibilité break-glass).channels.discord.execApprovals: livraison des approbations exec natives Discord et autorisation des approbateurs.enabled:true,falseou"auto"(par défaut). En mode auto, les approbations exec s’activent lorsque les approbateurs peuvent être résolus depuisapproversoucommands.ownerAllowFrom.approvers: identifiants d’utilisateurs Discord autorisés à approuver les demandes exec. Se rabat surcommands.ownerAllowFromlorsqu’il est omis.agentFilter: liste d’autorisation facultative d’identifiants d’agents. Omettez-la pour transférer les approbations pour tous les agents.sessionFilter: motifs facultatifs de clés de session (sous-chaîne ou expression régulière).target: où envoyer les invites d’approbation."dm"(par défaut) envoie aux DM des approbateurs,"channel"envoie au canal d’origine,"both"envoie aux deux. Lorsque la cible inclut"channel", les boutons ne sont utilisables que par les approbateurs résolus.cleanupAfterResolve: lorsquetrue, supprime les DM d’approbation après approbation, refus ou expiration.
Modes de notification par réaction : off (aucune), own (messages du bot, par défaut), all (tous les messages), allowlist (depuis guilds.<id>.users sur tous les messages).
Google Chat
{
channels: {
googlechat: {
enabled: true,
serviceAccountFile: "/path/to/service-account.json",
audienceType: "app-url", // app-url | project-number
audience: "https://gateway.example.com/googlechat",
webhookPath: "/googlechat",
botUser: "users/1234567890",
dm: {
enabled: true,
policy: "pairing",
allowFrom: ["users/1234567890"],
},
groupPolicy: "allowlist",
groups: {
"spaces/AAAA": { allow: true, requireMention: true },
},
actions: { reactions: true },
typingIndicator: "message",
mediaMaxMb: 20,
},
},
}
- JSON de compte de service : inline (
serviceAccount) ou basé sur un fichier (serviceAccountFile). - SecretRef de compte de service est également pris en charge (
serviceAccountRef). - Solutions de repli d’environnement :
GOOGLE_CHAT_SERVICE_ACCOUNTouGOOGLE_CHAT_SERVICE_ACCOUNT_FILE. - Utilisez
spaces/<spaceId>ouusers/<userId>pour les cibles de livraison. channels.googlechat.dangerouslyAllowNameMatchingréactive la correspondance mutable des principaux d’e-mail (mode de compatibilité break-glass).
Slack
{
channels: {
slack: {
enabled: true,
botToken: "xoxb-...",
appToken: "xapp-...",
socketMode: {
clientPingTimeout: 15000,
serverPingTimeout: 30000,
pingPongLoggingEnabled: false,
},
dmPolicy: "pairing",
allowFrom: ["U123", "U456", "*"],
dm: { enabled: true, groupEnabled: false, groupChannels: ["G123"] },
channels: {
C123: { allow: true, requireMention: true, allowBots: false },
"#general": {
allow: true,
requireMention: true,
allowBots: false,
users: ["U123"],
skills: ["docs"],
systemPrompt: "Short answers only.",
},
},
historyLimit: 50,
allowBots: false,
reactionNotifications: "own",
reactionAllowlist: ["U123"],
replyToMode: "off", // off | first | all | batched
thread: {
historyScope: "thread", // thread | channel
inheritParent: false,
},
actions: {
reactions: true,
messages: true,
pins: true,
memberInfo: true,
emojiList: true,
},
slashCommand: {
enabled: true,
name: "openclaw",
sessionPrefix: "slack:slash",
ephemeral: true,
},
typingReaction: "hourglass_flowing_sand",
textChunkLimit: 4000,
chunkMode: "length",
streaming: {
mode: "partial", // off | partial | block | progress
nativeTransport: true, // use Slack native streaming API when mode=partial
},
mediaMaxMb: 20,
execApprovals: {
enabled: "auto", // true | false | "auto"
approvers: ["U123"],
agentFilter: ["default"],
sessionFilter: ["slack:"],
target: "dm", // dm | channel | both
},
},
},
}
- Le mode socket nécessite à la fois
botTokenetappToken(SLACK_BOT_TOKEN+SLACK_APP_TOKENcomme solution de repli d’environnement pour le compte par défaut). - Le mode HTTP nécessite
botTokenplussigningSecret(à la racine ou par compte). socketModetransmet le réglage du transport Slack SDK Socket Mode à l’API publique du récepteur Bolt. Utilisez-le uniquement lors de l’investigation d’un délai d’expiration ping/pong ou d’un comportement websocket obsolète.botToken,appToken,signingSecretetuserTokenacceptent des chaînes en texte brut ou des objets SecretRef.- Les instantanés de compte Slack exposent des champs source/statut par identifiant tels que
botTokenSource,botTokenStatus,appTokenStatuset, en mode HTTP,signingSecretStatus.configured_unavailablesignifie que le compte est configuré via SecretRef mais que le chemin de commande/d’exécution actuel n’a pas pu résoudre la valeur du secret. configWrites: falsebloque les écritures de configuration initiées par Slack.- Le paramètre facultatif
channels.slack.defaultAccountremplace la sélection du compte par défaut lorsqu’il correspond à un identifiant de compte configuré. channels.slack.streaming.modeest la clé canonique du mode de flux Slack.channels.slack.streaming.nativeTransportcontrôle le transport de streaming natif de Slack. Les anciennes valeursstreamMode, booléennesstreamingetnativeStreamingrestent des alias d’exécution ; exécutezopenclaw doctor --fixpour réécrire la configuration persistante.- Utilisez
user:<id>(DM) ouchannel:<id>pour les cibles de livraison.
Modes de notification par réaction : off, own (par défaut), all, allowlist (depuis reactionAllowlist).
Isolation des sessions de fil : thread.historyScope est par fil (par défaut) ou partagé à travers le canal. thread.inheritParent copie la transcription du canal parent vers les nouveaux fils.
- Le streaming natif Slack ainsi que le statut de fil « is typing... » de style assistant Slack nécessitent une cible de fil de réponse. Les DM de niveau supérieur restent hors fil par défaut, ils peuvent donc toujours diffuser via les aperçus de brouillon Slack publier-et-modifier au lieu d’afficher l’aperçu natif de flux/statut de style fil.
typingReactionajoute une réaction temporaire au message Slack entrant pendant qu’une réponse est en cours, puis la supprime à la fin. Utilisez un shortcode d’emoji Slack tel que"hourglass_flowing_sand".channels.slack.execApprovals: livraison des approbations exec natives Slack et autorisation des approbateurs. Même schéma que Discord :enabled(true/false/"auto"),approvers(identifiants d’utilisateurs Slack),agentFilter,sessionFilterettarget("dm","channel"ou"both").
| Groupe d’actions | Par défaut | Notes |
|---|---|---|
| reactions | activé | Réagir + lister les réactions |
| messages | activé | Lire/envoyer/modifier/supprimer |
| pins | activé | Épingler/désépingler/lister |
| memberInfo | activé | Informations du membre |
| emojiList | activé | Liste d’emojis personnalisés |
Mattermost
Mattermost est fourni comme Plugin groupé dans les versions actuelles d’OpenClaw. Les builds plus anciens ou personnalisés peuvent installer un paquet npm actuel avec openclaw plugins install @openclaw/mattermost. Consultez npmjs.com/package/@openclaw/mattermost pour connaître les dist-tags actuels avant d’épingler une version.
{
channels: {
mattermost: {
enabled: true,
botToken: "mm-token",
baseUrl: "https://chat.example.com",
dmPolicy: "pairing",
chatmode: "oncall", // oncall | onmessage | onchar
oncharPrefixes: [">", "!"],
groups: {
"*": { requireMention: true },
"team-channel-id": { requireMention: false },
},
commands: {
native: true, // opt-in
nativeSkills: true,
callbackPath: "/api/channels/mattermost/command",
// Optional explicit URL for reverse-proxy/public deployments
callbackUrl: "https://gateway.example.com/api/channels/mattermost/command",
},
textChunkLimit: 4000,
chunkMode: "length",
},
},
}
Modes de chat : oncall (répond aux @mentions, par défaut), onmessage (chaque message), onchar (messages commençant par un préfixe déclencheur).
Lorsque les commandes natives Mattermost sont activées :
commands.callbackPathdoit être un chemin (par exemple/api/channels/mattermost/command), pas une URL complète.commands.callbackUrldoit se résoudre vers le point de terminaison du Gateway OpenClaw et être joignable depuis le serveur Mattermost.- Les rappels slash natifs sont authentifiés avec les jetons par commande retournés
par Mattermost lors de l’enregistrement des commandes slash. Si l’enregistrement échoue ou si aucune
commande n’est activée, OpenClaw rejette les rappels avec
Unauthorized: invalid command token. - Pour les hôtes de rappel privés/tailnet/internes, Mattermost peut nécessiter que
ServiceSettings.AllowedUntrustedInternalConnectionsinclue l’hôte/domaine de rappel. Utilisez des valeurs d’hôte/domaine, pas des URL complètes. channels.mattermost.configWrites: autoriser ou refuser les écritures de configuration initiées par Mattermost.channels.mattermost.requireMention: exiger une@mentionavant de répondre dans les canaux.channels.mattermost.groups.<channelId>.requireMention: remplacement par canal du filtrage par mention ("*"par défaut).channels.mattermost.defaultAccountfacultatif remplace la sélection du compte par défaut lorsqu’il correspond à un identifiant de compte configuré.
Signal
{
channels: {
signal: {
enabled: true,
account: "+15555550123", // optional account binding
dmPolicy: "pairing",
allowFrom: ["+15551234567", "uuid:123e4567-e89b-12d3-a456-426614174000"],
configWrites: true,
reactionNotifications: "own", // off | own | all | allowlist
reactionAllowlist: ["+15551234567", "uuid:123e4567-e89b-12d3-a456-426614174000"],
historyLimit: 50,
},
},
}
Modes de notification de réaction : off, own (par défaut), all, allowlist (depuis reactionAllowlist).
channels.signal.account: fixer le démarrage du canal à une identité de compte Signal spécifique.channels.signal.configWrites: autoriser ou refuser les écritures de configuration initiées par Signal.channels.signal.defaultAccountfacultatif remplace la sélection du compte par défaut lorsqu’il correspond à un identifiant de compte configuré.
BlueBubbles
BlueBubbles est l’ancien pont iMessage (adossé à un Plugin, configuré sous channels.bluebubbles). Les configurations existantes restent prises en charge, mais les nouveaux déploiements iMessage OpenClaw devraient préférer channels.imessage lorsque imsg peut s’exécuter sur l’hôte Messages.
{
channels: {
bluebubbles: {
enabled: true,
dmPolicy: "pairing",
// serverUrl, password, webhookPath, group controls, and advanced actions:
// see /channels/bluebubbles
},
},
}
- Chemins de clés principaux couverts ici :
channels.bluebubbles,channels.bluebubbles.dmPolicy. channels.bluebubbles.defaultAccountfacultatif remplace la sélection du compte par défaut lorsqu’il correspond à un identifiant de compte configuré.- Les entrées
bindings[]de premier niveau avectype: "acp"peuvent lier des conversations BlueBubbles à des sessions ACP persistantes. Utilisez un handle BlueBubbles ou une chaîne cible (chat_id:*,chat_guid:*,chat_identifier:*) dansmatch.peer.id. Sémantique des champs partagés : Agents ACP. - La configuration complète du canal BlueBubbles et les raisons de son obsolescence sont documentées dans BlueBubbles.
iMessage
OpenClaw lance imsg rpc (JSON-RPC via stdio). Aucun démon ni port requis. C’est le chemin recommandé pour les nouvelles configurations iMessage OpenClaw lorsque l’hôte peut accorder les autorisations de base de données Messages et d’automatisation.
{
channels: {
imessage: {
enabled: true,
cliPath: "imsg",
dbPath: "~/Library/Messages/chat.db",
remoteHost: "user@gateway-host",
dmPolicy: "pairing",
allowFrom: ["+15555550123", "[email protected]", "chat_id:123"],
historyLimit: 50,
includeAttachments: false,
attachmentRoots: ["/Users/*/Library/Messages/Attachments"],
remoteAttachmentRoots: ["/Users/*/Library/Messages/Attachments"],
mediaMaxMb: 16,
service: "auto",
region: "US",
},
},
}
-
channels.imessage.defaultAccountfacultatif remplace la sélection du compte par défaut lorsqu’il correspond à un identifiant de compte configuré. -
Nécessite l’accès complet au disque pour la base de données Messages.
-
Préférez les cibles
chat_id:<id>. Utilisezimsg chats --limit 20pour lister les chats. -
cliPathpeut pointer vers un wrapper SSH ; définissezremoteHost(hostouuser@host) pour récupérer les pièces jointes par SCP. -
attachmentRootsetremoteAttachmentRootsrestreignent les chemins de pièces jointes entrantes (par défaut :/Users/*/Library/Messages/Attachments). -
SCP utilise une vérification stricte des clés d’hôte ; assurez-vous donc que la clé d’hôte du relais existe déjà dans
~/.ssh/known_hosts. -
channels.imessage.configWrites: autoriser ou refuser les écritures de configuration initiées par iMessage. -
Les entrées
bindings[]de premier niveau avectype: "acp"peuvent lier des conversations iMessage à des sessions ACP persistantes. Utilisez un handle normalisé ou une cible de chat explicite (chat_id:*,chat_guid:*,chat_identifier:*) dansmatch.peer.id. Sémantique des champs partagés : Agents ACP.
Exemple de wrapper SSH iMessage
#!/usr/bin/env bash
exec ssh -T gateway-host imsg "$@"
Matrix
Matrix est adossé à un Plugin et configuré sous channels.matrix.
{
channels: {
matrix: {
enabled: true,
homeserver: "https://matrix.example.org",
accessToken: "syt_bot_xxx",
proxy: "http://127.0.0.1:7890",
encryption: true,
initialSyncLimit: 20,
defaultAccount: "ops",
accounts: {
ops: {
name: "Ops",
userId: "@ops:example.org",
accessToken: "syt_ops_xxx",
},
alerts: {
userId: "@alerts:example.org",
password: "secret",
proxy: "http://127.0.0.1:7891",
},
},
},
},
}
- L’authentification par jeton utilise
accessToken; l’authentification par mot de passe utiliseuserId+password. channels.matrix.proxyachemine le trafic HTTP Matrix via un proxy HTTP(S) explicite. Les comptes nommés peuvent le remplacer avecchannels.matrix.accounts.<id>.proxy.channels.matrix.network.dangerouslyAllowPrivateNetworkautorise les homeservers privés/internes.proxyet cette option réseau sont des contrôles indépendants.channels.matrix.defaultAccountsélectionne le compte préféré dans les configurations multicomptes.channels.matrix.autoJoinvautoffpar défaut ; les salons invités et les nouvelles invitations de type DM sont donc ignorés jusqu’à ce que vous définissiezautoJoin: "allowlist"avecautoJoinAllowlistouautoJoin: "always".channels.matrix.execApprovals: livraison des approbations d’exécution natives Matrix et autorisation des approbateurs.enabled:true,falseou"auto"(par défaut). En mode automatique, les approbations d’exécution s’activent lorsque les approbateurs peuvent être résolus depuisapproversoucommands.ownerAllowFrom.approvers: identifiants d’utilisateur Matrix (p. ex.@owner:example.org) autorisés à approuver les demandes d’exécution.agentFilter: liste d’autorisation facultative d’identifiants d’agent. Omettez-la pour transférer les approbations pour tous les agents.sessionFilter: motifs facultatifs de clés de session (sous-chaîne ou regex).target: destination des invites d’approbation."dm"(par défaut),"channel"(salon d’origine) ou"both".- Remplacements par compte :
channels.matrix.accounts.<id>.execApprovals.
channels.matrix.dm.sessionScopecontrôle la manière dont les DM Matrix sont regroupés en sessions :per-user(par défaut) partage par pair acheminé, tandis queper-roomisole chaque salon DM.- Les sondes d’état Matrix et les recherches d’annuaire en direct utilisent la même politique de proxy que le trafic d’exécution.
- La configuration complète de Matrix, les règles de ciblage et les exemples de configuration sont documentés dans Matrix.
Microsoft Teams
Microsoft Teams est adossé à un Plugin et configuré sous channels.msteams.
{
channels: {
msteams: {
enabled: true,
configWrites: true,
// appId, appPassword, tenantId, webhook, team/channel policies:
// see /channels/msteams
},
},
}
- Chemins de clés principaux couverts ici :
channels.msteams,channels.msteams.configWrites. - La configuration complète de Teams (identifiants, Webhook, politique de DM/groupe, remplacements par équipe/par canal) est documentée dans Microsoft Teams.
IRC
IRC est adossé à un Plugin et configuré sous channels.irc.
{
channels: {
irc: {
enabled: true,
dmPolicy: "pairing",
configWrites: true,
nickserv: {
enabled: true,
service: "NickServ",
password: "${IRC_NICKSERV_PASSWORD}",
register: false,
registerEmail: "[email protected]",
},
},
},
}
- Chemins de clés principaux couverts ici :
channels.irc,channels.irc.dmPolicy,channels.irc.configWrites,channels.irc.nickserv.*. channels.irc.defaultAccountfacultatif remplace la sélection du compte par défaut lorsqu’il correspond à un identifiant de compte configuré.- La configuration complète du canal IRC (hôte/port/TLS/canaux/listes d’autorisation/filtrage par mention) est documentée dans IRC.
Multicompte (tous les canaux)
Exécutez plusieurs comptes par canal (chacun avec son propre accountId) :
{
channels: {
telegram: {
accounts: {
default: {
name: "Primary bot",
botToken: "123456:ABC...",
},
alerts: {
name: "Alerts bot",
botToken: "987654:XYZ...",
},
},
},
},
}
defaultest utilisé lorsqueaccountIdest omis (CLI + routage).- Les jetons d’environnement s’appliquent uniquement au compte par défaut.
- Les paramètres de canal de base s’appliquent à tous les comptes, sauf remplacement par compte.
- Utilisez
bindings[].match.accountIdpour acheminer chaque compte vers un agent différent. - Si vous ajoutez un compte autre que le compte par défaut via
openclaw channels add(ou l’onboarding de canal) alors que vous êtes encore sur une configuration de canal de premier niveau à compte unique, OpenClaw promeut d’abord les valeurs de compte unique de premier niveau propres au compte vers la carte des comptes du canal, afin que le compte d’origine continue de fonctionner. La plupart des canaux les déplacent danschannels.<channel>.accounts.default; Matrix peut préserver à la place une cible nommée/par défaut correspondante existante. - Les liaisons existantes limitées au canal (sans
accountId) continuent de correspondre au compte par défaut ; les liaisons propres au compte restent facultatives. openclaw doctor --fixrépare également les formes mixtes en déplaçant les valeurs de compte unique de premier niveau propres au compte dans le compte promu choisi pour ce canal. La plupart des canaux utilisentaccounts.default; Matrix peut préserver à la place une cible nommée/par défaut correspondante existante.
Autres canaux Plugin
De nombreux canaux Plugin sont configurés comme channels.<id> et documentés dans leurs pages de canal dédiées (par exemple Feishu, Matrix, LINE, Nostr, Zalo, Nextcloud Talk, Synology Chat et Twitch).
Consultez l’index complet des canaux : Canaux.
Filtrage des mentions dans les discussions de groupe
Les messages de groupe exigent par défaut une mention obligatoire (mention de métadonnées ou motifs regex sûrs). S’applique aux discussions de groupe WhatsApp, Telegram, Discord, Google Chat et iMessage.
Les réponses visibles sont contrôlées séparément. Les salons de groupe/canal utilisent par défaut messages.groupChat.visibleReplies: "message_tool" : OpenClaw traite toujours le tour, mais les réponses finales normales restent privées et la sortie visible dans le salon nécessite message(action=send). Définissez "automatic" uniquement lorsque vous voulez le comportement hérité où les réponses normales sont publiées dans le salon. Pour appliquer le même comportement de réponse visible uniquement via outil aux conversations directes également, définissez messages.visibleReplies: "message_tool" ; le harnais Codex utilise aussi ce comportement uniquement via outil comme valeur par défaut non définie pour les conversations directes.
Les réponses visibles uniquement via outil nécessitent un modèle/runtime qui appelle les outils de façon fiable. Si
le journal de session affiche du texte d’assistant avec didSendViaMessagingTool: false, le
modèle a produit une réponse finale privée au lieu d’appeler l’outil de messagerie.
Passez à un modèle plus robuste pour les appels d’outils sur ce canal, ou définissez
messages.groupChat.visibleReplies: "automatic" pour restaurer les réponses finales visibles
héritées.
Si l’outil de messagerie est indisponible avec la politique d’outils active, OpenClaw revient aux réponses visibles automatiques au lieu de supprimer silencieusement la réponse. openclaw doctor avertit de cette incohérence.
Le Gateway recharge à chaud la configuration messages après l’enregistrement du fichier. Redémarrez uniquement lorsque la surveillance des fichiers ou le rechargement de la configuration est désactivé dans le déploiement.
Types de mentions :
- Mentions de métadonnées : @-mentions natives de la plateforme. Ignorées en mode auto-conversation WhatsApp.
- Motifs textuels : motifs regex sûrs dans
agents.list[].groupChat.mentionPatterns. Les motifs non valides et les répétitions imbriquées non sûres sont ignorés. - Le filtrage par mention est appliqué uniquement lorsque la détection est possible (mentions natives ou au moins un motif).
{
messages: {
visibleReplies: "automatic", // global default for direct/source chats; Codex harness defaults unset direct chats to message_tool
groupChat: {
historyLimit: 50,
visibleReplies: "message_tool", // default; use "automatic" for legacy final replies
},
},
agents: {
list: [{ id: "main", groupChat: { mentionPatterns: ["@openclaw", "openclaw"] } }],
},
}
messages.groupChat.historyLimit définit la valeur par défaut globale. Les canaux peuvent la remplacer avec channels.<channel>.historyLimit (ou par compte). Définissez 0 pour désactiver.
messages.visibleReplies est la valeur par défaut globale des tours source ; messages.groupChat.visibleReplies la remplace pour les tours source de groupe/canal. Lorsque messages.visibleReplies n’est pas défini, un harnais peut fournir sa propre valeur par défaut directe/source ; le harnais Codex utilise par défaut message_tool. Les listes d’autorisation de canal et le filtrage par mention décident toujours si un tour est traité.
Limites d’historique des DM
{
channels: {
telegram: {
dmHistoryLimit: 30,
dms: {
"123456789": { historyLimit: 50 },
},
},
},
}
Résolution : remplacement par DM → valeur par défaut du fournisseur → aucune limite (tout est conservé).
Pris en charge : telegram, whatsapp, discord, slack, signal, imessage, msteams.
Mode auto-conversation
Incluez votre propre numéro dans allowFrom pour activer le mode auto-conversation (ignore les @-mentions natives, répond uniquement aux motifs textuels) :
{
channels: {
whatsapp: {
allowFrom: ["+15555550123"],
groups: { "*": { requireMention: true } },
},
},
agents: {
list: [
{
id: "main",
groupChat: { mentionPatterns: ["reisponde", "@openclaw"] },
},
],
},
}
Commandes (gestion des commandes de chat)
{
commands: {
native: "auto", // register native commands when supported
nativeSkills: "auto", // register native skill commands when supported
text: true, // parse /commands in chat messages
bash: false, // allow ! (alias: /bash)
bashForegroundMs: 2000,
config: false, // allow /config
mcp: false, // allow /mcp
plugins: false, // allow /plugins
debug: false, // allow /debug
restart: true, // allow /restart + gateway restart tool
ownerAllowFrom: ["discord:123456789012345678"],
ownerDisplay: "raw", // raw | hash
ownerDisplaySecret: "${OWNER_ID_HASH_SECRET}",
allowFrom: {
"*": ["user1"],
discord: ["user:123"],
},
useAccessGroups: true,
},
}
Détails des commandes
- Ce bloc configure les surfaces de commande. Pour le catalogue actuel des commandes intégrées et groupées, consultez Commandes Slash.
- Cette page est une référence des clés de configuration, et non le catalogue complet des commandes. Les commandes détenues par des canaux/plugins, comme QQ Bot
/bot-ping/bot-help/bot-logs, LINE/card, l’appairage d’appareil/pair, la mémoire/dreaming, le contrôle de téléphone/phoneet Talk/voice, sont documentées dans leurs pages de canal/plugin ainsi que dans Commandes Slash. - Les commandes textuelles doivent être des messages autonomes commençant par
/. native: "auto"active les commandes natives pour Discord/Telegram, laisse Slack désactivé.nativeSkills: "auto"active les commandes natives de Skills pour Discord/Telegram, laisse Slack désactivé.- Remplacement par canal :
channels.discord.commands.native(booléen ou"auto"). Pour Discord,falseignore l’enregistrement et le nettoyage des commandes natives au démarrage. - Remplacez l’enregistrement des Skills natives par canal avec
channels.<provider>.commands.nativeSkills. channels.telegram.customCommandsajoute des entrées supplémentaires au menu du bot Telegram.bash: trueactive! <cmd>pour le shell hôte. Nécessitetools.elevated.enabledet un expéditeur danstools.elevated.allowFrom.<channel>.config: trueactive/config(lit/écritopenclaw.json). Pour les clients Gatewaychat.send, les écritures persistantes/config set|unsetnécessitent aussioperator.admin;/config showen lecture seule reste disponible pour les clients opérateurs normaux disposant d’une portée d’écriture.mcp: trueactive/mcppour la configuration des serveurs MCP gérés par OpenClaw sousmcp.servers.plugins: trueactive/pluginspour la découverte, l’installation et les contrôles d’activation/désactivation des plugins.channels.<provider>.configWritescontrôle les mutations de configuration par canal (par défaut : true).- Pour les canaux multi-comptes,
channels.<provider>.accounts.<id>.configWritescontrôle aussi les écritures ciblant ce compte (par exemple/allowlist --config --account <id>ou/config set channels.<provider>.accounts.<id>...). restart: falsedésactive/restartet les actions de l’outil de redémarrage du Gateway. Par défaut :true.ownerAllowFromest la liste d’autorisation explicite du propriétaire pour les commandes/outils réservés au propriétaire. Elle est distincte deallowFrom.ownerDisplay: "hash"hache les identifiants de propriétaire dans l’invite système. DéfinissezownerDisplaySecretpour contrôler le hachage.allowFromest propre à chaque fournisseur. Lorsqu’il est défini, il s’agit de la seule source d’autorisation (les listes d’autorisation/appairage de canal etuseAccessGroupssont ignorés).useAccessGroups: falsepermet aux commandes de contourner les politiques de groupe d’accès lorsqueallowFromn’est pas défini.- Carte de la documentation des commandes :
- catalogue intégré et groupé : Commandes Slash
- surfaces de commande propres aux canaux : Canaux
- commandes QQ Bot : QQ Bot
- commandes d’appairage : Appairage
- commande de carte LINE : LINE
- Dreaming de la mémoire : Dreaming
Connexe
- Référence de configuration — clés de premier niveau
- Configuration — agents
- Vue d’ensemble des canaux