当你希望在经典频道(Documentation Index
Fetch the complete documentation index at: https://openclaw.zhcndoc.com/llms.txt
Use this file to discover all available pages before exploring further.
#room)和直接消息中使用 OpenClaw 时,请使用 IRC。
IRC 作为捆绑插件提供,但在主配置中的 channels.irc 下进行配置。
快速开始
- 在
~/.openclaw/openclaw.json中启用 IRC 配置。 - 至少设置:
- 启动/重启网关:
安全默认值
channels.irc.dmPolicy的默认值为"pairing"。channels.irc.groupPolicy的默认值为"allowlist"。- 当
groupPolicy="allowlist"时,设置channels.irc.groups来定义允许的频道。 - 除非你有意接受明文传输,否则请使用 TLS(
channels.irc.tls=true)。
访问控制
IRC 频道有两个独立的“门”:- 频道访问(
groupPolicy+groups):机器人是否完全接受来自某个频道的消息。 - 发送者访问(
groupAllowFrom/ 按频道的groups["#channel"].allowFrom):谁可以在该频道中触发机器人。
- DM 白名单(DM 发送者访问):
channels.irc.allowFrom - 组发送者白名单(频道发送者访问):
channels.irc.groupAllowFrom - 每个频道的控制项(频道 + 发送者 + 提及规则):
channels.irc.groups["#channel"] channels.irc.groupPolicy="open"允许未配置的频道(默认情况下仍然受提及门控限制)
nick!user@host)。
仅使用裸 nick 匹配是可变的,并且只有在 channels.irc.dangerouslyAllowNameMatching: true 时才启用。
常见坑:allowFrom 用于 DM,不用于频道
如果你看到类似这样的日志:
irc: drop group sender alice!ident@host (policy=allowlist)
- 设置
channels.irc.groupAllowFrom(对所有频道全局生效),或 - 为每个频道设置发送者白名单:
channels.irc.groups["#channel"].allowFrom
#tuirc-dev 中任何人和机器人交谈):
回复触发(提及)
即使某个频道已被允许(通过groupPolicy + groups),且发送者也已被允许,OpenClaw 在组上下文中默认仍会启用提及门控。
这意味着你可能会看到类似 drop channel … (missing-mention) 的日志,除非消息中包含与机器人匹配的提及模式。
如果你想让机器人在 IRC 频道中无需提及也能回复,请为该频道关闭提及门控:
安全说明(公共频道推荐)
如果你在公共频道中允许allowFrom: ["*"],任何人都可以向机器人发起提示。
为降低风险,请限制该频道可用的工具。
频道中的所有人使用相同工具
不同发送者使用不同工具(所有者权限更高)
使用toolsBySender 为 "*" 应用更严格的策略,并为你的 nick 应用更宽松的策略:
toolsBySender的键应使用id:作为 IRC 发送者身份值:id:eigen或id:eigen!~eigen@174.127.248.171,以获得更强的匹配。- 旧式未加前缀的键仍然被接受,但只会按
id:进行匹配。 - 首个匹配到的发送者策略生效;
"*"是通配符回退。
NickServ
连接后使用 NickServ 进行身份验证:register,以避免重复的 REGISTER 尝试。
环境变量
默认账户支持:IRC_HOSTIRC_PORTIRC_TLSIRC_NICKIRC_USERNAMEIRC_REALNAMEIRC_PASSWORDIRC_CHANNELS(逗号分隔)IRC_NICKSERV_PASSWORDIRC_NICKSERV_REGISTER_EMAIL
IRC_HOST 不能从工作区的 .env 中设置;请参见 Workspace .env 文件。
故障排查
- 如果机器人已连接但在频道中从不回复,请检查
channels.irc.groups,以及提及门控是否正在丢弃消息(missing-mention)。如果你希望它在没有 ping 的情况下回复,请为该频道设置requireMention:false。 - 如果登录失败,请检查 nick 是否可用以及服务器密码是否正确。
- 如果在自定义网络上 TLS 失败,请检查主机/端口和证书设置。