Configuration

Broadcast-Gruppen

Status: experimental

Überblick

Broadcast-Gruppen ermöglichen es mehreren Agenten, dieselbe Nachricht gleichzeitig zu verarbeiten und darauf zu antworten. Dadurch können Sie spezialisierte Agenten-Teams erstellen, die in einer einzelnen WhatsApp-Gruppe oder DM zusammenarbeiten - alle mit einer Telefonnummer.

Aktueller Umfang: nur WhatsApp (Web-Kanal).

Broadcast-Gruppen werden nach Kanal-Allowlists und Regeln zur Gruppenaktivierung ausgewertet. In WhatsApp-Gruppen bedeutet das, dass Broadcasts erfolgen, wenn OpenClaw normalerweise antworten würde (zum Beispiel: bei Erwähnung, abhängig von Ihren Gruppeneinstellungen).

Die Live-WhatsApp-QA-Lane enthält whatsapp-broadcast-group-fanout, wodurch geprüft wird, dass eine erwähnte Gruppennachricht unterschiedliche sichtbare Antworten von zwei konfigurierten Agenten erzeugen kann.

Anwendungsfälle

1. Spezialisierte Agenten-Teams

Stellen Sie mehrere Agenten mit atomaren, fokussierten Zuständigkeiten bereit:

Code
Group: "Development Team"Agents:  - CodeReviewer (reviews code snippets)  - DocumentationBot (generates docs)  - SecurityAuditor (checks for vulnerabilities)  - TestGenerator (suggests test cases)

Jeder Agent verarbeitet dieselbe Nachricht und liefert seine spezialisierte Perspektive.

2. Mehrsprachige Unterstützung
Code
Group: "International Support"Agents:  - Agent_EN (responds in English)  - Agent_DE (responds in German)  - Agent_ES (responds in Spanish)
3. Workflows zur Qualitätssicherung
Code
Group: "Customer Support"Agents:  - SupportAgent (provides answer)  - QAAgent (reviews quality, only responds if issues found)
4. Aufgabenautomatisierung
Code
Group: "Project Management"Agents:  - TaskTracker (updates task database)  - TimeLogger (logs time spent)  - ReportGenerator (creates summaries)

Konfiguration

Grundeinrichtung

Fügen Sie einen broadcast-Abschnitt auf oberster Ebene hinzu (neben bindings). Schlüssel sind WhatsApp-Peer-IDs:

  • Gruppenchats: Gruppen-JID (z. B. 120363403215116621@g.us)
  • DMs: E.164-Telefonnummer (z. B. +15551234567)
json
{  "broadcast": {    "120363403215116621@g.us": ["alfred", "baerbel", "assistant3"]  }}

Ergebnis: Wenn OpenClaw in diesem Chat antworten würde, führt es alle drei Agenten aus.

Verarbeitungsstrategie

Steuern Sie, wie Agenten Nachrichten verarbeiten:

parallel (Standard)

Alle Agenten verarbeiten gleichzeitig:

json
{  "broadcast": {    "strategy": "parallel",    "120363403215116621@g.us": ["alfred", "baerbel"]  }}

sequenziell

Agenten verarbeiten der Reihe nach (einer wartet, bis der vorherige fertig ist):

json
{  "broadcast": {    "strategy": "sequential",    "120363403215116621@g.us": ["alfred", "baerbel"]  }}

Vollständiges Beispiel

json
{  "agents": {    "list": [      {        "id": "code-reviewer",        "name": "Code Reviewer",        "workspace": "/path/to/code-reviewer",        "sandbox": { "mode": "all" }      },      {        "id": "security-auditor",        "name": "Security Auditor",        "workspace": "/path/to/security-auditor",        "sandbox": { "mode": "all" }      },      {        "id": "docs-generator",        "name": "Documentation Generator",        "workspace": "/path/to/docs-generator",        "sandbox": { "mode": "all" }      }    ]  },  "broadcast": {    "strategy": "parallel",    "120363403215116621@g.us": ["code-reviewer", "security-auditor", "docs-generator"],    "120363424282127706@g.us": ["support-en", "support-de"],    "+15555550123": ["assistant", "logger"]  }}

Funktionsweise

