IRC
Usa IRC cuando quieras OpenClaw en canales clásicos (#room) y mensajes directos.
IRC se distribuye como un plugin de extensión, pero se configura en la configuración principal en channels.irc.
Inicio rápido
- Habilita la configuración de IRC en
~/.openclaw/openclaw.json. - Configura al menos:
- Inicia o reinicia el gateway:
Valores predeterminados de seguridad
channels.irc.dmPolicytiene como valor predeterminado"pairing".channels.irc.groupPolicytiene como valor predeterminado"allowlist".- Con
groupPolicy="allowlist", configurachannels.irc.groupspara definir los canales permitidos. - Usa TLS (
channels.irc.tls=true) a menos que aceptes intencionadamente transporte en texto sin formato.
Control de acceso
Hay dos “controles” separados para los canales de IRC:- Acceso al canal (
groupPolicy+groups): si el bot acepta mensajes de un canal en absoluto. - Acceso del remitente (
groupAllowFrom/groups["#channel"].allowFrompor canal): quién tiene permiso para activar el bot dentro de ese canal.
- Lista de permitidos de mensajes directos (acceso del remitente en mensajes directos):
channels.irc.allowFrom - Lista de permitidos de remitentes de grupo (acceso del remitente en canales):
channels.irc.groupAllowFrom - Controles por canal (canal + remitente + reglas de mención):
channels.irc.groups["#channel"] channels.irc.groupPolicy="open"permite canales sin configurar (aun así, con restricción 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.
Error habitual: allowFrom es para mensajes directos, no para canales
Si ves registros como:
irc: drop group sender alice!ident@host (policy=allowlist)
- configurando
channels.irc.groupAllowFrom(global para todos los canales), o - configurando 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 usa de forma predeterminada restricción por mención en contextos de grupo.
Eso significa que puedes ver registros como drop channel … (missing-mention) a menos que el mensaje incluya un patrón de mención que coincida con el bot.
Para que el bot responda en un canal de IRC sin necesitar una mención, desactiva la restricción 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 capacidades)
UsatoolsBySender para aplicar una política más estricta a "*" y una más flexible a tu nick:
- Las claves de
toolsBySenderdeben usarid:para los valores de identidad del remitente de IRC:id:eigenoid:eigen!~eigen@174.127.248.171para una coincidencia más fuerte. - Las claves heredadas sin prefijo siguen aceptándose y se comparan solo como
id:. - La primera política de remitente coincidente es la que se aplica;
"*"es el comodín de respaldo.
NickServ
Para identificarte con NickServ después de conectar:register después de que el nick esté registrado para evitar intentos repetidos de REGISTER.
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
Solución de problemas
- Si el bot se conecta pero nunca responde en canales, verifica
channels.irc.groupsy si la restricción por mención está descartando mensajes (missing-mention). Si quieres que responda sin menciones, configurarequireMention: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
- Resumen de canales — todos los canales compatibles
- Emparejamiento — autenticación de mensajes directos y flujo de emparejamiento
- Grupos — comportamiento del chat grupal y restricción por mención
- Enrutamiento de canales — enrutamiento de sesiones para mensajes
- Seguridad — modelo de acceso y refuerzo