Use IRC quando você quiser o OpenClaw em canais clássicos (Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
#room) e mensagens diretas.
O IRC é distribuído como um Plugin incluído, mas é configurado na configuração principal em channels.irc.
Início rápido
- Ative a configuração de IRC em
~/.openclaw/openclaw.json. - Defina pelo menos:
- Inicie/reinicie o Gateway:
Padrões de segurança
- O IRC usa soquetes TCP/TLS brutos fora do roteamento de proxy de encaminhamento gerenciado pelo operador do OpenClaw. Em implantações que exigem toda a saída por esse proxy de encaminhamento, defina
channels.irc.enabled=false, a menos que a saída direta de IRC seja explicitamente aprovada. channels.irc.dmPolicyusa"pairing"por padrão.channels.irc.groupPolicyusa"allowlist"por padrão.- Com
groupPolicy="allowlist", definachannels.irc.groupspara especificar os canais permitidos. - Use TLS (
channels.irc.tls=true), a menos que você aceite intencionalmente transporte em texto claro.
Controle de acesso
Há dois “portões” separados para canais IRC:- Acesso ao canal (
groupPolicy+groups): se o bot aceita mensagens de um canal. - Acesso do remetente (
groupAllowFrom/groups["#channel"].allowFrompor canal): quem tem permissão para acionar o bot dentro desse canal.
- Lista de permissões de DM (acesso do remetente de DM):
channels.irc.allowFrom - Lista de permissões de remetentes de grupo (acesso do remetente do canal):
channels.irc.groupAllowFrom - Controles por canal (regras de canal + remetente + menção):
channels.irc.groups["#channel"] channels.irc.groupPolicy="open"permite canais não configurados (ainda com controle por menção por padrão)
nick!user@host).
A correspondência por apelido simples é mutável e só é ativada quando channels.irc.dangerouslyAllowNameMatching: true.
Problema comum: allowFrom é para DMs, não canais
Se você vir logs como:
irc: drop group sender alice!ident@host (policy=allowlist)
channels.irc.groupAllowFrom(global para todos os canais), ou- listas de permissões de remetentes por canal:
channels.irc.groups["#channel"].allowFrom
#tuirc-dev fale com o bot):
Acionamento de resposta (menções)
Mesmo que um canal seja permitido (viagroupPolicy + groups) e o remetente seja permitido, o OpenClaw usa por padrão controle por menção em contextos de grupo.
Isso significa que você pode ver logs como drop channel … (missing-mention), a menos que a mensagem inclua um padrão de menção que corresponda ao bot.
Para fazer o bot responder em um canal IRC sem precisar de uma menção, desative o controle por menção para esse canal:
Observação de segurança (recomendado para canais públicos)
Se você permitirallowFrom: ["*"] em um canal público, qualquer pessoa poderá enviar prompts ao bot.
Para reduzir o risco, restrinja as ferramentas desse canal.
Mesmas ferramentas para todos no canal
Ferramentas diferentes por remetente (o proprietário tem mais poder)
UsetoolsBySender para aplicar uma política mais restrita a "*" e uma mais flexível ao seu apelido:
- As chaves de
toolsBySenderdevem usarid:para valores de identidade de remetente de IRC:id:eigenouid:eigen!~eigen@174.127.248.171para correspondência mais forte. - Chaves legadas sem prefixo ainda são aceitas e correspondem apenas como
id:. - A primeira política de remetente correspondente vence;
"*"é o fallback curinga.
NickServ
Para se identificar com o NickServ após conectar:register depois que o apelido estiver registrado para evitar tentativas repetidas de REGISTER.
Variáveis de ambiente
A conta padrão oferece suporte a:IRC_HOSTIRC_PORTIRC_TLSIRC_NICKIRC_USERNAMEIRC_REALNAMEIRC_PASSWORDIRC_CHANNELS(separados por vírgulas)IRC_NICKSERV_PASSWORDIRC_NICKSERV_REGISTER_EMAIL
IRC_HOST não pode ser definido a partir de um .env do workspace; consulte Arquivos .env do workspace.
Solução de problemas
- Se o bot se conecta, mas nunca responde em canais, verifique
channels.irc.groupse se o controle por menção está descartando mensagens (missing-mention). Se você quiser que ele responda sem pings, definarequireMention:falsepara o canal. - Se o login falhar, verifique a disponibilidade do apelido e a senha do servidor.
- Se TLS falhar em uma rede personalizada, verifique host/porta e a configuração do certificado.
Relacionados
- Visão geral dos canais — todos os canais compatíveis
- Pareamento — autenticação por DM e fluxo de pareamento
- Grupos — comportamento de chat em grupo e controle por menção
- Roteamento de canais — roteamento de sessão para mensagens
- Segurança — modelo de acesso e fortalecimento