Mainstream messaging
Discord
Pronto per DM e canali guild tramite il Gateway ufficiale di Discord.
I DM di Discord usano per impostazione predefinita la modalità di abbinamento.
Comportamento dei comandi nativi e catalogo dei comandi.
Diagnostica cross-channel e flusso di riparazione.
Configurazione rapida
Dovrai creare una nuova applicazione con un bot, aggiungere il bot al tuo server e abbinarlo a OpenClaw. Consigliamo di aggiungere il bot al tuo server privato. Se non ne hai ancora uno, creane prima uno (scegli Create My Own > For me and my friends).
Crea un'applicazione Discord e un bot
Vai al Discord Developer Portal e fai clic su New Application. Assegnale un nome come "OpenClaw".
Fai clic su Bot nella barra laterale. Imposta Username su come vuoi chiamare il tuo agente OpenClaw.
Abilita gli intent privilegiati
Sempre nella pagina Bot, scorri verso il basso fino a Privileged Gateway Intents e abilita:
- Message Content Intent (obbligatorio)
- Server Members Intent (consigliato; obbligatorio per le allowlist dei ruoli e la corrispondenza da nome a ID)
- Presence Intent (facoltativo; necessario solo per gli aggiornamenti di presenza)
Copia il token del bot
Scorri di nuovo verso l'alto nella pagina Bot e fai clic su Reset Token.
Copia il token e salvalo da qualche parte. Questo è il tuo Bot Token e ti servirà tra poco.
Genera un URL di invito e aggiungi il bot al tuo server
Fai clic su OAuth2 nella barra laterale. Genererai un URL di invito con le autorizzazioni corrette per aggiungere il bot al tuo server.
Scorri verso il basso fino a OAuth2 URL Generator e abilita:
botapplications.commands
Sotto apparirà una sezione Bot Permissions. Abilita almeno:
Autorizzazioni generali
- Visualizzare canali
Autorizzazioni di testo
- Inviare messaggi
- Leggere la cronologia dei messaggi
- Incorporare link
- Allegare file
- Aggiungere reazioni (facoltativo)
Questo è il set di base per i normali canali di testo. Se prevedi di pubblicare nei thread di Discord, inclusi i flussi di lavoro dei canali forum o media che creano o continuano un thread, abilita anche Send Messages in Threads. Copia l'URL generato in fondo, incollalo nel browser, seleziona il tuo server e fai clic su Continue per connettere. Ora dovresti vedere il tuo bot nel server Discord.
Abilita la modalità sviluppatore e raccogli i tuoi ID
Tornando nell'app Discord, devi abilitare la modalità sviluppatore per poter copiare gli ID interni.
-
Fai clic su User Settings (icona a ingranaggio accanto al tuo avatar) → scorri fino a Developer nella barra laterale → attiva Developer Mode
(Nota: nell'app mobile Discord, la modalità sviluppatore si trova in App Settings → Advanced)
-
Fai clic con il pulsante destro sull'icona del server nella barra laterale → Copy Server ID
-
Fai clic con il pulsante destro sul tuo avatar → Copy User ID
Salva il tuo Server ID e User ID insieme al Bot Token — nel passaggio successivo li invierai tutti e tre a OpenClaw.
Consenti i DM dai membri del server
Perché l'abbinamento funzioni, Discord deve consentire al bot di inviarti DM. Fai clic con il pulsante destro sull'icona del server → Privacy Settings → attiva Direct Messages.
Questo consente ai membri del server (inclusi i bot) di inviarti DM. Lascialo abilitato se vuoi usare i DM di Discord con OpenClaw. Se prevedi di usare solo i canali guild, puoi disabilitare i DM dopo l'abbinamento.
Imposta il token del bot in modo sicuro (non inviarlo in chat)
Il token del bot Discord è un segreto (come una password). Impostalo sulla macchina che esegue OpenClaw prima di inviare messaggi al tuo agente.
export DISCORD_BOT_TOKEN="YOUR_BOT_TOKEN"cat > discord.patch.json5 <<'JSON5'{channels: {discord: { enabled: true, token: { source: "env", provider: "default", id: "DISCORD_BOT_TOKEN" },},},}JSON5openclaw config patch --file ./discord.patch.json5 --dry-runopenclaw config patch --file ./discord.patch.json5openclaw gatewaySe OpenClaw è già in esecuzione come servizio in background, riavvialo tramite l'app OpenClaw per Mac oppure arrestando e riavviando il processo openclaw gateway run.
Per le installazioni come servizio gestito, esegui openclaw gateway install da una shell in cui DISCORD_BOT_TOKEN è presente, oppure archivia la variabile in ~/.openclaw/.env, in modo che il servizio possa risolvere il SecretRef env dopo il riavvio.
Se il tuo host è bloccato o soggetto a limitazione di frequenza dalla ricerca dell'applicazione all'avvio di Discord, imposta l'ID applicazione/client Discord dal Developer Portal in modo che l'avvio possa saltare quella chiamata REST. Usa channels.discord.applicationId per l'account predefinito, oppure channels.discord.accounts.<accountId>.applicationId quando esegui più bot Discord.
Configura OpenClaw e abbina
Chiedi al tuo agente
Chatta con il tuo agente OpenClaw su qualsiasi canale esistente (ad esempio Telegram) e comunicaglielo. Se Discord è il tuo primo canale, usa invece la scheda CLI / config.
"Ho già impostato il token del mio bot Discord nella configurazione. Completa la configurazione di Discord con User ID
<user_id>e Server ID<server_id>."
CLI / config
Se preferisci la configurazione basata su file, imposta:
{channels: {discord: {enabled: true,token: {source: "env",provider: "default",id: "DISCORD_BOT_TOKEN",},},},}Fallback env per l'account predefinito:
DISCORD_BOT_TOKEN=...Per configurazioni con script o remote, scrivi lo stesso blocco JSON5 con openclaw config patch --file ./discord.patch.json5 --dry-run e poi riesegui senza --dry-run. I valori token in testo normale sono supportati. Anche i valori SecretRef sono supportati per channels.discord.token tra provider env/file/exec. Vedi Gestione dei segreti.
Per più bot Discord, mantieni ogni token del bot e ID applicazione nel relativo account. Un channels.discord.applicationId di livello superiore viene ereditato dagli account, quindi impostalo lì solo quando ogni account deve usare lo stesso ID applicazione.
{channels: {discord: {enabled: true,accounts: {personal: { token: { source: "env", provider: "default", id: "DISCORD_PERSONAL_TOKEN" }, applicationId: "111111111111111111",},work: { token: { source: "env", provider: "default", id: "DISCORD_WORK_TOKEN" }, applicationId: "222222222222222222",},},},},}Approva il primo abbinamento DM
Attendi che il Gateway sia in esecuzione, poi invia un DM al bot in Discord. Risponderà con un codice di abbinamento.
Chiedi al tuo agente
Invia il codice di abbinamento al tuo agente sul canale esistente:
"Approva questo codice di abbinamento Discord:
<CODE>"
CLI
openclaw pairing list discordopenclaw pairing approve discord <CODE>I codici di abbinamento scadono dopo 1 ora.
Ora dovresti poter chattare con il tuo agente in Discord tramite DM.
Consigliato: configura un workspace guild
Una volta che i DM funzionano, puoi configurare il server Discord come workspace completo in cui ogni canale ottiene la propria sessione agente con il proprio contesto. È consigliato per server privati in cui ci sei solo tu e il tuo bot.
Aggiungi il server alla allowlist delle guild
Questo abilita il tuo agente a rispondere in qualsiasi canale sul tuo server, non solo nei DM.
Chiedi al tuo agente
"Aggiungi il mio Discord Server ID
<server_id>alla allowlist delle guild"
Configurazione
{channels: {discord: {groupPolicy: "allowlist",guilds: {YOUR_SERVER_ID: { requireMention: true, users: ["YOUR_USER_ID"],},},},},}Consenti risposte senza @mention
Per impostazione predefinita, il tuo agente risponde nei canali guild solo quando viene @menzionato. Per un server privato, probabilmente vuoi che risponda a ogni messaggio.
Nei canali guild, le normali risposte vengono pubblicate automaticamente per impostazione predefinita. Per stanze condivise sempre attive, abilita messages.groupChat.visibleReplies: "message_tool" così l'agente può restare in ascolto e pubblicare solo quando decide che una risposta nel canale è utile. Funziona meglio con modelli di ultima generazione affidabili con gli strumenti, come GPT 5.5. Gli eventi ambientali della stanza restano silenziosi a meno che lo strumento non invii. Vedi Eventi ambientali della stanza per la configurazione completa della modalità in ascolto.
Se Discord mostra la digitazione e i log mostrano l'uso dei token ma nessun messaggio pubblicato, controlla se il turno era configurato come evento ambientale della stanza o se aveva abilitato le risposte visibili tramite strumento messaggi.
Chiedi al tuo agente
"Consenti al mio agente di rispondere su questo server senza dover essere @menzionato"
Configurazione
Imposta requireMention: false nella configurazione della guild:
{channels: {discord: {guilds: {YOUR_SERVER_ID: { requireMention: false,},},},},}Per richiedere invii tramite strumento messaggi per le risposte visibili di gruppo/canale, imposta messages.groupChat.visibleReplies: "message_tool".
Pianifica la memoria nei canali guild
Per impostazione predefinita, la memoria a lungo termine (MEMORY.md) viene caricata solo nelle sessioni DM. I canali guild non caricano automaticamente MEMORY.md.
Chiedi al tuo agente
"Quando faccio domande nei canali Discord, usa memory_search o memory_get se ti serve contesto a lungo termine da MEMORY.md."
Manuale
Se hai bisogno di contesto condiviso in ogni canale, inserisci le istruzioni stabili in AGENTS.md o USER.md (vengono iniettate per ogni sessione). Conserva le note a lungo termine in MEMORY.md e accedivi su richiesta con gli strumenti di memoria.
Ora crea alcuni canali sul tuo server Discord e inizia a chattare. Il tuo agente può vedere il nome del canale e ogni canale ottiene la propria sessione isolata — così puoi configurare #coding, #home, #research o qualsiasi cosa si adatti al tuo flusso di lavoro.
Modello runtime
- Gateway possiede la connessione Discord.
- Il routing delle risposte è deterministico: le risposte in ingresso da Discord tornano a Discord.
- I metadati di server/canale Discord vengono aggiunti al prompt del modello come contesto non attendibile, non come prefisso di risposta visibile all'utente. Se un modello copia quell'involucro nella risposta, OpenClaw rimuove i metadati copiati dalle risposte in uscita e dal contesto di riproduzione futuro.
- Per impostazione predefinita (
session.dmScope=main), le chat dirette condividono la sessione principale dell'agente (agent:main:main). - I canali dei server sono chiavi di sessione isolate (
agent:<agentId>:discord:channel:<channelId>). - I DM di gruppo vengono ignorati per impostazione predefinita (
channels.discord.dm.groupEnabled=false). - I comandi slash nativi vengono eseguiti in sessioni di comando isolate (
agent:<agentId>:discord:slash:<userId>), pur trasportandoCommandTargetSessionKeyverso la sessione di conversazione instradata. - La consegna di annunci cron/heartbeat solo testo a Discord usa una sola volta la risposta finale visibile all'assistente. I payload multimediali e dei componenti strutturati restano multi-messaggio quando l'agente emette più payload consegnabili.
Canali forum
I canali forum e multimediali di Discord accettano solo post di thread. OpenClaw supporta due modi per crearli:
- Invia un messaggio al forum padre (
channel:<forumId>) per creare automaticamente un thread. Il titolo del thread usa la prima riga non vuota del messaggio. - Usa
openclaw message thread createper creare direttamente un thread. Non passare--message-idper i canali forum.
Esempio: inviare al forum padre per creare un thread
openclaw message send --channel discord --target channel:<forumId> \ --message "Topic title\nBody of the post"Esempio: creare esplicitamente un thread del forum
openclaw message thread create --channel discord --target channel:<forumId> \ --thread-name "Topic title" --message "Body of the post"I forum padre non accettano componenti Discord. Se hai bisogno di componenti, invia al thread stesso (channel:<threadId>).
Componenti interattivi
OpenClaw supporta contenitori di componenti Discord v2 per i messaggi degli agenti. Usa lo strumento messaggio con un payload components. I risultati delle interazioni vengono instradati di nuovo all'agente come normali messaggi in ingresso e seguono le impostazioni Discord replyToMode esistenti.
Blocchi supportati:
text,section,separator,actions,media-gallery,file- Le righe di azioni consentono fino a 5 pulsanti o un singolo menu di selezione
- Tipi di selezione:
string,user,role,mentionable,channel
Per impostazione predefinita, i componenti sono monouso. Imposta components.reusable=true per consentire l'uso ripetuto di pulsanti, selezioni e moduli finché non scadono.
Per limitare chi può fare clic su un pulsante, imposta allowedUsers su quel pulsante (ID utente Discord, tag o *). Quando configurato, gli utenti non corrispondenti ricevono un rifiuto effimero.
I callback dei componenti scadono dopo 30 minuti per impostazione predefinita. Imposta channels.discord.agentComponents.ttlMs per modificare la durata del registro dei callback per l'account Discord predefinito, oppure channels.discord.accounts.<accountId>.agentComponents.ttlMs per sovrascrivere un account in una configurazione multi-account. Il valore è in millisecondi, deve essere un numero intero positivo ed è limitato a 86400000 (24 ore). TTL più lunghi sono utili per flussi di revisione o approvazione che richiedono che i pulsanti restino utilizzabili, ma estendono anche la finestra in cui un vecchio messaggio Discord può ancora attivare un'azione. Preferisci il TTL più breve adatto al flusso di lavoro e mantieni il valore predefinito quando callback obsoleti risulterebbero sorprendenti.
I comandi slash /model e /models aprono un selettore di modelli interattivo con menu a discesa per provider, modello e runtime compatibile, più un passaggio di invio. /models add è deprecato e ora restituisce un messaggio di deprecazione invece di registrare modelli dalla chat. La risposta del selettore è effimera e solo l'utente che l'ha invocata può usarla. I menu di selezione Discord sono limitati a 25 opzioni, quindi aggiungi voci provider/* a agents.defaults.models quando vuoi che il selettore mostri i modelli scoperti dinamicamente solo per provider selezionati come openai o vllm.
Allegati file:
- I blocchi
filedevono puntare a un riferimento allegato (attachment://<filename>) - Fornisci l'allegato tramite
media/path/filePath(singolo file); usamedia-galleryper più file - Usa
filenameper sovrascrivere il nome di caricamento quando deve corrispondere al riferimento allegato
Moduli modali:
- Aggiungi
components.modalcon un massimo di 5 campi - Tipi di campo:
text,checkbox,radio,select,role-select,user-select - OpenClaw aggiunge automaticamente un pulsante di attivazione
Esempio:
{ channel: "discord", action: "send", to: "channel:123456789012345678", message: "Optional fallback text", components: { reusable: true, text: "Choose a path", blocks: [ { type: "actions", buttons: [ { label: "Approve", style: "success", allowedUsers: ["123456789012345678"], }, { label: "Decline", style: "danger" }, ], }, { type: "actions", select: { type: "string", placeholder: "Pick an option", options: [ { label: "Option A", value: "a" }, { label: "Option B", value: "b" }, ], }, }, ], modal: { title: "Details", triggerLabel: "Open form", fields: [ { type: "text", label: "Requester" }, { type: "select", label: "Priority", options: [ { label: "Low", value: "low" }, { label: "High", value: "high" }, ], }, ], }, },}Controllo degli accessi e routing
DM policy
channels.discord.dmPolicy controlla l'accesso ai DM. channels.discord.allowFrom è l'allowlist canonica dei DM.
pairing(predefinito)allowlistopen(richiede chechannels.discord.allowFromincluda"*")disabled
Se la policy DM non è aperta, gli utenti sconosciuti vengono bloccati (o invitati all'abbinamento in modalità pairing).
Precedenza multi-account:
channels.discord.accounts.default.allowFromsi applica solo all'accountdefault.- Per un account,
allowFromha precedenza sul legacydm.allowFrom. - Gli account denominati ereditano
channels.discord.allowFromquando il proprioallowFrome il legacydm.allowFromnon sono impostati. - Gli account denominati non ereditano
channels.discord.accounts.default.allowFrom.
Il legacy channels.discord.dm.policy e channels.discord.dm.allowFrom vengono ancora letti per compatibilità. openclaw doctor --fix li migra a dmPolicy e allowFrom quando può farlo senza modificare l'accesso.
Formato di destinazione DM per la consegna:
user:<id>- menzione
<@id>
Gli ID numerici semplici normalmente si risolvono come ID canale quando è attivo un canale predefinito, ma gli ID elencati nell'allowFrom DM effettivo dell'account vengono trattati come destinazioni DM utente per compatibilità.
Access groups
I DM Discord e l'autorizzazione dei comandi testuali possono usare voci dinamiche accessGroup:<name> in channels.discord.allowFrom.
I nomi dei gruppi di accesso sono condivisi tra i canali di messaggistica. Usa type: "message.senders" per un gruppo statico i cui membri sono espressi nella normale sintassi allowFrom di ogni canale, oppure type: "discord.channelAudience" quando il pubblico ViewChannel corrente di un canale Discord deve definire dinamicamente l'appartenenza. Il comportamento condiviso dei gruppi di accesso è documentato qui: Gruppi di accesso.
{accessGroups: {operators: { type: "message.senders", members: { "*": ["global-owner-id"], discord: ["discord:123456789012345678"], telegram: ["987654321"], },},},channels: {discord: { dmPolicy: "allowlist", allowFrom: ["accessGroup:operators"],},},}Un canale testuale Discord non ha un elenco membri separato. type: "discord.channelAudience" modella l'appartenenza così: il mittente DM è membro del server configurato e al momento dispone dell'autorizzazione effettiva ViewChannel sul canale configurato dopo l'applicazione delle sovrascritture di ruoli e canali.
Esempio: consentire a chiunque possa vedere #maintainers di inviare DM al bot, mantenendo i DM chiusi a tutti gli altri.
{accessGroups: {maintainers: { type: "discord.channelAudience", guildId: "1456350064065904867", channelId: "1456744319972282449", membership: "canViewChannel",},},channels: {discord: { dmPolicy: "allowlist", allowFrom: ["accessGroup:maintainers"],},},}Puoi combinare voci dinamiche e statiche:
{accessGroups: {maintainers: { type: "discord.channelAudience", guildId: "1456350064065904867", channelId: "1456744319972282449",},},channels: {discord: { dmPolicy: "allowlist", allowFrom: ["accessGroup:maintainers", "discord:123456789012345678"],},},}Le ricerche falliscono in chiuso. Se Discord restituisce Missing Access, la ricerca del membro fallisce o il canale appartiene a un server diverso, il mittente DM viene trattato come non autorizzato.
Abilita Server Members Intent del Discord Developer Portal per il bot quando usi gruppi di accesso basati sul pubblico del canale. I DM non includono lo stato membro del server, quindi OpenClaw risolve il membro tramite Discord REST al momento dell'autorizzazione.
Guild policy
La gestione dei server è controllata da channels.discord.groupPolicy:
openallowlistdisabled
La baseline sicura quando channels.discord esiste è allowlist.
Comportamento di allowlist:
- il server deve corrispondere a
channels.discord.guilds(idpreferito, slug accettato) - allowlist opzionali dei mittenti:
users(ID stabili consigliati) eroles(solo ID ruolo); se una delle due è configurata, i mittenti sono consentiti quando corrispondono ausersOroles - la corrispondenza diretta di nome/tag è disabilitata per impostazione predefinita; abilita
channels.discord.dangerouslyAllowNameMatching: truesolo come modalità di compatibilità di emergenza - nomi/tag sono supportati per
users, ma gli ID sono più sicuri;openclaw security auditavvisa quando vengono usate voci nome/tag - se un server ha
channelsconfigurato, i canali non elencati vengono negati - se un server non ha un blocco
channels, tutti i canali in quel server in allowlist sono consentiti
Esempio:
{channels: {discord: { groupPolicy: "allowlist", guilds: { "123456789012345678": { requireMention: true, ignoreOtherMentions: true, users: ["987654321098765432"], roles: ["123456789012345678"], channels: { general: { allow: true }, help: { allow: true, requireMention: true }, }, }, },},},}Se imposti solo DISCORD_BOT_TOKEN e non crei un blocco channels.discord, il fallback runtime è groupPolicy="allowlist" (con un avviso nei log), anche se channels.defaults.groupPolicy è open.
Mentions and group DMs
I messaggi dei server richiedono una menzione per impostazione predefinita.
Il rilevamento delle menzioni include:
- menzione esplicita del bot
- pattern di menzione configurati (
agents.list[].groupChat.mentionPatterns, fallbackmessages.groupChat.mentionPatterns) - comportamento implicito di risposta al bot nei casi supportati
Quando scrivi messaggi Discord in uscita, usa la sintassi di menzione canonica: <@USER_ID> per gli utenti, <#CHANNEL_ID> per i canali e <@&ROLE_ID> per i ruoli. Non usare la forma di menzione nickname legacy <@!USER_ID>.
requireMention è configurato per server/canale (channels.discord.guilds...).
ignoreOtherMentions scarta facoltativamente i messaggi che menzionano un altro utente/ruolo ma non il bot (escludendo @everyone/@here).
DM di gruppo:
- predefinito: ignorati (
dm.groupEnabled=false) - allowlist opzionale tramite
dm.groupChannels(ID canale o slug)
Routing degli agenti basato sui ruoli
Usa bindings[].match.roles per instradare i membri della guild Discord verso agenti diversi in base all'ID del ruolo. I binding basati sui ruoli accettano solo ID ruolo e vengono valutati dopo i binding peer o parent-peer e prima dei binding solo guild. Se un binding imposta anche altri campi di corrispondenza (per esempio peer + guildId + roles), tutti i campi configurati devono corrispondere.
{ bindings: [ { agentId: "opus", match: { channel: "discord", guildId: "123456789012345678", roles: ["111111111111111111"], }, }, { agentId: "sonnet", match: { channel: "discord", guildId: "123456789012345678", }, }, ],}Comandi nativi e autorizzazione dei comandi
commands.nativeè impostato per impostazione predefinita su"auto"ed è abilitato per Discord.- Override per canale:
channels.discord.commands.native. commands.native=falsesalta la registrazione e la pulizia degli slash command Discord durante l'avvio. I comandi registrati in precedenza potrebbero rimanere visibili in Discord finché non li rimuovi dall'app Discord.- L'autorizzazione dei comandi nativi usa le stesse liste consentite/policy Discord della normale gestione dei messaggi.
- I comandi potrebbero essere ancora visibili nell'interfaccia utente Discord per gli utenti non autorizzati; l'esecuzione applica comunque l'autorizzazione OpenClaw e restituisce "non autorizzato".
Vedi Slash command per il catalogo e il comportamento dei comandi.
Impostazioni predefinite degli slash command:
ephemeral: true
Dettagli della funzionalità
Tag di risposta e risposte native
Discord supporta i tag di risposta nell'output dell'agente:
[[reply_to_current]][[reply_to:<id>]]
Controllato da channels.discord.replyToMode:
off(predefinito)firstallbatched
Nota: off disabilita il threading di risposta implicito. I tag espliciti [[reply_to_*]] sono comunque rispettati.
first collega sempre il riferimento di risposta nativa implicita al primo messaggio Discord in uscita per il turno.
batched collega il riferimento di risposta nativa implicita di Discord solo quando
l'evento in ingresso era un batch con debounce di più messaggi. Questo è utile
quando vuoi risposte native soprattutto per chat ambigue e a raffica, non per ogni
turno con un singolo messaggio.
Gli ID dei messaggi vengono esposti nel contesto/nella cronologia così gli agenti possono puntare a messaggi specifici.
Anteprime dei link
Discord genera embed avanzati dei link per gli URL per impostazione predefinita. OpenClaw sopprime per impostazione predefinita quegli embed generati sui messaggi Discord in uscita, quindi gli URL inviati dall'agente rimangono link semplici a meno che tu non scelga diversamente:
{channels: {discord: { suppressEmbeds: false,},},}Imposta channels.discord.accounts.<id>.suppressEmbeds per eseguire l'override di un account. Gli invii tramite lo strumento messaggi dell'agente possono anche passare suppressEmbeds: false per un singolo messaggio. I payload Discord embeds espliciti non vengono soppressi dall'impostazione predefinita dell'anteprima dei link.
Anteprima dello stream live
OpenClaw può trasmettere in streaming bozze di risposta inviando un messaggio temporaneo e modificandolo man mano che arriva il testo. channels.discord.streaming accetta off | partial | block | progress (predefinito). progress mantiene una bozza di stato modificabile e la aggiorna con l'avanzamento degli strumenti fino alla consegna finale; l'etichetta iniziale condivisa è una riga scorrevole, quindi scompare come il resto quando appare abbastanza lavoro. streamMode è un alias runtime legacy. Esegui openclaw doctor --fix per riscrivere la configurazione persistita nella chiave canonica.
Imposta channels.discord.streaming.mode su off per disabilitare le modifiche dell'anteprima Discord. Se lo streaming a blocchi Discord è abilitato esplicitamente, OpenClaw salta lo stream di anteprima per evitare il doppio streaming.
{channels: {discord: { streaming: { mode: "progress", progress: { label: "auto", maxLines: 8, maxLineChars: 120, toolProgress: true, commentary: false, }, },},},}partialmodifica un singolo messaggio di anteprima man mano che arrivano i token.blockemette blocchi della dimensione di una bozza (usadraftChunkper regolare dimensione e punti di interruzione, limitati atextChunkLimit).- Media, errori e finali con risposta esplicita annullano le modifiche di anteprima in sospeso.
streaming.preview.toolProgress(predefinitotrue) controlla se gli aggiornamenti di strumenti/avanzamento riutilizzano il messaggio di anteprima.- Le righe di strumenti/avanzamento vengono renderizzate come emoji compatta + titolo + dettaglio quando disponibili, per esempio
🛠️ Bash: run testso🔎 Web Search: for "query". streaming.progress.commentary(predefinitofalse) abilita il testo di commento/preambolo dell'assistente nella bozza temporanea di avanzamento. Il commento viene pulito prima della visualizzazione, resta transitorio e non modifica la consegna della risposta finale.streaming.progress.maxLineCharscontrolla il budget dell'anteprima di avanzamento per riga. Il testo in prosa viene abbreviato ai confini delle parole; i dettagli di comandi e percorsi mantengono suffissi utili.streaming.preview.commandText/streaming.progress.commandTextcontrolla i dettagli di comando/exec nelle righe di avanzamento compatte:raw(predefinito) ostatus(solo etichetta dello strumento).
Nascondi il testo grezzo di comando/exec mantenendo le righe di avanzamento compatte:
{ "channels": { "discord": { "streaming": { "mode": "progress", "progress": { "toolProgress": true, "commandText": "status" } } } }}Lo streaming di anteprima è solo testuale; le risposte multimediali ricadono sulla consegna normale. Quando lo streaming block è abilitato esplicitamente, OpenClaw salta lo stream di anteprima per evitare il doppio streaming.
Cronologia, contesto e comportamento dei thread
Contesto della cronologia della guild:
channels.discord.historyLimitpredefinito20- fallback:
messages.groupChat.historyLimit 0disabilita
Controlli della cronologia dei DM:
channels.discord.dmHistoryLimitchannels.discord.dms["<user_id>"].historyLimit
Comportamento dei thread:
- I thread Discord vengono instradati come sessioni di canale ed ereditano la configurazione del canale padre salvo override.
- Le sessioni thread ereditano la selezione
/modela livello di sessione del canale padre come fallback solo modello; le selezioni/modellocali al thread hanno comunque la precedenza e la cronologia della trascrizione padre non viene copiata a meno che l'ereditarietà della trascrizione non sia abilitata. channels.discord.thread.inheritParent(predefinitofalse) abilita i nuovi auto-thread al seeding dalla trascrizione padre. Gli override per account si trovano inchannels.discord.accounts.<id>.thread.inheritParent.- Le reazioni dello strumento messaggi possono risolvere target DM
user:<id>. guilds.<guild>.channels.<channel>.requireMention: falseviene preservato durante il fallback di attivazione in fase di risposta.
Gli argomenti dei canali vengono iniettati come contesto non attendibile. Le liste consentite regolano chi può attivare l'agente, non sono un confine completo di oscuramento del contesto supplementare.
Sessioni vincolate ai thread per sottoagenti
Discord può vincolare un thread a un target di sessione così i messaggi successivi in quel thread continuano a essere instradati alla stessa sessione (incluse le sessioni dei sottoagenti).
Comandi:
/focus <target>vincola il thread corrente/nuovo a un target sottoagente/sessione/unfocusrimuove il binding del thread corrente/agentsmostra le esecuzioni attive e lo stato del binding/session idle <duration|off>ispeziona/aggiorna l'auto-unfocus per inattività per i binding focalizzati/session max-age <duration|off>ispeziona/aggiorna l'età massima rigida per i binding focalizzati
Configurazione:
{session: {threadBindings: { enabled: true, idleHours: 24, maxAgeHours: 0,},},channels: {discord: { threadBindings: { enabled: true, idleHours: 24, maxAgeHours: 0, spawnSessions: true, defaultSpawnContext: "fork", },},},}Note:
session.threadBindings.*imposta i valori predefiniti globali.channels.discord.threadBindings.*esegue l'override del comportamento Discord.spawnSessionscontrolla la creazione/il binding automatici dei thread persessions_spawn({ thread: true })e gli spawn di thread ACP. Predefinito:true.defaultSpawnContextcontrolla il contesto nativo del sottoagente per gli spawn vincolati a thread. Predefinito:"fork".- Le chiavi deprecate
spawnSubagentSessions/spawnAcpSessionsvengono migrate daopenclaw doctor --fix. - Se i binding dei thread sono disabilitati per un account,
/focuse le operazioni correlate di binding dei thread non sono disponibili.
Vedi Sottoagenti, Agenti ACP e Riferimento di configurazione.
Binding persistenti dei canali ACP
Per workspace ACP stabili e "sempre attivi", configura binding ACP tipizzati di primo livello che puntano a conversazioni Discord.
Percorso di configurazione:
bindings[]contype: "acp"ematch.channel: "discord"
Esempio:
{agents: {list: [ { id: "codex", runtime: { type: "acp", acp: { agent: "codex", backend: "acpx", mode: "persistent", cwd: "/workspace/openclaw", }, }, },],},bindings: [{ type: "acp", agentId: "codex", match: { channel: "discord", accountId: "default", peer: { kind: "channel", id: "222222222222222222" }, }, acp: { label: "codex-main" },},],channels: {discord: { guilds: { "111111111111111111": { channels: { "222222222222222222": { requireMention: false, }, }, }, },},},}Note:
/acp spawn codex --bind herevincola il canale o thread corrente sul posto e mantiene i messaggi futuri sulla stessa sessione ACP. I messaggi del thread ereditano il binding del canale padre.- In un canale o thread vincolato,
/newe/resetreimpostano la stessa sessione ACP sul posto. I binding temporanei dei thread possono eseguire l'override della risoluzione del target mentre sono attivi. spawnSessionsregola la creazione/il binding dei thread figli tramite--thread auto|here.
Vedi Agenti ACP per i dettagli sul comportamento dei binding.
Notifiche di reazione
Modalità di notifica delle reazioni per guild:
offown(predefinito)allallowlist(usaguilds.<id>.users)
Gli eventi di reazione vengono trasformati in eventi di sistema e collegati alla sessione Discord instradata.
Reazioni di ack
ackReaction invia un'emoji di conferma mentre OpenClaw sta elaborando un messaggio in ingresso.
Ordine di risoluzione:
channels.discord.accounts.<accountId>.ackReactionchannels.discord.ackReactionmessages.ackReaction- fallback all'emoji dell'identità dell'agente (
agents.list[].identity.emoji, altrimenti "👀")
Note:
- Discord accetta emoji Unicode o nomi di emoji personalizzate.
- Usa
""per disabilitare la reazione per un canale o account.
Scritture di configurazione
Le scritture di configurazione avviate dal canale sono abilitate per impostazione predefinita.
Questo influisce sui flussi /config set|unset (quando le funzionalità dei comandi sono abilitate).
Disabilita:
{channels: {discord: { configWrites: false,},},}Proxy Gateway
Instrada il traffico WebSocket del Gateway Discord e le ricerche REST di avvio (ID applicazione + risoluzione della lista consentita) tramite un proxy HTTP(S) con channels.discord.proxy.
Il proxy WebSocket del Discord Gateway è esplicito; le connessioni WebSocket non ereditano le variabili d'ambiente proxy ambientali dal processo Gateway. Le ricerche REST di avvio usano questo proxy quando channels.discord.proxy è configurato.
{channels: {discord: { proxy: "http://proxy.example:8080",},},}Override per account:
{channels: {discord: { accounts: { primary: { proxy: "http://proxy.example:8080", }, },},},}Supporto PluralKit
Abilita la risoluzione PluralKit per mappare i messaggi proxy all'identità del membro del sistema:
{channels: {discord: { pluralkit: { enabled: true, token: "pk_live_...", // optional; needed for private systems },},},}Note:
- gli allowlist possono usare
pk:<memberId> - i nomi visualizzati dei membri vengono confrontati per nome/slug solo quando
channels.discord.dangerouslyAllowNameMatching: true - le ricerche usano l'ID del messaggio originale e sono vincolate a una finestra temporale
- se la ricerca non riesce, i messaggi proxy vengono trattati come messaggi di bot ed eliminati, a meno che
allowBots=true
Alias delle menzioni in uscita
Usa mentionAliases quando gli agenti hanno bisogno di menzioni in uscita deterministiche per utenti Discord noti. Le chiavi sono handle senza la @ iniziale; i valori sono ID utente Discord. Gli handle sconosciuti, @everyone, @here e le menzioni all'interno di code span Markdown vengono lasciati invariati.
{channels: {discord: { mentionAliases: { Vladislava: "123456789012345678", }, accounts: { ops: { mentionAliases: { OpsLead: "234567890123456789", }, }, },},},}Configurazione della presenza
Gli aggiornamenti della presenza vengono applicati quando imposti un campo di stato o attività, oppure quando abiliti la presenza automatica.
Esempio solo stato:
{channels: {discord: { status: "idle",},},}Esempio di attività (lo stato personalizzato è il tipo di attività predefinito):
{channels: {discord: { activity: "Focus time", activityType: 4,},},}Esempio di streaming:
{channels: {discord: { activity: "Live coding", activityType: 1, activityUrl: "https://twitch.tv/openclaw",},},}Mappa dei tipi di attività:
- 0: In gioco
- 1: Streaming (richiede
activityUrl) - 2: In ascolto
- 3: In visione
- 4: Personalizzata (usa il testo dell'attività come stato; l'emoji è facoltativa)
- 5: In competizione
Esempio di presenza automatica (segnale di integrità del runtime):
{channels: {discord: { autoPresence: { enabled: true, intervalMs: 30000, minUpdateIntervalMs: 15000, exhaustedText: "token exhausted", },},},}La presenza automatica mappa la disponibilità del runtime allo stato Discord: integro => online, degradato o sconosciuto => inattivo, esaurito o non disponibile => dnd. Override di testo facoltativi:
autoPresence.healthyTextautoPresence.degradedTextautoPresence.exhaustedText(supporta il placeholder{reason})
Approvazioni in Discord
Discord supporta la gestione delle approvazioni basata su pulsanti nei DM e può facoltativamente pubblicare richieste di approvazione nel canale di origine.
Percorso di configurazione:
channels.discord.execApprovals.enabledchannels.discord.execApprovals.approvers(facoltativo; ripiega sucommands.ownerAllowFromquando possibile)channels.discord.execApprovals.target(dm|channel|both, predefinito:dm)agentFilter,sessionFilter,cleanupAfterResolve
Discord abilita automaticamente le approvazioni exec native quando enabled non è impostato o è "auto" e almeno un approvatore può essere risolto, da execApprovals.approvers oppure da commands.ownerAllowFrom. Discord non inferisce gli approvatori exec da allowFrom del canale, da dm.allowFrom legacy o da defaultTo dei messaggi diretti. Imposta enabled: false per disabilitare esplicitamente Discord come client di approvazione nativo.
Per comandi di gruppo sensibili riservati al proprietario, come /diagnostics e /export-trajectory, OpenClaw invia privatamente le richieste di approvazione e i risultati finali. Prova prima con un DM Discord quando il proprietario che invoca il comando ha una route proprietario Discord; se non è disponibile, ripiega sulla prima route proprietario disponibile da commands.ownerAllowFrom, come Telegram.
Quando target è channel o both, la richiesta di approvazione è visibile nel canale. Solo gli approvatori risolti possono usare i pulsanti; gli altri utenti ricevono un diniego effimero. Le richieste di approvazione includono il testo del comando, quindi abilita la consegna nel canale solo in canali attendibili. Se l'ID del canale non può essere derivato dalla chiave della sessione, OpenClaw ripiega sulla consegna tramite DM.
Discord renderizza anche i pulsanti di approvazione condivisi usati dagli altri canali chat. L'adapter Discord nativo aggiunge principalmente il routing DM degli approvatori e il fanout di canale.
Quando questi pulsanti sono presenti, sono la UX di approvazione primaria; OpenClaw
dovrebbe includere un comando manuale /approve solo quando il risultato dello strumento indica
che le approvazioni chat non sono disponibili o che l'approvazione manuale è l'unico percorso.
Se il runtime di approvazione nativo Discord non è attivo, OpenClaw mantiene visibile
la richiesta locale deterministica /approve <id> <decision>. Se il
runtime è attivo ma non è possibile consegnare una scheda nativa ad alcun target,
OpenClaw invia un avviso di fallback nella stessa chat con il comando /approve
esatto dell'approvazione in sospeso.
L'autenticazione Gateway e la risoluzione delle approvazioni seguono il contratto condiviso del client Gateway (gli ID plugin: si risolvono tramite plugin.approval.resolve; gli altri ID tramite exec.approval.resolve). Per impostazione predefinita, le approvazioni scadono dopo 30 minuti.
Vedi Approvazioni exec.
Strumenti e gate di azione
Le azioni dei messaggi Discord includono messaggistica, amministrazione dei canali, moderazione, presenza e azioni sui metadati.
Esempi principali:
- messaggistica:
sendMessage,readMessages,editMessage,deleteMessage,threadReply - reazioni:
react,reactions,emojiList - moderazione:
timeout,kick,ban - presenza:
setPresence
L'azione event-create accetta un parametro facoltativo image (URL o percorso di file locale) per impostare l'immagine di copertina dell'evento programmato.
I gate di azione si trovano sotto channels.discord.actions.*.
Comportamento predefinito dei gate:
| Gruppo di azioni | Predefinito |
|---|---|
| reazioni, messaggi, thread, pin, sondaggi, ricerca, info membro, info ruolo, info canale, canali, stato voce, eventi, sticker, caricamenti emoji, caricamenti sticker, autorizzazioni | abilitato |
| ruoli | disabilitato |
| moderazione | disabilitato |
| presenza | disabilitato |
UI componenti v2
OpenClaw usa i componenti Discord v2 per le approvazioni exec e i marcatori tra contesti. Le azioni dei messaggi Discord possono anche accettare components per UI personalizzate (avanzato; richiede di costruire un payload componente tramite lo strumento discord), mentre gli embeds legacy restano disponibili ma non sono consigliati.
channels.discord.ui.components.accentColorimposta il colore di accento usato dai contenitori dei componenti Discord (hex).- Impostalo per account con
channels.discord.accounts.<id>.ui.components.accentColor. channels.discord.agentComponents.ttlMscontrolla per quanto tempo i callback dei componenti Discord inviati restano registrati (predefinito1800000, massimo86400000). Impostalo per account conchannels.discord.accounts.<id>.agentComponents.ttlMs.- Gli
embedsvengono ignorati quando sono presenti componenti v2. - Le anteprime degli URL semplici sono soppresse per impostazione predefinita. Imposta
suppressEmbeds: falsesu un'azione messaggio quando un singolo link in uscita deve espandersi.
Esempio:
{ channels: { discord: { ui: { components: { accentColor: "#5865F2", }, }, }, },}Voce
Discord ha due superfici voce distinte: canali vocali realtime (conversazioni continue) e allegati di messaggi vocali (il formato di anteprima con forma d'onda). Il gateway supporta entrambe.
Canali vocali
Checklist di configurazione:
- Abilita Message Content Intent nel Discord Developer Portal.
- Abilita Server Members Intent quando vengono usati allowlist di ruoli/utenti.
- Invita il bot con gli ambiti
boteapplications.commands. - Concedi Connect, Speak, Send Messages e Read Message History nel canale vocale di destinazione.
- Abilita i comandi nativi (
commands.nativeochannels.discord.commands.native). - Configura
channels.discord.voice.
Usa /vc join|leave|status per controllare le sessioni. Il comando usa l'agente predefinito dell'account e segue le stesse regole di allowlist e policy di gruppo degli altri comandi Discord.
/vc join channel:<voice-channel-id>/vc status/vc leavePer esaminare le autorizzazioni effettive del bot prima dell'accesso, esegui:
openclaw channels capabilities --channel discord --target channel:<voice-channel-id>Esempio di accesso automatico:
{ channels: { discord: { voice: { enabled: true, model: "openai/gpt-5.5", autoJoin: [ { guildId: "123456789012345678", channelId: "234567890123456789", }, ], allowedChannels: [ { guildId: "123456789012345678", channelId: "234567890123456789", }, ], daveEncryption: true, decryptionFailureTolerance: 24, connectTimeoutMs: 30000, reconnectGraceMs: 15000, realtime: { provider: "openai", model: "gpt-realtime-2", speakerVoice: "cedar", }, }, }, },}Note:
voice.ttssovrascrivemessages.ttssolo per la riproduzione vocalestt-tts. Le modalità realtime usanovoice.realtime.speakerVoice.voice.modecontrolla il percorso della conversazione. Il valore predefinito èagent-proxy: un front end vocale realtime gestisce la temporizzazione dei turni, l'interruzione e la riproduzione, delega il lavoro sostanziale all'agente OpenClaw instradato tramiteopenclaw_agent_consulte tratta il risultato come un prompt Discord digitato da quello speaker.stt-ttsmantiene il vecchio flusso batch STT più TTS.bidiconsente al modello realtime di conversare direttamente esponendoopenclaw_agent_consultper il cervello OpenClaw.voice.agentSessioncontrolla quale conversazione OpenClaw riceve i turni vocali. Lascialo non impostato per la sessione del canale vocale stesso, oppure imposta{ mode: "target", target: "channel:<text-channel-id>" }per fare in modo che il canale vocale agisca come estensione microfono/speaker di una sessione esistente di un canale testuale Discord, ad esempio#maintainers.voice.modelsovrascrive il cervello dell'agente OpenClaw per le risposte vocali Discord e le consultazioni realtime. Lascialo non impostato per ereditare il modello dell'agente instradato. È separato davoice.realtime.model.voice.followUsersconsente al bot di entrare, spostarsi e uscire dalla voce Discord con utenti selezionati. Vedi Segui utenti in voce per regole di comportamento ed esempi.agent-proxyinstrada il parlato tramitediscord-voice, che preserva la normale autorizzazione proprietario/strumenti per lo speaker e la sessione di destinazione ma nasconde lo strumento agentettsperché la voce Discord possiede la riproduzione. Per impostazione predefinita,agent-proxyconcede alla consultazione accesso completo agli strumenti equivalente al proprietario per gli speaker proprietari (voice.realtime.toolPolicy: "owner") e preferisce fortemente consultare l'agente OpenClaw prima delle risposte sostanziali (voice.realtime.consultPolicy: "always"). In quella modalità predefinitaalways, il livello realtime non pronuncia automaticamente riempitivi prima della risposta della consultazione; cattura e trascrive il parlato, poi pronuncia la risposta OpenClaw instradata. Se più risposte di consultazione forzata terminano mentre Discord sta ancora riproducendo la prima risposta, le risposte vocali esatte successive vengono accodate fino a quando la riproduzione è inattiva invece di sostituire il parlato a metà frase.- In modalità
stt-tts, STT usatools.media.audio;voice.modelnon influisce sulla trascrizione. - Nelle modalità realtime,
voice.realtime.provider,voice.realtime.modelevoice.realtime.speakerVoiceconfigurano la sessione audio realtime. Per OpenAI Realtime 2 più il cervello Codex, usavoice.realtime.model: "gpt-realtime-2"evoice.model: "openai/gpt-5.5". - Le modalità vocali realtime includono per impostazione predefinita piccoli file profilo
IDENTITY.md,USER.mdeSOUL.mdnelle istruzioni del provider realtime, così i turni diretti rapidi mantengono la stessa identità, lo stesso radicamento utente e la stessa persona dell'agente OpenClaw instradato. Impostavoice.realtime.bootstrapContextFilessu un sottoinsieme per personalizzarlo, oppure[]per disabilitarlo. I file di bootstrap realtime supportati sono limitati a quei file profilo;AGENTS.mdresta nel normale contesto dell'agente. Il contesto profilo iniettato non sostituisceopenclaw_agent_consultper lavoro nell'area di lavoro, fatti correnti, consultazione della memoria o azioni basate su strumenti. - Nella modalità realtime OpenAI
agent-proxy, impostavoice.realtime.requireWakeName: trueper mantenere silenziosa la voce realtime Discord finché una trascrizione non inizia o finisce con un nome di attivazione. I nomi di attivazione configurati devono essere di una o due parole. Sevoice.realtime.wakeNamesnon è impostato, OpenClaw usa ilnamedell'agente instradato piùOpenClaw, con fallback all'id dell'agente piùOpenClaw. Il gate tramite nome di attivazione disabilita la risposta automatica del provider realtime, instrada i turni accettati attraverso il percorso di consultazione dell'agente OpenClaw e dà un breve riconoscimento parlato quando un nome di attivazione iniziale viene riconosciuto dalla trascrizione parziale prima dell'arrivo della trascrizione finale. - Il provider realtime OpenAI accetta i nomi evento correnti di Realtime 2 e gli alias legacy compatibili con Codex per eventi audio di output e trascrizione, così gli snapshot del provider compatibili possono divergere senza perdere l'audio dell'assistente.
voice.realtime.bargeIncontrolla se gli eventi di inizio parlato dello speaker Discord interrompono la riproduzione realtime attiva. Se non impostato, segue l'impostazione di interruzione audio di input del provider realtime.voice.realtime.minBargeInAudioEndMscontrolla la durata minima della riproduzione dell'assistente prima che un barge-in realtime OpenAI tronchi l'audio. Valore predefinito:250. Imposta0per interruzione immediata in stanze con poca eco, oppure aumentalo per configurazioni speaker con molta eco.- Per una voce OpenAI sulla riproduzione Discord, imposta
voice.tts.provider: "openai"e scegli una voce Text-to-speech sottovoice.tts.providers.openai.speakerVoice.cedarè una buona scelta dal suono maschile sull'attuale modello TTS OpenAI. - Le sovrascritture Discord
systemPromptper canale si applicano ai turni di trascrizione vocale per quel canale vocale. - I turni di trascrizione vocale derivano lo stato di proprietario da Discord
allowFrom(odm.allowFrom) per comandi protetti da proprietario e azioni del canale. La visibilità degli strumenti agente segue la policy strumenti configurata per la sessione instradata. - La voce Discord è opt-in per le configurazioni solo testo; imposta
channels.discord.voice.enabled=true(oppure mantieni un bloccochannels.discord.voiceesistente) per abilitare i comandi/vc, il runtime vocale e l'intent GatewayGuildVoiceStates. channels.discord.intents.voiceStatespuò sovrascrivere esplicitamente la sottoscrizione all'intent dello stato vocale. Lascialo non impostato perché l'intent segua l'abilitazione effettiva della voce.- Se
voice.autoJoinha più voci per la stessa guild, OpenClaw entra nell'ultimo canale configurato per quella guild. voice.allowedChannelsè una allowlist di permanenza opzionale. Lasciala non impostata per consentire/vc joinin qualsiasi canale vocale Discord autorizzato. Quando è impostata,/vc join, l'auto-join all'avvio e gli spostamenti dello stato vocale del bot sono limitati alle voci{ guildId, channelId }elencate. Impostala su un array vuoto per negare tutti gli ingressi vocali Discord. Se Discord sposta il bot fuori dalla allowlist, OpenClaw lascia quel canale e rientra nella destinazione di auto-join configurata quando disponibile.voice.daveEncryptionevoice.decryptionFailureTolerancevengono passati alle opzioni di join di@discordjs/voice.- I valori predefiniti di
@discordjs/voicesonodaveEncryption=trueedecryptionFailureTolerance=24se non impostati. - OpenClaw usa il codec
libopus-wasmincluso per la ricezione vocale Discord e la riproduzione PCM grezza realtime. Distribuisce una build WebAssembly libopus fissata e non richiede addon opus nativi. voice.connectTimeoutMscontrolla l'attesa iniziale Ready di@discordjs/voiceper/vc joine i tentativi di auto-join. Valore predefinito:30000.voice.reconnectGraceMscontrolla per quanto tempo OpenClaw attende che una sessione vocale disconnessa inizi la riconnessione prima di distruggerla. Valore predefinito:15000.- In modalità
stt-tts, la riproduzione vocale non si ferma solo perché un altro utente inizia a parlare. Per evitare loop di feedback, OpenClaw ignora la nuova cattura vocale mentre TTS è in riproduzione; parla dopo la fine della riproduzione per il turno successivo. Le modalità realtime inoltrano gli inizi parlato degli speaker come segnali di barge-in al provider realtime. - Nelle modalità realtime, l'eco dagli speaker verso un microfono aperto può sembrare un barge-in e interrompere la riproduzione. Per stanze Discord con molta eco, imposta
voice.realtime.providers.openai.interruptResponseOnInputAudio: falseper impedire a OpenAI di interrompere automaticamente sull'audio di input. Aggiungivoice.realtime.bargeIn: truese vuoi comunque che gli eventi di inizio parlato degli speaker Discord interrompano la riproduzione attiva. Il bridge realtime OpenAI ignora i troncamenti di riproduzione più brevi divoice.realtime.minBargeInAudioEndMscome probabile eco/rumore e li registra come saltati invece di cancellare la riproduzione Discord. voice.captureSilenceGraceMscontrolla per quanto tempo OpenClaw attende dopo che Discord segnala che uno speaker ha smesso prima di finalizzare quel segmento audio per STT. Valore predefinito:2000; aumentalo se Discord divide pause normali in trascrizioni parziali frammentate.- Quando ElevenLabs è il provider TTS selezionato, la riproduzione vocale Discord usa TTS in streaming e parte dallo stream di risposta del provider. I provider senza supporto streaming ripiegano sul percorso del file temporaneo sintetizzato.
- OpenClaw monitora anche gli errori di decrittazione in ricezione e recupera automaticamente uscendo e rientrando nel canale vocale dopo errori ripetuti in una finestra breve.
- Se i log di ricezione mostrano ripetutamente
DecryptionFailed(UnencryptedWhenPassthroughDisabled)dopo l'aggiornamento, raccogli un report delle dipendenze e i log. La linea@discordjs/voiceinclusa include la correzione upstream del padding dalla PR discord.js #11449, che ha chiuso l'issue discord.js #11419. - Gli eventi di ricezione
The operation was abortedsono attesi quando OpenClaw finalizza un segmento speaker catturato; sono diagnostica dettagliata, non avvisi. - I log dettagliati della voce Discord includono un'anteprima limitata a una riga della trascrizione STT per ogni segmento speaker accettato, così il debug mostra sia il lato utente sia il lato risposta dell'agente senza scaricare testo di trascrizione illimitato.
- In modalità
agent-proxy, il fallback della consultazione forzata salta frammenti di trascrizione probabilmente incompleti, ad esempio testo che termina in...o un connettore finale comeand, più chiusure ovviamente non azionabili come “torno subito” o “ciao”. I log mostranoforced agent consult skipped reason=...quando questo impedisce una risposta accodata obsoleta.
Segui utenti in voce
Usa voice.followUsers quando vuoi che il bot vocale Discord resti con uno o più utenti Discord noti invece di entrare in un canale fisso all'avvio o attendere /vc join.
{ channels: { discord: { voice: { enabled: true, followUsersEnabled: true, followUsers: ["discord:123456789012345678"], allowedChannels: [ { guildId: "123456789012345678", channelId: "234567890123456789", }, ], }, }, },}Comportamento:
followUsersaccetta ID utente Discord grezzi e valoridiscord:<id>. OpenClaw normalizza entrambe le forme prima di confrontare gli eventi di stato vocale.followUsersEnabledè predefinito atruequandofollowUsersè configurato. Impostalo sufalseper mantenere l'elenco salvato ma interrompere il seguito vocale automatico.- Quando un utente seguito entra in un canale vocale consentito, OpenClaw entra in quel canale. Quando l'utente si sposta, OpenClaw si sposta con lui. Quando l'utente seguito attivo si disconnette, OpenClaw esce.
- Se più utenti seguiti sono nella stessa guild e l'utente seguito attivo esce, OpenClaw si sposta nel canale di un altro utente seguito tracciato prima di uscire dalla guild. Se più utenti seguiti si spostano contemporaneamente, vince l'ultimo evento di stato vocale osservato.
allowedChannelssi applica comunque. Un utente seguito in un canale non consentito viene ignorato, e una sessione posseduta dal seguito si sposta a un altro utente seguito o esce.- OpenClaw riconcilia gli eventi di stato vocale mancati all'avvio e a un intervallo limitato. La riconciliazione campiona le guild configurate e limita le ricerche REST per esecuzione, quindi elenchi
followUsersmolto grandi possono richiedere più di un intervallo per convergere. - Se Discord o un amministratore sposta il bot mentre sta seguendo un utente, OpenClaw ricostruisce la sessione vocale e preserva la proprietà del seguito quando la destinazione è consentita. Se il bot viene spostato fuori da
allowedChannels, OpenClaw esce e rientra nella destinazione configurata quando ne esiste una. - Il recupero ricezione DAVE può uscire e rientrare nello stesso canale dopo errori di decrittazione ripetuti. Le sessioni possedute dal seguito mantengono la loro proprietà del seguito attraverso quel percorso di recupero, quindi una successiva disconnessione dell'utente seguito lascia comunque il canale.
Scegli tra le modalità di ingresso:
- Usa
followUsersper configurazioni personali o operative in cui il bot dovrebbe essere automaticamente in voce quando lo sei tu. - Usa
autoJoinper bot di stanze fisse che dovrebbero essere presenti anche quando nessun utente tracciato è in voce. - Usa
/vc joinper ingressi una tantum o stanze in cui la presenza vocale automatica sarebbe sorprendente.
Codec vocale Discord:
- I log di ricezione vocale mostrano
discord voice: opus decoder: libopus-wasm. - La riproduzione in tempo reale codifica PCM stereo grezzo a 48 kHz in Opus con lo stesso pacchetto
libopus-wasmincluso prima di passare i pacchetti a@discordjs/voice. - La riproduzione di file e stream del provider transcodifica in PCM stereo grezzo a 48 kHz con ffmpeg, poi usa
libopus-wasmper lo stream di pacchetti Opus inviato a Discord.
Pipeline STT più TTS:
- L'acquisizione PCM di Discord viene convertita in un file temporaneo WAV.
tools.media.audiogestisce STT, per esempioopenai/gpt-4o-mini-transcribe.- La trascrizione viene inviata tramite ingresso e routing Discord mentre l'LLM di risposta viene eseguito con una policy di output vocale che nasconde lo strumento
ttsdell'agente e richiede testo restituito, perché Discord voice possiede la riproduzione TTS finale. voice.model, quando impostato, sovrascrive solo l'LLM di risposta per questo turno del canale vocale.voice.ttsviene unito sopramessages.tts; i provider con supporto allo streaming alimentano direttamente il player, altrimenti il file audio risultante viene riprodotto nel canale a cui si è uniti.
Esempio di sessione del canale vocale agent-proxy predefinita:
{ channels: { discord: { voice: { enabled: true, model: "openai/gpt-5.5", followUsersEnabled: true, followUsers: ["123456789012345678"], realtime: { provider: "openai", model: "gpt-realtime-2", speakerVoice: "cedar", }, }, }, },}Senza un blocco voice.agentSession, ogni canale vocale ottiene la propria sessione OpenClaw instradata. Per esempio, /vc join channel:234567890123456789 parla con la sessione per quel canale vocale Discord. Il modello in tempo reale è solo il front end vocale; le richieste sostanziali vengono passate all'agente OpenClaw configurato. Se il modello in tempo reale produce una trascrizione finale senza chiamare lo strumento di consultazione, OpenClaw forza la consultazione come fallback, così il comportamento predefinito resta quello di parlare con l'agente.
Esempio legacy STT più TTS:
{ channels: { discord: { voice: { enabled: true, mode: "stt-tts", model: "openai/gpt-5.4-mini", tts: { provider: "openai", providers: { openai: { model: "gpt-4o-mini-tts", speakerVoice: "cedar", }, }, }, }, }, },}Esempio bidi in tempo reale:
{ channels: { discord: { voice: { enabled: true, mode: "bidi", model: "openai/gpt-5.5", realtime: { provider: "openai", model: "gpt-realtime-2", speakerVoice: "cedar", toolPolicy: "safe-read-only", consultPolicy: "always", }, }, }, },}Voce come estensione di una sessione di canale Discord esistente:
{ channels: { discord: { voice: { enabled: true, mode: "agent-proxy", model: "openai/gpt-5.5", agentSession: { mode: "target", target: "channel:123456789012345678", }, realtime: { provider: "openai", model: "gpt-realtime-2", speakerVoice: "cedar", }, }, }, },}In modalità agent-proxy, il bot entra nel canale vocale configurato, ma i turni dell'agente OpenClaw usano la sessione instradata normale del canale di destinazione e il relativo agente. La sessione vocale in tempo reale pronuncia il risultato restituito nel canale vocale. L'agente supervisore può comunque usare i normali strumenti di messaggistica secondo la propria policy degli strumenti, incluso l'invio di un messaggio Discord separato se questa è l'azione corretta.
Mentre è attiva un'esecuzione OpenClaw delegata, le nuove trascrizioni vocali Discord vengono trattate come controllo dell'esecuzione live prima di avviare un altro turno dell'agente. Frasi come "status", "cancel that", "use the smaller fix" o "when you're done also check tests" vengono classificate come input di stato, annullamento, guida o follow-up per la sessione attiva. Gli esiti di stato, annullamento, guida accettata e follow-up vengono pronunciati nel canale vocale, così chi chiama sa se OpenClaw ha gestito la richiesta.
Forme di destinazione utili:
target: "channel:123456789012345678"instrada tramite una sessione di canale testuale Discord.target: "123456789012345678"viene trattato come destinazione di canale.target: "dm:123456789012345678"otarget: "user:123456789012345678"instrada tramite quella sessione di messaggio diretto.
Esempio OpenAI Realtime con molto eco:
{ channels: { discord: { voice: { enabled: true, mode: "bidi", model: "openai/gpt-5.5", realtime: { provider: "openai", model: "gpt-realtime-2", speakerVoice: "cedar", bargeIn: true, minBargeInAudioEndMs: 500, consultPolicy: "always", providers: { openai: { interruptResponseOnInputAudio: false, }, }, }, }, }, },}Usalo quando il modello sente la propria riproduzione Discord attraverso un microfono aperto, ma vuoi comunque interromperlo parlando. OpenClaw impedisce a OpenAI di interrompere automaticamente sull'audio di input grezzo, mentre bargeIn: true consente agli eventi di avvio parlante Discord e all'audio di un parlante già attivo di annullare le risposte in tempo reale attive prima che il turno acquisito successivo raggiunga OpenAI. I segnali di interruzione molto precoci con audioEndMs inferiore a minBargeInAudioEndMs vengono trattati come probabile eco/rumore e ignorati, così il modello non si interrompe al primo frame di riproduzione.
Log vocali attesi:
- All'ingresso:
discord voice: joining ... voiceSession=... supervisorSession=... agentSessionMode=... voiceModel=... realtimeModel=... - All'avvio in tempo reale:
discord voice: realtime bridge starting ... autoRespond=false interruptResponse=false bargeIn=false minBargeInAudioEndMs=... - Sull'audio del parlante:
discord voice: realtime speaker turn opened ...,discord voice: realtime input audio started ... outputAudioMs=... outputActive=...ediscord voice: realtime speaker turn closed ... chunks=... discordBytes=... realtimeBytes=... interruptedPlayback=... - Sul parlato obsoleto saltato:
discord voice: realtime forced agent consult skipped reason=incomplete-transcript ...oreason=non-actionable-closing ... - Al completamento della risposta in tempo reale:
discord voice: realtime audio playback finishing reason=response.done ... audioMs=... chunks=... - All'arresto/ripristino della riproduzione:
discord voice: realtime audio playback stopped reason=... audioMs=... elapsedMs=... chunks=... - Sulla consultazione in tempo reale:
discord voice: realtime consult requested ... voiceSession=... supervisorSession=... question=... - Alla risposta dell'agente:
discord voice: agent turn answer ... - Sul parlato esatto accodato:
discord voice: realtime exact speech queued ... queued=... outputAudioMs=... outputActive=..., seguito dadiscord voice: realtime exact speech dequeued reason=player-idle ... - Al rilevamento di interruzione:
discord voice: realtime barge-in detected source=speaker-start ...odiscord voice: realtime barge-in detected source=active-speaker-audio ..., seguito dadiscord voice: realtime barge-in requested reason=... outputAudioMs=... outputActive=... - All'interruzione in tempo reale:
discord voice: realtime model interrupt requested client:response.cancel reason=barge-in, seguito dadiscord voice: realtime model audio truncated client:conversation.item.truncate reason=barge-in audioEndMs=...oppurediscord voice: realtime model interrupt confirmed server:response.done status=cancelled ... - Su eco/rumore ignorati:
discord voice: realtime model interrupt ignored client:conversation.item.truncate.skipped reason=barge-in audioEndMs=0 minAudioEndMs=250 - Con interruzione disabilitata:
discord voice: realtime capture ignored during playback (barge-in disabled) ... - Con riproduzione inattiva:
discord voice: realtime barge-in ignored reason=... outputActive=false ... playbackChunks=0
Per eseguire il debug di audio tagliato, leggi i log vocali in tempo reale come una cronologia:
realtime audio playback startedsignifica che Discord ha iniziato a riprodurre l'audio dell'assistente. Da questo punto il bridge inizia a contare i chunk di output dell'assistente, i byte PCM Discord, i byte in tempo reale del provider e la durata dell'audio sintetizzato.realtime speaker turn openedindica che un parlante Discord diventa attivo. Se la riproduzione è già attiva ebargeInè abilitato, questo può essere seguito dabarge-in detected source=speaker-start.realtime input audio startedindica il primo frame audio effettivo ricevuto per quel turno del parlante.outputActive=trueo unoutputAudioMsdiverso da zero qui significa che il microfono sta inviando input mentre la riproduzione dell'assistente è ancora attiva.barge-in detected source=active-speaker-audiosignifica che OpenClaw ha visto audio live del parlante mentre la riproduzione dell'assistente era attiva. Questo è utile per distinguere una vera interruzione da un evento Discord di avvio parlante senza audio utile.barge-in requested reason=...significa che OpenClaw ha chiesto al provider in tempo reale di annullare o troncare la risposta attiva. IncludeoutputAudioMs,outputActiveeplaybackChunkscosì puoi vedere quanto audio dell'assistente era stato effettivamente riprodotto prima dell'interruzione.realtime audio playback stopped reason=...è il punto locale di ripristino della riproduzione Discord. Il motivo dice chi ha fermato la riproduzione:barge-in,player-idle,provider-clear-audio,forced-agent-consult,stream-closeosession-close.realtime speaker turn closedriepiloga il turno di input acquisito.chunks=0ohasAudio=falsesignifica che il turno del parlante si è aperto ma nessun audio utilizzabile ha raggiunto il bridge in tempo reale.interruptedPlayback=truesignifica che quel turno di input si è sovrapposto all'output dell'assistente e ha attivato la logica di interruzione.
Campi utili:
outputAudioMs: durata dell'audio dell'assistente generato dal provider in tempo reale prima della riga di log.audioMs: durata dell'audio dell'assistente conteggiata da OpenClaw prima che la riproduzione si fermasse.elapsedMs: tempo wall-clock tra l'apertura e la chiusura dello stream di riproduzione o del turno del parlante.discordBytes: byte PCM stereo a 48 kHz inviati a o ricevuti da Discord voice.realtimeBytes: byte PCM nel formato del provider inviati a o ricevuti dal provider in tempo reale.playbackChunks: chunk audio dell'assistente inoltrati a Discord per la risposta attiva.sinceLastAudioMs: intervallo tra l'ultimo frame audio acquisito del parlante e la chiusura del turno del parlante.
Pattern comuni:
- Taglio immediato con
source=active-speaker-audio,outputAudioMspiccolo e lo stesso utente nelle vicinanze di solito indica eco dell'altoparlante che entra nel microfono. Aumentavoice.realtime.minBargeInAudioEndMs, abbassa il volume dell'altoparlante, usa cuffie oppure impostavoice.realtime.providers.openai.interruptResponseOnInputAudio: false. source=speaker-startseguito daspeaker turn closed ... hasAudio=falsesignifica che Discord ha segnalato l'avvio di un parlante ma nessun audio ha raggiunto OpenClaw. Può trattarsi di un evento vocale Discord transitorio, del comportamento del noise gate o di un client che attiva brevemente il microfono.audio playback stopped reason=stream-closesenza una vicina interruzione oprovider-clear-audiosignifica che lo stream di riproduzione Discord locale è terminato in modo imprevisto. Controlla i log precedenti del provider e del player Discord.capture ignored during playback (barge-in disabled)significa che OpenClaw ha scartato intenzionalmente l'input mentre l'audio dell'assistente era attivo. Abilitavoice.realtime.bargeInse vuoi che il parlato interrompa la riproduzione.barge-in ignored ... outputActive=falsesignifica che Discord o il VAD del provider ha segnalato parlato, ma OpenClaw non aveva alcuna riproduzione attiva da interrompere. Questo non dovrebbe tagliare l'audio.
Le credenziali vengono risolte per componente: autenticazione del route LLM per voice.model, autenticazione STT per tools.media.audio, autenticazione TTS per messages.tts/voice.tts e autenticazione del provider in tempo reale per voice.realtime.providers o la normale configurazione di autenticazione del provider.
Messaggi vocali
I messaggi vocali Discord mostrano un'anteprima della forma d'onda e richiedono audio OGG/Opus. OpenClaw genera automaticamente la forma d'onda, ma ha bisogno di ffmpeg e ffprobe sull'host del Gateway per ispezionare e convertire.
- Fornisci un percorso file locale (gli URL vengono rifiutati).
- Ometti il contenuto testuale (Discord rifiuta testo + messaggio vocale nello stesso payload).
- Qualsiasi formato audio è accettato; OpenClaw converte in OGG/Opus secondo necessità.
message(action="send", channel="discord", target="channel:123", path="/path/to/audio.mp3", asVoice=true)Risoluzione dei problemi
Intent non consentiti usati o il bot non vede messaggi della gilda
- abilita Message Content Intent
- abilita Server Members Intent quando dipendi dalla risoluzione di utenti/membri
- riavvia il Gateway dopo aver modificato gli intent
Messaggi della gilda bloccati in modo imprevisto
- verifica
groupPolicy - verifica l'allowlist della gilda in
channels.discord.guilds - se esiste la mappa
channelsdella gilda, sono consentiti solo i canali elencati - verifica il comportamento di
requireMentione i pattern di menzione
Controlli utili:
openclaw doctoropenclaw channels status --probeopenclaw logs --followMenzione obbligatoria false ma ancora bloccato
Cause comuni:
groupPolicy="allowlist"senza allowlist di gilda/canale corrispondenterequireMentionconfigurato nel posto sbagliato (deve essere inchannels.discord.guildso nella voce del canale)- mittente bloccato dall'allowlist
usersdella gilda/del canale
Turni Discord lunghi o risposte duplicate
Log tipici:
Slow listener detected ...stuck session: sessionKey=agent:...:discord:... state=processing ...
Parametri della coda del Gateway Discord:
- account singolo:
channels.discord.eventQueue.listenerTimeout - multi-account:
channels.discord.accounts.<accountId>.eventQueue.listenerTimeout - questo controlla solo il lavoro del listener del Gateway Discord, non la durata del turno dell'agente
Discord non applica un timeout di proprietà del canale ai turni agente in coda. I listener dei messaggi passano subito il controllo, e le esecuzioni Discord in coda conservano l'ordine per sessione finché il ciclo di vita di sessione/strumento/runtime completa o interrompe il lavoro.
{channels: {discord: { accounts: { default: { eventQueue: { listenerTimeout: 120000, }, }, },},},}Avvisi di timeout nella ricerca dei metadati del Gateway
OpenClaw recupera i metadati Discord /gateway/bot prima di connettersi. Gli errori transitori ricadono sull'URL Gateway predefinito di Discord e sono limitati nei log.
Parametri di timeout dei metadati:
- account singolo:
channels.discord.gatewayInfoTimeoutMs - multi-account:
channels.discord.accounts.<accountId>.gatewayInfoTimeoutMs - fallback env quando la configurazione non è impostata:
OPENCLAW_DISCORD_GATEWAY_INFO_TIMEOUT_MS - predefinito:
30000(30 secondi), max:120000
Riavvii per timeout READY del Gateway
OpenClaw attende l'evento READY del Gateway Discord durante l'avvio e dopo le riconnessioni runtime. Le configurazioni multi-account con scaglionamento all'avvio possono richiedere una finestra READY di avvio più lunga di quella predefinita.
Parametri di timeout READY:
- avvio account singolo:
channels.discord.gatewayReadyTimeoutMs - avvio multi-account:
channels.discord.accounts.<accountId>.gatewayReadyTimeoutMs - fallback env di avvio quando la configurazione non è impostata:
OPENCLAW_DISCORD_READY_TIMEOUT_MS - predefinito avvio:
15000(15 secondi), max:120000 - runtime account singolo:
channels.discord.gatewayRuntimeReadyTimeoutMs - runtime multi-account:
channels.discord.accounts.<accountId>.gatewayRuntimeReadyTimeoutMs - fallback env runtime quando la configurazione non è impostata:
OPENCLAW_DISCORD_RUNTIME_READY_TIMEOUT_MS - predefinito runtime:
30000(30 secondi), max:120000
Disallineamenti nell'audit dei permessi
I controlli dei permessi di channels status --probe funzionano solo per ID canale numerici.
Se usi chiavi slug, la corrispondenza runtime può comunque funzionare, ma il probe non può verificare completamente i permessi.
Problemi di DM e pairing
- DM disabilitato:
channels.discord.dm.enabled=false - policy DM disabilitata:
channels.discord.dmPolicy="disabled"(legacy:channels.discord.dm.policy) - in attesa dell'approvazione del pairing in modalità
pairing
Loop da bot a bot
Per impostazione predefinita, i messaggi scritti dai bot vengono ignorati.
Se imposti channels.discord.allowBots=true, usa regole di menzione e allowlist rigorose per evitare comportamenti di loop.
Preferisci channels.discord.allowBots="mentions" per accettare solo messaggi di bot che menzionano il bot.
OpenClaw include anche una protezione dai loop dei bot condivisa. Ogni volta che allowBots consente ai messaggi scritti dai bot di arrivare al dispatch, Discord mappa l'evento in ingresso sui fatti (account, channel, bot pair) e la guardia generica della coppia sopprime la coppia dopo che supera il budget di eventi configurato. La guardia impedisce loop incontrollati tra due bot che prima dovevano essere fermati dai limiti di frequenza di Discord; non influisce sulle distribuzioni con un singolo bot o sulle risposte bot singole che restano sotto il budget.
Impostazioni predefinite (attive quando allowBots è impostato):
maxEventsPerWindow: 20-- la coppia di bot può scambiare 20 messaggi nella finestra scorrevolewindowSeconds: 60-- durata della finestra scorrevolecooldownSeconds: 60-- una volta superato il budget, ogni ulteriore messaggio da bot a bot in entrambe le direzioni viene scartato per un minuto
Configura una volta il valore predefinito condiviso in channels.defaults.botLoopProtection, poi sovrascrivi Discord quando un workflow legittimo necessita di più margine. La precedenza è:
channels.discord.accounts.<account>.botLoopProtectionchannels.discord.botLoopProtectionchannels.defaults.botLoopProtection- impostazioni predefinite integrate
Discord usa le chiavi generiche maxEventsPerWindow, windowSeconds e cooldownSeconds.
{channels: {defaults: { botLoopProtection: { maxEventsPerWindow: 20, windowSeconds: 60, cooldownSeconds: 60, },},discord: { // Optional Discord-wide override. Account blocks override individual // fields and inherit omitted fields from here. botLoopProtection: { maxEventsPerWindow: 4, }, accounts: { mantis: { // Mantis listens to other bots only when they mention her. allowBots: "mentions", }, molty: { // Molty listens to all bot-authored Discord messages. allowBots: true, mentionAliases: { // Lets Molty write a Mantis Discord mention with the configured user id. Mantis: "MANTIS_DISCORD_USER_ID", }, botLoopProtection: { // Allow up to five messages per minute before suppressing the pair. maxEventsPerWindow: 5, windowSeconds: 60, cooldownSeconds: 90, }, }, },},},}Cadute STT vocali con DecryptionFailed(...)
- mantieni OpenClaw aggiornato (
openclaw update) così la logica di recupero della ricezione vocale Discord è presente - conferma
channels.discord.voice.daveEncryption=true(predefinito) - parti da
channels.discord.voice.decryptionFailureTolerance=24(predefinito upstream) e regola solo se necessario - osserva i log per:
discord voice: DAVE decrypt failures detecteddiscord voice: repeated decrypt failures; attempting rejoin
- se gli errori continuano dopo il rientro automatico, raccogli i log e confrontali con la cronologia upstream di ricezione DAVE in discord.js #11419 e discord.js #11449
Riferimento di configurazione
Riferimento principale: Riferimento di configurazione - Discord.
Campi Discord ad alto segnale
- avvio/auth:
enabled,token,accounts.*,allowBots - policy:
groupPolicy,dm.*,guilds.*,guilds.*.channels.* - comando:
commands.native,commands.useAccessGroups,configWrites,slashCommand.* - coda eventi:
eventQueue.listenerTimeout(budget listener),eventQueue.maxQueueSize,eventQueue.maxConcurrency - Gateway:
gatewayInfoTimeoutMs,gatewayReadyTimeoutMs,gatewayRuntimeReadyTimeoutMs - risposta/cronologia:
replyToMode,historyLimit,dmHistoryLimit,dms.*.historyLimit - consegna:
textChunkLimit,chunkMode,maxLinesPerMessage - streaming:
streaming(alias legacy:streamMode),streaming.preview.toolProgress,draftChunk,blockStreaming,blockStreamingCoalesce - media/riprova:
mediaMaxMb(limita gli upload Discord in uscita, predefinito100MB),retry - azioni:
actions.* - presenza:
activity,status,activityType,activityUrl - UI:
ui.components.accentColor - funzionalità:
threadBindings,bindings[]di primo livello (type: "acp"),pluralkit,execApprovals,intents,agentComponents.enabled,agentComponents.ttlMs,heartbeat,responsePrefix
Sicurezza e operazioni
- Tratta i token bot come segreti (
DISCORD_BOT_TOKENpreferito in ambienti supervisionati). - Concedi i permessi Discord con privilegio minimo.
- Se deploy/stato dei comandi è obsoleto, riavvia il Gateway e ricontrolla con
openclaw channels status --probe.
Correlati
Associa un utente Discord al Gateway.
Chat di gruppo e comportamento dell'allowlist.
Instrada i messaggi in ingresso agli agenti.
Modello di minaccia e hardening.
Mappa gilde e canali sugli agenti.
Comportamento dei comandi nativi.