Gateway
Configuração — canais
Configuração por canal em channels.*. Abrange acesso por DM e grupos,
configurações de múltiplas contas, controle por menção e chaves por canal para Slack, Discord,
Telegram, WhatsApp, Matrix, iMessage e os outros plugins de canal incluídos.
Para agentes, ferramentas, runtime do Gateway e outras chaves de nível superior, consulte Referência de configuração.
Canais
Cada canal inicia automaticamente quando sua seção de configuração existe (a menos que enabled: false).
Acesso por DM e grupo
Todos os canais oferecem suporte a políticas de DM e políticas de grupo:
| Política de DM | Comportamento |
|---|---|
pairing (padrão) |
Remetentes desconhecidos recebem um código de pareamento único; o proprietário deve aprovar |
allowlist |
Apenas remetentes em allowFrom (ou no armazenamento de permissões pareadas) |
open |
Permite todas as DMs de entrada (requer allowFrom: ["*"]) |
disabled |
Ignora todas as DMs de entrada |
| Política de grupo | Comportamento |
|---|---|
allowlist (padrão) |
Apenas grupos que correspondem à lista de permissões configurada |
open |
Ignora listas de permissões de grupo (o controle por menção ainda se aplica) |
disabled |
Bloqueia todas as mensagens de grupo/sala |
Substituições de modelo por canal
Use channels.modelByChannel para fixar IDs de canal específicos a um modelo. Os valores aceitam provider/model ou aliases de modelo configurados. O mapeamento de canal se aplica quando uma sessão ainda não tem uma substituição de modelo (por exemplo, definida via /model).
{
channels: {
modelByChannel: {
discord: {
"123456789012345678": "anthropic/claude-opus-4-6",
},
slack: {
C1234567890: "openai/gpt-4.1",
},
telegram: {
"-1001234567890": "openai/gpt-4.1-mini",
"-1001234567890:topic:99": "anthropic/claude-sonnet-4-6",
},
},
},
}
Padrões de canal e Heartbeat
Use channels.defaults para comportamento compartilhado de política de grupo e Heartbeat entre provedores:
{
channels: {
defaults: {
groupPolicy: "allowlist", // open | allowlist | disabled
contextVisibility: "all", // all | allowlist | allowlist_quote
heartbeat: {
showOk: false,
showAlerts: true,
useIndicator: true,
},
},
},
}
channels.defaults.groupPolicy: política de grupo de fallback quando umgroupPolicyno nível do provedor não está definido.channels.defaults.contextVisibility: modo padrão de visibilidade de contexto suplementar para todos os canais. Valores:all(padrão, inclui todo contexto citado/thread/histórico),allowlist(inclui apenas contexto de remetentes na lista de permissões),allowlist_quote(igual a allowlist, mas mantém contexto explícito de citação/resposta). Substituição por canal:channels.<channel>.contextVisibility.channels.defaults.heartbeat.showOk: inclui status íntegros de canais na saída de Heartbeat.channels.defaults.heartbeat.showAlerts: inclui status degradados/com erro na saída de Heartbeat.channels.defaults.heartbeat.useIndicator: renderiza saída compacta de Heartbeat no estilo de indicador.
O WhatsApp roda pelo canal web do Gateway (Baileys Web). Ele inicia automaticamente quando existe uma sessão vinculada.
{
web: {
enabled: true,
heartbeatSeconds: 60,
whatsapp: {
keepAliveIntervalMs: 25000,
connectTimeoutMs: 60000,
defaultQueryTimeoutMs: 60000,
},
reconnect: {
initialMs: 2000,
maxMs: 120000,
factor: 1.4,
jitter: 0.2,
maxAttempts: 0,
},
},
channels: {
whatsapp: {
dmPolicy: "pairing", // pairing | allowlist | open | disabled
allowFrom: ["+15555550123", "+447700900123"],
textChunkLimit: 4000,
chunkMode: "length", // length | newline
mediaMaxMb: 50,
sendReadReceipts: true, // blue ticks (false in self-chat mode)
groups: {
"*": { requireMention: true },
},
groupPolicy: "allowlist",
groupAllowFrom: ["+15551234567"],
},
},
}
WhatsApp com múltiplas contas
{
channels: {
whatsapp: {
accounts: {
default: {},
personal: {},
biz: {
// authDir: "~/.openclaw/credentials/whatsapp/biz",
},
},
},
},
}
- Comandos de saída usam por padrão a conta
default, se presente; caso contrário, o primeiro id de conta configurado (ordenado). - O opcional
channels.whatsapp.defaultAccountsubstitui essa seleção de conta padrão de fallback quando corresponde a um id de conta configurado. - O diretório legado de autenticação Baileys de conta única é migrado pelo
openclaw doctorparawhatsapp/default. - Substituições por conta:
channels.whatsapp.accounts.<id>.sendReadReceipts,channels.whatsapp.accounts.<id>.dmPolicy,channels.whatsapp.accounts.<id>.allowFrom.
Telegram
{
channels: {
telegram: {
enabled: true,
botToken: "your-bot-token",
dmPolicy: "pairing",
allowFrom: ["tg:123456789"],
groups: {
"*": { requireMention: true },
"-1001234567890": {
allowFrom: ["@admin"],
systemPrompt: "Keep answers brief.",
topics: {
"99": {
requireMention: false,
skills: ["search"],
systemPrompt: "Stay on topic.",
},
},
},
},
customCommands: [
{ command: "backup", description: "Git backup" },
{ command: "generate", description: "Create an image" },
],
historyLimit: 50,
replyToMode: "first", // off | first | all | batched
linkPreview: true,
streaming: "partial", // off | partial | block | progress (default: off; opt in explicitly to avoid preview-edit rate limits)
actions: { reactions: true, sendMessage: true },
reactionNotifications: "own", // off | own | all
mediaMaxMb: 100,
retry: {
attempts: 3,
minDelayMs: 400,
maxDelayMs: 30000,
jitter: 0.1,
},
network: {
autoSelectFamily: true,
dnsResultOrder: "ipv4first",
},
apiRoot: "https://api.telegram.org",
proxy: "socks5://localhost:9050",
webhookUrl: "https://example.com/telegram-webhook",
webhookSecret: "secret",
webhookPath: "/telegram-webhook",
},
},
}
- Token do bot:
channels.telegram.botTokenouchannels.telegram.tokenFile(somente arquivo regular; symlinks rejeitados), comTELEGRAM_BOT_TOKENcomo fallback para a conta padrão. apiRooté apenas a raiz da Telegram Bot API. Usehttps://api.telegram.orgou sua raiz auto-hospedada/proxy, nãohttps://api.telegram.org/bot<TOKEN>;openclaw doctor --fixremove um sufixo/bot<TOKEN>final acidental.- O opcional
channels.telegram.defaultAccountsubstitui a seleção de conta padrão quando corresponde a um id de conta configurado. - Em configurações de múltiplas contas (2+ ids de conta), defina um padrão explícito (
channels.telegram.defaultAccountouchannels.telegram.accounts.default) para evitar roteamento de fallback;openclaw doctoravisa quando isso está ausente ou inválido. configWrites: falsebloqueia gravações de configuração iniciadas pelo Telegram (migrações de ID de supergrupo,/config set|unset).- Entradas
bindings[]de nível superior comtype: "acp"configuram vinculações ACP persistentes para tópicos de fórum (use o formato canônicochatId:topic:topicIdemmatch.peer.id). A semântica dos campos é compartilhada em Agentes ACP. - Pré-visualizações de stream do Telegram usam
sendMessage+editMessageText(funciona em conversas diretas e em grupos). - Política de nova tentativa: consulte Política de nova tentativa.
Discord
{
channels: {
discord: {
enabled: true,
token: "your-bot-token",
mediaMaxMb: 100,
allowBots: false,
actions: {
reactions: true,
stickers: true,
polls: true,
permissions: true,
messages: true,
threads: true,
pins: true,
search: true,
memberInfo: true,
roleInfo: true,
roles: false,
channelInfo: true,
voiceStatus: true,
events: true,
moderation: false,
},
replyToMode: "off", // off | first | all | batched
dmPolicy: "pairing",
allowFrom: ["1234567890", "123456789012345678"],
dm: { enabled: true, groupEnabled: false, groupChannels: ["openclaw-dm"] },
guilds: {
"123456789012345678": {
slug: "friends-of-openclaw",
requireMention: false,
ignoreOtherMentions: true,
reactionNotifications: "own",
users: ["987654321098765432"],
channels: {
general: { allow: true },
help: {
allow: true,
requireMention: true,
users: ["987654321098765432"],
skills: ["docs"],
systemPrompt: "Short answers only.",
},
},
},
},
historyLimit: 20,
textChunkLimit: 2000,
chunkMode: "length", // length | newline
streaming: {
mode: "progress", // off | partial | block | progress (Discord default: progress)
progress: {
label: "auto",
maxLines: 8,
toolProgress: true,
},
},
maxLinesPerMessage: 17,
ui: {
components: {
accentColor: "#5865F2",
},
},
threadBindings: {
enabled: true,
idleHours: 24,
maxAgeHours: 0,
spawnSessions: true,
defaultSpawnContext: "fork",
},
voice: {
enabled: true,
autoJoin: [
{
guildId: "123456789012345678",
channelId: "234567890123456789",
},
],
daveEncryption: true,
decryptionFailureTolerance: 24,
connectTimeoutMs: 30000,
reconnectGraceMs: 15000,
tts: {
provider: "openai",
openai: { voice: "alloy" },
},
},
execApprovals: {
enabled: "auto", // true | false | "auto"
approvers: ["987654321098765432"],
agentFilter: ["default"],
sessionFilter: ["discord:"],
target: "dm", // dm | channel | both
cleanupAfterResolve: false,
},
retry: {
attempts: 3,
minDelayMs: 500,
maxDelayMs: 30000,
jitter: 0.1,
},
},
},
}
- Token:
channels.discord.token, comDISCORD_BOT_TOKENcomo fallback para a conta padrão. - Chamadas diretas de saída que fornecem um
tokendo Discord explícito usam esse token para a chamada; as configurações de tentativa/política da conta ainda vêm da conta selecionada no snapshot de runtime ativo. - O
channels.discord.defaultAccountopcional substitui a seleção da conta padrão quando corresponde a um id de conta configurado. - Use
user:<id>(DM) ouchannel:<id>(canal de guilda) para destinos de entrega; IDs numéricos sem prefixo são rejeitados. - Slugs de guilda ficam em minúsculas com espaços substituídos por
-; chaves de canal usam o nome com slug (sem#). Prefira IDs de guilda. - Mensagens de autoria de bots são ignoradas por padrão.
allowBots: trueas habilita; useallowBots: "mentions"para aceitar apenas mensagens de bots que mencionem o bot (as próprias mensagens ainda são filtradas). channels.discord.guilds.<id>.ignoreOtherMentions(e substituições de canal) descarta mensagens que mencionam outro usuário ou cargo, mas não o bot (excluindo @everyone/@here).channels.discord.mentionAliasesmapeia texto@handleestável de saída para IDs de usuário do Discord antes do envio, para que colegas de equipe conhecidos possam ser mencionados de forma determinística mesmo quando o cache de diretório transitório estiver vazio. Substituições por conta ficam emchannels.discord.accounts.<accountId>.mentionAliases.maxLinesPerMessage(padrão 17) divide mensagens altas mesmo quando têm menos de 2000 caracteres.channels.discord.threadBindingscontrola o roteamento vinculado a threads do Discord:enabled: substituição do Discord para recursos de sessão vinculada a thread (/focus,/unfocus,/agents,/session idle,/session max-agee entrega/roteamento vinculados)idleHours: substituição do Discord para auto-desfoco por inatividade em horas (0desabilita)maxAgeHours: substituição do Discord para idade máxima rígida em horas (0desabilita)spawnSessions: alternador parasessions_spawn({ thread: true })e criação/vinculação automática de thread em spawn de thread ACP (padrão:true)defaultSpawnContext: contexto nativo de subagente para spawns vinculados a thread ("fork"por padrão)
- Entradas
bindings[]de nível superior comtype: "acp"configuram vinculações ACP persistentes para canais e threads (use o id de canal/thread emmatch.peer.id). A semântica dos campos é compartilhada em Agentes ACP. channels.discord.ui.components.accentColordefine a cor de destaque para contêineres de componentes v2 do Discord.channels.discord.voicehabilita conversas em canais de voz do Discord e substituições opcionais de entrada automática + LLM + TTS. Configurações do Discord somente texto deixam voz desativada por padrão; definachannels.discord.voice.enabled=truepara optar por ativar.channels.discord.voice.modelopcionalmente substitui o modelo LLM usado para respostas em canais de voz do Discord.channels.discord.voice.daveEncryptionechannels.discord.voice.decryptionFailureTolerancesão repassados para as opções DAVE de@discordjs/voice(truee24por padrão).channels.discord.voice.connectTimeoutMscontrola a espera inicial por Ready do@discordjs/voicepara/vc joine tentativas de entrada automática (30000por padrão).channels.discord.voice.reconnectGraceMscontrola quanto tempo uma sessão de voz desconectada pode levar para entrar em sinalização de reconexão antes que o OpenClaw a destrua (15000por padrão).- A reprodução de voz do Discord não é interrompida pelo evento de início de fala de outro usuário. Para evitar loops de feedback, o OpenClaw ignora nova captura de voz enquanto o TTS está sendo reproduzido.
- O OpenClaw também tenta recuperar o recebimento de voz saindo/entrando novamente em uma sessão de voz após falhas repetidas de descriptografia.
channels.discord.streamingé a chave canônica do modo de stream. O Discord usastreaming.mode: "progress"por padrão, para que o progresso de ferramentas/trabalho apareça em uma mensagem de prévia editada; definastreaming.mode: "off"para desabilitar. Valores legados destreamModeestreamingbooleano permanecem como aliases de runtime; executeopenclaw doctor --fixpara reescrever a configuração persistida.channels.discord.autoPresencemapeia a disponibilidade de runtime para a presença do bot (healthy => online, degraded => idle, exhausted => dnd) e permite substituições opcionais de texto de status.channels.discord.dangerouslyAllowNameMatchingreabilita correspondência mutável por nome/tag (modo de compatibilidade de emergência).channels.discord.execApprovals: entrega de aprovação de exec nativa do Discord e autorização de aprovadores.enabled:true,falseou"auto"(padrão). No modo automático, aprovações de exec são ativadas quando aprovadores podem ser resolvidos deapproversoucommands.ownerAllowFrom.approvers: IDs de usuário do Discord autorizados a aprovar solicitações de exec. Usacommands.ownerAllowFromcomo fallback quando omitido.agentFilter: allowlist opcional de IDs de agente. Omita para encaminhar aprovações de todos os agentes.sessionFilter: padrões opcionais de chave de sessão (substring ou regex).target: para onde enviar prompts de aprovação."dm"(padrão) envia para DMs dos aprovadores,"channel"envia para o canal de origem,"both"envia para ambos. Quando o destino inclui"channel", os botões só podem ser usados por aprovadores resolvidos.cleanupAfterResolve: quandotrue, exclui DMs de aprovação após aprovação, negação ou timeout.
Modos de notificação de reação: off (nenhuma), own (mensagens do bot, padrão), all (todas as mensagens), allowlist (de guilds.<id>.users em todas as mensagens).
Google Chat
{
channels: {
googlechat: {
enabled: true,
serviceAccountFile: "/path/to/service-account.json",
audienceType: "app-url", // app-url | project-number
audience: "https://gateway.example.com/googlechat",
webhookPath: "/googlechat",
botUser: "users/1234567890",
dm: {
enabled: true,
policy: "pairing",
allowFrom: ["users/1234567890"],
},
groupPolicy: "allowlist",
groups: {
"spaces/AAAA": { allow: true, requireMention: true },
},
actions: { reactions: true },
typingIndicator: "message",
mediaMaxMb: 20,
},
},
}
- JSON de conta de serviço: inline (
serviceAccount) ou baseado em arquivo (serviceAccountFile). - SecretRef de conta de serviço também é compatível (
serviceAccountRef). - Fallbacks de env:
GOOGLE_CHAT_SERVICE_ACCOUNTouGOOGLE_CHAT_SERVICE_ACCOUNT_FILE. - Use
spaces/<spaceId>ouusers/<userId>para destinos de entrega. channels.googlechat.dangerouslyAllowNameMatchingreabilita correspondência mutável de principal de e-mail (modo de compatibilidade de emergência).
Slack
{
channels: {
slack: {
enabled: true,
botToken: "xoxb-...",
appToken: "xapp-...",
socketMode: {
clientPingTimeout: 15000,
serverPingTimeout: 30000,
pingPongLoggingEnabled: false,
},
dmPolicy: "pairing",
allowFrom: ["U123", "U456", "*"],
dm: { enabled: true, groupEnabled: false, groupChannels: ["G123"] },
channels: {
C123: { allow: true, requireMention: true, allowBots: false },
"#general": {
allow: true,
requireMention: true,
allowBots: false,
users: ["U123"],
skills: ["docs"],
systemPrompt: "Short answers only.",
},
},
historyLimit: 50,
allowBots: false,
reactionNotifications: "own",
reactionAllowlist: ["U123"],
replyToMode: "off", // off | first | all | batched
thread: {
historyScope: "thread", // thread | channel
inheritParent: false,
},
actions: {
reactions: true,
messages: true,
pins: true,
memberInfo: true,
emojiList: true,
},
slashCommand: {
enabled: true,
name: "openclaw",
sessionPrefix: "slack:slash",
ephemeral: true,
},
typingReaction: "hourglass_flowing_sand",
textChunkLimit: 4000,
chunkMode: "length",
streaming: {
mode: "partial", // off | partial | block | progress
nativeTransport: true, // use Slack native streaming API when mode=partial
},
mediaMaxMb: 20,
execApprovals: {
enabled: "auto", // true | false | "auto"
approvers: ["U123"],
agentFilter: ["default"],
sessionFilter: ["slack:"],
target: "dm", // dm | channel | both
},
},
},
}
- Modo Socket exige
botTokeneappToken(SLACK_BOT_TOKEN+SLACK_APP_TOKENpara fallback de env da conta padrão). - Modo HTTP exige
botTokenmaissigningSecret(na raiz ou por conta). socketModerepassa ajustes de transporte do Socket Mode do SDK Slack para a API pública do receptor Bolt. Use apenas ao investigar timeout de ping/pong ou comportamento obsoleto de websocket.botToken,appToken,signingSecreteuserTokenaceitam strings de texto simples ou objetos SecretRef.- Snapshots de conta do Slack expõem campos de origem/status por credencial, como
botTokenSource,botTokenStatus,appTokenStatuse, no modo HTTP,signingSecretStatus.configured_unavailablesignifica que a conta está configurada por SecretRef, mas o caminho atual de comando/runtime não conseguiu resolver o valor do segredo. configWrites: falsebloqueia gravações de configuração iniciadas pelo Slack.- O
channels.slack.defaultAccountopcional substitui a seleção da conta padrão quando corresponde a um id de conta configurado. channels.slack.streaming.modeé a chave canônica do modo de stream do Slack.channels.slack.streaming.nativeTransportcontrola o transporte de streaming nativo do Slack. Valores legados destreamMode,streamingbooleano enativeStreamingpermanecem como aliases de runtime; executeopenclaw doctor --fixpara reescrever a configuração persistida.- Use
user:<id>(DM) ouchannel:<id>para destinos de entrega.
Modos de notificação de reação: off, own (padrão), all, allowlist (de reactionAllowlist).
Isolamento de sessão de thread: thread.historyScope é por thread (padrão) ou compartilhado pelo canal. thread.inheritParent copia a transcrição do canal pai para novas threads.
- O streaming nativo do Slack mais o status de thread "is typing..." no estilo de assistente do Slack exigem um destino de thread de resposta. DMs de nível superior ficam fora de threads por padrão, então ainda podem transmitir por meio de prévias de rascunho publicar-e-editar do Slack em vez de mostrar a prévia nativa de stream/status no estilo de thread.
typingReactionadiciona uma reação temporária à mensagem de entrada do Slack enquanto uma resposta está em andamento e a remove ao concluir. Use um shortcode de emoji do Slack, como"hourglass_flowing_sand".channels.slack.execApprovals: entrega de aprovação de exec nativa do Slack e autorização de aprovadores. Mesmo esquema do Discord:enabled(true/false/"auto"),approvers(IDs de usuário do Slack),agentFilter,sessionFilteretarget("dm","channel"ou"both").
| Grupo de ações | Padrão | Observações |
|---|---|---|
| reactions | habilitado | Reagir + listar reações |
| messages | habilitado | Ler/enviar/editar/excluir |
| pins | habilitado | Fixar/desafixar/listar |
| memberInfo | habilitado | Informações do membro |
| emojiList | habilitado | Lista de emojis personalizados |
Mattermost
O Mattermost é distribuído como um Plugin integrado nas versões atuais do OpenClaw. Builds mais antigos ou personalizados podem instalar um pacote npm atual com openclaw plugins install @openclaw/mattermost. Verifique npmjs.com/package/@openclaw/mattermost para os dist-tags atuais antes de fixar uma versão.
{
channels: {
mattermost: {
enabled: true,
botToken: "mm-token",
baseUrl: "https://chat.example.com",
dmPolicy: "pairing",
chatmode: "oncall", // oncall | onmessage | onchar
oncharPrefixes: [">", "!"],
groups: {
"*": { requireMention: true },
"team-channel-id": { requireMention: false },
},
commands: {
native: true, // opt-in
nativeSkills: true,
callbackPath: "/api/channels/mattermost/command",
// Optional explicit URL for reverse-proxy/public deployments
callbackUrl: "https://gateway.example.com/api/channels/mattermost/command",
},
textChunkLimit: 4000,
chunkMode: "length",
},
},
}
Modos de chat: oncall (responde a @-menção, padrão), onmessage (toda mensagem), onchar (mensagens que começam com o prefixo acionador).
Quando comandos nativos do Mattermost estão habilitados:
commands.callbackPathdeve ser um caminho (por exemplo/api/channels/mattermost/command), não uma URL completa.commands.callbackUrldeve resolver para o endpoint do Gateway do OpenClaw e estar acessível a partir do servidor Mattermost.- Callbacks slash nativos são autenticados com os tokens por comando retornados
pelo Mattermost durante o registro de comandos slash. Se o registro falhar ou nenhum
comando for ativado, o OpenClaw rejeita callbacks com
Unauthorized: invalid command token. - Para hosts de callback privados/tailnet/internos, o Mattermost pode exigir que
ServiceSettings.AllowedUntrustedInternalConnectionsinclua o host/domínio de callback. Use valores de host/domínio, não URLs completas. channels.mattermost.configWrites: permite ou nega gravações de configuração iniciadas pelo Mattermost.channels.mattermost.requireMention: exige@mentionantes de responder em canais.channels.mattermost.groups.<channelId>.requireMention: substituição por canal para bloqueio por menção ("*"como padrão).channels.mattermost.defaultAccountopcional substitui a seleção de conta padrão quando corresponde a um id de conta configurado.
Signal
{
channels: {
signal: {
enabled: true,
account: "+15555550123", // optional account binding
dmPolicy: "pairing",
allowFrom: ["+15551234567", "uuid:123e4567-e89b-12d3-a456-426614174000"],
configWrites: true,
reactionNotifications: "own", // off | own | all | allowlist
reactionAllowlist: ["+15551234567", "uuid:123e4567-e89b-12d3-a456-426614174000"],
historyLimit: 50,
},
},
}
Modos de notificação de reação: off, own (padrão), all, allowlist (de reactionAllowlist).
channels.signal.account: fixa a inicialização do canal a uma identidade de conta específica do Signal.channels.signal.configWrites: permite ou nega gravações de configuração iniciadas pelo Signal.channels.signal.defaultAccountopcional substitui a seleção de conta padrão quando corresponde a um id de conta configurado.
BlueBubbles
BlueBubbles é a ponte legada do iMessage (baseada em Plugin, configurada em channels.bluebubbles). Configurações existentes continuam com suporte, mas novas implantações do iMessage no OpenClaw devem preferir channels.imessage quando imsg puder ser executado no host do Messages.
{
channels: {
bluebubbles: {
enabled: true,
dmPolicy: "pairing",
// serverUrl, password, webhookPath, group controls, and advanced actions:
// see /channels/bluebubbles
},
},
}
- Principais caminhos de chave cobertos aqui:
channels.bluebubbles,channels.bluebubbles.dmPolicy. channels.bluebubbles.defaultAccountopcional substitui a seleção de conta padrão quando corresponde a um id de conta configurado.- Entradas
bindings[]de nível superior comtype: "acp"podem vincular conversas do BlueBubbles a sessões ACP persistentes. Use um identificador do BlueBubbles ou uma string de destino (chat_id:*,chat_guid:*,chat_identifier:*) emmatch.peer.id. Semântica de campos compartilhados: Agentes ACP. - A configuração completa do canal BlueBubbles e a justificativa de descontinuação estão documentadas em BlueBubbles.
iMessage
O OpenClaw inicia imsg rpc (JSON-RPC sobre stdio). Nenhum daemon ou porta é necessário. Este é o caminho preferido para novas configurações do iMessage no OpenClaw quando o host pode conceder permissões de banco de dados do Messages e Automação.
{
channels: {
imessage: {
enabled: true,
cliPath: "imsg",
dbPath: "~/Library/Messages/chat.db",
remoteHost: "user@gateway-host",
dmPolicy: "pairing",
allowFrom: ["+15555550123", "[email protected]", "chat_id:123"],
historyLimit: 50,
includeAttachments: false,
attachmentRoots: ["/Users/*/Library/Messages/Attachments"],
remoteAttachmentRoots: ["/Users/*/Library/Messages/Attachments"],
mediaMaxMb: 16,
service: "auto",
region: "US",
},
},
}
-
channels.imessage.defaultAccountopcional substitui a seleção de conta padrão quando corresponde a um id de conta configurado. -
Exige Acesso Total ao Disco para o banco de dados do Messages.
-
Prefira destinos
chat_id:<id>. Useimsg chats --limit 20para listar chats. -
cliPathpode apontar para um wrapper SSH; definaremoteHost(hostouuser@host) para buscar anexos por SCP. -
attachmentRootseremoteAttachmentRootsrestringem caminhos de anexos recebidos (padrão:/Users/*/Library/Messages/Attachments). -
SCP usa verificação estrita de chave de host, então garanta que a chave do host de retransmissão já exista em
~/.ssh/known_hosts. -
channels.imessage.configWrites: permite ou nega gravações de configuração iniciadas pelo iMessage. -
Entradas
bindings[]de nível superior comtype: "acp"podem vincular conversas do iMessage a sessões ACP persistentes. Use um identificador normalizado ou destino de chat explícito (chat_id:*,chat_guid:*,chat_identifier:*) emmatch.peer.id. Semântica de campos compartilhados: Agentes ACP.
Exemplo de wrapper SSH do iMessage
#!/usr/bin/env bash
exec ssh -T gateway-host imsg "$@"
Matrix
Matrix é baseado em Plugin e configurado em channels.matrix.
{
channels: {
matrix: {
enabled: true,
homeserver: "https://matrix.example.org",
accessToken: "syt_bot_xxx",
proxy: "http://127.0.0.1:7890",
encryption: true,
initialSyncLimit: 20,
defaultAccount: "ops",
accounts: {
ops: {
name: "Ops",
userId: "@ops:example.org",
accessToken: "syt_ops_xxx",
},
alerts: {
userId: "@alerts:example.org",
password: "secret",
proxy: "http://127.0.0.1:7891",
},
},
},
},
}
- A autenticação por token usa
accessToken; a autenticação por senha usauserId+password. channels.matrix.proxyroteia o tráfego HTTP do Matrix por um proxy HTTP(S) explícito. Contas nomeadas podem substituí-lo comchannels.matrix.accounts.<id>.proxy.channels.matrix.network.dangerouslyAllowPrivateNetworkpermite homeservers privados/internos.proxye esta opção de rede são controles independentes.channels.matrix.defaultAccountseleciona a conta preferida em configurações com várias contas.channels.matrix.autoJoinusaoffpor padrão, então salas convidadas e novos convites no estilo DM são ignorados até você definirautoJoin: "allowlist"comautoJoinAllowlistouautoJoin: "always".channels.matrix.execApprovals: entrega de aprovação de exec nativa do Matrix e autorização de aprovador.enabled:true,falseou"auto"(padrão). No modo automático, aprovações de exec são ativadas quando aprovadores podem ser resolvidos a partir deapproversoucommands.ownerAllowFrom.approvers: IDs de usuário Matrix (por exemplo,@owner:example.org) autorizados a aprovar solicitações de exec.agentFilter: lista de permissões opcional de IDs de agente. Omita para encaminhar aprovações para todos os agentes.sessionFilter: padrões opcionais de chave de sessão (substring ou regex).target: para onde enviar prompts de aprovação."dm"(padrão),"channel"(sala de origem) ou"both".- Substituições por conta:
channels.matrix.accounts.<id>.execApprovals.
channels.matrix.dm.sessionScopecontrola como DMs do Matrix são agrupadas em sessões:per-user(padrão) compartilha por par roteado, enquantoper-roomisola cada sala de DM.- Sondagens de status do Matrix e consultas ao diretório em tempo real usam a mesma política de proxy do tráfego em runtime.
- A configuração completa do Matrix, regras de direcionamento e exemplos de configuração estão documentados em Matrix.
Microsoft Teams
Microsoft Teams é baseado em Plugin e configurado em channels.msteams.
{
channels: {
msteams: {
enabled: true,
configWrites: true,
// appId, appPassword, tenantId, webhook, team/channel policies:
// see /channels/msteams
},
},
}
- Principais caminhos de chave cobertos aqui:
channels.msteams,channels.msteams.configWrites. - A configuração completa do Teams (credenciais, Webhook, política de DM/grupo, substituições por equipe/por canal) está documentada em Microsoft Teams.
IRC
IRC é baseado em Plugin e configurado em channels.irc.
{
channels: {
irc: {
enabled: true,
dmPolicy: "pairing",
configWrites: true,
nickserv: {
enabled: true,
service: "NickServ",
password: "${IRC_NICKSERV_PASSWORD}",
register: false,
registerEmail: "[email protected]",
},
},
},
}
- Principais caminhos de chave cobertos aqui:
channels.irc,channels.irc.dmPolicy,channels.irc.configWrites,channels.irc.nickserv.*. channels.irc.defaultAccountopcional substitui a seleção de conta padrão quando corresponde a um id de conta configurado.- A configuração completa do canal IRC (host/porta/TLS/canais/listas de permissões/bloqueio por menção) está documentada em IRC.
Várias contas (todos os canais)
Execute várias contas por canal (cada uma com seu próprio accountId):
{
channels: {
telegram: {
accounts: {
default: {
name: "Primary bot",
botToken: "123456:ABC...",
},
alerts: {
name: "Alerts bot",
botToken: "987654:XYZ...",
},
},
},
},
}
defaulté usado quandoaccountIdé omitido (CLI + roteamento).- Tokens de ambiente se aplicam apenas à conta padrão.
- Configurações base do canal se aplicam a todas as contas, a menos que sejam substituídas por conta.
- Use
bindings[].match.accountIdpara rotear cada conta para um agente diferente. - Se você adicionar uma conta não padrão via
openclaw channels add(ou onboarding de canal) enquanto ainda estiver em uma configuração de canal de nível superior com uma única conta, o OpenClaw primeiro promove valores de conta única de nível superior com escopo de conta para o mapa de contas do canal para que a conta original continue funcionando. A maioria dos canais os move parachannels.<channel>.accounts.default; o Matrix pode preservar um destino nomeado/padrão correspondente existente. - Bindings existentes somente de canal (sem
accountId) continuam correspondendo à conta padrão; bindings com escopo de conta permanecem opcionais. openclaw doctor --fixtambém repara formatos mistos movendo valores de conta única de nível superior com escopo de conta para a conta promovida escolhida para esse canal. A maioria dos canais usaaccounts.default; o Matrix pode preservar um destino nomeado/padrão correspondente existente.
Outros canais de Plugin
Muitos canais de Plugin são configurados como channels.<id> e documentados em suas páginas de canal dedicadas (por exemplo Feishu, Matrix, LINE, Nostr, Zalo, Nextcloud Talk, Synology Chat e Twitch).
Veja o índice completo de canais: Canais.
Bloqueio por menção em chat de grupo
Mensagens de grupo exigem menção obrigatória por padrão (menção de metadados ou padrões regex seguros). Aplica-se a chats de grupo do WhatsApp, Telegram, Discord, Google Chat e iMessage.
As respostas visíveis são controladas separadamente. Salas de grupo/canal usam por padrão messages.groupChat.visibleReplies: "message_tool": o OpenClaw ainda processa o turno, mas as respostas finais normais permanecem privadas e a saída visível da sala exige message(action=send). Defina "automatic" somente quando quiser o comportamento legado em que respostas normais são publicadas de volta na sala. Para aplicar o mesmo comportamento de resposta visível somente por ferramenta também a conversas diretas, defina messages.visibleReplies: "message_tool"; o harness do Codex também usa esse comportamento somente por ferramenta como padrão não definido para conversas diretas.
Respostas visíveis somente por ferramenta exigem um modelo/runtime que chame ferramentas de forma confiável. Se
o log da sessão mostrar texto do assistente com didSendViaMessagingTool: false, o
modelo produziu uma resposta final privada em vez de chamar a ferramenta de mensagens.
Troque para um modelo mais forte em chamadas de ferramentas para esse canal, ou defina
messages.groupChat.visibleReplies: "automatic" para restaurar as respostas finais
visíveis legadas.
Se a ferramenta de mensagens estiver indisponível sob a política de ferramentas ativa, o OpenClaw recorre a respostas visíveis automáticas em vez de suprimir silenciosamente a resposta. openclaw doctor avisa sobre essa incompatibilidade.
O gateway recarrega a configuração de messages a quente depois que o arquivo é salvo. Reinicie somente quando a observação de arquivos ou o recarregamento de configuração estiver desativado na implantação.
Tipos de menção:
- Menções de metadados: @-menções nativas da plataforma. Ignoradas no modo de conversa consigo mesmo do WhatsApp.
- Padrões de texto: Padrões regex seguros em
agents.list[].groupChat.mentionPatterns. Padrões inválidos e repetição aninhada insegura são ignorados. - O bloqueio por menção é imposto somente quando a detecção é possível (menções nativas ou pelo menos um padrão).
{
messages: {
visibleReplies: "automatic", // padrão global para conversas diretas/de origem; o harness do Codex usa message_tool como padrão para conversas diretas não definidas
groupChat: {
historyLimit: 50,
visibleReplies: "message_tool", // padrão; use "automatic" para respostas finais legadas
},
},
agents: {
list: [{ id: "main", groupChat: { mentionPatterns: ["@openclaw", "openclaw"] } }],
},
}
messages.groupChat.historyLimit define o padrão global. Canais podem substituir com channels.<channel>.historyLimit (ou por conta). Defina 0 para desativar.
messages.visibleReplies é o padrão global para turnos de origem; messages.groupChat.visibleReplies o substitui para turnos de origem de grupo/canal. Quando messages.visibleReplies não está definido, um harness pode fornecer seu próprio padrão direto/de origem; o harness do Codex usa message_tool por padrão. Listas de permissões de canal e bloqueio por menção ainda decidem se um turno é processado.
Limites de histórico de DM
{
channels: {
telegram: {
dmHistoryLimit: 30,
dms: {
"123456789": { historyLimit: 50 },
},
},
},
}
Resolução: substituição por DM → padrão do provedor → sem limite (tudo retido).
Compatível com: telegram, whatsapp, discord, slack, signal, imessage, msteams.
Modo de conversa consigo mesmo
Inclua seu próprio número em allowFrom para ativar o modo de conversa consigo mesmo (ignora @-menções nativas, responde apenas a padrões de texto):
{
channels: {
whatsapp: {
allowFrom: ["+15555550123"],
groups: { "*": { requireMention: true } },
},
},
agents: {
list: [
{
id: "main",
groupChat: { mentionPatterns: ["reisponde", "@openclaw"] },
},
],
},
}
Comandos (tratamento de comandos no chat)
{
commands: {
native: "auto", // registra comandos nativos quando houver suporte
nativeSkills: "auto", // registra comandos de skill nativos quando houver suporte
text: true, // analisa /commands em mensagens de chat
bash: false, // permite ! (alias: /bash)
bashForegroundMs: 2000,
config: false, // permite /config
mcp: false, // permite /mcp
plugins: false, // permite /plugins
debug: false, // permite /debug
restart: true, // permite /restart + ferramenta de reinício do gateway
ownerAllowFrom: ["discord:123456789012345678"],
ownerDisplay: "raw", // raw | hash
ownerDisplaySecret: "${OWNER_ID_HASH_SECRET}",
allowFrom: {
"*": ["user1"],
discord: ["user:123"],
},
useAccessGroups: true,
},
}
Detalhes dos comandos
- Este bloco configura superfícies de comando. Para o catálogo atual de comandos integrados + empacotados, consulte Comandos Slash.
- Esta página é uma referência de chaves de configuração, não o catálogo completo de comandos. Comandos pertencentes a canais/plugins, como QQ Bot
/bot-ping/bot-help/bot-logs, LINE/card, pareamento de dispositivo/pair, memória/dreaming, controle de telefone/phonee Talk/voice, estão documentados em suas páginas de canal/plugin mais Comandos Slash. - Comandos de texto devem ser mensagens isoladas com
/inicial. native: "auto"ativa comandos nativos para Discord/Telegram, deixa Slack desativado.nativeSkills: "auto"ativa comandos de skill nativos para Discord/Telegram, deixa Slack desativado.- Substituição por canal:
channels.discord.commands.native(bool ou"auto"). Para Discord,falsepula o registro e a limpeza de comandos nativos durante a inicialização. - Substitua o registro de skill nativo por canal com
channels.<provider>.commands.nativeSkills. channels.telegram.customCommandsadiciona entradas extras ao menu do bot do Telegram.bash: trueativa! <cmd>para o shell do host. Exigetools.elevated.enablede remetente emtools.elevated.allowFrom.<channel>.config: trueativa/config(lê/gravaopenclaw.json). Para clienteschat.senddo gateway, gravações persistentes de/config set|unsettambém exigemoperator.admin;/config showsomente leitura permanece disponível para clientes operadores normais com escopo de escrita.mcp: trueativa/mcppara configuração de servidor MCP gerenciada pelo OpenClaw emmcp.servers.plugins: trueativa/pluginspara descoberta, instalação e controles de ativar/desativar plugins.channels.<provider>.configWritescontrola mutações de configuração por canal (padrão: true).- Para canais de múltiplas contas,
channels.<provider>.accounts.<id>.configWritestambém controla gravações que miram essa conta (por exemplo,/allowlist --config --account <id>ou/config set channels.<provider>.accounts.<id>...). restart: falsedesativa/restarte ações da ferramenta de reinício do gateway. Padrão:true.ownerAllowFromé a lista de permissões explícita do proprietário para comandos/ferramentas exclusivos do proprietário. Ela é separada deallowFrom.ownerDisplay: "hash"gera hashes dos ids de proprietários no prompt do sistema. DefinaownerDisplaySecretpara controlar o hashing.allowFromé por provedor. Quando definido, é a única fonte de autorização (listas de permissões/pareamento de canal euseAccessGroupssão ignorados).useAccessGroups: falsepermite que comandos ignorem políticas de grupo de acesso quandoallowFromnão está definido.- Mapa da documentação de comandos:
- catálogo integrado + empacotado: Comandos Slash
- superfícies de comando específicas por canal: Canais
- comandos do QQ Bot: QQ Bot
- comandos de pareamento: Pareamento
- comando de cartão LINE: LINE
- dreaming da memória: Dreaming
Relacionado
- Referência de configuração — chaves de nível superior
- Configuração — agentes
- Visão geral de canais