Cada agente em uma configuração multiagente pode substituir a sandbox global e a política de ferramentas. Esta página aborda a configuração por agente, as regras de precedência e exemplos.Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Sandboxing
Backends e modos — referência completa de sandbox.
Sandbox vs tool policy vs elevated
Depure “por que isto está bloqueado?”
Elevated mode
Execução elevada para remetentes confiáveis.
Exemplos de configuração
Example 1: Personal + restricted family agent
Example 1: Personal + restricted family agent
- agente
main: executa no host, com acesso completo às ferramentas. - agente
family: executa no Docker (um contêiner por agente), apenasreade envios de mensagem na conversa atual.
Example 2: Work agent with shared sandbox
Example 2: Work agent with shared sandbox
Example 2b: Global coding profile + messaging-only agent
Example 2b: Global coding profile + messaging-only agent
- agentes padrão recebem ferramentas de programação.
- o agente
supporté somente para mensagens (+ ferramenta Slack).
Example 3: Different sandbox modes per agent
Example 3: Different sandbox modes per agent
Precedência da configuração
Quando existem configurações globais (agents.defaults.*) e específicas de agente (agents.list[].*):
Configuração de sandbox
As configurações específicas de agente substituem as globais:agents.list[].sandbox.{docker,browser,prune}.* substitui agents.defaults.sandbox.{docker,browser,prune}.* para esse agente (ignorado quando o escopo da sandbox resolve para "shared").Restrições de ferramentas
A ordem de filtragem é:Provider tool profile
tools.byProvider[provider].profile ou agents.list[].tools.byProvider[provider].profile.Precedence rules
Precedence rules
- Cada nível pode restringir ainda mais as ferramentas, mas não pode conceder novamente ferramentas negadas em níveis anteriores.
- Se
agents.list[].tools.sandbox.toolsestiver definido, ele substituitools.sandbox.toolspara esse agente. - Se
agents.list[].tools.profileestiver definido, ele substituitools.profilepara esse agente. - Chaves de ferramentas de provedor aceitam
provider(por exemplo,google-antigravity) ouprovider/model(por exemplo,openai/gpt-5.4).
Empty allowlist behavior
Empty allowlist behavior
Se qualquer lista de permissões explícita nessa cadeia deixar a execução sem ferramentas chamáveis, o OpenClaw para antes de enviar o prompt ao modelo. Isso é intencional: um agente configurado com uma ferramenta ausente, como
agents.list[].tools.allow: ["query_db"], deve falhar de forma clara até que o plugin que registra query_db seja habilitado, em vez de continuar como um agente apenas de texto.group:*, que se expandem para várias ferramentas. Consulte Grupos de ferramentas para ver a lista completa.
Substituições elevadas por agente (agents.list[].tools.elevated) podem restringir ainda mais a execução elevada para agentes específicos. Consulte Modo elevado para obter detalhes.
Migração de agente único
- Antes (agente único)
- Depois (multiagente)
Configurações legadas
agent.* são migradas pelo openclaw doctor; prefira agents.defaults + agents.list daqui em diante.Exemplos de restrição de ferramentas
- Agente somente leitura
- Execução de shell com ferramentas do sistema de arquivos desabilitadas
- Somente comunicação
Armadilha comum: “non-main”
Testes
Depois de configurar sandbox e ferramentas multiagente:Testar restrições de ferramentas
- Envie uma mensagem que exija ferramentas restritas.
- Verifique se o agente não consegue usar ferramentas negadas.
Solução de problemas
Agente não está em sandbox apesar de `mode: 'all'`
Agente não está em sandbox apesar de `mode: 'all'`
- Verifique se há um
agents.defaults.sandbox.modeglobal que o substitui. - A configuração específica do agente tem precedência, portanto defina
agents.list[].sandbox.mode: "all".
Ferramentas ainda disponíveis apesar da lista de negação
Ferramentas ainda disponíveis apesar da lista de negação
- Verifique a ordem de filtragem de ferramentas: global → agente → sandbox → subagente.
- Cada nível só pode restringir ainda mais, não conceder de volta.
- Verifique com os logs:
[tools] filtering tools for agent:${agentId}.
Contêiner não isolado por agente
Contêiner não isolado por agente
- Defina
scope: "agent"na configuração de sandbox específica do agente. - O padrão é
"session", que cria um contêiner por sessão.
Relacionado
- Modo elevado
- Roteamento multiagente
- Configuração de sandbox
- Sandbox vs política de ferramentas vs elevado — depuração de “por que isso está bloqueado?”
- Sandboxing — referência completa de sandbox (modos, escopos, backends, imagens)
- Gerenciamento de sessão