群组消息(WhatsApp 网页渠道)
目标:让 Clawd 待在 WhatsApp 群组中,仅在收到 ping 时唤醒,并将该线程与个人私信会话分开。 注意:agents.list[].groupChat.mentionPatterns 现在也用于 Telegram/Discord/Slack/iMessage;本文档重点介绍 WhatsApp 特有的行为。对于多代理设置,请为每个代理单独设置 agents.list[].groupChat.mentionPatterns(或使用 messages.groupChat.mentionPatterns 作为全局回退)。
已实现功能(2025-12-03)
- 激活模式:
mention(默认)或always。mention需要通过 ping 触发(通过mentionedJids发送的真实 WhatsApp @提及、正则表达式模式,或文本中任何位置出现的机器人 E.164 号码)。always会在每条消息到达时唤醒代理,但只有在能够提供有意义价值时才回复;否则返回静默标记NO_REPLY。默认值可在配置中设置(channels.whatsapp.groups),并可通过/activation在群组级别覆盖。当channels.whatsapp.groups设置时,它还充当群组白名单(包含"*"则允许所有)。 - 群组策略:
channels.whatsapp.groupPolicy控制是否接受群组消息(open|disabled|allowlist)。allowlist使用channels.whatsapp.groupAllowFrom(回退:显式channels.whatsapp.allowFrom)。默认是allowlist(阻止所有消息,直到你添加发送者)。 - 每个群组的独立会话:会话密钥格式为
agent:<agentId>:whatsapp:group:<jid>,因此诸如/verbose on或/think high的命令(作为独立消息发送)仅限于该群组;个人私信状态不受影响。群组线程会跳过心跳检测。 - 上下文注入:未触发运行的待处理群组消息(默认 50 条)会以
[Chat messages since your last reply - for context]为前缀,触发行则以[Current message - respond to this]标记。已在会话中的消息不会被重新注入。 - 发送者标识:每个群组批处理现在都以
[from: Sender Name (+E164)]结尾,以便 Pi 能够识别发言者。 - 临时消息/阅后即焚:我们在提取文本和提及之前先解包这些消息,因此其中的 ping 仍然可以触发。
- 群组系统提示:在群组会话的第一轮(以及每当
/activation更改模式时),我们会向系统提示中注入一段简短说明,如You are replying inside the WhatsApp group "<subject>". Group members: Alice (+44...), Bob (+43...), … Activation: trigger-only … Address the specific sender noted in the message context.。如果元数据不可用,我们仍会告知代理这是一个群聊。
WhatsApp 配置示例
在~/.openclaw/openclaw.json 中添加一个 groupChat 块,以便即使 WhatsApp 在文本主体中删除了视觉 @,显示名 ping 也能正常工作:
- 正则表达式不区分大小写;它们涵盖类似
@openclaw的显示名 ping,以及带有或不带+/空格的原始号码。 - 当有人点击联系人时,WhatsApp 仍会通过
mentionedJids发送规范提及,因此很少需要使用号码回退,但它是一个有用的安全网。
激活命令(仅限群主)
使用群聊命令:/activation mention/activation always
channels.whatsapp.allowFrom,或在未设置时使用机器人的 E.164)才能更改此设置。在群组中发送 /status 作为独立消息,即可查看当前的激活模式。
使用方法
- 将你的 WhatsApp 账号(运行 OpenClaw 的账号)加入群组。
- 说出
@openclaw …(或包含号码)。除非你设置groupPolicy: "open",否则只有白名单中的发送者才能触发。 - 代理提示中将包含最近的群组上下文以及末尾的
[from: …]标记,以便它能准确回应正确的用户。 - 会话级指令(
/verbose on、/think high、/new或/reset、/compact)仅适用于该群组的会话;请将其作为独立消息发送,以便生效。你的个人私信会话保持独立。
测试与验证
- 手动烟雾测试:
- 在群组中发送一个
@openclawping,并确认回复中引用了发送者姓名。 - 发送第二个 ping,并验证历史块已包含并在下一轮中被清除。
- 在群组中发送一个
- 检查网关日志(使用
--verbose运行),查看inbound web message条目,显示from: <groupJid>和[from: …]后缀。
已知注意事项
- 为避免嘈杂的广播,群组会主动跳过心跳检测。
- 回声抑制基于合并后的批处理字符串;如果你两次发送完全相同的文本且不含提及,只有第一次会得到响应。
- 会话存储条目将在会话存储中显示为
agent:<agentId>:whatsapp:group:<jid>(默认为~/.openclaw/agents/<agentId>/sessions/sessions.json);缺少条目只是表示该群组尚未触发运行。 - 群组中的打字指示遵循
agents.defaults.typingMode(默认:未提及时为message)。