Usa IRC cuando quieras OpenClaw en canales clásicos (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) y mensajes directos.
IRC se incluye como Plugin empaquetado, pero se configura en la configuración principal bajo channels.irc.
Inicio rápido
- Habilita la configuración de IRC en
~/.openclaw/openclaw.json. - Define al menos:
- Inicia/reinicia el Gateway:
Valores predeterminados de seguridad
- IRC usa sockets TCP/TLS sin procesar fuera del enrutamiento del proxy de reenvío administrado por el operador de OpenClaw. En implementaciones que requieren que todo el tráfico saliente pase por ese proxy de reenvío, define
channels.irc.enabled=falsesalvo que la salida directa de IRC esté aprobada explícitamente. channels.irc.dmPolicytiene el valor predeterminado"pairing".channels.irc.groupPolicytiene el valor predeterminado"allowlist".- Con
groupPolicy="allowlist", definechannels.irc.groupspara especificar los canales permitidos. - Usa TLS (
channels.irc.tls=true) salvo que aceptes intencionalmente el transporte en texto plano.
Control de acceso
Hay dos “puertas” separadas para canales IRC:- Acceso al canal (
groupPolicy+groups): si el bot acepta mensajes de un canal. - Acceso del remitente (
groupAllowFrom/groups["#channel"].allowFrompor canal): quién puede activar el bot dentro de ese canal.
- Lista de permitidos de DM (acceso de remitente por DM):
channels.irc.allowFrom - Lista de permitidos de remitentes de grupo (acceso de remitente de canal):
channels.irc.groupAllowFrom - Controles por canal (reglas de canal, remitente y mención):
channels.irc.groups["#channel"] channels.irc.groupPolicy="open"permite canales no configurados (aun así, con control por mención de forma predeterminada)
nick!user@host).
La coincidencia solo por nick es mutable y solo se habilita cuando channels.irc.dangerouslyAllowNameMatching: true.
Problema frecuente: allowFrom es para DM, no para canales
Si ves registros como:
irc: drop group sender alice!ident@host (policy=allowlist)
- definiendo
channels.irc.groupAllowFrom(global para todos los canales), o - definiendo listas de permitidos de remitentes por canal:
channels.irc.groups["#channel"].allowFrom
#tuirc-dev hable con el bot):
Activación de respuestas (menciones)
Aunque un canal esté permitido (mediantegroupPolicy + groups) y el remitente esté permitido, OpenClaw aplica de forma predeterminada control por mención en contextos de grupo.
Eso significa que puedes ver registros como drop channel … (missing-mention) salvo que el mensaje incluya un patrón de mención que coincida con el bot.
Para hacer que el bot responda en un canal IRC sin necesitar una mención, deshabilita el control por mención para ese canal:
Nota de seguridad (recomendada para canales públicos)
Si permitesallowFrom: ["*"] en un canal público, cualquiera puede enviar indicaciones al bot.
Para reducir el riesgo, restringe las herramientas para ese canal.
Las mismas herramientas para todos en el canal
Herramientas diferentes por remitente (el propietario obtiene más poder)
UsatoolsBySender para aplicar una política más estricta a "*" y una más flexible a tu nick:
- Las claves de
toolsBySenderdeben usarid:para valores de identidad de remitente IRC:id:eigenoid:eigen!~eigen@174.127.248.171para una coincidencia más fuerte. - Las claves heredadas sin prefijo todavía se aceptan y solo se comparan como
id:. - La primera política de remitente que coincida gana;
"*"es la alternativa comodín.
NickServ
Para identificarte con NickServ después de conectarte:register después de que el nick esté registrado para evitar intentos REGISTER repetidos.
Variables de entorno
La cuenta predeterminada admite:IRC_HOSTIRC_PORTIRC_TLSIRC_NICKIRC_USERNAMEIRC_REALNAMEIRC_PASSWORDIRC_CHANNELS(separados por comas)IRC_NICKSERV_PASSWORDIRC_NICKSERV_REGISTER_EMAIL
IRC_HOST no puede definirse desde un archivo .env del espacio de trabajo; consulta archivos .env del espacio de trabajo.
Solución de problemas
- Si el bot se conecta pero nunca responde en canales, verifica
channels.irc.groupsy si el control por mención está descartando mensajes (missing-mention). Si quieres que responda sin pings, definerequireMention:falsepara el canal. - Si el inicio de sesión falla, verifica la disponibilidad del nick y la contraseña del servidor.
- Si TLS falla en una red personalizada, verifica el host/puerto y la configuración del certificado.
Relacionado
- Descripción general de canales — todos los canales compatibles
- Emparejamiento — autenticación por DM y flujo de emparejamiento
- Grupos — comportamiento de chat grupal y control por mención
- Enrutamiento de canales — enrutamiento de sesiones para mensajes
- Seguridad — modelo de acceso y refuerzo de seguridad