Configuration

Roteamento de canais

Canais e roteamento

O OpenClaw roteia respostas de volta para o canal de onde a mensagem veio. O modelo não escolhe um canal; o roteamento é determinístico e controlado pela configuração do host.

Termos principais

  • Canal: telegram, whatsapp, discord, irc, googlechat, slack, signal, imessage, line, além de canais de Plugin. webchat é o canal interno da interface WebChat e não é um canal de saída configurável.
  • AccountId: instância de conta por canal (quando compatível).
  • Conta padrão opcional do canal: channels.<channel>.defaultAccount escolhe qual conta é usada quando um caminho de saída não especifica accountId.
    • Em configurações com várias contas, defina um padrão explícito (defaultAccount ou accounts.default) quando duas ou mais contas estiverem configuradas. Sem isso, o roteamento de fallback pode escolher o primeiro ID de conta normalizado.
  • AgentId: um workspace isolado + armazenamento de sessão ("cérebro").
  • SessionKey: a chave de bucket usada para armazenar contexto e controlar concorrência.

Prefixos de destino de saída

Destinos de saída explícitos podem incluir um prefixo de provedor, como telegram:123 ou tg:123. O core trata esse prefixo como uma dica de seleção de canal apenas quando o canal selecionado é last ou está de outro modo indefinido, e somente quando o Plugin carregado anuncia esse prefixo. Se o chamador já selecionou um canal explícito, o prefixo do provedor deve corresponder a esse canal; combinações entre canais, como entrega do WhatsApp para telegram:123, falham antes da normalização de destino específica do Plugin.

Prefixos de tipo de destino e serviço, como channel:<id>, user:<id>, room:<id>, thread:<id>, imessage:<handle> e sms:<number>, permanecem dentro da gramática do canal selecionado. Eles não selecionam o provedor por si só.

Formatos de chave de sessão (exemplos)

Mensagens diretas são consolidadas na sessão principal do agente por padrão:

  • agent:<agentId>:<mainKey> (padrão: agent:main:main)

Mesmo quando o histórico de conversa de mensagens diretas é compartilhado com a sessão principal, a política de sandbox e ferramentas usa uma chave de runtime derivada por conta para chat direto em DMs externas, para que mensagens originadas de canais não sejam tratadas como execuções locais da sessão principal.

Grupos e canais permanecem isolados por canal:

  • Grupos: agent:<agentId>:<channel>:group:<id>
  • Canais/salas: agent:<agentId>:<channel>:channel:<id>

Threads:

  • Threads do Slack/Discord acrescentam :thread:<threadId> à chave base.
  • Tópicos de fórum do Telegram incorporam :topic:<topicId> à chave do grupo.

Exemplos:

  • agent:main:telegram:group:-1001234567890:topic:42
  • agent:main:discord:channel:123456:thread:987654

Fixação de rota de DM principal

Quando session.dmScope é main, mensagens diretas podem compartilhar uma sessão principal. Para impedir que o lastRoute da sessão seja sobrescrito por DMs que não sejam do proprietário, o OpenClaw infere um proprietário fixado a partir de allowFrom quando todos estes itens são verdadeiros:

  • allowFrom tem exatamente uma entrada sem wildcard.
  • A entrada pode ser normalizada para um ID de remetente concreto desse canal.
  • O remetente da DM recebida não corresponde a esse proprietário fixado.

Nesse caso de incompatibilidade, o OpenClaw ainda registra metadados da sessão recebida, mas pula a atualização do lastRoute da sessão principal.

Registro de entrada protegido

Plugins de canal podem marcar um registro de sessão recebida como createIfMissing: false quando um caminho protegido não deve criar uma nova sessão do OpenClaw. Nesse modo, o OpenClaw pode atualizar metadados e lastRoute para uma sessão existente, mas não cria uma entrada de sessão apenas de rota só porque uma mensagem foi observada.

Regras de roteamento (como um agente é escolhido)

O roteamento escolhe um agente para cada mensagem recebida:

  1. Correspondência exata de par (bindings com peer.kind + peer.id).
  2. Correspondência de par pai (herança de thread).
  3. Correspondência de guilda + funções (Discord) via guildId + roles.
  4. Correspondência de guilda (Discord) via guildId.
  5. Correspondência de equipe (Slack) via teamId.
  6. Correspondência de conta (accountId no canal).
  7. Correspondência de canal (qualquer conta nesse canal, accountId: "*").
  8. Agente padrão (agents.list[].default, senão a primeira entrada da lista, fallback para main).

Quando um vínculo inclui vários campos de correspondência (peer, guildId, teamId, roles), todos os campos fornecidos devem corresponder para que esse vínculo seja aplicado.

O agente correspondente determina qual workspace e armazenamento de sessão são usados.

Grupos de transmissão (executar vários agentes)

Grupos de transmissão permitem executar vários agentes para o mesmo par quando o OpenClaw normalmente responderia (por exemplo: em grupos do WhatsApp, após gating de menção/ativação).

Configuração:

{
  broadcast: {
    strategy: "parallel",
    "[email protected]": ["alfred", "baerbel"],
    "+15555550123": ["support", "logger"],
  },
}

Veja: Grupos de transmissão.

Visão geral da configuração

  • agents.list: definições de agentes nomeados (workspace, modelo etc.).
  • bindings: mapeia canais/contas/pares recebidos para agentes.

Exemplo:

{
  agents: {
    list: [{ id: "support", name: "Support", workspace: "~/.openclaw/workspace-support" }],
  },
  bindings: [
    { match: { channel: "slack", teamId: "T123" }, agentId: "support" },
    { match: { channel: "telegram", peer: { kind: "group", id: "-100123" } }, agentId: "support" },
  ],
}

Armazenamento de sessão

Armazenamentos de sessão ficam no diretório de estado (padrão ~/.openclaw):

  • ~/.openclaw/agents/<agentId>/sessions/sessions.json
  • Transcrições JSONL ficam ao lado do armazenamento

Você pode substituir o caminho do armazenamento via session.store e templates com {agentId}.

A descoberta de sessões do Gateway e ACP também varre armazenamentos de agentes em disco sob a raiz padrão agents/ e sob raízes de session.store com templates. Armazenamentos descobertos devem permanecer dentro dessa raiz de agente resolvida e usar um arquivo sessions.json regular. Symlinks e caminhos fora da raiz são ignorados.

Comportamento do WebChat

O WebChat se conecta ao agente selecionado e usa por padrão a sessão principal do agente. Por isso, o WebChat permite ver o contexto entre canais desse agente em um só lugar.

Contexto de resposta

Respostas recebidas incluem:

  • ReplyToId, ReplyToBody e ReplyToSender quando disponíveis.
  • O contexto citado é acrescentado ao Body como um bloco [Replying to ...].

Isso é consistente em todos os canais.

Relacionados