Discord (Bot API)
Status: pronto para DMs e canais de servidor via gateway oficial do Discord.Pareamento
Comandos slash
Solução de problemas de canais
Configuração rápida
Você precisará criar um novo aplicativo com um bot, adicionar o bot ao seu servidor e pareá-lo ao OpenClaw. Recomendamos adicionar seu bot ao seu próprio servidor privado. Se você ainda não tiver um, crie um primeiro (escolha Create My Own > For me and my friends).Criar um aplicativo e bot no Discord
Ativar intents privilegiados
- Message Content Intent (obrigatório)
- Server Members Intent (recomendado; obrigatório para allowlists por função e correspondência de nome para ID)
- Presence Intent (opcional; necessário apenas para atualizações de presença)
Copiar o token do bot
Gerar uma URL de convite e adicionar o bot ao seu servidor
botapplications.commands
- View Channels
- Send Messages
- Read Message History
- Embed Links
- Attach Files
- Add Reactions (opcional)
Ativar o Developer Mode e coletar seus IDs
- Clique em User Settings (ícone de engrenagem ao lado do seu avatar) → Advanced → ative Developer Mode
- Clique com o botão direito no ícone do seu servidor na barra lateral → Copy Server ID
- Clique com o botão direito no seu próprio avatar → Copy User ID
Permitir DMs de membros do servidor
Definir seu token de bot com segurança (não o envie no chat)
openclaw gateway run.Configurar o OpenClaw e fazer o pareamento
- Pedir ao seu agente
- CLI / config
“Já defini meu token do bot do Discord na configuração. Conclua a configuração do Discord com User ID<user_id>e Server ID<server_id>.”
Aprovar o primeiro pareamento por DM
- Pedir ao seu agente
- CLI
“Aprove este código de pareamento do Discord: <CODE>”
DISCORD_BOT_TOKEN é usado apenas para a conta padrão.
Para chamadas avançadas de saída (ferramenta de mensagens/ações de canal), um token explícito por chamada é usado nessa chamada. Isso se aplica a ações de envio e de leitura/sondagem (por exemplo, read/search/fetch/thread/pins/permissions). As configurações de política da conta/tentativa continuam vindo da conta selecionada no snapshot de runtime ativo.Recomendado: configurar um workspace de servidor
Quando as DMs estiverem funcionando, você poderá configurar seu servidor do Discord como um workspace completo, em que cada canal recebe sua própria sessão de agente com seu próprio contexto. Isso é recomendado para servidores privados em que só estão você e seu bot.Adicionar seu servidor à allowlist de servidores
- Pedir ao seu agente
- Config
“Adicione meu Server ID do Discord <server_id> à allowlist de servidores”
Permitir respostas sem @mention
- Pedir ao seu agente
- Config
“Permita que meu agente responda neste servidor sem precisar ser mencionado com @”
Planejar a memória em canais de servidor
- Pedir ao seu agente
- Manual
“Quando eu fizer perguntas em canais do Discord, use memory_search ou memory_get se precisar de contexto de longo prazo de MEMORY.md.”
#coding, #home, #research ou o que fizer sentido para seu fluxo de trabalho.
Modelo de runtime
- O gateway é o proprietário da conexão com o Discord.
- O roteamento de respostas é determinístico: respostas recebidas do Discord voltam para o Discord.
- Por padrão (
session.dmScope=main), conversas diretas compartilham a sessão principal do agente (agent:main:main). - Canais de servidor usam chaves de sessão isoladas (
agent:<agentId>:discord:channel:<channelId>). - DMs em grupo são ignoradas por padrão (
channels.discord.dm.groupEnabled=false). - Comandos slash nativos são executados em sessões de comando isoladas (
agent:<agentId>:discord:slash:<userId>), enquanto ainda carregamCommandTargetSessionKeypara a sessão de conversa roteada.
Canais de fórum
Canais de fórum e mídia do Discord aceitam apenas postagens em threads. O OpenClaw oferece suporte a duas formas de criá-las:- Envie uma mensagem para o pai do fórum (
channel:<forumId>) para criar automaticamente uma thread. O título da thread usa a primeira linha não vazia da sua mensagem. - Use
openclaw message thread createpara criar uma thread diretamente. Não passe--message-idpara canais de fórum.
channel:<threadId>).
Componentes interativos
O OpenClaw oferece suporte a contêineres Discord components v2 para mensagens do agente. Use a ferramenta de mensagens com uma cargacomponents. Os resultados da interação são roteados de volta ao agente como mensagens de entrada normais e seguem as configurações existentes de replyToMode do Discord.
Blocos compatíveis:
text,section,separator,actions,media-gallery,file- Linhas de ação permitem até 5 botões ou um único menu de seleção
- Tipos de seleção:
string,user,role,mentionable,channel
components.reusable=true para permitir que botões, seleções e formulários sejam usados várias vezes até expirarem.
Para restringir quem pode clicar em um botão, defina allowedUsers nesse botão (IDs de usuário do Discord, tags ou *). Quando configurado, usuários não correspondentes recebem uma negação efêmera.
Os comandos slash /model e /models abrem um seletor interativo de modelo com listas suspensas de provedor e modelo, além de uma etapa de envio. A resposta do seletor é efêmera e apenas o usuário que o invocou pode usá-la.
Anexos de arquivo:
- blocos
filedevem apontar para uma referência de anexo (attachment://<filename>) - Forneça o anexo por
media/path/filePath(arquivo único); usemedia-gallerypara vários arquivos - Use
filenamepara substituir o nome do upload quando ele precisar corresponder à referência do anexo
- Adicione
components.modalcom até 5 campos - Tipos de campo:
text,checkbox,radio,select,role-select,user-select - O OpenClaw adiciona automaticamente um botão de acionamento
Controle de acesso e roteamento
- Política de DM
- Política de servidor
- Menções e DMs em grupo
channels.discord.dmPolicy controla o acesso por DM (legado: channels.discord.dm.policy):pairing(padrão)allowlistopen(exige quechannels.discord.allowFrominclua"*"; legado:channels.discord.dm.allowFrom)disabled
pairing).Precedência em múltiplas contas:channels.discord.accounts.default.allowFromse aplica apenas à contadefault.- Contas nomeadas herdam
channels.discord.allowFromquando seu próprioallowFromnão está definido. - Contas nomeadas não herdam
channels.discord.accounts.default.allowFrom.
user:<id>- menção
<@id>
Roteamento de agente baseado em função
Usebindings[].match.roles para rotear membros de servidor do Discord para agentes diferentes por ID de função. Bindings baseados em função aceitam apenas IDs de função e são avaliados após bindings de peer ou peer pai e antes de bindings apenas de servidor. Se um binding também definir outros campos de correspondência (por exemplo peer + guildId + roles), todos os campos configurados devem corresponder.
Configuração do Developer Portal
Criar aplicativo e bot
Criar aplicativo e bot
- Discord Developer Portal -> Applications -> New Application
- Bot -> Add Bot
- Copie o token do bot
Intents privilegiados
Intents privilegiados
- Message Content Intent
- Server Members Intent (recomendado)
setPresence) não exige ativar atualizações de presença para membros.Escopos OAuth e permissões de linha de base
Escopos OAuth e permissões de linha de base
- escopos:
bot,applications.commands
- View Channels
- Send Messages
- Read Message History
- Embed Links
- Attach Files
- Add Reactions (opcional)
Administrator a menos que seja explicitamente necessário.Copiar IDs
Copiar IDs
- ID do servidor
- ID do canal
- ID do usuário
Comandos nativos e autenticação de comandos
commands.nativeusa"auto"por padrão e é ativado para o Discord.- Substituição por canal:
channels.discord.commands.native. commands.native=falselimpa explicitamente comandos nativos do Discord registrados anteriormente.- A autenticação de comandos nativos usa as mesmas allowlists/políticas do Discord que o tratamento normal de mensagens.
- Os comandos ainda podem ficar visíveis na interface do Discord para usuários não autorizados; a execução ainda aplica a autenticação do OpenClaw e retorna “não autorizado”.
ephemeral: true
Detalhes dos recursos
Tags de resposta e respostas nativas
Tags de resposta e respostas nativas
Pré-visualização de streaming ao vivo
Pré-visualização de streaming ao vivo
channels.discord.streamingcontrola o streaming de pré-visualização (off|partial|block|progress, padrão:off).- O padrão continua sendo
offporque edições de pré-visualização no Discord podem atingir limites de taxa rapidamente, especialmente quando vários bots ou gateways compartilham a mesma conta ou tráfego de servidor. progressé aceito para consistência entre canais e mapeia parapartialno Discord.channels.discord.streamModeé um alias legado e é migrado automaticamente.partialedita uma única mensagem de pré-visualização à medida que os tokens chegam.blockemite blocos do tamanho de rascunho (usedraftChunkpara ajustar tamanho e pontos de quebra).
block (limitados por channels.discord.textChunkLimit):Histórico, contexto e comportamento de threads
Histórico, contexto e comportamento de threads
channels.discord.historyLimitpadrão20- fallback:
messages.groupChat.historyLimit 0desativa
channels.discord.dmHistoryLimitchannels.discord.dms["<user_id>"].historyLimit
- threads do Discord são roteadas como sessões de canal
- metadados da thread pai podem ser usados para vinculação à sessão pai
- a configuração da thread herda a configuração do canal pai, a menos que exista uma entrada específica para a thread
Sessões vinculadas a threads para subagentes
Sessões vinculadas a threads para subagentes
/focus <target>vincula a thread atual/nova a um destino de subagente/sessão/unfocusremove o vínculo atual da thread/agentsmostra execuções ativas e estado de vínculo/session idle <duration|off>inspeciona/atualiza o desfoco automático por inatividade para vínculos em foco/session max-age <duration|off>inspeciona/atualiza a idade máxima rígida para vínculos em foco
session.threadBindings.*define padrões globais.channels.discord.threadBindings.*substitui o comportamento do Discord.spawnSubagentSessionsdeve sertruepara criar/vincular automaticamente threads parasessions_spawn({ thread: true }).spawnAcpSessionsdeve sertruepara criar/vincular automaticamente threads para ACP (/acp spawn ... --thread ...ousessions_spawn({ runtime: "acp", thread: true })).- Se vínculos de thread estiverem desativados para uma conta,
/focuse operações relacionadas a vínculo de thread não estarão disponíveis.
Vínculos persistentes de canal ACP
Vínculos persistentes de canal ACP
bindings[]comtype: "acp"ematch.channel: "discord"
/acp spawn codex --bind herevincula o canal ou thread atual do Discord no próprio lugar e mantém mensagens futuras roteadas para a mesma sessão ACP.- Isso ainda pode significar “iniciar uma nova sessão ACP do Codex”, mas não cria uma nova thread do Discord por si só. O canal existente continua sendo a superfície do chat.
- O Codex ainda pode ser executado em seu próprio
cwdou workspace de backend no disco. Esse workspace é estado de runtime, não uma thread do Discord. - Mensagens de thread podem herdar o vínculo ACP do canal pai.
- Em um canal ou thread vinculados,
/newe/resetredefinem a mesma sessão ACP no próprio lugar. - Vínculos temporários de thread ainda funcionam e podem substituir a resolução do destino enquanto estiverem ativos.
spawnAcpSessionsé necessário apenas quando o OpenClaw precisa criar/vincular uma thread filha por--thread auto|here. Não é necessário para/acp spawn ... --bind hereno canal atual.
Notificações de reação
Notificações de reação
offown(padrão)allallowlist(usaguilds.<id>.users)
Reações de confirmação
Reações de confirmação
ackReaction envia um emoji de confirmação enquanto o OpenClaw está processando uma mensagem recebida.Ordem de resolução:channels.discord.accounts.<accountId>.ackReactionchannels.discord.ackReactionmessages.ackReaction- fallback para emoji de identidade do agente (
agents.list[].identity.emoji, caso contrário ”👀”)
- O Discord aceita emoji unicode ou nomes de emoji personalizados.
- Use
""para desativar a reação para um canal ou conta.
Gravações de configuração
Gravações de configuração
/config set|unset (quando os recursos de comando estão ativados).Desativar:Proxy do gateway
Proxy do gateway
channels.discord.proxy.Suporte ao PluralKit
Suporte ao PluralKit
- allowlists podem usar
pk:<memberId> - nomes de exibição de membros são correspondidos por nome/slug apenas quando
channels.discord.dangerouslyAllowNameMatching: true - buscas usam o ID da mensagem original e são limitadas por janela de tempo
- se a busca falhar, mensagens com proxy são tratadas como mensagens de bot e descartadas, a menos que
allowBots=true
Configuração de presença
Configuração de presença
- 0: Jogando
- 1: Transmitindo (exige
activityUrl) - 2: Ouvindo
- 3: Assistindo
- 4: Personalizado (usa o texto da atividade como estado de status; emoji é opcional)
- 5: Competindo
autoPresence.healthyTextautoPresence.degradedTextautoPresence.exhaustedText(compatível com placeholder{reason})
Aprovações no Discord
Aprovações no Discord
channels.discord.execApprovals.enabledchannels.discord.execApprovals.approvers(opcional; usa fallback paracommands.ownerAllowFromquando possível)channels.discord.execApprovals.target(dm|channel|both, padrão:dm)agentFilter,sessionFilter,cleanupAfterResolve
enabled não está definido ou é "auto" e pelo menos um aprovador pode ser resolvido, seja de execApprovals.approvers ou de commands.ownerAllowFrom. O Discord não infere aprovadores de execução a partir de allowFrom do canal, dm.allowFrom legado ou defaultTo de mensagem direta. Defina enabled: false para desativar explicitamente o Discord como cliente nativo de aprovação.Quando target é channel ou both, o prompt de aprovação fica visível no canal. Apenas aprovadores resolvidos podem usar os botões; outros usuários recebem uma negação efêmera. Prompts de aprovação incluem o texto do comando, portanto ative a entrega no canal apenas em canais confiáveis. Se o ID do canal não puder ser derivado da chave da sessão, o OpenClaw faz fallback para entrega por DM.O Discord também renderiza os botões de aprovação compartilhados usados por outros canais de chat. O adaptador nativo do Discord adiciona principalmente o roteamento de DM de aprovadores e o fanout para o canal.
Quando esses botões estão presentes, eles são a UX principal de aprovação; o OpenClaw
só deve incluir um comando manual /approve quando o resultado da ferramenta disser
que aprovações por chat não estão disponíveis ou que a aprovação manual é o único caminho.A autenticação do gateway para esse manipulador usa o mesmo contrato compartilhado de resolução de credenciais que outros clientes do Gateway:- autenticação local com prioridade para env (
OPENCLAW_GATEWAY_TOKEN/OPENCLAW_GATEWAY_PASSWORDe depoisgateway.auth.*) - no modo local,
gateway.remote.*pode ser usado como fallback apenas quandogateway.auth.*não está definido; SecretRefs locais configurados, mas não resolvidos, falham de forma fechada - suporte a modo remoto via
gateway.remote.*quando aplicável - substituições de URL são seguras para override: overrides de CLI não reutilizam credenciais implícitas, e overrides de env usam apenas credenciais de env
- IDs com prefixo
plugin:são resolvidos porplugin.approval.resolve. - Outros IDs são resolvidos por
exec.approval.resolve. - O Discord não faz aqui um salto extra de fallback de execução para plugin; o prefixo do ID decide qual método de gateway ele chama.
Ferramentas e gates de ação
As ações de mensagem do Discord incluem mensagens, administração de canal, moderação, presença e ações de metadados. Exemplos principais:- mensagens:
sendMessage,readMessages,editMessage,deleteMessage,threadReply - reações:
react,reactions,emojiList - moderação:
timeout,kick,ban - presença:
setPresence
channels.discord.actions.*.
Comportamento padrão dos gates:
| Grupo de ação | Padrão |
|---|---|
| reactions, messages, threads, pins, polls, search, memberInfo, roleInfo, channelInfo, channels, voiceStatus, events, stickers, emojiUploads, stickerUploads, permissions | ativado |
| roles | desativado |
| moderation | desativado |
| presence | desativado |
Interface components v2
O OpenClaw usa Discord components v2 para aprovações de execução e marcadores entre contextos. Ações de mensagem do Discord também podem aceitarcomponents para interface personalizada (avançado; exige a construção de uma carga de componente pela ferramenta Discord), enquanto embeds legados continuam disponíveis, mas não são recomendados.
channels.discord.ui.components.accentColordefine a cor de destaque usada por contêineres de componentes do Discord (hex).- Defina por conta com
channels.discord.accounts.<id>.ui.components.accentColor. embedssão ignorados quando components v2 estão presentes.
Canais de voz
O OpenClaw pode entrar em canais de voz do Discord para conversas contínuas em tempo real. Isso é separado de anexos de mensagem de voz. Requisitos:- Ative comandos nativos (
commands.nativeouchannels.discord.commands.native). - Configure
channels.discord.voice. - O bot precisa das permissões Connect + Speak no canal de voz de destino.
/vc join|leave|status para controlar sessões. O comando usa o agente padrão da conta e segue as mesmas regras de allowlist e política de grupo que outros comandos do Discord.
Exemplo de entrada automática:
voice.ttssubstituimessages.ttsapenas para reprodução de voz.- Voltas de transcrição de voz derivam o status de proprietário de
allowFromdo Discord (oudm.allowFrom); locutores que não são proprietários não podem acessar ferramentas exclusivas de proprietário (por exemplogatewayecron). - Voz é ativada por padrão; defina
channels.discord.voice.enabled=falsepara desativá-la. voice.daveEncryptionevoice.decryptionFailureTolerancesão repassados para opções de entrada de@discordjs/voice.- Os padrões de
@discordjs/voicesãodaveEncryption=trueedecryptionFailureTolerance=24quando não definidos. - O OpenClaw também monitora falhas de descriptografia na recepção e se recupera automaticamente saindo e entrando novamente no canal de voz após falhas repetidas em uma janela curta.
- Se os logs de recepção mostrarem repetidamente
DecryptionFailed(UnencryptedWhenPassthroughDisabled), isso pode ser o bug de recepção upstream de@discordjs/voiceregistrado em discord.js #11419.
Mensagens de voz
Mensagens de voz do Discord exibem uma prévia de forma de onda e exigem áudio OGG/Opus mais metadados. O OpenClaw gera a forma de onda automaticamente, mas precisa deffmpeg e ffprobe disponíveis no host do gateway para inspecionar e converter arquivos de áudio.
Requisitos e restrições:
- Forneça um caminho de arquivo local (URLs são rejeitadas).
- Omita conteúdo de texto (o Discord não permite texto + mensagem de voz na mesma carga).
- Qualquer formato de áudio é aceito; o OpenClaw converte para OGG/Opus quando necessário.
Solução de problemas
Usou intents não permitidos ou o bot não vê mensagens de servidor
Usou intents não permitidos ou o bot não vê mensagens de servidor
- ative Message Content Intent
- ative Server Members Intent quando depender de resolução de usuário/membro
- reinicie o gateway após alterar intents
Mensagens de servidor bloqueadas inesperadamente
Mensagens de servidor bloqueadas inesperadamente
- verifique
groupPolicy - verifique a allowlist de servidores em
channels.discord.guilds - se o mapa
channelsdo servidor existir, apenas canais listados serão permitidos - verifique o comportamento de
requireMentione os padrões de menção
Require mention false, mas ainda bloqueado
Require mention false, mas ainda bloqueado
groupPolicy="allowlist"sem allowlist de servidor/canal correspondenterequireMentionconfigurado no lugar errado (deve ficar emchannels.discord.guildsou na entrada do canal)- remetente bloqueado pela allowlist
usersdo servidor/canal
Manipuladores de longa duração expiram ou duplicam respostas
Manipuladores de longa duração expiram ou duplicam respostas
Listener DiscordMessageListener timed out after 30000ms for event MESSAGE_CREATESlow listener detected ...discord inbound worker timed out after ...
- conta única:
channels.discord.eventQueue.listenerTimeout - várias contas:
channels.discord.accounts.<accountId>.eventQueue.listenerTimeout
- conta única:
channels.discord.inboundWorker.runTimeoutMs - várias contas:
channels.discord.accounts.<accountId>.inboundWorker.runTimeoutMs - padrão:
1800000(30 minutos); defina0para desativar
eventQueue.listenerTimeout para configuração lenta de listener e inboundWorker.runTimeoutMs
apenas se quiser uma válvula de segurança separada para turnos de agente enfileirados.Incompatibilidades na auditoria de permissões
Incompatibilidades na auditoria de permissões
channels status --probe funcionam apenas para IDs numéricos de canal.Se você usar chaves slug, a correspondência em runtime ainda pode funcionar, mas a sonda não consegue verificar permissões por completo.Problemas de DM e pareamento
Problemas de DM e pareamento
- DM desativada:
channels.discord.dm.enabled=false - política de DM desativada:
channels.discord.dmPolicy="disabled"(legado:channels.discord.dm.policy) - aguardando aprovação de pareamento no modo
pairing
Loops de bot para bot
Loops de bot para bot
channels.discord.allowBots=true, use regras estritas de menção e allowlist para evitar comportamento de loop.
Prefira channels.discord.allowBots="mentions" para aceitar apenas mensagens de bot que mencionem o bot.STT de voz falha com DecryptionFailed(...)
STT de voz falha com DecryptionFailed(...)
- mantenha o OpenClaw atualizado (
openclaw update) para que a lógica de recuperação de recepção de voz do Discord esteja presente - confirme
channels.discord.voice.daveEncryption=true(padrão) - comece com
channels.discord.voice.decryptionFailureTolerance=24(padrão upstream) e ajuste apenas se necessário - monitore os logs para:
discord voice: DAVE decrypt failures detecteddiscord voice: repeated decrypt failures; attempting rejoin
- se as falhas continuarem após a nova entrada automática, colete os logs e compare com discord.js #11419
Ponteiros da referência de configuração
Referência principal: Campos do Discord com maior sinal:- inicialização/autenticação:
enabled,token,accounts.*,allowBots - política:
groupPolicy,dm.*,guilds.*,guilds.*.channels.* - comando:
commands.native,commands.useAccessGroups,configWrites,slashCommand.* - fila de eventos:
eventQueue.listenerTimeout(orçamento do listener),eventQueue.maxQueueSize,eventQueue.maxConcurrency - worker de entrada:
inboundWorker.runTimeoutMs - resposta/histórico:
replyToMode,historyLimit,dmHistoryLimit,dms.*.historyLimit - entrega:
textChunkLimit,chunkMode,maxLinesPerMessage - streaming:
streaming(alias legado:streamMode),draftChunk,blockStreaming,blockStreamingCoalesce - mídia/tentativa:
mediaMaxMb,retrymediaMaxMblimita uploads de saída do Discord (padrão:8MB)
- ações:
actions.* - presença:
activity,status,activityType,activityUrl - UI:
ui.components.accentColor - recursos:
threadBindings,bindings[]de nível superior (type: "acp"),pluralkit,execApprovals,intents,agentComponents,heartbeat,responsePrefix
Segurança e operações
- Trate tokens de bot como segredos (
DISCORD_BOT_TOKENé preferível em ambientes supervisionados). - Conceda permissões mínimas necessárias no Discord.
- Se o estado/implantação de comandos estiver desatualizado, reinicie o gateway e verifique novamente com
openclaw channels status --probe.