Chaves de configuração com escopo de agente emDocumentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
agents.*, multiAgent.*, session.*,
messages.* e talk.*. Para canais, ferramentas, runtime do Gateway e outras
chaves de nível superior, consulte Referência de configuração.
Padrões do agente
agents.defaults.workspace
Padrão: ~/.openclaw/workspace.
agents.defaults.repoRoot
Raiz opcional do repositório exibida na linha Runtime do prompt do sistema. Se não definida, o OpenClaw detecta automaticamente percorrendo para cima a partir do espaço de trabalho.
agents.defaults.skills
Lista de permissões padrão opcional de Skills para agentes que não definem
agents.list[].skills.
- Omita
agents.defaults.skillspara Skills irrestritas por padrão. - Omita
agents.list[].skillspara herdar os padrões. - Defina
agents.list[].skills: []para nenhuma Skills. - Uma lista
agents.list[].skillsnão vazia é o conjunto final desse agente; ela não é mesclada com os padrões.
agents.defaults.skipBootstrap
Desativa a criação automática de arquivos de bootstrap do espaço de trabalho (AGENTS.md, SOUL.md, TOOLS.md, IDENTITY.md, USER.md, HEARTBEAT.md, BOOTSTRAP.md).
agents.defaults.skipOptionalBootstrapFiles
Ignora a criação de arquivos opcionais selecionados do espaço de trabalho enquanto ainda grava os arquivos de bootstrap obrigatórios. Valores válidos: SOUL.md, USER.md, HEARTBEAT.md e IDENTITY.md.
agents.defaults.contextInjection
Controla quando os arquivos de bootstrap do espaço de trabalho são injetados no prompt do sistema. Padrão: "always".
"continuation-skip": turnos de continuação seguros (após uma resposta concluída do assistente) pulam a reinjeção do bootstrap do espaço de trabalho, reduzindo o tamanho do prompt. Execuções de Heartbeat e novas tentativas pós-Compaction ainda recriam o contexto."never": desativa o bootstrap do espaço de trabalho e a injeção de arquivos de contexto em todos os turnos. Use isso apenas para agentes que controlam totalmente o ciclo de vida do próprio prompt (mecanismos de contexto personalizados, runtimes nativos que criam o próprio contexto ou fluxos de trabalho especializados sem bootstrap). Turnos de Heartbeat e de recuperação de Compaction também pulam a injeção.
agents.defaults.bootstrapMaxChars
Máximo de caracteres por arquivo de bootstrap do espaço de trabalho antes do truncamento. Padrão: 12000.
agents.defaults.bootstrapTotalMaxChars
Máximo total de caracteres injetados em todos os arquivos de bootstrap do espaço de trabalho. Padrão: 60000.
agents.defaults.bootstrapPromptTruncationWarning
Controla o aviso visível ao agente no prompt do sistema quando o contexto de bootstrap é truncado.
Padrão: "once".
"off": nunca injeta texto de aviso de truncamento no prompt do sistema."once": injeta um aviso conciso uma vez por assinatura de truncamento única (recomendado)."always": injeta um aviso conciso em toda execução quando houver truncamento.
Mapa de propriedade do orçamento de contexto
O OpenClaw tem vários orçamentos de prompt/contexto de alto volume, e eles são intencionalmente divididos por subsistema em vez de todos passarem por um único controle genérico.agents.defaults.bootstrapMaxChars/agents.defaults.bootstrapTotalMaxChars: injeção normal de bootstrap do espaço de trabalho.agents.defaults.startupContext.*: preâmbulo de execução do modelo de reinicialização/inicialização de uso único, incluindo arquivosmemory/*.mddiários recentes. Comandos simples de chat/newe/resetsão confirmados sem invocar o modelo.skills.limits.*: a lista compacta de Skills injetada no prompt do sistema.agents.defaults.contextLimits.*: trechos de runtime limitados e blocos injetados pertencentes ao runtime.memory.qmd.limits.*: dimensionamento de injeção e trecho de busca de memória indexada.
agents.list[].skillsLimits.maxSkillsPromptCharsagents.list[].contextLimits.*
agents.defaults.startupContext
Controla o preâmbulo de inicialização do primeiro turno injetado em execuções do modelo de reinicialização/inicialização.
Comandos simples de chat /new e /reset confirmam a reinicialização sem invocar
o modelo, portanto não carregam esse preâmbulo.
agents.defaults.contextLimits
Padrões compartilhados para superfícies de contexto de runtime limitadas.
memoryGetMaxChars: limite padrão de trecho dememory_getantes que metadados de truncamento e aviso de continuação sejam adicionados.memoryGetDefaultLines: janela de linhas padrão dememory_getquandolinesé omitido.toolResultMaxChars: limite de resultado de ferramenta ao vivo usado para resultados persistidos e recuperação de overflow.postCompactionMaxChars: limite de trecho de AGENTS.md usado durante a injeção de atualização pós-Compaction.
agents.list[].contextLimits
Substituição por agente para os controles compartilhados de contextLimits. Campos omitidos herdam
de agents.defaults.contextLimits.
skills.limits.maxSkillsPromptChars
Limite global para a lista compacta de Skills injetada no prompt do sistema. Isso
não afeta a leitura de arquivos SKILL.md sob demanda.
agents.list[].skillsLimits.maxSkillsPromptChars
Substituição por agente para o orçamento de prompt de Skills.
agents.defaults.imageMaxDimensionPx
Tamanho máximo em pixels para o maior lado da imagem em blocos de imagem de transcrição/ferramenta antes das chamadas ao provedor.
Padrão: 1200.
Valores mais baixos geralmente reduzem o uso de tokens de visão e o tamanho da carga útil da solicitação em execuções com muitas capturas de tela.
Valores mais altos preservam mais detalhes visuais.
agents.defaults.userTimezone
Fuso horário para o contexto do prompt do sistema (não para carimbos de data/hora de mensagens). Recorre ao fuso horário do host.
agents.defaults.timeFormat
Formato de hora no prompt do sistema. Padrão: auto (preferência do sistema operacional).
agents.defaults.model
model: aceita uma string ("provider/model") ou um objeto ({ primary, fallbacks }).- A forma de string define apenas o modelo primário.
- A forma de objeto define o primário mais modelos de failover ordenados.
imageModel: aceita uma string ("provider/model") ou um objeto ({ primary, fallbacks }).- Usado pelo caminho da ferramenta
imagecomo sua configuração de modelo de visão. - Também usado como roteamento de fallback quando o modelo selecionado/padrão não aceita entrada de imagem.
- Prefira refs explícitas
provider/model. IDs simples são aceitos por compatibilidade; se um ID simples corresponder exclusivamente a uma entrada configurada com suporte a imagens emmodels.providers.*.models, o OpenClaw o qualifica para esse provedor. Correspondências configuradas ambíguas exigem um prefixo de provedor explícito.
- Usado pelo caminho da ferramenta
imageGenerationModel: aceita uma string ("provider/model") ou um objeto ({ primary, fallbacks }).- Usado pela capacidade compartilhada de geração de imagens e por qualquer superfície futura de ferramenta/plugin que gere imagens.
- Valores típicos:
google/gemini-3.1-flash-image-previewpara geração nativa de imagens do Gemini,fal/fal-ai/flux/devpara fal,openai/gpt-image-2para OpenAI Images ouopenai/gpt-image-1.5para saída PNG/WebP do OpenAI com fundo transparente. - Se você selecionar um provedor/modelo diretamente, configure também a autenticação correspondente do provedor (por exemplo,
GEMINI_API_KEYouGOOGLE_API_KEYparagoogle/*,OPENAI_API_KEYou OpenAI Codex OAuth paraopenai/gpt-image-2/openai/gpt-image-1.5,FAL_KEYparafal/*). - Se omitido,
image_generateainda pode inferir um padrão de provedor com autenticação. Ele tenta primeiro o provedor padrão atual e, em seguida, os provedores restantes registrados para geração de imagens em ordem de ID do provedor.
musicGenerationModel: aceita uma string ("provider/model") ou um objeto ({ primary, fallbacks }).- Usado pela capacidade compartilhada de geração de música e pela ferramenta integrada
music_generate. - Valores típicos:
google/lyria-3-clip-preview,google/lyria-3-pro-previewouminimax/music-2.6. - Se omitido,
music_generateainda pode inferir um padrão de provedor com autenticação. Ele tenta primeiro o provedor padrão atual e, em seguida, os provedores restantes registrados para geração de música em ordem de ID do provedor. - Se você selecionar um provedor/modelo diretamente, configure também a autenticação/chave de API correspondente do provedor.
- Usado pela capacidade compartilhada de geração de música e pela ferramenta integrada
videoGenerationModel: aceita uma string ("provider/model") ou um objeto ({ primary, fallbacks }).- Usado pela capacidade compartilhada de geração de vídeo e pela ferramenta integrada
video_generate. - Valores típicos:
qwen/wan2.6-t2v,qwen/wan2.6-i2v,qwen/wan2.6-r2v,qwen/wan2.6-r2v-flashouqwen/wan2.7-r2v. - Se omitido,
video_generateainda pode inferir um padrão de provedor com autenticação. Ele tenta primeiro o provedor padrão atual e, em seguida, os provedores restantes registrados para geração de vídeo em ordem de ID do provedor. - Se você selecionar um provedor/modelo diretamente, configure também a autenticação/chave de API correspondente do provedor.
- O provedor integrado de geração de vídeo Qwen aceita até 1 vídeo de saída, 1 imagem de entrada, 4 vídeos de entrada, duração de 10 segundos e opções de nível de provedor
size,aspectRatio,resolution,audioewatermark.
- Usado pela capacidade compartilhada de geração de vídeo e pela ferramenta integrada
pdfModel: aceita uma string ("provider/model") ou um objeto ({ primary, fallbacks }).- Usado pela ferramenta
pdfpara roteamento de modelos. - Se omitido, a ferramenta de PDF usa como fallback
imageModele, depois, o modelo resolvido da sessão/padrão.
- Usado pela ferramenta
pdfMaxBytesMb: limite padrão de tamanho de PDF para a ferramentapdfquandomaxBytesMbnão é passado no momento da chamada.pdfMaxPages: máximo padrão de páginas consideradas pelo modo de fallback de extração na ferramentapdf.verboseDefault: nível detalhado padrão para agentes. Valores:"off","on","full". Padrão:"off".toolProgressDetail: modo de detalhe para resumos de ferramentas de/verbosee linhas de ferramenta em rascunhos de progresso. Valores:"explain"(padrão, rótulos humanos compactos) ou"raw"(anexa comando/detalhe bruto quando disponível).agents.list[].toolProgressDetailpor agente substitui esse padrão.reasoningDefault: visibilidade padrão de raciocínio para agentes. Valores:"off","on","stream".agents.list[].reasoningDefaultpor agente substitui esse padrão. Padrões de raciocínio configurados só são aplicados para proprietários, remetentes autorizados ou contextos Gateway de operador-admin quando nenhuma substituição de raciocínio por mensagem ou por sessão estiver definida.elevatedDefault: nível padrão de saída elevada para agentes. Valores:"off","on","ask","full". Padrão:"on".model.primary: formatoprovider/model(por exemplo,openai/gpt-5.5para acesso por chave de API da OpenAI ou Codex OAuth). Se você omitir o provedor, o OpenClaw tenta primeiro um alias, depois uma correspondência exclusiva de provedor configurado para esse ID de modelo exato e só então usa como fallback o provedor padrão configurado (comportamento de compatibilidade obsoleto, então prefiraprovider/modelexplícito). Se esse provedor não expuser mais o modelo padrão configurado, o OpenClaw usa como fallback o primeiro provedor/modelo configurado em vez de expor um padrão obsoleto de provedor removido.models: o catálogo de modelos configurado e a lista de permissões para/model. Cada entrada pode incluiralias(atalho) eparams(específicos do provedor, por exemplotemperature,maxTokens,cacheRetention,context1m,responsesServerCompaction,responsesCompactThreshold,chat_template_kwargs,extra_body/extraBody).- Use entradas
provider/*, como"openai-codex/*": {}ou"vllm/*": {}, para mostrar todos os modelos descobertos para provedores selecionados sem listar manualmente cada ID de modelo. - Edições seguras: use
openclaw config set agents.defaults.models '<json>' --strict-json --mergepara adicionar entradas.config setrecusa substituições que removeriam entradas existentes da lista de permissões, a menos que você passe--replace. - Fluxos de configuração/onboarding com escopo de provedor mesclam os modelos selecionados do provedor neste mapa e preservam provedores não relacionados já configurados.
- Para modelos OpenAI Responses diretos, Compaction no servidor é ativada automaticamente. Use
params.responsesServerCompaction: falsepara parar de injetarcontext_managementouparams.responsesCompactThresholdpara substituir o limite. Consulte Compaction da OpenAI no servidor.
- Use entradas
params: parâmetros globais padrão de provedor aplicados a todos os modelos. Definido emagents.defaults.params(por exemplo,{ cacheRetention: "long" }).- Precedência de mesclagem de
params(configuração):agents.defaults.params(base global) é substituído poragents.defaults.models["provider/model"].params(por modelo), entãoagents.list[].params(ID de agente correspondente) substitui por chave. Consulte Cache de prompts para obter detalhes. params.extra_body/params.extraBody: JSON avançado de repasse mesclado aos corpos de solicitaçãoapi: "openai-completions"para proxies compatíveis com OpenAI. Se colidir com chaves de solicitação geradas, o corpo extra vence; rotas de completions não nativas ainda removemstoreexclusivo da OpenAI depois disso.params.chat_template_kwargs: argumentos de modelo de chat compatíveis com vLLM/OpenAI mesclados aos corpos de solicitaçãoapi: "openai-completions"de nível superior. Paravllm/nemotron-3-*com raciocínio desativado, o plugin vLLM integrado envia automaticamenteenable_thinking: falseeforce_nonempty_content: true;chat_template_kwargsexplícito substitui os padrões gerados, eextra_body.chat_template_kwargsainda tem precedência final. Para controles de raciocínio do vLLM Qwen, definaparams.qwenThinkingFormatcomo"chat-template"ou"top-level"nessa entrada de modelo.compat.thinkingFormat: estilo de payload de raciocínio compatível com OpenAI. Use"qwen"paraenable_thinkingde nível superior no estilo Qwen ou"qwen-chat-template"parachat_template_kwargs.enable_thinkingem backends da família Qwen que aceitam kwargs de modelo de chat no nível da solicitação, como vLLM. O OpenClaw mapeia raciocínio desativado parafalsee raciocínio ativado paratrue.compat.supportedReasoningEfforts: lista de esforço de raciocínio compatível com OpenAI por modelo. Inclua"xhigh"para endpoints personalizados que realmente o aceitam; então o OpenClaw expõe/think xhighem menus de comando, linhas de sessão do Gateway, validação de patch de sessão, validação da CLI de agentes e validação dellm-taskpara esse provedor/modelo configurado. Usecompat.reasoningEffortMapquando o backend quiser um valor específico do provedor para um nível canônico.params.preserveThinking: adesão somente para Z.AI para raciocínio preservado. Quando ativado e o raciocínio está ligado, o OpenClaw enviathinking.clear_thinking: falsee reproduzreasoning_contentanterior; consulte raciocínio da Z.AI e raciocínio preservado.localService: gerenciador de processos opcional no nível do provedor para servidores de modelos locais/auto-hospedados. Quando o modelo selecionado pertence a esse provedor, o OpenClaw sondahealthUrl(oubaseUrl + "/models"), iniciacommandcomargsse o endpoint estiver inativo, aguarda atéreadyTimeoutMse então envia a solicitação do modelo.commanddeve ser um caminho absoluto.idleStopMs: 0mantém o processo ativo até o OpenClaw sair; um valor positivo interrompe o processo iniciado pelo OpenClaw depois dessa quantidade de milissegundos ociosos. Consulte Serviços de modelo local.- A política de runtime pertence a provedores ou modelos, não a
agents.defaults. Usemodels.providers.<provider>.agentRuntimepara regras de todo o provedor ouagents.defaults.models["provider/model"].agentRuntime/agents.list[].models["provider/model"].agentRuntimepara regras específicas de modelo. Modelos de agente OpenAI no provedor oficial da OpenAI selecionam o Codex por padrão. - Gravadores de configuração que alteram esses campos (por exemplo,
/models set,/models set-imagee comandos de adicionar/remover fallback) salvam a forma canônica de objeto e preservam listas de fallback existentes quando possível. maxConcurrent: máximo de execuções paralelas de agentes entre sessões (cada sessão ainda é serializada). Padrão: 4.
Política de runtime
id:"auto","pi", um ID registrado de harness de plugin ou um alias de backend de CLI compatível. O plugin integrado Codex registracodex; o plugin integrado Anthropic fornece o backend de CLIclaude-cli.id: "auto"permite que harnesses de plugin registrados reivindiquem turnos compatíveis e usa PI quando nenhum harness corresponde. Um runtime de plugin explícito, comoid: "codex", exige esse harness e falha de forma fechada se ele estiver indisponível ou falhar.- Chaves de runtime de agente inteiro são legadas.
agents.defaults.agentRuntime,agents.list[].agentRuntime, pins de runtime de sessão eOPENCLAW_AGENT_RUNTIMEsão ignorados pela seleção de runtime. Executeopenclaw doctor --fixpara remover valores obsoletos. - Modelos de agente OpenAI usam o harness Codex por padrão;
agentRuntime.id: "codex"de provedor/modelo continua válido quando você quiser tornar isso explícito. - Para implantações Claude CLI, prefira
model: "anthropic/claude-opus-4-7"maisagentRuntime.id: "claude-cli"com escopo de modelo. Refs de modelo legadasclaude-cli/claude-opus-4-7ainda funcionam por compatibilidade, mas novas configurações devem manter a seleção de provedor/modelo canônica e colocar o backend de execução na política de runtime de provedor/modelo. - Isso controla apenas a execução de turnos de agente de texto. Geração de mídia, visão, PDF, música, vídeo e TTS ainda usam suas configurações de provedor/modelo.
agents.defaults.models):
| Apelido | Modelo |
|---|---|
opus | anthropic/claude-opus-4-6 |
sonnet | anthropic/claude-sonnet-4-6 |
gpt | openai/gpt-5.5 |
gpt-mini | openai/gpt-5.4-mini |
gpt-nano | openai/gpt-5.4-nano |
gemini | google/gemini-3.1-pro-preview |
gemini-flash | google/gemini-3-flash-preview |
gemini-flash-lite | google/gemini-3.1-flash-lite-preview |
--thinking off ou configure agents.defaults.models["zai/<model>"].params.thinking por conta própria.
Os modelos Z.AI ativam tool_stream por padrão para streaming de chamadas de ferramenta. Defina agents.defaults.models["zai/<model>"].params.tool_stream como false para desativá-lo.
Os modelos Anthropic Claude 4.6 usam adaptive como padrão de raciocínio quando nenhum nível explícito de raciocínio é definido.
agents.defaults.cliBackends
Backends de CLI opcionais para execuções de fallback somente de texto (sem chamadas de ferramenta). Úteis como backup quando provedores de API falham.
- Backends de CLI priorizam texto; ferramentas estão sempre desativadas.
- Sessões são compatíveis quando
sessionArgestá definido. - Pass-through de imagem é compatível quando
imageArgaceita caminhos de arquivo. reseedFromRawTranscriptWhenUncompacted: truepermite que um backend recupere sessões invalidadas seguras a partir de uma cauda limitada da transcrição bruta do OpenClaw antes que exista o primeiro resumo de Compaction. Alterações de perfil de autenticação ou de época de credenciais ainda nunca fazem reseed bruto.
agents.defaults.systemPromptOverride
Substitui todo o prompt de sistema montado pelo OpenClaw por uma string fixa. Defina no nível padrão (agents.defaults.systemPromptOverride) ou por agente (agents.list[].systemPromptOverride). Valores por agente têm precedência; um valor vazio ou composto apenas por espaços em branco é ignorado. Útil para experimentos controlados de prompt.
agents.defaults.promptOverlays
Sobreposições de prompt independentes de provedor aplicadas por família de modelo. IDs de modelos da família GPT-5 recebem o contrato de comportamento compartilhado entre provedores; personality controla apenas a camada amigável de estilo de interação.
"friendly"(padrão) e"on"ativam a camada amigável de estilo de interação."off"desativa apenas a camada amigável; o contrato de comportamento marcado do GPT-5 permanece ativado.plugins.entries.openai.config.personalitylegado ainda é lido quando essa configuração compartilhada não está definida.
agents.defaults.heartbeat
Execuções periódicas de Heartbeat.
every: string de duração (ms/s/m/h). Padrão:30m(autenticação por chave de API) ou1h(autenticação OAuth). Defina como0mpara desativar.includeSystemPromptSection: quando falso, omite a seção Heartbeat do prompt de sistema e ignora a injeção deHEARTBEAT.mdno contexto de bootstrap. Padrão:true.suppressToolErrorWarnings: quando verdadeiro, suprime payloads de aviso de erro de ferramenta durante execuções de heartbeat.timeoutSeconds: tempo máximo em segundos permitido para um turno do agente de heartbeat antes que ele seja abortado. Deixe indefinido para usaragents.defaults.timeoutSeconds.directPolicy: política de entrega direta/DM.allow(padrão) permite entrega para alvo direto.blocksuprime a entrega para alvo direto e emitereason=dm-blocked.lightContext: quando verdadeiro, execuções de heartbeat usam contexto de bootstrap leve e mantêm apenasHEARTBEAT.mddos arquivos de bootstrap do workspace.isolatedSession: quando verdadeiro, cada heartbeat é executado em uma sessão nova sem histórico de conversa anterior. Mesmo padrão de isolamento do cronsessionTarget: "isolated". Reduz o custo de tokens por heartbeat de ~100K para ~2-5K tokens.skipWhenBusy: quando verdadeiro, execuções de heartbeat são adiadas nas faixas ocupadas extras desse agente: seu próprio subagente chaveado por sessão ou trabalho de comando aninhado. Faixas de Cron sempre adiam heartbeats, mesmo sem esta flag.- Por agente: defina
agents.list[].heartbeat. Quando qualquer agente defineheartbeat, apenas esses agentes executam heartbeats. - Heartbeats executam turnos completos do agente — intervalos mais curtos consomem mais tokens.
agents.defaults.compaction
mode:defaultousafeguard(resumo em partes para históricos longos). Consulte Compaction.provider: id de um Plugin provedor de Compaction registrado. Quando definido, osummarize()do provedor é chamado em vez do resumo de LLM integrado. Retorna ao integrado em caso de falha. Definir um provedor forçamode: "safeguard". Consulte Compaction.timeoutSeconds: máximo de segundos permitidos para uma única operação de Compaction antes que o OpenClaw a aborte. Padrão:900.keepRecentTokens: orçamento de ponto de corte do Pi para manter literalmente a cauda mais recente da transcrição./compactmanual respeita isso quando definido explicitamente; caso contrário, a Compaction manual é um checkpoint rígido.identifierPolicy:strict(padrão),offoucustom.strictprefixa orientações integradas de retenção de identificadores opacos durante o resumo de Compaction.identifierInstructions: texto personalizado opcional para preservação de identificadores usado quandoidentifierPolicy=custom.qualityGuard: verificações de nova tentativa em saída malformada para resumos de salvaguarda. Ativado por padrão no modo de salvaguarda; definaenabled: falsepara ignorar a auditoria.midTurnPrecheck: verificação opcional de pressão do loop de ferramentas do Pi. Quandoenabled: true, o OpenClaw verifica a pressão de contexto depois que resultados de ferramenta são anexados e antes da próxima chamada ao modelo. Se o contexto não couber mais, ele aborta a tentativa atual antes de enviar o prompt e reutiliza o caminho de recuperação de pré-verificação existente para truncar resultados de ferramenta ou compactar e tentar novamente. Funciona com os modos de Compactiondefaultesafeguard. Padrão: desativado.postCompactionSections: nomes opcionais de seções H2/H3 de AGENTS.md para reinjetar após a Compaction. O padrão é["Session Startup", "Red Lines"]; defina[]para desativar a reinjeção. Quando indefinido ou definido explicitamente para esse par padrão, os cabeçalhos antigosEvery Session/Safetytambém são aceitos como fallback legado.model: substituição opcionalprovider/model-idapenas para resumo de Compaction. Use isto quando a sessão principal deve manter um modelo, mas os resumos de Compaction devem ser executados em outro; quando indefinido, a Compaction usa o modelo primário da sessão.maxActiveTranscriptBytes: limite opcional de bytes (numberou strings como"20mb") que aciona Compaction local normal antes de uma execução quando o JSONL ativo ultrapassa o limite. RequertruncateAfterCompactionpara que uma Compaction bem-sucedida possa rotacionar para uma transcrição sucessora menor. Desativado quando indefinido ou0.notifyUser: quandotrue, envia avisos breves ao usuário quando a Compaction começa e quando termina (por exemplo, “Compactando contexto…” e “Compaction concluída”). Desativado por padrão para manter a Compaction silenciosa.memoryFlush: turno agêntico silencioso antes da Compaction automática para armazenar memórias duráveis. Definamodelcomo um provedor/modelo exato, comoollama/qwen3:8b, quando esse turno de manutenção deve permanecer em um modelo local; a substituição não herda a cadeia de fallback da sessão ativa. Ignorado quando o workspace é somente leitura.
agents.defaults.runRetries
Limites de iteração de nova tentativa do loop externo de execução para o executor Pi incorporado, a fim de evitar loops de execução infinitos durante a recuperação de falhas. Observe que esta configuração atualmente se aplica apenas ao runtime de agente incorporado, não aos runtimes ACP ou CLI.
base: número base de iterações de nova tentativa de execução para o loop externo de execução. Padrão:24.perProfile: iterações adicionais de nova tentativa de execução concedidas por candidato de perfil de fallback. Padrão:8.min: limite absoluto mínimo para iterações de nova tentativa de execução. Padrão:32.max: limite absoluto máximo para iterações de nova tentativa de execução, para evitar execução descontrolada. Padrão:160.
agents.defaults.contextPruning
Remove resultados antigos de ferramentas do contexto em memória antes de enviar para o LLM. Não modifica o histórico da sessão em disco.
Comportamento do modo cache-ttl
Comportamento do modo cache-ttl
mode: "cache-ttl"habilita passagens de poda.ttlcontrola com que frequência a poda pode ser executada novamente (após o último toque no cache).- A poda primeiro faz o soft-trim de resultados de ferramenta grandes demais e, depois, faz o hard-clear de resultados de ferramenta mais antigos, se necessário.
... no meio.Hard-clear substitui todo o resultado da ferramenta pelo placeholder.Observações:- Blocos de imagem nunca são aparados/limpos.
- As proporções são baseadas em caracteres (aproximadas), não em contagens exatas de tokens.
- Se houver menos de
keepLastAssistantsmensagens do assistente, a poda será ignorada.
Streaming em blocos
- Canais que não sejam Telegram exigem
*.blockStreaming: trueexplícito para habilitar respostas em blocos. - Substituições por canal:
channels.<channel>.blockStreamingCoalesce(e variantes por conta). Signal/Slack/Discord/Google Chat usamminChars: 1500como padrão. humanDelay: pausa aleatória entre respostas em blocos.natural= 800–2500ms. Substituição por agente:agents.list[].humanDelay.
Indicadores de digitação
- Padrões:
instantpara conversas diretas/menções,messagepara conversas em grupo sem menção. - Substituições por sessão:
session.typingMode,session.typingIntervalSeconds.
agents.defaults.sandbox
Sandboxing opcional para o agente integrado. Consulte Sandboxing para o guia completo.
Detalhes do sandbox
Detalhes do sandbox
Back-end:Modo OpenShell:
docker: runtime Docker local (padrão)ssh: runtime remoto genérico baseado em SSHopenshell: runtime OpenShell
backend: "openshell" é selecionado, as configurações específicas do runtime passam para
plugins.entries.openshell.config.Configuração do back-end SSH:target: destino SSH no formatouser@host[:port]command: comando do cliente SSH (padrão:ssh)workspaceRoot: raiz remota absoluta usada para workspaces por escopoidentityFile/certificateFile/knownHostsFile: arquivos locais existentes passados para o OpenSSHidentityData/certificateData/knownHostsData: conteúdos inline ou SecretRefs que o OpenClaw materializa em arquivos temporários em runtimestrictHostKeyChecking/updateHostKeys: controles de política de chave de host do OpenSSH
identityDataprevalece sobreidentityFilecertificateDataprevalece sobrecertificateFileknownHostsDataprevalece sobreknownHostsFile- Valores
*Databaseados em SecretRef são resolvidos a partir do snapshot ativo do runtime de segredos antes do início da sessão de sandbox
- semeia o workspace remoto uma vez após criação ou recriação
- depois mantém o workspace SSH remoto como canônico
- roteia
exec, ferramentas de arquivo e caminhos de mídia por SSH - não sincroniza automaticamente alterações remotas de volta para o host
- não oferece suporte a contêineres de navegador em sandbox
none: workspace de sandbox por escopo em~/.openclaw/sandboxesro: workspace de sandbox em/workspace, workspace do agente montado como somente leitura em/agentrw: workspace do agente montado como leitura/gravação em/workspace
session: contêiner + workspace por sessãoagent: um contêiner + workspace por agente (padrão)shared: contêiner e workspace compartilhados (sem isolamento entre sessões)
mirror: semeia o remoto a partir do local antes de executar, sincroniza de volta após a execução; o workspace local permanece canônicoremote: semeia o remoto uma vez quando o sandbox é criado e, depois, mantém o workspace remoto como canônico
remote, edições locais do host feitas fora do OpenClaw não são sincronizadas automaticamente para o sandbox após a etapa de semeadura.
O transporte é SSH para dentro do sandbox OpenShell, mas o Plugin é responsável pelo ciclo de vida do sandbox e pela sincronização espelhada opcional.setupCommand é executado uma vez após a criação do contêiner (via sh -lc). Requer saída de rede, raiz gravável e usuário root.Contêineres usam network: "none" por padrão — defina como "bridge" (ou uma rede bridge personalizada) se o agente precisar de acesso de saída.
"host" é bloqueado. "container:<id>" é bloqueado por padrão, a menos que você defina explicitamente
sandbox.docker.dangerouslyAllowContainerNamespaceJoin: true (quebra de emergência).Anexos de entrada são preparados em media/inbound/* no workspace ativo.docker.binds monta diretórios adicionais do host; binds globais e por agente são mesclados.Navegador em sandbox (sandbox.browser.enabled): Chromium + CDP em um contêiner. URL noVNC injetada no prompt do sistema. Não requer browser.enabled em openclaw.json.
O acesso de observador noVNC usa autenticação VNC por padrão, e o OpenClaw emite uma URL com token de curta duração (em vez de expor a senha na URL compartilhada).allowHostControl: false(padrão) impede sessões em sandbox de mirar o navegador do host.networkusaopenclaw-sandbox-browsercomo padrão (rede bridge dedicada). Defina comobridgesomente quando você quiser explicitamente conectividade bridge global.cdpSourceRangerestringe opcionalmente a entrada CDP na borda do contêiner a um intervalo CIDR (por exemplo,172.21.0.1/32).sandbox.browser.bindsmonta diretórios adicionais do host somente no contêiner de navegador em sandbox. Quando definido (incluindo[]), substituidocker.bindspara o contêiner do navegador.- Os padrões de inicialização são definidos em
scripts/sandbox-browser-entrypoint.she ajustados para hosts de contêiner:--remote-debugging-address=127.0.0.1--remote-debugging-port=<derived from OPENCLAW_BROWSER_CDP_PORT>--user-data-dir=${HOME}/.chrome--no-first-run--no-default-browser-check--disable-3d-apis--disable-gpu--disable-software-rasterizer--disable-dev-shm-usage--disable-background-networking--disable-features=TranslateUI--disable-breakpad--disable-crash-reporter--renderer-process-limit=2--no-zygote--metrics-recording-only--disable-extensions(habilitado por padrão)--disable-3d-apis,--disable-software-rasterizere--disable-gpusão habilitados por padrão e podem ser desabilitados comOPENCLAW_BROWSER_DISABLE_GRAPHICS_FLAGS=0se o uso de WebGL/3D exigir.OPENCLAW_BROWSER_DISABLE_EXTENSIONS=0reabilita extensões se o seu fluxo de trabalho depender delas.--renderer-process-limit=2pode ser alterado comOPENCLAW_BROWSER_RENDERER_PROCESS_LIMIT=<N>; defina0para usar o limite de processos padrão do Chromium.- além de
--no-sandboxquandonoSandboxestiver habilitado. - Os padrões são a base da imagem do contêiner; use uma imagem de navegador personalizada com um entrypoint personalizado para alterar os padrões do contêiner.
sandbox.docker.binds são exclusivos do Docker.
Crie as imagens (a partir de um checkout do código-fonte):
docker build inline.
agents.list (substituições por agente)
Use agents.list[].tts para dar a um agente seu próprio provedor de TTS, voz, modelo,
estilo ou modo de TTS automático. O bloco do agente faz uma mesclagem profunda sobre o
messages.tts global, então as credenciais compartilhadas podem ficar em um só lugar enquanto agentes
individuais substituem apenas os campos de voz ou provedor de que precisam. A substituição do agente ativo
se aplica a respostas faladas automáticas, /tts audio, /tts status e
à ferramenta de agente tts. Consulte Texto para fala
para exemplos de provedores e precedência.
id: id estável do agente (obrigatório).default: quando vários são definidos, o primeiro vence (aviso registrado). Se nenhum for definido, a primeira entrada da lista é o padrão.model: a forma em string define um primário estrito por agente sem fallback de modelo; a forma em objeto{ primary }também é estrita, a menos que você adicionefallbacks. Use{ primary, fallbacks: [...] }para habilitar fallback para esse agente, ou{ primary, fallbacks: [] }para tornar explícito o comportamento estrito. Trabalhos Cron que substituem apenasprimaryainda herdam os fallbacks padrão, a menos que você definafallbacks: [].params: parâmetros de stream por agente mesclados sobre a entrada de modelo selecionada emagents.defaults.models. Use isto para substituições específicas do agente, comocacheRetention,temperatureoumaxTokens, sem duplicar todo o catálogo de modelos.tts: substituições opcionais de texto para fala por agente. O bloco faz uma mesclagem profunda sobremessages.tts, então mantenha credenciais compartilhadas de provedores e política de fallback emmessages.ttse defina aqui apenas valores específicos da persona, como provedor, voz, modelo, estilo ou modo automático.skills: allowlist opcional de Skills por agente. Se omitida, o agente herdaagents.defaults.skillsquando definido; uma lista explícita substitui os padrões em vez de mesclar, e[]significa sem Skills.thinkingDefault: nível de thinking padrão opcional por agente (off | minimal | low | medium | high | xhigh | adaptive | max). Substituiagents.defaults.thinkingDefaultpara este agente quando nenhuma substituição por mensagem ou sessão está definida. O perfil de provedor/modelo selecionado controla quais valores são válidos; para Google Gemini,adaptivemantém o thinking dinâmico controlado pelo provedor (thinkingLevelomitido no Gemini 3/3.1,thinkingBudget: -1no Gemini 2.5).reasoningDefault: visibilidade de reasoning padrão opcional por agente (on | off | stream). Substituiagents.defaults.reasoningDefaultpara este agente quando nenhuma substituição de reasoning por mensagem ou sessão está definida.fastModeDefault: padrão opcional por agente para modo rápido (true | false). Aplica-se quando nenhuma substituição de modo rápido por mensagem ou sessão está definida.models: catálogo de modelos opcional por agente/substituições de runtime indexadas por ids completosprovider/model. Usemodels["provider/model"].agentRuntimepara exceções de runtime por agente.runtime: descritor de runtime opcional por agente. Usetype: "acp"com os padrões deruntime.acp(agent,backend,mode,cwd) quando o agente deve usar sessões de harness ACP por padrão.identity.avatar: caminho relativo ao workspace, URLhttp(s)ou URIdata:.identityderiva padrões:ackReactiondeemoji,mentionPatternsdename/emoji.subagents.allowAgents: allowlist de ids de agente para alvos explícitossessions_spawn.agentId(["*"]= qualquer; padrão: apenas o mesmo agente). Inclua o id do solicitante quando chamadasagentIddirecionadas ao próprio agente devem ser permitidas.- Proteção de herança do sandbox: se a sessão solicitante estiver em sandbox,
sessions_spawnrejeita alvos que rodariam sem sandbox. subagents.requireAgentId: quando true, bloqueia chamadassessions_spawnque omitemagentId(força seleção explícita de perfil; padrão: false).
Roteamento multiagente
Execute vários agentes isolados dentro de um único Gateway. Consulte Multiagente.Campos de correspondência de binding
type(opcional):routepara roteamento normal (tipo ausente usa route por padrão),acppara bindings persistentes de conversa ACP.match.channel(obrigatório)match.accountId(opcional;*= qualquer conta; omitido = conta padrão)match.peer(opcional;{ kind: direct|group|channel, id })match.guildId/match.teamId(opcional; específico do canal)acp(opcional; apenas paratype: "acp"):{ mode, label, cwd, backend }
match.peermatch.guildIdmatch.teamIdmatch.accountId(exato, sem peer/guild/team)match.accountId: "*"(abrange todo o canal)- Agente padrão
bindings vence.
Para entradas type: "acp", o OpenClaw resolve pela identidade exata da conversa (match.channel + conta + match.peer.id) e não usa a ordem de camadas de binding de rota acima.
Perfis de acesso por agente
Acesso total (sem sandbox)
Acesso total (sem sandbox)
Ferramentas somente leitura + workspace
Ferramentas somente leitura + workspace
Sem acesso ao sistema de arquivos (somente mensagens)
Sem acesso ao sistema de arquivos (somente mensagens)
Sessão
Detalhes dos campos de sessão
Detalhes dos campos de sessão
scope: estratégia base de agrupamento de sessões para contextos de chat em grupo.per-sender(padrão): cada remetente recebe uma sessão isolada dentro de um contexto de canal.global: todos os participantes em um contexto de canal compartilham uma única sessão (use somente quando o contexto compartilhado for intencional).
dmScope: como as DMs são agrupadas.main: todas as DMs compartilham a sessão principal.per-peer: isola por id do remetente entre canais.per-channel-peer: isola por canal + remetente (recomendado para caixas de entrada multiusuário).per-account-channel-peer: isola por conta + canal + remetente (recomendado para múltiplas contas).
identityLinks: mapeia ids canônicos para pares com prefixo do provedor para compartilhamento de sessão entre canais. Comandos de dock como/dock_discordusam o mesmo mapa para alternar a rota de resposta da sessão ativa para outro par de canal vinculado; consulte Acoplamento de canais.reset: política principal de redefinição.dailyredefine no horário localatHour;idleredefine apósidleMinutes. Quando ambos estão configurados, vence o que expirar primeiro. A atualização da redefinição diária usa osessionStartedAtda linha de sessão; a atualização da redefinição por inatividade usalastInteractionAt. Gravações em segundo plano/eventos do sistema, como Heartbeat, despertares de Cron, notificações de exec e contabilidade do Gateway, podem atualizarupdatedAt, mas não mantêm sessões diárias/por inatividade atualizadas.resetByType: substituições por tipo (direct,group,thread). O legadodmé aceito como alias dedirect.mainKey: campo legado. Em runtime, sempre usa"main"para o bucket principal de chat direto.agentToAgent.maxPingPongTurns: máximo de turnos de resposta de volta entre agentes durante trocas agente-a-agente (inteiro, intervalo:0-20, padrão:5).0desativa o encadeamento de ping-pong.sendPolicy: corresponde porchannel,chatType(direct|group|channel, com alias legadodm),keyPrefixourawKeyPrefix. A primeira negação vence.maintenance: limpeza do armazenamento de sessões + controles de retenção.mode:warnemite apenas avisos;enforceaplica a limpeza.pruneAfter: limite de idade para entradas obsoletas (padrão30d).maxEntries: número máximo de entradas emsessions.json(padrão500). O runtime grava a limpeza em lote com um pequeno buffer de limite superior para limites de tamanho de produção;openclaw sessions cleanup --enforceaplica o limite imediatamente.rotateBytes: obsoleto e ignorado;openclaw doctor --fixo remove de configurações antigas.resetArchiveRetention: retenção para arquivos de transcrição*.reset.<timestamp>. O padrão épruneAfter; defina comofalsepara desativar.maxDiskBytes: orçamento opcional de disco do diretório de sessões. No modowarn, registra avisos; no modoenforce, remove primeiro os artefatos/sessões mais antigos.highWaterBytes: destino opcional após a limpeza de orçamento. O padrão é80%demaxDiskBytes.
threadBindings: padrões globais para recursos de sessão vinculados a threads.enabled: chave padrão mestre (provedores podem substituir; Discord usachannels.discord.threadBindings.enabled)idleHours: desenfoque automático padrão por inatividade em horas (0desativa; provedores podem substituir)maxAgeHours: idade máxima rígida padrão em horas (0desativa; provedores podem substituir)spawnSessions: controle padrão para criar sessões de trabalho vinculadas a threads a partir desessions_spawne spawns de thread ACP. O padrão étruequando os vínculos de thread estão ativados; provedores/contas podem substituir.defaultSpawnContext: contexto nativo padrão de subagente para spawns vinculados a threads ("fork"ou"isolated"). O padrão é"fork".
Mensagens
Prefixo de resposta
Substituições por canal/conta:channels.<channel>.responsePrefix, channels.<channel>.accounts.<id>.responsePrefix.
Resolução (o mais específico vence): conta → canal → global. "" desativa e interrompe a cascata. "auto" deriva [{identity.name}].
Variáveis de template:
| Variável | Descrição | Exemplo |
|---|---|---|
{model} | Nome curto do modelo | claude-opus-4-6 |
{modelFull} | Identificador completo do modelo | anthropic/claude-opus-4-6 |
{provider} | Nome do provedor | anthropic |
{thinkingLevel} | Nível de pensamento atual | high, low, off |
{identity.name} | Nome da identidade do agente | (mesmo que "auto") |
{think} é um alias para {thinkingLevel}.
Reação de confirmação
- O padrão é
identity.emojido agente ativo, caso contrário"👀". Defina""para desativar. - Substituições por canal:
channels.<channel>.ackReaction,channels.<channel>.accounts.<id>.ackReaction. - Ordem de resolução: conta → canal →
messages.ackReaction→ fallback de identidade. - Escopo:
group-mentions(padrão),group-all,direct,all. removeAckAfterReply: remove a confirmação após a resposta em canais compatíveis com reações, como Slack, Discord, Telegram, WhatsApp e iMessage.messages.statusReactions.enabled: ativa reações de status do ciclo de vida no Slack, Discord e Telegram. No Slack e Discord, deixar indefinido mantém reações de status ativadas quando reações de confirmação estão ativas. No Telegram, defina explicitamente comotruepara ativar reações de status do ciclo de vida.
Debounce de entrada
Agrupa mensagens rápidas somente de texto do mesmo remetente em um único turno do agente. Mídia/anexos forçam envio imediato. Comandos de controle ignoram o debounce.TTS (texto para fala)
autocontrola o modo auto-TTS padrão:off,always,inboundoutagged./tts on|offpode substituir preferências locais, e/tts statusmostra o estado efetivo.summaryModelsubstituiagents.defaults.model.primarypara resumo automático.modelOverridesé ativado por padrão;modelOverrides.allowProvidertem padrãofalse(opt-in).- Chaves de API usam fallback para
ELEVENLABS_API_KEY/XI_API_KEYeOPENAI_API_KEY. - Provedores de fala incluídos são de propriedade do Plugin. Se
plugins.allowestiver definido, inclua cada Plugin de provedor TTS que você deseja usar, por exemplomicrosoftpara Edge TTS. O id de provedor legadoedgeé aceito como alias demicrosoft. providers.openai.baseUrlsubstitui o endpoint TTS da OpenAI. A ordem de resolução é configuração, depoisOPENAI_TTS_BASE_URL, depoishttps://api.openai.com/v1.- Quando
providers.openai.baseUrlaponta para um endpoint que não é da OpenAI, o OpenClaw o trata como um servidor TTS compatível com OpenAI e relaxa a validação de modelo/voz.
Talk
Padrões para o modo Talk (macOS/iOS/Android).talk.providerdeve corresponder a uma chave emtalk.providersquando múltiplos provedores de Talk estiverem configurados.- Chaves planas legadas de Talk (
talk.voiceId,talk.voiceAliases,talk.modelId,talk.outputFormat,talk.apiKey) existem somente para compatibilidade. Executeopenclaw doctor --fixpara reescrever a configuração persistida emtalk.providers.<provider>. - IDs de voz usam fallback para
ELEVENLABS_VOICE_IDouSAG_VOICE_ID. providers.*.apiKeyaceita strings em texto puro ou objetos SecretRef.- O fallback
ELEVENLABS_API_KEYse aplica somente quando nenhuma chave de API de Talk está configurada. providers.*.voiceAliasespermite que diretivas de Talk usem nomes amigáveis.providers.mlx.modelIdseleciona o repositório Hugging Face usado pelo auxiliar MLX local do macOS. Se omitido, o macOS usamlx-community/Soprano-80M-bf16.- A reprodução MLX no macOS é executada pelo auxiliar incluído
openclaw-mlx-ttsquando presente, ou por um executável noPATH;OPENCLAW_MLX_TTS_BINsubstitui o caminho do auxiliar para desenvolvimento. consultThinkingLevelcontrola o nível de pensamento da execução completa do agente OpenClaw por trás de chamadas Control UI Talk em tempo realopenclaw_agent_consult. Deixe indefinido para preservar o comportamento normal de sessão/modelo.consultFastModedefine uma substituição única de modo rápido para consultas Control UI Talk em tempo real sem alterar a configuração normal de modo rápido da sessão.speechLocaledefine o id de localidade BCP 47 usado pelo reconhecimento de fala do Talk no iOS/macOS. Deixe indefinido para usar o padrão do dispositivo.silenceTimeoutMscontrola por quanto tempo o modo Talk espera após o silêncio do usuário antes de enviar a transcrição. Indefinido mantém a janela de pausa padrão da plataforma (700 ms no macOS e Android, 900 ms no iOS).realtime.instructionsacrescenta instruções de sistema voltadas ao provedor ao prompt em tempo real integrado do OpenClaw, para que o estilo de voz possa ser configurado sem perder a orientação padrão deopenclaw_agent_consult.
Relacionados
- Referência de configuração — todas as outras chaves de configuração
- Configuração — tarefas comuns e configuração rápida
- Exemplos de configuração