群组消息 (WhatsApp Web 通道)
目标:让 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 删除了文本正文中的视觉 @,显示名称提及仍然有效:
- 正则表达式不区分大小写,并与其他配置正则表达式表面使用相同的安全正则表达式防护措施;无效的模式和不安全的嵌套重复将被忽略。
- 当有人点击联系人时,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运行)以查看显示from: <groupJid>和[from: …]后缀的inbound web message条目。
已知注意事项
- 为了避免嘈杂的广播,群组有意跳过心跳检测。
- 回显抑制使用组合的批次字符串;如果您在不提及的情况下两次发送相同的文本,只有第一条会收到回复。
- 会话存储条目将显示为会话存储中的
agent:<agentId>:whatsapp:group:<jid>(默认为~/.openclaw/agents/<agentId>/sessions/sessions.json);缺少条目仅意味着该群组尚未触发运行。 - 群组中的输入指示器遵循
agents.defaults.typingMode(默认情况下:未被提及时为message)。
本页面源自 openclaw/openclaw,由 BeaversLab 翻译,遵循 MIT 协议 发布。