目标:让 Clawd 留在 WhatsApp 群组中,仅在被提及时唤醒,并将该对话线程与个人私信会话分开。
注意:agents.list[].groupChat.mentionPatterns 现在也被 Telegram/Discord/Slack/iMessage 使用;本文档重点介绍 WhatsApp 特定的行为。对于多智能体设置,为每个智能体设置 agents.list[].groupChat.mentionPatterns(或使用 messages.groupChat.mentionPatterns 作为全局回退)。
已实现的功能(2025-12-03) 激活模式:mention(默认)或 always。mention 需要被提及(通过 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 知道是谁在说话。 阅后即焚/一次性查看:我们在提取文本/提及之前会先解包这些消息,因此其中的提及仍会触发。 群组系统提示:在群组会话的第一轮(以及每当 /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 剥离文本正文中的可视 @ 时,显示名称提及仍能正常工作:
...