Nachrichtenfluss

  • Eingehende Nachricht trifft ein

    Eine WhatsApp-Gruppen- oder DM-Nachricht trifft ein.

  • Routing und Zulassung

    OpenClaw wendet Kanal-Allowlists, Regeln zur Gruppenaktivierung und die konfigurierte Zuständigkeit von ACP-Bindings an.

  • Broadcast-Prüfung

    Wenn kein konfiguriertes ACP-Binding die Route besitzt, prüft OpenClaw, ob die Peer-ID in broadcast enthalten ist.

  • Wenn Broadcast zutrifft

    • Alle aufgelisteten Agenten verarbeiten die Nachricht.
    • Jeder Agent hat seinen eigenen Sitzungsschlüssel und isolierten Kontext.
    • Agenten verarbeiten parallel (Standard) oder sequenziell.
  • Wenn Broadcast nicht zutrifft

    OpenClaw dispatcht die normale Route oder die konfigurierte ACP-Sitzungsroute, die beim Routing ausgewählt wurde.

  • Sitzungsisolation

    Jeder Agent in einer Broadcast-Gruppe verwaltet vollständig getrennte:

    • Sitzungsschlüssel (agent:alfred:whatsapp:group:120363... vs agent:baerbel:whatsapp:group:120363...)
    • Konversationsverlauf (Agent sieht die Nachrichten anderer Agenten nicht)
    • Workspace (separate Sandboxes, falls konfiguriert)
    • Tool-Zugriff (unterschiedliche Allow-/Deny-Listen)
    • Speicher/Kontext (separate IDENTITY.md, SOUL.md usw.)
    • Gruppenkontextpuffer (aktuelle Gruppennachrichten, die als Kontext verwendet werden) wird pro Peer geteilt, sodass alle Broadcast-Agenten bei Auslösung denselben Kontext sehen

    Dadurch kann jeder Agent Folgendes haben:

    • Unterschiedliche Persönlichkeiten
    • Unterschiedlichen Tool-Zugriff (z. B. nur lesend vs. lesend und schreibend)
    • Unterschiedliche Modelle (z. B. opus vs. sonnet)
    • Unterschiedliche installierte Skills

    Beispiel: isolierte Sitzungen

    In Gruppe 120363403215116621@g.us mit Agenten ["alfred", "baerbel"]:

    Alfreds Kontext

    Code
    Session: agent:alfred:whatsapp:group:120363403215116621@g.usHistory: [user message, alfred's previous responses]Workspace: /Users/user/openclaw-alfred/Tools: read, write, exec

    Bärbels Kontext

    Code
    Session: agent:baerbel:whatsapp:group:120363403215116621@g.usHistory: [user message, baerbel's previous responses]Workspace: /Users/user/openclaw-baerbel/Tools: read only

    Best Practices

    1. Agenten fokussiert halten

    Entwerfen Sie jeden Agenten mit einer einzelnen, klaren Zuständigkeit:

    json
    {  "broadcast": {    "DEV_GROUP": ["formatter", "linter", "tester"]  }}

    Gut: Jeder Agent hat eine Aufgabe. ❌ Schlecht: Ein generischer „dev-helper“-Agent.

    2. Beschreibende Namen verwenden

    Machen Sie klar, was jeder Agent tut:

    json
    {  "agents": {    "security-scanner": { "name": "Security Scanner" },    "code-formatter": { "name": "Code Formatter" },    "test-generator": { "name": "Test Generator" }  }}
    3. Unterschiedlichen Tool-Zugriff konfigurieren

    Geben Sie Agenten nur die Tools, die sie benötigen:

    json
    {  "agents": {    "reviewer": {      "tools": { "allow": ["read", "exec"] }    },    "fixer": {      "tools": { "allow": ["read", "write", "edit", "exec"] }    }  }}

    reviewer ist nur lesend. fixer kann lesen und schreiben.

    4. Leistung überwachen

    Bei vielen Agenten sollten Sie Folgendes erwägen:

    • "strategy": "parallel" (Standard) für Geschwindigkeit verwenden
    • Broadcast-Gruppen auf 5-10 Agenten begrenzen
    • Schnellere Modelle für einfachere Agenten verwenden
    5. Fehler elegant handhaben

    Agenten schlagen unabhängig fehl. Der Fehler eines Agenten blockiert andere nicht:

    Code
    Message → [Agent A ✓, Agent B ✗ error, Agent C ✓]Result: Agent A and C respond, Agent B logs error

    Kompatibilität

    Provider

    Broadcast-Gruppen funktionieren derzeit mit:

    • ✅ WhatsApp (implementiert)
    • 🚧 Telegram (geplant)
    • 🚧 Discord (geplant)
    • 🚧 Slack (geplant)

    Routing

    Broadcast-Gruppen funktionieren zusammen mit bestehendem Routing:

    json
    {  "bindings": [    {      "match": { "channel": "whatsapp", "peer": { "kind": "group", "id": "GROUP_A" } },      "agentId": "alfred"    }  ],  "broadcast": {    "GROUP_B": ["agent1", "agent2"]  }}
    • GROUP_A: Nur alfred antwortet (normales Routing).
    • GROUP_B: agent1 UND agent2 antworten (Broadcast).

    Fehlerbehebung

    Agenten antworten nicht

    Prüfen:

    1. Agent-IDs existieren in agents.list.
    2. Das Peer-ID-Format ist korrekt (z. B. 120363403215116621@g.us).
    3. Agenten befinden sich nicht in Deny-Listen.

    Debug:

    bash
    tail -f ~/.openclaw/logs/gateway.log | grep broadcast
    Nur ein Agent antwortet

    Ursache: Peer-ID könnte in normalen Route-Bindings, aber nicht in broadcast enthalten sein, oder sie könnte mit einem exklusiven konfigurierten ACP-Binding übereinstimmen.

    Behebung: Fügen Sie normale route-gebundene Peers der Broadcast-Konfiguration hinzu, oder entfernen/ändern Sie das konfigurierte ACP-Binding, wenn Fan-out-Broadcast gewünscht ist.

    Leistungsprobleme

    Wenn es mit vielen Agenten langsam ist:

    • Reduzieren Sie die Anzahl der Agenten pro Gruppe.
    • Verwenden Sie leichtere Modelle (sonnet statt opus).
    • Prüfen Sie die Sandbox-Startzeit.

    Beispiele

    Beispiel 1: Code-Review-Team
    json
    {  "broadcast": {    "strategy": "parallel",    "120363403215116621@g.us": [      "code-formatter",      "security-scanner",      "test-coverage",      "docs-checker"    ]  },  "agents": {    "list": [      {        "id": "code-formatter",        "workspace": "~/agents/formatter",        "tools": { "allow": ["read", "write"] }      },      {        "id": "security-scanner",        "workspace": "~/agents/security",        "tools": { "allow": ["read", "exec"] }      },      {        "id": "test-coverage",        "workspace": "~/agents/testing",        "tools": { "allow": ["read", "exec"] }      },      { "id": "docs-checker", "workspace": "~/agents/docs", "tools": { "allow": ["read"] } }    ]  }}

    Benutzer sendet: Codeausschnitt.

    Antworten:

    • code-formatter: „Einrückung korrigiert und Type Hints hinzugefügt“
    • security-scanner: „⚠️ SQL-Injection-Schwachstelle in Zeile 12“
    • test-coverage: „Abdeckung beträgt 45 %, Tests für Fehlerfälle fehlen“
    • docs-checker: „Docstring für Funktion process_data fehlt“
    Beispiel 2: Mehrsprachige Unterstützung
    json
    {  "broadcast": {    "strategy": "sequential",    "+15555550123": ["detect-language", "translator-en", "translator-de"]  },  "agents": {    "list": [      { "id": "detect-language", "workspace": "~/agents/lang-detect" },      { "id": "translator-en", "workspace": "~/agents/translate-en" },      { "id": "translator-de", "workspace": "~/agents/translate-de" }    ]  }}

    API-Referenz

    Konfigurationsschema

    typescript
    interface OpenClawConfig {  broadcast?: {    strategy?: "parallel" | "sequential";    [peerId: string]: string[];  };}

    Felder

    strategy"parallel" | "sequential"default: "parallel"

    So werden Agenten verarbeitet. parallel führt alle Agenten gleichzeitig aus; sequential führt sie in Array-Reihenfolge aus.

    [peerId]string[]

    WhatsApp-Gruppen-JID, E.164-Nummer oder andere Peer-ID. Der Wert ist das Array der Agenten-IDs, die Nachrichten verarbeiten sollen.

    Einschränkungen

    1. Max. Agenten: Keine harte Begrenzung, aber 10+ Agenten können langsam sein.
    2. Gemeinsamer Kontext: Agenten sehen die Antworten der jeweils anderen nicht (absichtlich).
    3. Nachrichtenreihenfolge: Parallele Antworten können in beliebiger Reihenfolge eintreffen.
    4. Ratenbegrenzungen: Alle Agenten zählen zu den WhatsApp-Ratenbegrenzungen.

    Zukünftige Erweiterungen

    Geplante Funktionen:

    • [ ] Modus für gemeinsamen Kontext (Agenten sehen die Antworten der jeweils anderen)
    • [ ] Agentenkoordination (Agenten können einander Signale senden)
    • [ ] Dynamische Agentenauswahl (Agenten anhand des Nachrichteninhalts auswählen)
    • [ ] Agentenprioritäten (einige Agenten antworten vor anderen)

    Verwandte Themen

    Was this useful?
    On this page

    On this page