Configuration
Messaggi di gruppo WhatsApp
Per il modello dei gruppi cross-channel (Discord, iMessage, Matrix, Microsoft Teams, Signal, Slack, Telegram, WhatsApp, Zalo), vedi Gruppi. Questa pagina descrive il comportamento specifico di WhatsApp sopra quel modello: attivazione, allowlist dei gruppi, chiavi di sessione per gruppo e iniezione del contesto dei messaggi in sospeso.
Obiettivo: permettere a OpenClaw di restare nei gruppi WhatsApp, attivarsi solo quando viene chiamato in causa e mantenere quel thread separato dalla sessione DM personale.
Comportamento
- Modalità di attivazione:
mention(predefinita) oalways.mentionrichiede un ping (vere @-menzioni di WhatsApp tramitementionedJids, pattern regex sicuri oppure l'E.164 del bot in qualsiasi punto del testo).alwaysattiva l'agente a ogni messaggio, ma dovrebbe rispondere solo quando può aggiungere valore significativo; altrimenti restituisce il token silenzioso esattoNO_REPLY/no_reply. I valori predefiniti possono essere impostati nella configurazione (channels.whatsapp.groups) e sovrascritti per gruppo tramite/activation. Quandochannels.whatsapp.groupsè impostato, funziona anche come allowlist dei gruppi (includi"*"per consentire tutti). - Criterio dei gruppi:
channels.whatsapp.groupPolicycontrolla se i messaggi di gruppo sono accettati (open|disabled|allowlist).allowlistusachannels.whatsapp.groupAllowFrom(fallback:channels.whatsapp.allowFromesplicito). Il valore predefinito èallowlist(bloccato finché non aggiungi mittenti). - Sessioni per gruppo: le chiavi di sessione hanno la forma
agent:<agentId>:whatsapp:group:<jid>, quindi comandi come/verbose on,/trace ono/think high(inviati come messaggi autonomi) sono limitati a quel gruppo; lo stato del DM personale resta intatto. Gli Heartbeat vengono saltati per i thread di gruppo. - Iniezione del contesto: i messaggi di gruppo solo in sospeso (50 per impostazione predefinita) che non hanno attivato un'esecuzione sono prefissati sotto
[Chat messages since your last reply - for context], con la riga di attivazione sotto[Current message - respond to this]. I messaggi già presenti nella sessione non vengono reiniettati. - Esposizione del mittente: ogni batch di gruppo ora termina con
[from: Sender Name (+E164)], così OpenClaw sa chi sta parlando. - Effimeri/visualizzabili una sola volta: li estraiamo prima di ricavare testo/menzioni, quindi i ping al loro interno attivano comunque.
- Prompt di sistema del gruppo: al primo turno di una sessione di gruppo (e ogni volta che
/activationcambia la modalità) iniettiamo un breve testo nel prompt di sistema comeYou 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.Se i metadati non sono disponibili, diciamo comunque all'agente che si tratta di una chat di gruppo.
Esempio di configurazione (WhatsApp)
Aggiungi un blocco groupChat a ~/.openclaw/openclaw.json in modo che i ping tramite nome visualizzato funzionino anche quando WhatsApp rimuove la @ visiva dal corpo del testo:
{ channels: { whatsapp: { groups: { "*": { requireMention: true }, }, }, }, agents: { list: [ { id: "main", groupChat: { historyLimit: 50, mentionPatterns: ["@?openclaw", "\\+?15555550123"], }, }, ], },}Note:
- Le regex non distinguono tra maiuscole e minuscole e usano le stesse protezioni safe-regex delle altre superfici regex di configurazione; i pattern non validi e la ripetizione annidata non sicura vengono ignorati.
- WhatsApp invia comunque menzioni canoniche tramite
mentionedJidsquando qualcuno tocca il contatto, quindi il fallback sul numero è raramente necessario, ma è una rete di sicurezza utile.
Comando di attivazione (solo proprietario)
Usa il comando della chat di gruppo:
/activation mention/activation always
Solo il numero del proprietario (da channels.whatsapp.allowFrom, oppure l'E.164 del bot quando non è impostato) può modificarlo. Invia /status come messaggio autonomo nel gruppo per vedere la modalità di attivazione corrente.
Come usare
- Aggiungi il tuo account WhatsApp (quello che esegue OpenClaw) al gruppo.
- Scrivi
@openclaw …(o includi il numero). Solo i mittenti in allowlist possono attivarlo, a meno che tu non impostigroupPolicy: "open". - Il prompt dell'agente includerà il contesto recente del gruppo più il marcatore finale
[from: …], così potrà rivolgersi alla persona corretta. - Le direttive a livello di sessione (
/verbose on,/trace on,/think high,/newo/reset,/compact) si applicano solo alla sessione di quel gruppo; inviale come messaggi autonomi in modo che vengano registrate. La tua sessione DM personale resta indipendente.
Test / verifica
- Smoke test manuale:
- Invia un ping
@openclawnel gruppo e conferma una risposta che faccia riferimento al nome del mittente. - Invia un secondo ping e verifica che il blocco della cronologia sia incluso e poi cancellato al turno successivo.
- Invia un ping
- Controlla i log del Gateway (esegui con
--verbose) per vedere vociinbound web messageche mostranofrom: <groupJid>e il suffisso[from: …].
Considerazioni note
- Gli Heartbeat vengono saltati intenzionalmente per i gruppi per evitare broadcast rumorosi.
- La soppressione dell'eco usa la stringa combinata del batch; se invii due volte testo identico senza menzioni, solo il primo riceverà una risposta.
- Le voci dell'archivio sessioni appariranno come
agent:<agentId>:whatsapp:group:<jid>nell'archivio sessioni (~/.openclaw/agents/<agentId>/sessions/sessions.jsonper impostazione predefinita); una voce mancante significa semplicemente che il gruppo non ha ancora attivato un'esecuzione. - Gli indicatori di digitazione nei gruppi seguono
agents.defaults.typingMode. Quando le risposte visibili sono abilitate in modalità solo strumento messaggi, la digitazione inizia immediatamente per impostazione predefinita, così i membri del gruppo possono vedere che l'agente sta lavorando anche se non viene pubblicata alcuna risposta finale automatica. La configurazione esplicita della modalità di digitazione ha comunque la precedenza.