Chiavi di configurazione per canale sottoDocumentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
channels.*. Copre accesso a DM e gruppi,
configurazioni multi-account, gating delle menzioni e chiavi per canale per Slack, Discord,
Telegram, WhatsApp, Matrix, iMessage e gli altri Plugin canale inclusi.
Per agenti, strumenti, runtime del gateway e altre chiavi di livello superiore, consulta
Riferimento di configurazione.
Canali
Ogni canale si avvia automaticamente quando esiste la relativa sezione di configurazione (a meno cheenabled: false).
Accesso a DM e gruppi
Tutti i canali supportano criteri per DM e criteri per gruppi:| Criterio DM | Comportamento |
|---|---|
pairing (default) | I mittenti sconosciuti ricevono un codice di pairing monouso; il proprietario deve approvare |
allowlist | Solo i mittenti in allowFrom (o nello store allow associato) |
open | Consente tutti i DM in ingresso (richiede allowFrom: ["*"]) |
disabled | Ignora tutti i DM in ingresso |
| Criterio gruppo | Comportamento |
|---|---|
allowlist (default) | Solo i gruppi che corrispondono all’allowlist configurata |
open | Ignora le allowlist dei gruppi (il gating delle menzioni resta applicato) |
disabled | Blocca tutti i messaggi di gruppo/stanza |
channels.defaults.groupPolicy imposta il valore predefinito quando groupPolicy di un provider non è impostato.
I codici di pairing scadono dopo 1 ora. Le richieste di pairing DM in sospeso sono limitate a 3 per canale.
Se manca completamente un blocco provider (channels.<provider> assente), il criterio di gruppo runtime torna a allowlist (fail-closed) con un avviso all’avvio.Override del modello del canale
Usachannels.modelByChannel per fissare ID canale specifici a un modello. I valori accettano provider/model o alias di modello configurati. La mappatura del canale si applica quando una sessione non ha già un override del modello (ad esempio, impostato tramite /model).
Valori predefiniti dei canali e Heartbeat
Usachannels.defaults per comportamento condiviso di criteri di gruppo e heartbeat tra provider:
channels.defaults.groupPolicy: criterio di gruppo di fallback quandogroupPolicya livello di provider non è impostato.channels.defaults.contextVisibility: modalità predefinita di visibilità del contesto supplementare per tutti i canali. Valori:all(predefinito, include tutto il contesto citato/thread/cronologia),allowlist(include solo il contesto da mittenti in allowlist),allowlist_quote(uguale ad allowlist ma mantiene il contesto esplicito di citazione/risposta). Override per canale:channels.<channel>.contextVisibility.channels.defaults.heartbeat.showOk: include gli stati dei canali sani nell’output heartbeat.channels.defaults.heartbeat.showAlerts: include gli stati degradati/di errore nell’output heartbeat.channels.defaults.heartbeat.useIndicator: renderizza un output heartbeat compatto in stile indicatore.
WhatsApp multi-account
WhatsApp multi-account
- I comandi in uscita usano per impostazione predefinita l’account
defaultse presente; altrimenti il primo ID account configurato (ordinato). channels.whatsapp.defaultAccountopzionale sovrascrive quella selezione dell’account predefinito di fallback quando corrisponde a un ID account configurato.- La directory di autenticazione Baileys legacy a singolo account viene migrata da
openclaw doctorinwhatsapp/default. - Override per account:
channels.whatsapp.accounts.<id>.sendReadReceipts,channels.whatsapp.accounts.<id>.dmPolicy,channels.whatsapp.accounts.<id>.allowFrom.
Telegram
- Token del bot:
channels.telegram.botTokenochannels.telegram.tokenFile(solo file regolare; symlink rifiutati), conTELEGRAM_BOT_TOKENcome fallback per l’account predefinito. apiRootè solo la root della Telegram Bot API. Usahttps://api.telegram.orgo la tua root self-hosted/proxy, nonhttps://api.telegram.org/bot<TOKEN>;openclaw doctor --fixrimuove un suffisso finale accidentale/bot<TOKEN>.channels.telegram.defaultAccountopzionale sovrascrive la selezione dell’account predefinito quando corrisponde a un ID account configurato.- Nelle configurazioni multi-account (2 o più ID account), imposta un predefinito esplicito (
channels.telegram.defaultAccountochannels.telegram.accounts.default) per evitare il routing di fallback;openclaw doctoravvisa quando manca o non è valido. configWrites: falseblocca le scritture di configurazione avviate da Telegram (migrazioni ID supergruppo,/config set|unset).- Le voci
bindings[]di livello superiore contype: "acp"configurano binding ACP persistenti per gli argomenti dei forum (usachatId:topic:topicIdcanonico inmatch.peer.id). Le semantiche dei campi sono condivise in Agenti ACP. - Le anteprime stream di Telegram usano
sendMessage+editMessageText(funziona nelle chat dirette e di gruppo). - Criterio di retry: consulta Criterio di retry.
Discord
- Token:
channels.discord.token, conDISCORD_BOT_TOKENcome fallback per l’account predefinito. - Le chiamate in uscita dirette che forniscono un
tokenDiscord esplicito usano quel token per la chiamata; le impostazioni di retry/policy dell’account provengono comunque dall’account selezionato nello snapshot runtime attivo. channels.discord.defaultAccountfacoltativo sovrascrive la selezione dell’account predefinito quando corrisponde a un id account configurato.- Usa
user:<id>(DM) ochannel:<id>(canale guild) per i destinatari di consegna; gli ID numerici semplici vengono rifiutati. - Gli slug delle guild sono in minuscolo con gli spazi sostituiti da
-; le chiavi dei canali usano il nome in formato slug (senza#). Preferisci gli ID guild. - I messaggi scritti dai bot vengono ignorati per impostazione predefinita.
allowBots: trueli abilita; usaallowBots: "mentions"per accettare solo i messaggi dei bot che menzionano il bot (i messaggi propri restano filtrati). channels.discord.guilds.<id>.ignoreOtherMentions(e le sovrascritture dei canali) scarta i messaggi che menzionano un altro utente o ruolo ma non il bot (escludendo @everyone/@here).channels.discord.mentionAliasesmappa testo@handlestabile in uscita a ID utente Discord prima dell’invio, così i compagni di team noti possono essere menzionati in modo deterministico anche quando la cache temporanea della directory è vuota. Le sovrascritture per account si trovano inchannels.discord.accounts.<accountId>.mentionAliases.maxLinesPerMessage(predefinito 17) divide i messaggi alti anche quando sono sotto i 2000 caratteri.channels.discord.threadBindingscontrolla il routing Discord vincolato ai thread:enabled: sovrascrittura Discord per le funzionalità di sessione vincolate ai thread (/focus,/unfocus,/agents,/session idle,/session max-agee consegna/routing vincolati)idleHours: sovrascrittura Discord per auto-unfocus dopo inattività in ore (0disabilita)maxAgeHours: sovrascrittura Discord per età massima rigida in ore (0disabilita)spawnSessions: interruttore persessions_spawn({ thread: true })e creazione/vincolo automatici di thread da spawn thread ACP (predefinito:true)defaultSpawnContext: contesto subagent nativo per spawn vincolati ai thread ("fork"per impostazione predefinita)
- Le voci
bindings[]di livello superiore contype: "acp"configurano binding ACP persistenti per canali e thread (usa l’id canale/thread inmatch.peer.id). Le semantiche dei campi sono condivise in Agenti ACP. channels.discord.ui.components.accentColorimposta il colore di accento per i contenitori dei componenti Discord v2.channels.discord.voiceabilita le conversazioni nei canali vocali Discord e sovrascritture facoltative per auto-join + LLM + TTS. Le configurazioni Discord solo testo lasciano la voce disattivata per impostazione predefinita; impostachannels.discord.voice.enabled=trueper aderire.channels.discord.voice.modelsovrascrive facoltativamente il modello LLM usato per le risposte nei canali vocali Discord.channels.discord.voice.daveEncryptionechannels.discord.voice.decryptionFailureTolerancevengono passati alle opzioni DAVE di@discordjs/voice(truee24per impostazione predefinita).channels.discord.voice.connectTimeoutMscontrolla l’attesa iniziale Ready di@discordjs/voiceper/vc joine i tentativi di auto-join (30000per impostazione predefinita).channels.discord.voice.reconnectGraceMscontrolla quanto tempo una sessione vocale disconnessa può impiegare per entrare nella segnalazione di riconnessione prima che OpenClaw la distrugga (15000per impostazione predefinita).- La riproduzione vocale Discord non viene interrotta dall’evento di inizio parlato di un altro utente. Per evitare loop di feedback, OpenClaw ignora la nuova acquisizione vocale mentre TTS è in riproduzione.
- OpenClaw tenta inoltre il recupero della ricezione vocale uscendo/rientrando in una sessione vocale dopo ripetuti errori di decifratura.
channels.discord.streamingè la chiave canonica della modalità stream. Discord usa per impostazione predefinitastreaming.mode: "progress"così l’avanzamento di strumenti/lavoro appare in un unico messaggio di anteprima modificato; impostastreaming.mode: "off"per disabilitarla. I valori legacystreamModee booleanistreamingrestano alias runtime; eseguiopenclaw doctor --fixper riscrivere la configurazione persistita.channels.discord.autoPresencemappa la disponibilità runtime alla presenza del bot (healthy => online, degraded => idle, exhausted => dnd) e consente sovrascritture facoltative del testo di stato.channels.discord.dangerouslyAllowNameMatchingriabilita il matching mutabile di nome/tag (modalità di compatibilità break-glass).channels.discord.execApprovals: consegna nativa Discord delle approvazioni exec e autorizzazione degli approvatori.enabled:true,falseo"auto"(predefinito). In modalità auto, le approvazioni exec si attivano quando gli approvatori possono essere risolti daapproversocommands.ownerAllowFrom.approvers: ID utente Discord autorizzati ad approvare richieste exec. Ripiega sucommands.ownerAllowFromquando omesso.agentFilter: allowlist facoltativa di ID agent. Ometti per inoltrare approvazioni per tutti gli agent.sessionFilter: pattern facoltativi di chiavi sessione (sottostringa o regex).target: dove inviare le richieste di approvazione."dm"(predefinito) invia ai DM degli approvatori,"channel"invia al canale di origine,"both"invia a entrambi. Quando target include"channel", i pulsanti sono utilizzabili solo dagli approvatori risolti.cleanupAfterResolve: quandotrue, elimina i DM di approvazione dopo approvazione, rifiuto o timeout.
off (nessuna), own (messaggi del bot, predefinito), all (tutti i messaggi), allowlist (da guilds.<id>.users su tutti i messaggi).
Google Chat
- JSON account di servizio: inline (
serviceAccount) o basato su file (serviceAccountFile). - È supportato anche SecretRef dell’account di servizio (
serviceAccountRef). - Fallback env:
GOOGLE_CHAT_SERVICE_ACCOUNToGOOGLE_CHAT_SERVICE_ACCOUNT_FILE. - Usa
spaces/<spaceId>ousers/<userId>per i destinatari di consegna. channels.googlechat.dangerouslyAllowNameMatchingriabilita il matching mutabile dei principal email (modalità di compatibilità break-glass).
Slack
- Socket mode richiede sia
botTokensiaappToken(SLACK_BOT_TOKEN+SLACK_APP_TOKENper il fallback env dell’account predefinito). - Modalità HTTP richiede
botTokenpiùsigningSecret(alla radice o per account). socketModepassa la regolazione del trasporto Socket Mode dell’SDK Slack all’API pubblica del receiver Bolt. Usalo solo quando indaghi timeout ping/pong o comportamento websocket obsoleto.botToken,appToken,signingSecreteuserTokenaccettano stringhe in testo normale o oggetti SecretRef.- Gli snapshot degli account Slack espongono campi sorgente/stato per credenziale come
botTokenSource,botTokenStatus,appTokenStatuse, in modalità HTTP,signingSecretStatus.configured_unavailablesignifica che l’account è configurato tramite SecretRef ma il percorso comando/runtime corrente non ha potuto risolvere il valore del segreto. configWrites: falseblocca le scritture di configurazione avviate da Slack.channels.slack.defaultAccountfacoltativo sovrascrive la selezione dell’account predefinito quando corrisponde a un id account configurato.channels.slack.streaming.modeè la chiave canonica della modalità stream Slack.channels.slack.streaming.nativeTransportcontrolla il trasporto di streaming nativo di Slack. I valori legacystreamMode, booleanistreamingenativeStreamingrestano alias runtime; eseguiopenclaw doctor --fixper riscrivere la configurazione persistita.unfurlLinkseunfurlMediapassano i booleani di unfurl di link e media dichat.postMessagedi Slack per le risposte del bot. Omettili per mantenere il comportamento predefinito di Slack; impostali inchannels.slack.accounts.<accountId>per sovrascrivere il valore predefinito di livello superiore per un account.- Usa
user:<id>(DM) ochannel:<id>per i destinatari di consegna.
off, own (predefinito), all, allowlist (da reactionAllowlist).
Isolamento delle sessioni thread: thread.historyScope è per thread (predefinito) o condiviso a livello di canale. thread.inheritParent copia la trascrizione del canale padre nei nuovi thread.
- Lo streaming nativo Slack più lo stato thread “is typing…” in stile assistente Slack richiedono un target thread di risposta. I DM di livello superiore restano fuori thread per impostazione predefinita, quindi possono comunque trasmettere tramite anteprime bozza Slack pubblica-e-modifica invece di mostrare l’anteprima stream/stato nativa in stile thread.
typingReactionaggiunge una reazione temporanea al messaggio Slack in ingresso mentre una risposta è in esecuzione, poi la rimuove al completamento. Usa uno shortcode emoji Slack come"hourglass_flowing_sand".channels.slack.execApprovals: consegna nativa Slack delle approvazioni exec e autorizzazione degli approvatori. Stesso schema di Discord:enabled(true/false/"auto"),approvers(ID utente Slack),agentFilter,sessionFilteretarget("dm","channel"o"both").
| Gruppo azione | Predefinito | Note |
|---|---|---|
| reactions | abilitato | Reagisci + elenca reazioni |
| messages | abilitato | Leggi/invia/modifica/elimina |
| pins | abilitato | Fissa/rimuovi fissaggio/elenca |
| memberInfo | abilitato | Informazioni membro |
| emojiList | abilitato | Elenco emoji personalizzate |
Mattermost
Mattermost viene distribuito come Plugin incluso nelle versioni correnti di OpenClaw. Le build più vecchie o personalizzate possono installare un pacchetto npm corrente conopenclaw plugins install @openclaw/mattermost. Controlla
npmjs.com/package/@openclaw/mattermost
per i dist-tag correnti prima di fissare una versione.
oncall (risponde alla @-menzione, predefinita), onmessage (ogni messaggio), onchar (messaggi che iniziano con il prefisso di attivazione).
Quando i comandi nativi di Mattermost sono abilitati:
commands.callbackPathdeve essere un percorso (per esempio/api/channels/mattermost/command), non un URL completo.commands.callbackUrldeve risolversi nell’endpoint Gateway di OpenClaw ed essere raggiungibile dal server Mattermost.- I callback slash nativi sono autenticati con i token specifici del comando restituiti
da Mattermost durante la registrazione del comando slash. Se la registrazione non riesce o non viene
attivato alcun comando, OpenClaw rifiuta i callback con
Unauthorized: invalid command token. - Per host di callback privati/tailnet/interni, Mattermost potrebbe richiedere
che
ServiceSettings.AllowedUntrustedInternalConnectionsincluda l’host/dominio del callback. Usa valori di host/dominio, non URL completi. channels.mattermost.configWrites: consente o nega le scritture di configurazione avviate da Mattermost.channels.mattermost.requireMention: richiede@mentionprima di rispondere nei canali.channels.mattermost.groups.<channelId>.requireMention: override per canale del vincolo di menzione ("*"per il valore predefinito).channels.mattermost.defaultAccountfacoltativo sovrascrive la selezione dell’account predefinito quando corrisponde a un ID account configurato.
Signal
off, own (predefinita), all, allowlist (da reactionAllowlist).
channels.signal.account: vincola l’avvio del canale a una specifica identità account Signal.channels.signal.configWrites: consente o nega le scritture di configurazione avviate da Signal.channels.signal.defaultAccountfacoltativo sovrascrive la selezione dell’account predefinito quando corrisponde a un ID account configurato.
iMessage
OpenClaw avviaimsg rpc (JSON-RPC su stdio). Non sono richiesti daemon o porte. Questo è il percorso preferito per le nuove configurazioni iMessage di OpenClaw quando l’host può concedere le autorizzazioni per il database di Messaggi e Automazione.
Il supporto BlueBubbles è stato rimosso. channels.bluebubbles non è una superficie di configurazione runtime supportata nell’OpenClaw attuale. Migra le vecchie configurazioni a channels.imessage; usa Rimozione di BlueBubbles e il percorso iMessage imsg per la versione breve e Provenienza da BlueBubbles per la tabella di traduzione completa.
Se il Gateway non è in esecuzione sul Mac Messaggi con accesso effettuato, mantieni channels.imessage.enabled=true e imposta channels.imessage.cliPath su un wrapper SSH che esegua imsg "$@" su quel Mac. Il percorso locale predefinito di imsg è solo per macOS.
-
channels.imessage.defaultAccountfacoltativo sovrascrive la selezione dell’account predefinito quando corrisponde a un ID account configurato. - Richiede Full Disk Access al database Messaggi.
-
Preferisci target
chat_id:<id>. Usaimsg chats --limit 20per elencare le chat. -
cliPathpuò puntare a un wrapper SSH; impostaremoteHost(hostouser@host) per il recupero degli allegati tramite SCP. -
attachmentRootseremoteAttachmentRootslimitano i percorsi degli allegati in ingresso (predefinito:/Users/*/Library/Messages/Attachments). -
SCP usa il controllo rigoroso della chiave host, quindi assicurati che la chiave host del relay esista già in
~/.ssh/known_hosts. -
channels.imessage.configWrites: consente o nega le scritture di configurazione avviate da iMessage. -
channels.imessage.actions.*: abilita azioni API private che sono anche vincolate daimsg status/openclaw channels status --probe. -
channels.imessage.includeAttachmentsè disattivato per impostazione predefinita; impostalo sutrueprima di aspettarti contenuti multimediali in ingresso nei turni dell’agente. -
channels.imessage.catchup.enabled: abilita la riproduzione dei messaggi in ingresso arrivati mentre il Gateway era inattivo. -
channels.imessage.groups: registro dei gruppi e impostazioni per gruppo. CongroupPolicy: "allowlist", configura chiavichat_idesplicite oppure una voce wildcard"*"in modo che i messaggi di gruppo possano superare il gate del registro. -
Le voci
bindings[]di primo livello contype: "acp"possono associare conversazioni iMessage a sessioni ACP persistenti. Usa un handle normalizzato o un target chat esplicito (chat_id:*,chat_guid:*,chat_identifier:*) inmatch.peer.id. Semantica dei campi condivisi: Agenti ACP.
Esempio di wrapper SSH iMessage
Esempio di wrapper SSH iMessage
Matrix
Matrix è supportato da Plugin e configurato sottochannels.matrix.
- L’autenticazione tramite token usa
accessToken; l’autenticazione tramite password usauserId+password. channels.matrix.proxyinstrada il traffico HTTP di Matrix attraverso un proxy HTTP(S) esplicito. Gli account nominati possono sovrascriverlo conchannels.matrix.accounts.<id>.proxy.channels.matrix.network.dangerouslyAllowPrivateNetworkconsente homeserver privati/interni.proxye questo opt-in di rete sono controlli indipendenti.channels.matrix.defaultAccountseleziona l’account preferito nelle configurazioni multi-account.channels.matrix.autoJoinusa come valore predefinitooff, quindi le stanze invitate e i nuovi inviti in stile DM vengono ignorati finché non impostiautoJoin: "allowlist"conautoJoinAllowlistoautoJoin: "always".channels.matrix.execApprovals: recapito delle approvazioni exec nativo di Matrix e autorizzazione degli approvatori.enabled:true,falseo"auto"(predefinito). In modalità automatica, le approvazioni exec si attivano quando gli approvatori possono essere risolti daapproversocommands.ownerAllowFrom.approvers: ID utente Matrix (ad es.@owner:example.org) autorizzati ad approvare le richieste exec.agentFilter: allowlist facoltativa di ID agente. Omettila per inoltrare le approvazioni per tutti gli agenti.sessionFilter: pattern facoltativi di chiavi sessione (sottostringa o regex).target: dove inviare le richieste di approvazione."dm"(predefinito),"channel"(stanza di origine) o"both".- Override per account:
channels.matrix.accounts.<id>.execApprovals.
channels.matrix.dm.sessionScopecontrolla come i DM di Matrix vengono raggruppati in sessioni:per-user(predefinito) condivide in base al peer instradato, mentreper-roomisola ogni stanza DM.- I probe di stato Matrix e le ricerche live nella directory usano la stessa policy proxy del traffico runtime.
- La configurazione completa di Matrix, le regole di targeting e gli esempi di configurazione sono documentati in Matrix.
Microsoft Teams
Microsoft Teams è supportato da Plugin e configurato sottochannels.msteams.
- Percorsi chiave principali trattati qui:
channels.msteams,channels.msteams.configWrites. - La configurazione completa di Teams (credenziali, Webhook, policy DM/gruppo, override per team/per canale) è documentata in Microsoft Teams.
IRC
IRC è supportato da Plugin e configurato sottochannels.irc.
- Percorsi chiave principali trattati qui:
channels.irc,channels.irc.dmPolicy,channels.irc.configWrites,channels.irc.nickserv.*. channels.irc.defaultAccountfacoltativo sovrascrive la selezione dell’account predefinito quando corrisponde a un ID account configurato.- La configurazione completa del canale IRC (host/porta/TLS/canali/allowlist/vincolo di menzione) è documentata in IRC.
Multi-account (tutti i canali)
Esegui più account per canale (ciascuno con il proprioaccountId):
defaultviene usato quandoaccountIdè omesso (CLI + routing).- I token env si applicano solo all’account default.
- Le impostazioni di base del canale si applicano a tutti gli account salvo override per account.
- Usa
bindings[].match.accountIdper instradare ciascun account a un agente diverso. - Se aggiungi un account non predefinito tramite
openclaw channels add(o onboarding del canale) mentre usi ancora una configurazione del canale di primo livello con account singolo, OpenClaw promuove prima i valori di account singolo di primo livello con ambito account nella mappa degli account del canale, così l’account originale continua a funzionare. La maggior parte dei canali li sposta inchannels.<channel>.accounts.default; Matrix può invece preservare un target nominato/predefinito corrispondente esistente. - Le associazioni esistenti solo a livello canale (senza
accountId) continuano a corrispondere all’account predefinito; le associazioni con ambito account restano facoltative. - Anche
openclaw doctor --fixripara forme miste spostando i valori di account singolo di primo livello con ambito account nell’account promosso scelto per quel canale. La maggior parte dei canali usaaccounts.default; Matrix può invece preservare un target nominato/predefinito corrispondente esistente.
Altri canali Plugin
Molti canali Plugin sono configurati comechannels.<id> e documentati nelle rispettive pagine dedicate dei canali (per esempio Feishu, Matrix, LINE, Nostr, Zalo, Nextcloud Talk, Synology Chat e Twitch).
Consulta l’indice completo dei canali: Canali.
Vincolo di menzione nelle chat di gruppo
I messaggi di gruppo richiedono per impostazione predefinita una menzione obbligatoria (menzione nei metadati o pattern regex sicuri). Si applica alle chat di gruppo WhatsApp, Telegram, Discord, Google Chat e iMessage. Le risposte visibili sono controllate separatamente. Le stanze di gruppo/canale usano per impostazione predefinitamessages.groupChat.visibleReplies: "message_tool": OpenClaw elabora comunque il turno, ma le normali risposte finali restano private e l’output visibile nella stanza richiede message(action=send). Imposta "automatic" solo quando vuoi il comportamento legacy in cui le risposte normali vengono pubblicate di nuovo nella stanza. Per applicare lo stesso comportamento di risposte visibili solo tramite strumento anche alle chat dirette, imposta messages.visibleReplies: "message_tool"; anche l’harness Codex usa quel comportamento solo tramite strumento come impostazione predefinita non configurata per le chat dirette.
Le risposte visibili solo tramite strumento richiedono un modello/runtime che chiami gli strumenti in modo affidabile. Se
il log della sessione mostra testo dell’assistente con didSendViaMessagingTool: false, il
modello ha prodotto una risposta finale privata invece di chiamare lo strumento di messaggistica.
Passa a un modello più forte nella chiamata degli strumenti per quel canale, oppure imposta
messages.groupChat.visibleReplies: "automatic" per ripristinare le risposte finali visibili
legacy.
Se lo strumento di messaggistica non è disponibile con la policy degli strumenti attiva, OpenClaw ripiega sulle risposte visibili automatiche invece di sopprimere silenziosamente la risposta. openclaw doctor avvisa di questa mancata corrispondenza.
Il Gateway ricarica a caldo la configurazione messages dopo il salvataggio del file. Riavvia solo quando il controllo dei file o il ricaricamento della configurazione è disabilitato nel deployment.
Tipi di menzione:
- Menzioni nei metadati: @-menzioni native della piattaforma. Ignorate nella modalità chat con se stessi di WhatsApp.
- Pattern di testo: pattern regex sicuri in
agents.list[].groupChat.mentionPatterns. I pattern non validi e la ripetizione annidata non sicura vengono ignorati. - Il gating delle menzioni viene applicato solo quando il rilevamento è possibile (menzioni native o almeno un pattern).
messages.groupChat.historyLimit imposta il valore predefinito globale. I canali possono sovrascriverlo con channels.<channel>.historyLimit (o per account). Imposta 0 per disabilitarlo.
messages.visibleReplies è il valore predefinito globale per i turni sorgente; messages.groupChat.visibleReplies lo sovrascrive per i turni sorgente di gruppo/canale. Quando messages.visibleReplies non è impostato, un harness può fornire il proprio valore predefinito diretto/sorgente; l’harness Codex usa come valore predefinito message_tool. Le allowlist dei canali e il gating delle menzioni decidono comunque se un turno viene elaborato.
Limiti della cronologia dei DM
telegram, whatsapp, discord, slack, signal, imessage, msteams.
Modalità chat con se stessi
Includi il tuo numero inallowFrom per abilitare la modalità chat con se stessi (ignora le @-menzioni native, risponde solo ai pattern di testo):
Comandi (gestione dei comandi in chat)
Dettagli dei comandi
Dettagli dei comandi
- Questo blocco configura le superfici dei comandi. Per l’attuale catalogo di comandi integrati + in bundle, consulta Comandi slash.
- Questa pagina è un riferimento delle chiavi di configurazione, non il catalogo completo dei comandi. I comandi di proprietà del canale/Plugin come QQ Bot
/bot-ping/bot-help/bot-logs, LINE/card, associazione dispositivo/pair, memoria/dreaming, controllo telefono/phonee Talk/voicesono documentati nelle rispettive pagine di canale/Plugin più Comandi slash. - I comandi di testo devono essere messaggi autonomi con
/iniziale. native: "auto"attiva i comandi nativi per Discord/Telegram, lascia Slack disattivato.nativeSkills: "auto"attiva i comandi Skills nativi per Discord/Telegram, lascia Slack disattivato.- Override per canale:
channels.discord.commands.native(booleano o"auto"). Per Discord,falsesalta la registrazione e la pulizia dei comandi nativi durante l’avvio. - Sovrascrivi la registrazione delle Skill native per canale con
channels.<provider>.commands.nativeSkills. channels.telegram.customCommandsaggiunge voci extra al menu del bot Telegram.bash: trueabilita! <cmd>per la shell host. Richiedetools.elevated.enablede il mittente intools.elevated.allowFrom.<channel>.config: trueabilita/config(legge/scriveopenclaw.json). Per i client Gatewaychat.send, le scritture persistenti/config set|unsetrichiedono ancheoperator.admin;/config showin sola lettura resta disponibile per i normali client operatore con ambito di scrittura.mcp: trueabilita/mcpper la configurazione dei server MCP gestiti da OpenClaw sottomcp.servers.plugins: trueabilita/pluginsper il rilevamento, l’installazione e i controlli di abilitazione/disabilitazione dei Plugin.channels.<provider>.configWritescontrolla le mutazioni della configurazione per canale (predefinito: true).- Per i canali multi-account,
channels.<provider>.accounts.<id>.configWritescontrolla anche le scritture che puntano a quell’account (per esempio/allowlist --config --account <id>o/config set channels.<provider>.accounts.<id>...). restart: falsedisabilita/restarte le azioni dello strumento di riavvio del Gateway. Predefinito:true.ownerAllowFromè l’allowlist esplicita del proprietario per comandi/strumenti riservati al proprietario. È separata daallowFrom.ownerDisplay: "hash"esegue l’hash degli ID proprietario nel prompt di sistema. ImpostaownerDisplaySecretper controllare l’hashing.allowFromè per provider. Quando è impostato, è l’unica fonte di autorizzazione (le allowlist/associazioni dei canali euseAccessGroupsvengono ignorati).useAccessGroups: falseconsente ai comandi di bypassare le policy dei gruppi di accesso quandoallowFromnon è impostato.- Mappa della documentazione dei comandi:
- catalogo integrato + in bundle: Comandi slash
- superfici dei comandi specifiche per canale: Canali
- comandi QQ Bot: QQ Bot
- comandi di associazione: Associazione
- comando scheda LINE: LINE
- dreaming della memoria: Dreaming
Correlati
- Riferimento di configurazione — chiavi di primo livello
- Configurazione — agenti
- Panoramica dei canali