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>.defaultAccountescolhe qual conta é usada quando um caminho de saída não especificaaccountId.- Em configurações com várias contas, defina um padrão explícito (
defaultAccountouaccounts.default) quando duas ou mais contas estiverem configuradas. Sem isso, o roteamento de fallback pode escolher o primeiro ID de conta normalizado.
- Em configurações com várias contas, defina um padrão explícito (
- 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:42agent: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:
allowFromtem 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:
- Correspondência exata de par (
bindingscompeer.kind+peer.id). - Correspondência de par pai (herança de thread).
- Correspondência de guilda + funções (Discord) via
guildId+roles. - Correspondência de guilda (Discord) via
guildId. - Correspondência de equipe (Slack) via
teamId. - Correspondência de conta (
accountIdno canal). - Correspondência de canal (qualquer conta nesse canal,
accountId: "*"). - Agente padrão (
agents.list[].default, senão a primeira entrada da lista, fallback paramain).
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,ReplyToBodyeReplyToSenderquando disponíveis.- O contexto citado é acrescentado ao
Bodycomo um bloco[Replying to ...].
Isso é consistente em todos os canais.