Claves de configuración con alcance de agente bajoDocumentation 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.* y talk.*. Para canales, herramientas, runtime del Gateway y otras
claves de nivel superior, consulta Referencia de configuración.
Valores predeterminados del agente
agents.defaults.workspace
Valor predeterminado: ~/.openclaw/workspace.
agents.defaults.repoRoot
Raíz opcional del repositorio que se muestra en la línea Runtime del prompt del sistema. Si no se establece, OpenClaw la detecta automáticamente recorriendo hacia arriba desde el espacio de trabajo.
agents.defaults.skills
Lista de permisos predeterminada opcional de Skills para agentes que no establecen
agents.list[].skills.
- Omite
agents.defaults.skillspara permitir Skills sin restricciones de forma predeterminada. - Omite
agents.list[].skillspara heredar los valores predeterminados. - Establece
agents.list[].skills: []para no usar Skills. - Una lista no vacía de
agents.list[].skillses el conjunto final para ese agente; no se combina con los valores predeterminados.
agents.defaults.skipBootstrap
Desactiva la creación automática de archivos de inicialización del espacio de trabajo (AGENTS.md, SOUL.md, TOOLS.md, IDENTITY.md, USER.md, HEARTBEAT.md, BOOTSTRAP.md).
agents.defaults.skipOptionalBootstrapFiles
Omite la creación de archivos opcionales seleccionados del espacio de trabajo mientras sigue escribiendo los archivos de inicialización requeridos. Valores válidos: SOUL.md, USER.md, HEARTBEAT.md e IDENTITY.md.
agents.defaults.contextInjection
Controla cuándo se inyectan los archivos de inicialización del espacio de trabajo en el prompt del sistema. Valor predeterminado: "always".
"continuation-skip": los turnos de continuación seguros (después de una respuesta completada del asistente) omiten la reinyección de inicialización del espacio de trabajo, lo que reduce el tamaño del prompt. Las ejecuciones de Heartbeat y los reintentos posteriores a la Compaction siguen reconstruyendo el contexto."never": desactiva la inicialización del espacio de trabajo y la inyección de archivos de contexto en cada turno. Usa esto solo para agentes que controlan por completo el ciclo de vida de su prompt (motores de contexto personalizados, runtimes nativos que construyen su propio contexto o flujos de trabajo especializados sin inicialización). Los turnos de Heartbeat y recuperación de Compaction también omiten la inyección.
agents.defaults.bootstrapMaxChars
Máximo de caracteres por archivo de inicialización del espacio de trabajo antes del truncamiento. Valor predeterminado: 12000.
agents.defaults.bootstrapTotalMaxChars
Máximo total de caracteres inyectados entre todos los archivos de inicialización del espacio de trabajo. Valor predeterminado: 60000.
agents.defaults.bootstrapPromptTruncationWarning
Controla el aviso visible para el agente en el prompt del sistema cuando se trunca el contexto de inicialización.
Valor predeterminado: "once".
"off": nunca inyecta texto de aviso de truncamiento en el prompt del sistema."once": inyecta un aviso conciso una vez por cada firma de truncamiento única (recomendado)."always": inyecta un aviso conciso en cada ejecución cuando existe truncamiento.
Mapa de propiedad del presupuesto de contexto
OpenClaw tiene varios presupuestos de prompt/contexto de alto volumen, y se dividen intencionalmente por subsistema en lugar de pasar todos por una sola opción genérica.agents.defaults.bootstrapMaxChars/agents.defaults.bootstrapTotalMaxChars: inyección normal de inicialización del espacio de trabajo.agents.defaults.startupContext.*: preámbulo único de ejecución de modelo al restablecer/iniciar, incluidos los archivos recientes diariosmemory/*.md. Los comandos de chat sin argumentos/newy/resetse reconocen sin invocar el modelo.skills.limits.*: la lista compacta de Skills inyectada en el prompt del sistema.agents.defaults.contextLimits.*: extractos acotados de runtime y bloques inyectados propiedad del runtime.memory.qmd.limits.*: fragmento de búsqueda de memoria indexado y dimensionamiento de inyección.
agents.list[].skillsLimits.maxSkillsPromptCharsagents.list[].contextLimits.*
agents.defaults.startupContext
Controla el preámbulo de inicio del primer turno inyectado en ejecuciones de modelo de restablecimiento/inicio.
Los comandos de chat sin argumentos /new y /reset reconocen el restablecimiento sin invocar
el modelo, por lo que no cargan este preámbulo.
agents.defaults.contextLimits
Valores predeterminados compartidos para superficies acotadas de contexto de runtime.
memoryGetMaxChars: límite predeterminado del extracto dememory_getantes de agregar metadatos de truncamiento y aviso de continuación.memoryGetDefaultLines: ventana de líneas predeterminada dememory_getcuando se omitelines.toolResultMaxChars: límite de resultado de herramienta en vivo usado para resultados persistidos y recuperación de desbordamiento.postCompactionMaxChars: límite del extracto de AGENTS.md usado durante la inyección de actualización posterior a la Compaction.
agents.list[].contextLimits
Sobrescritura por agente para las opciones compartidas de contextLimits. Los campos omitidos heredan
de agents.defaults.contextLimits.
skills.limits.maxSkillsPromptChars
Límite global para la lista compacta de Skills inyectada en el prompt del sistema. Esto
no afecta la lectura bajo demanda de archivos SKILL.md.
agents.list[].skillsLimits.maxSkillsPromptChars
Sobrescritura por agente para el presupuesto del prompt de Skills.
agents.defaults.imageMaxDimensionPx
Tamaño máximo en píxeles del lado más largo de la imagen en bloques de imagen de transcript/herramienta antes de las llamadas al proveedor.
Valor predeterminado: 1200.
Los valores más bajos suelen reducir el uso de tokens de visión y el tamaño de la carga útil de la solicitud en ejecuciones con muchas capturas de pantalla.
Los valores más altos conservan más detalle visual.
agents.defaults.userTimezone
Zona horaria para el contexto del prompt del sistema (no para marcas de tiempo de mensajes). Recurre a la zona horaria del host.
agents.defaults.timeFormat
Formato de hora en el prompt del sistema. Valor predeterminado: auto (preferencia del sistema operativo).
agents.defaults.model
model: acepta una cadena ("provider/model") o un objeto ({ primary, fallbacks }).- La forma de cadena establece solo el modelo principal.
- La forma de objeto establece el principal más modelos de conmutación por error ordenados.
imageModel: acepta una cadena ("provider/model") o un objeto ({ primary, fallbacks }).- Lo usa la ruta de la herramienta
imagecomo su configuración de modelo de visión. - También se usa como enrutamiento de respaldo cuando el modelo seleccionado/predeterminado no puede aceptar entrada de imagen.
- Prefiere referencias
provider/modelexplícitas. Los identificadores sin prefijo se aceptan por compatibilidad; si un identificador sin prefijo coincide de forma única con una entrada configurada compatible con imágenes enmodels.providers.*.models, OpenClaw lo califica para ese proveedor. Las coincidencias configuradas ambiguas requieren un prefijo de proveedor explícito.
- Lo usa la ruta de la herramienta
imageGenerationModel: acepta una cadena ("provider/model") o un objeto ({ primary, fallbacks }).- Lo usan la capacidad compartida de generación de imágenes y cualquier superficie futura de herramienta/Plugin que genere imágenes.
- Valores típicos:
google/gemini-3.1-flash-image-previewpara la generación de imágenes nativa de Gemini,fal/fal-ai/flux/devpara fal,openai/gpt-image-2para OpenAI Images, oopenai/gpt-image-1.5para salida PNG/WebP de OpenAI con fondo transparente. - Si seleccionas un proveedor/modelo directamente, configura también la autenticación del proveedor correspondiente (por ejemplo
GEMINI_API_KEYoGOOGLE_API_KEYparagoogle/*,OPENAI_API_KEYo OpenAI Codex OAuth paraopenai/gpt-image-2/openai/gpt-image-1.5,FAL_KEYparafal/*). - Si se omite,
image_generateaún puede inferir un valor predeterminado de proveedor respaldado por autenticación. Primero prueba el proveedor predeterminado actual y luego los proveedores de generación de imágenes registrados restantes en orden de identificador de proveedor.
musicGenerationModel: acepta una cadena ("provider/model") o un objeto ({ primary, fallbacks }).- Lo usan la capacidad compartida de generación de música y la herramienta integrada
music_generate. - Valores típicos:
google/lyria-3-clip-preview,google/lyria-3-pro-previewominimax/music-2.6. - Si se omite,
music_generateaún puede inferir un valor predeterminado de proveedor respaldado por autenticación. Primero prueba el proveedor predeterminado actual y luego los proveedores de generación de música registrados restantes en orden de identificador de proveedor. - Si seleccionas un proveedor/modelo directamente, configura también la autenticación/clave de API del proveedor correspondiente.
- Lo usan la capacidad compartida de generación de música y la herramienta integrada
videoGenerationModel: acepta una cadena ("provider/model") o un objeto ({ primary, fallbacks }).- Lo usan la capacidad compartida de generación de video y la herramienta integrada
video_generate. - Valores típicos:
qwen/wan2.6-t2v,qwen/wan2.6-i2v,qwen/wan2.6-r2v,qwen/wan2.6-r2v-flashoqwen/wan2.7-r2v. - Si se omite,
video_generateaún puede inferir un valor predeterminado de proveedor respaldado por autenticación. Primero prueba el proveedor predeterminado actual y luego los proveedores de generación de video registrados restantes en orden de identificador de proveedor. - Si seleccionas un proveedor/modelo directamente, configura también la autenticación/clave de API del proveedor correspondiente.
- El proveedor incluido de generación de video Qwen admite hasta 1 video de salida, 1 imagen de entrada, 4 videos de entrada, 10 segundos de duración y opciones de nivel de proveedor
size,aspectRatio,resolution,audioywatermark.
- Lo usan la capacidad compartida de generación de video y la herramienta integrada
pdfModel: acepta una cadena ("provider/model") o un objeto ({ primary, fallbacks }).- Lo usa la herramienta
pdfpara el enrutamiento de modelos. - Si se omite, la herramienta PDF recurre a
imageModely luego al modelo de sesión/predeterminado resuelto.
- Lo usa la herramienta
pdfMaxBytesMb: límite de tamaño de PDF predeterminado para la herramientapdfcuandomaxBytesMbno se pasa en el momento de la llamada.pdfMaxPages: máximo de páginas predeterminado que considera el modo de respaldo de extracción en la herramientapdf.verboseDefault: nivel detallado predeterminado para agentes. Valores:"off","on","full". Predeterminado:"off".toolProgressDetail: modo de detalle para resúmenes de herramientas de/verbosey líneas de herramienta de borrador de progreso. Valores:"explain"(predeterminado, etiquetas humanas compactas) o"raw"(añade comando/detalle sin procesar cuando está disponible).agents.list[].toolProgressDetailpor agente sobrescribe este valor predeterminado.reasoningDefault: visibilidad de razonamiento predeterminada para agentes. Valores:"off","on","stream".agents.list[].reasoningDefaultpor agente sobrescribe este valor predeterminado. Los valores predeterminados de razonamiento configurados solo se aplican a propietarios, remitentes autorizados o contextos de Gateway de administrador operador cuando no hay una sobrescritura de razonamiento por mensaje o por sesión.elevatedDefault: nivel predeterminado de salida elevada para agentes. Valores:"off","on","ask","full". Predeterminado:"on".model.primary: formatoprovider/model(p. ej.,openai/gpt-5.5para acceso con clave de API de OpenAI o Codex OAuth). Si omites el proveedor, OpenClaw prueba primero un alias, luego una coincidencia única de proveedor configurado para ese identificador de modelo exacto y solo entonces recurre al proveedor predeterminado configurado (comportamiento de compatibilidad obsoleto, así que prefiereprovider/modelexplícito). Si ese proveedor ya no expone el modelo predeterminado configurado, OpenClaw recurre al primer proveedor/modelo configurado en lugar de mostrar un valor predeterminado obsoleto de un proveedor eliminado.models: el catálogo de modelos configurado y la lista de permitidos para/model. Cada entrada puede incluiralias(atajo) yparams(específicos del proveedor, por ejemplotemperature,maxTokens,cacheRetention,context1m,responsesServerCompaction,responsesCompactThreshold,chat_template_kwargs,extra_body/extraBody).- Usa entradas
provider/*como"openai-codex/*": {}o"vllm/*": {}para mostrar todos los modelos descubiertos de los proveedores seleccionados sin listar manualmente cada identificador de modelo. - Ediciones seguras: usa
openclaw config set agents.defaults.models '<json>' --strict-json --mergepara añadir entradas.config setrechaza reemplazos que eliminarían entradas existentes de la lista de permitidos salvo que pases--replace. - Los flujos de configuración/incorporación con ámbito de proveedor fusionan los modelos de proveedor seleccionados en este mapa y conservan los proveedores no relacionados que ya estén configurados.
- Para modelos directos de OpenAI Responses, la Compaction del lado del servidor se habilita automáticamente. Usa
params.responsesServerCompaction: falsepara dejar de inyectarcontext_management, oparams.responsesCompactThresholdpara sobrescribir el umbral. Consulta Compaction del lado del servidor de OpenAI.
- Usa entradas
params: parámetros globales predeterminados de proveedor aplicados a todos los modelos. Se establece enagents.defaults.params(p. ej.{ cacheRetention: "long" }).- Prioridad de fusión de
params(configuración):agents.defaults.params(base global) se sobrescribe conagents.defaults.models["provider/model"].params(por modelo), luegoagents.list[].params(identificador de agente coincidente) sobrescribe por clave. Consulta almacenamiento en caché de prompts para obtener detalles. params.extra_body/params.extraBody: JSON avanzado de paso directo fusionado en cuerpos de solicitudapi: "openai-completions"para proxies compatibles con OpenAI. Si entra en conflicto con claves de solicitud generadas, gana el cuerpo adicional; las rutas de completions no nativas aún eliminan despuésstore, que solo es de OpenAI.params.chat_template_kwargs: argumentos de plantilla de chat compatibles con vLLM/OpenAI fusionados en cuerpos de solicitud de nivel superiorapi: "openai-completions". Paravllm/nemotron-3-*con pensamiento desactivado, el Plugin vLLM incluido envía automáticamenteenable_thinking: falseyforce_nonempty_content: true;chat_template_kwargsexplícito sobrescribe los valores predeterminados generados, yextra_body.chat_template_kwargsaún tiene la prioridad final. Para controles de pensamiento Qwen de vLLM, estableceparams.qwenThinkingFormaten"chat-template"o"top-level"en esa entrada de modelo.compat.thinkingFormat: estilo de carga útil de pensamiento compatible con OpenAI. Usa"qwen"paraenable_thinkingde nivel superior de estilo Qwen, o"qwen-chat-template"parachat_template_kwargs.enable_thinkingen backends de la familia Qwen que admitan kwargs de plantilla de chat a nivel de solicitud, como vLLM. OpenClaw asigna el pensamiento deshabilitado afalsey el pensamiento habilitado atrue.compat.supportedReasoningEfforts: lista de esfuerzo de razonamiento compatible con OpenAI por modelo. Incluye"xhigh"para endpoints personalizados que realmente lo acepten; entonces OpenClaw expone/think xhighen menús de comandos, filas de sesión de Gateway, validación de parches de sesión, validación de CLI de agente y validación dellm-taskpara ese proveedor/modelo configurado. Usacompat.reasoningEffortMapcuando el backend requiera un valor específico del proveedor para un nivel canónico.params.preserveThinking: activación opcional solo para Z.AI de pensamiento preservado. Cuando se habilita y el pensamiento está activado, OpenClaw envíathinking.clear_thinking: falsey reproducereasoning_contentanterior; consulta pensamiento y pensamiento preservado de Z.AI.localService: gestor de procesos opcional a nivel de proveedor para servidores de modelos locales/autohospedados. Cuando el modelo seleccionado pertenece a ese proveedor, OpenClaw sondeahealthUrl(obaseUrl + "/models"), iniciacommandconargssi el endpoint está caído, espera hastareadyTimeoutMsy luego envía la solicitud del modelo.commanddebe ser una ruta absoluta.idleStopMs: 0mantiene el proceso vivo hasta que OpenClaw sale; un valor positivo detiene el proceso iniciado por OpenClaw después de esa cantidad de milisegundos inactivos. Consulta servicios de modelos locales.- La política de runtime pertenece a proveedores o modelos, no a
agents.defaults. Usamodels.providers.<provider>.agentRuntimepara reglas de todo el proveedor oagents.defaults.models["provider/model"].agentRuntime/agents.list[].models["provider/model"].agentRuntimepara reglas específicas del modelo. Los modelos de agente de OpenAI en el proveedor oficial de OpenAI seleccionan Codex de forma predeterminada. - Los escritores de configuración que mutan estos campos (por ejemplo
/models set,/models set-imagey comandos de añadir/eliminar respaldos) guardan la forma de objeto canónica y conservan las listas de respaldos existentes cuando es posible. maxConcurrent: máximo de ejecuciones paralelas de agentes entre sesiones (cada sesión sigue serializada). Predeterminado: 4.
Política de runtime
id:"auto","pi", un identificador de harness de Plugin registrado o un alias de backend de CLI compatible. El Plugin Codex incluido registracodex; el Plugin Anthropic incluido proporciona el backend de CLIclaude-cli.id: "auto"permite que los harnesses de Plugin registrados reclamen turnos compatibles y usa PI cuando ningún harness coincide. Un runtime de Plugin explícito comoid: "codex"requiere ese harness y falla de forma cerrada si no está disponible o falla.- Las claves de runtime de agente completo son heredadas.
agents.defaults.agentRuntime,agents.list[].agentRuntime, las fijaciones de runtime de sesión yOPENCLAW_AGENT_RUNTIMEse ignoran en la selección de runtime. Ejecutaopenclaw doctor --fixpara eliminar valores obsoletos. - Los modelos de agente de OpenAI usan el harness de Codex de forma predeterminada;
agentRuntime.id: "codex"de proveedor/modelo sigue siendo válido cuando quieres hacerlo explícito. - Para despliegues de Claude CLI, prefiere
model: "anthropic/claude-opus-4-7"másagentRuntime.id: "claude-cli"con ámbito de modelo. Las referencias de modelo heredadasclaude-cli/claude-opus-4-7aún funcionan por compatibilidad, pero la configuración nueva debe mantener canónica la selección de proveedor/modelo y colocar el backend de ejecución en la política de runtime de proveedor/modelo. - Esto solo controla la ejecución de turnos de agente de texto. La generación de medios, visión, PDF, música, video y TTS siguen usando sus ajustes de proveedor/modelo.
agents.defaults.models):
| Alias | 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 o definas agents.defaults.models["zai/<model>"].params.thinking por tu cuenta.
Los modelos Z.AI habilitan tool_stream de forma predeterminada para la transmisión de llamadas a herramientas. Configura agents.defaults.models["zai/<model>"].params.tool_stream como false para deshabilitarlo.
Los modelos Anthropic Claude 4.6 usan de forma predeterminada el razonamiento adaptive cuando no se establece un nivel de razonamiento explícito.
agents.defaults.cliBackends
Backends CLI opcionales para ejecuciones alternativas solo de texto (sin llamadas a herramientas). Útiles como respaldo cuando fallan los proveedores de API.
- Los backends CLI priorizan el texto; las herramientas siempre están deshabilitadas.
- Las sesiones son compatibles cuando
sessionArgestá definido. - El paso directo de imágenes es compatible cuando
imageArgacepta rutas de archivo. reseedFromRawTranscriptWhenUncompacted: truepermite que un backend recupere sesiones invalidadas seguras a partir de una cola acotada de transcripción sin procesar de OpenClaw antes de que exista el primer resumen de Compaction. Los cambios de perfil de autenticación o de época de credenciales siguen sin volver a sembrarse nunca desde datos sin procesar.
agents.defaults.systemPromptOverride
Reemplaza todo el prompt de sistema ensamblado por OpenClaw con una cadena fija. Configúralo en el nivel predeterminado (agents.defaults.systemPromptOverride) o por agente (agents.list[].systemPromptOverride). Los valores por agente tienen prioridad; se ignora un valor vacío o que solo contenga espacios en blanco. Útil para experimentos de prompt controlados.
agents.defaults.promptOverlays
Superposiciones de prompt independientes del proveedor aplicadas por familia de modelos. Los ids de modelos de la familia GPT-5 reciben el contrato de comportamiento compartido entre proveedores; personality controla solo la capa de estilo de interacción amigable.
"friendly"(valor predeterminado) y"on"habilitan la capa de estilo de interacción amigable."off"deshabilita solo la capa amigable; el contrato de comportamiento GPT-5 etiquetado permanece habilitado.- El ajuste heredado
plugins.entries.openai.config.personalityse sigue leyendo cuando este ajuste compartido no está definido.
agents.defaults.heartbeat
Ejecuciones periódicas de Heartbeat.
every: cadena de duración (ms/s/m/h). Valor predeterminado:30m(autenticación con clave de API) o1h(autenticación OAuth). Configúralo como0mpara deshabilitarlo.includeSystemPromptSection: cuando es false, omite la sección Heartbeat del prompt de sistema y omite la inyección deHEARTBEAT.mden el contexto de arranque. Valor predeterminado:true.suppressToolErrorWarnings: cuando es true, suprime las cargas de advertencia de error de herramienta durante las ejecuciones de heartbeat.timeoutSeconds: tiempo máximo en segundos permitido para un turno del agente de heartbeat antes de abortarlo. Déjalo sin definir para usaragents.defaults.timeoutSeconds.directPolicy: política de entrega directa/DM.allow(valor predeterminado) permite la entrega a destino directo.blocksuprime la entrega a destino directo y emitereason=dm-blocked.lightContext: cuando es true, las ejecuciones de heartbeat usan contexto de arranque ligero y conservan soloHEARTBEAT.mdde los archivos de arranque del espacio de trabajo.isolatedSession: cuando es true, cada heartbeat se ejecuta en una sesión nueva sin historial de conversación previo. El mismo patrón de aislamiento que cronsessionTarget: "isolated". Reduce el costo de tokens por heartbeat de ~100K a ~2-5K tokens.skipWhenBusy: cuando es true, las ejecuciones de heartbeat se aplazan en las rutas ocupadas adicionales de ese agente: su propio subagente con clave de sesión o trabajo de comandos anidados. Las rutas de Cron siempre aplazan los heartbeats, incluso sin esta marca.- Por agente: configura
agents.list[].heartbeat. Cuando cualquier agente defineheartbeat, solo esos agentes ejecutan heartbeats. - Los heartbeats ejecutan turnos completos del agente: intervalos más cortos consumen más tokens.
agents.defaults.compaction
mode:defaultosafeguard(resumen por fragmentos para historiales largos). Consulta Compaction.provider: id de un Plugin de proveedor de compaction registrado. Cuando está definido, se llama asummarize()del proveedor en lugar del resumen LLM integrado. Recurre al integrado si falla. Configurar un proveedor fuerzamode: "safeguard". Consulta Compaction.timeoutSeconds: segundos máximos permitidos para una única operación de compaction antes de que OpenClaw la aborte. Valor predeterminado:900.keepRecentTokens: presupuesto de punto de corte de Pi para conservar literalmente la cola más reciente de la transcripción./compactmanual respeta esto cuando se define explícitamente; de lo contrario, la compaction manual es un punto de control estricto.identifierPolicy:strict(valor predeterminado),offocustom.strictantepone una guía integrada de retención de identificadores opacos durante el resumen de compaction.identifierInstructions: texto personalizado opcional de preservación de identificadores usado cuandoidentifierPolicy=custom.qualityGuard: comprobaciones de reintento ante salida mal formada para resúmenes de safeguard. Habilitado de forma predeterminada en modo safeguard; configuraenabled: falsepara omitir la auditoría.midTurnPrecheck: comprobación opcional de presión del bucle de herramientas de Pi. Cuandoenabled: true, OpenClaw comprueba la presión del contexto después de anexar los resultados de herramientas y antes de la siguiente llamada al modelo. Si el contexto ya no cabe, aborta el intento actual antes de enviar el prompt y reutiliza la ruta existente de recuperación de precomprobación para truncar resultados de herramientas o compactar y reintentar. Funciona con los modos de compactiondefaultysafeguard. Valor predeterminado: deshabilitado.postCompactionSections: nombres opcionales de secciones H2/H3 de AGENTS.md para reinyectar después de la compaction. El valor predeterminado es["Session Startup", "Red Lines"]; configura[]para deshabilitar la reinyección. Cuando no está definido o se define explícitamente como ese par predeterminado, también se aceptan los encabezados antiguosEvery Session/Safetycomo alternativa heredada.model: reemplazo opcionalprovider/model-idsolo para el resumen de compaction. Úsalo cuando la sesión principal deba conservar un modelo, pero los resúmenes de compaction deban ejecutarse en otro; cuando no está definido, la compaction usa el modelo principal de la sesión.maxActiveTranscriptBytes: umbral opcional en bytes (numbero cadenas como"20mb") que activa la compaction local normal antes de una ejecución cuando el JSONL activo supera el umbral. RequieretruncateAfterCompactionpara que una compaction correcta pueda rotar a una transcripción sucesora más pequeña. Deshabilitado cuando no está definido o es0.notifyUser: cuando estrue, envía avisos breves al usuario cuando empieza la compaction y cuando se completa (por ejemplo, “Compacting context…” y “Compaction complete”). Deshabilitado de forma predeterminada para mantener la compaction en silencio.memoryFlush: turno agéntico silencioso antes de la compaction automática para almacenar memorias duraderas. Configuramodelcomo un proveedor/modelo exacto, comoollama/qwen3:8b, cuando este turno de mantenimiento deba permanecer en un modelo local; el reemplazo no hereda la cadena de alternativas de la sesión activa. Se omite cuando el espacio de trabajo es de solo lectura.
agents.defaults.runRetries
Límites de iteración de reintento del bucle externo de ejecución para el runner Pi integrado, con el fin de evitar bucles de ejecución infinitos durante la recuperación de fallos. Ten en cuenta que este ajuste actualmente solo se aplica al runtime de agente integrado, no a los runtimes ACP ni CLI.
base: número base de iteraciones de reintento de ejecución para el bucle externo de ejecución. Valor predeterminado:24.perProfile: iteraciones adicionales de reintento de ejecución concedidas por cada candidato de perfil alternativo. Valor predeterminado:8.min: límite absoluto mínimo para las iteraciones de reintento de ejecución. Valor predeterminado:32.max: límite absoluto máximo para las iteraciones de reintento de ejecución para evitar ejecuciones descontroladas. Valor predeterminado:160.
agents.defaults.contextPruning
Elimina resultados antiguos de herramientas del contexto en memoria antes de enviarlo al LLM. No modifica el historial de sesión en disco.
cache-ttl mode behavior
cache-ttl mode behavior
mode: "cache-ttl"habilita las pasadas de poda.ttlcontrola con qué frecuencia puede volver a ejecutarse la poda (después del último contacto con la caché).- La poda primero recorta suavemente los resultados de herramientas demasiado grandes y luego, si es necesario, borra por completo los resultados de herramientas más antiguos.
... en el medio.Borrado completo reemplaza todo el resultado de la herramienta por el marcador de posición.Notas:- Los bloques de imagen nunca se recortan ni se borran.
- Las proporciones se basan en caracteres (aproximadas), no en recuentos exactos de tokens.
- Si existen menos de
keepLastAssistantsmensajes de asistente, se omite la poda.
Transmisión por bloques
- Los canales que no son Telegram requieren
*.blockStreaming: trueexplícito para habilitar las respuestas por bloques. - Sobrescrituras de canal:
channels.<channel>.blockStreamingCoalesce(y variantes por cuenta). Signal/Slack/Discord/Google Chat tienenminChars: 1500de forma predeterminada. humanDelay: pausa aleatorizada entre respuestas por bloques.natural= 800–2500 ms. Sobrescritura por agente:agents.list[].humanDelay.
Indicadores de escritura
- Valores predeterminados:
instantpara chats directos/menciones,messagepara chats grupales sin mención. - Sobrescrituras por sesión:
session.typingMode,session.typingIntervalSeconds.
agents.defaults.sandbox
Aislamiento opcional para el agente incrustado. Consulta Aislamiento para ver la guía completa.
Sandbox details
Sandbox details
Backend:Modo de OpenShell:
docker: entorno de ejecución local de Docker (predeterminado)ssh: entorno de ejecución remoto genérico respaldado por SSHopenshell: entorno de ejecución de OpenShell
backend: "openshell", la configuración específica del entorno de ejecución pasa a
plugins.entries.openshell.config.Configuración del backend SSH:target: destino SSH con formatouser@host[:port]command: comando de cliente SSH (predeterminado:ssh)workspaceRoot: raíz remota absoluta usada para espacios de trabajo por alcanceidentityFile/certificateFile/knownHostsFile: archivos locales existentes pasados a OpenSSHidentityData/certificateData/knownHostsData: contenidos en línea o SecretRefs que OpenClaw materializa en archivos temporales en tiempo de ejecuciónstrictHostKeyChecking/updateHostKeys: controles de política de claves de host de OpenSSH
identityDatatiene prioridad sobreidentityFilecertificateDatatiene prioridad sobrecertificateFileknownHostsDatatiene prioridad sobreknownHostsFile- Los valores
*Datarespaldados por SecretRef se resuelven desde la instantánea activa del entorno de ejecución de secretos antes de que comience la sesión de sandbox
- inicializa el espacio de trabajo remoto una vez después de crear o recrear
- luego mantiene el espacio de trabajo SSH remoto como canónico
- enruta
exec, las herramientas de archivos y las rutas de medios por SSH - no sincroniza automáticamente los cambios remotos de vuelta al host
- no admite contenedores de navegador de sandbox
none: espacio de trabajo de sandbox por alcance bajo~/.openclaw/sandboxesro: espacio de trabajo de sandbox en/workspace, espacio de trabajo del agente montado como solo lectura en/agentrw: espacio de trabajo del agente montado como lectura/escritura en/workspace
session: contenedor + espacio de trabajo por sesiónagent: un contenedor + espacio de trabajo por agente (predeterminado)shared: contenedor y espacio de trabajo compartidos (sin aislamiento entre sesiones)
mirror: inicializa el remoto desde el local antes de exec, sincroniza de vuelta después de exec; el espacio de trabajo local permanece como canónicoremote: inicializa el remoto una vez cuando se crea el sandbox y luego mantiene el espacio de trabajo remoto como canónico
remote, las ediciones locales del host realizadas fuera de OpenClaw no se sincronizan automáticamente en el sandbox después del paso de inicialización.
El transporte es SSH hacia el sandbox de OpenShell, pero el Plugin es propietario del ciclo de vida del sandbox y de la sincronización espejo opcional.setupCommand se ejecuta una vez después de la creación del contenedor (mediante sh -lc). Necesita salida de red, raíz escribible y usuario root.Los contenedores usan network: "none" de forma predeterminada: configúralo en "bridge" (o una red puente personalizada) si el agente necesita acceso saliente.
"host" está bloqueado. "container:<id>" está bloqueado de forma predeterminada salvo que configures explícitamente
sandbox.docker.dangerouslyAllowContainerNamespaceJoin: true (opción de emergencia).Los adjuntos entrantes se preparan en media/inbound/* en el espacio de trabajo activo.docker.binds monta directorios de host adicionales; los binds globales y por agente se fusionan.Navegador en sandbox (sandbox.browser.enabled): Chromium + CDP en un contenedor. La URL de noVNC se inyecta en el prompt del sistema. No requiere browser.enabled en openclaw.json.
El acceso de observador noVNC usa autenticación VNC de forma predeterminada y OpenClaw emite una URL de token de corta duración (en lugar de exponer la contraseña en la URL compartida).allowHostControl: false(predeterminado) impide que las sesiones en sandbox apunten al navegador del host.networkusaopenclaw-sandbox-browserde forma predeterminada (red puente dedicada). Configúralo enbridgesolo cuando quieras explícitamente conectividad de puente global.cdpSourceRangerestringe opcionalmente la entrada de CDP en el borde del contenedor a un rango CIDR (por ejemplo,172.21.0.1/32).sandbox.browser.bindsmonta directorios de host adicionales solo en el contenedor del navegador de sandbox. Cuando se configura (incluido[]), reemplazadocker.bindspara el contenedor del navegador.- Los valores predeterminados de inicio se definen en
scripts/sandbox-browser-entrypoint.shy están ajustados para hosts de contenedores:--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 de forma predeterminada)--disable-3d-apis,--disable-software-rasterizery--disable-gpuestán habilitados de forma predeterminada y se pueden deshabilitar conOPENCLAW_BROWSER_DISABLE_GRAPHICS_FLAGS=0si el uso de WebGL/3D lo requiere.OPENCLAW_BROWSER_DISABLE_EXTENSIONS=0vuelve a habilitar las extensiones si tu flujo de trabajo depende de ellas.--renderer-process-limit=2se puede cambiar conOPENCLAW_BROWSER_RENDERER_PROCESS_LIMIT=<N>; establece0para usar el límite de procesos predeterminado de Chromium.- además de
--no-sandboxcuandonoSandboxestá habilitado. - Los valores predeterminados son la línea base de la imagen de contenedor; usa una imagen de navegador personalizada con un punto de entrada personalizado para cambiar los valores predeterminados del contenedor.
sandbox.docker.binds son solo para Docker.
Crear imágenes (desde un checkout de código fuente):
docker build en línea.
agents.list (sobrescrituras por agente)
Use agents.list[].tts para dar a un agente su propio proveedor de TTS, voz, modelo,
estilo o modo de TTS automático. El bloque del agente se fusiona en profundidad sobre
messages.tts, por lo que las credenciales compartidas pueden permanecer en un solo lugar mientras los
agentes individuales sobrescriben solo los campos de voz o proveedor que necesitan. La sobrescritura
del agente activo se aplica a las respuestas habladas automáticas, /tts audio, /tts status y
la herramienta de agente tts. Consulta Texto a voz
para ver ejemplos de proveedores y precedencia.
id: id de agente estable (obligatorio).default: cuando se configuran varios, gana el primero (se registra una advertencia). Si no se configura ninguno, la primera entrada de la lista es la predeterminada.model: la forma de cadena establece un primario estricto por agente sin alternativa de modelo; la forma de objeto{ primary }también es estricta a menos que agreguesfallbacks. Usa{ primary, fallbacks: [...] }para habilitar alternativas para ese agente, o{ primary, fallbacks: [] }para hacer explícito el comportamiento estricto. Los trabajos Cron que solo sobrescribenprimarysiguen heredando las alternativas predeterminadas a menos que configuresfallbacks: [].params: parámetros de flujo por agente fusionados sobre la entrada del modelo seleccionado enagents.defaults.models. Usa esto para sobrescrituras específicas del agente comocacheRetention,temperatureomaxTokenssin duplicar todo el catálogo de modelos.tts: sobrescrituras opcionales de texto a voz por agente. El bloque se fusiona en profundidad sobremessages.tts, así que mantén las credenciales de proveedor compartidas y la política de alternativas enmessages.tts, y configura aquí solo valores específicos de la personalidad, como proveedor, voz, modelo, estilo o modo automático.skills: lista de permitidos opcional de Skills por agente. Si se omite, el agente heredaagents.defaults.skillscuando está configurado; una lista explícita reemplaza los valores predeterminados en lugar de fusionarse, y[]significa sin Skills.thinkingDefault: nivel de razonamiento predeterminado opcional por agente (off | minimal | low | medium | high | xhigh | adaptive | max). Sobrescribeagents.defaults.thinkingDefaultpara este agente cuando no se configura una sobrescritura por mensaje o sesión. El perfil de proveedor/modelo seleccionado controla qué valores son válidos; para Google Gemini,adaptivemantiene el razonamiento dinámico gestionado por el proveedor (thinkingLevelomitido en Gemini 3/3.1,thinkingBudget: -1en Gemini 2.5).reasoningDefault: visibilidad de razonamiento predeterminada opcional por agente (on | off | stream). Sobrescribeagents.defaults.reasoningDefaultpara este agente cuando no se configura una sobrescritura de razonamiento por mensaje o sesión.fastModeDefault: valor predeterminado opcional por agente para el modo rápido (true | false). Se aplica cuando no se configura una sobrescritura de modo rápido por mensaje o sesión.models: catálogo de modelos/sobrescrituras de runtime opcionales por agente, indexados por ids completosprovider/model. Usamodels["provider/model"].agentRuntimepara excepciones de runtime por agente.runtime: descriptor de runtime opcional por agente. Usatype: "acp"con los valores predeterminados deruntime.acp(agent,backend,mode,cwd) cuando el agente deba usar sesiones del arnés ACP de forma predeterminada.identity.avatar: ruta relativa al espacio de trabajo, URLhttp(s)o URIdata:.identityderiva valores predeterminados:ackReactiondesdeemoji,mentionPatternsdesdename/emoji.subagents.allowAgents: lista de permitidos de ids de agente para destinos explícitossessions_spawn.agentId(["*"]= cualquiera; predeterminado: solo el mismo agente). Incluye el id del solicitante cuando deban permitirse llamadasagentIddirigidas a sí mismo.- Protección de herencia de sandbox: si la sesión solicitante está en sandbox,
sessions_spawnrechaza destinos que se ejecutarían sin sandbox. subagents.requireAgentId: cuando es true, bloquea las llamadassessions_spawnque omitenagentId(fuerza la selección explícita de perfil; predeterminado: false).
Enrutamiento multiagente
Ejecuta varios agentes aislados dentro de un Gateway. Consulta Multiagente.Campos de coincidencia de vinculación
type(opcional):routepara enrutamiento normal (si falta el tipo, el valor predeterminado es route),acppara vinculaciones de conversación ACP persistentes.match.channel(obligatorio)match.accountId(opcional;*= cualquier cuenta; omitido = cuenta predeterminada)match.peer(opcional;{ kind: direct|group|channel, id })match.guildId/match.teamId(opcional; específico del canal)acp(opcional; solo paratype: "acp"):{ mode, label, cwd, backend }
match.peermatch.guildIdmatch.teamIdmatch.accountId(exacto, sin peer/guild/team)match.accountId: "*"(todo el canal)- Agente predeterminado
bindings.
Para entradas type: "acp", OpenClaw resuelve por identidad exacta de conversación (match.channel + cuenta + match.peer.id) y no usa el orden de niveles de vinculación de ruta anterior.
Perfiles de acceso por agente
Acceso completo (sin sandbox)
Acceso completo (sin sandbox)
Herramientas de solo lectura + espacio de trabajo
Herramientas de solo lectura + espacio de trabajo
Sin acceso al sistema de archivos (solo mensajería)
Sin acceso al sistema de archivos (solo mensajería)
Sesión
Detalles de los campos de sesión
Detalles de los campos de sesión
scope: estrategia base de agrupación de sesiones para contextos de chat grupal.per-sender(predeterminado): cada remitente obtiene una sesión aislada dentro de un contexto de canal.global: todos los participantes de un contexto de canal comparten una sola sesión (úsalo solo cuando se pretende un contexto compartido).
dmScope: cómo se agrupan los mensajes directos.main: todos los mensajes directos comparten la sesión principal.per-peer: aísla por id de remitente entre canales.per-channel-peer: aísla por canal + remitente (recomendado para bandejas de entrada multiusuario).per-account-channel-peer: aísla por cuenta + canal + remitente (recomendado para múltiples cuentas).
identityLinks: asigna ids canónicos a pares con prefijo de proveedor para compartir sesiones entre canales. Los comandos Dock, como/dock_discord, usan el mismo mapa para cambiar la ruta de respuesta de la sesión activa a otro par de canal vinculado; consulta acoplamiento de canales.reset: política principal de restablecimiento.dailyse restablece a la hora localatHour;idlese restablece después deidleMinutes. Cuando ambos están configurados, gana el que expire primero. La vigencia del restablecimiento diario usa elsessionStartedAtde la fila de sesión; la vigencia del restablecimiento por inactividad usalastInteractionAt. Las escrituras en segundo plano o de eventos del sistema, como Heartbeat, activaciones Cron, notificaciones de exec y mantenimiento del Gateway, pueden actualizarupdatedAt, pero no mantienen frescas las sesiones diarias o por inactividad.resetByType: anulaciones por tipo (direct,group,thread). Se acepta eldmheredado como alias dedirect.mainKey: campo heredado. En tiempo de ejecución siempre se usa"main"para el contenedor principal de chat directo.agentToAgent.maxPingPongTurns: número máximo de turnos de respuesta entre agentes durante intercambios de agente a agente (entero, rango:0-20, predeterminado:5).0desactiva el encadenamiento ping-pong.sendPolicy: coincide porchannel,chatType(direct|group|channel, con alias heredadodm),keyPrefixorawKeyPrefix. La primera denegación gana.maintenance: controles de limpieza + retención del almacén de sesiones.mode:warnsolo emite advertencias;enforceaplica la limpieza.pruneAfter: límite de antigüedad para entradas obsoletas (predeterminado30d).maxEntries: número máximo de entradas ensessions.json(predeterminado500). En tiempo de ejecución, escribe limpieza por lotes con un pequeño búfer de marca alta para límites de tamaño de producción;openclaw sessions cleanup --enforceaplica el límite inmediatamente.rotateBytes: obsoleto e ignorado;openclaw doctor --fixlo elimina de configuraciones antiguas.resetArchiveRetention: retención de archivos de transcripción*.reset.<timestamp>. El valor predeterminado espruneAfter; configúralo enfalsepara desactivarlo.maxDiskBytes: presupuesto opcional de disco para el directorio de sesiones. En modowarnregistra advertencias; en modoenforceelimina primero los artefactos/sesiones más antiguos.highWaterBytes: objetivo opcional después de la limpieza por presupuesto. El valor predeterminado es80%demaxDiskBytes.
threadBindings: valores predeterminados globales para funciones de sesión vinculadas a hilos.enabled: interruptor maestro predeterminado (los proveedores pueden anularlo; Discord usachannels.discord.threadBindings.enabled)idleHours: desenfoque automático predeterminado por inactividad en horas (0lo desactiva; los proveedores pueden anularlo)maxAgeHours: antigüedad máxima estricta predeterminada en horas (0la desactiva; los proveedores pueden anularla)spawnSessions: puerta predeterminada para crear sesiones de trabajo vinculadas a hilos desdesessions_spawny generaciones de hilos ACP. El valor predeterminado estruecuando las vinculaciones de hilos están activadas; los proveedores/cuentas pueden anularlo.defaultSpawnContext: contexto predeterminado de subagente nativo para generaciones vinculadas a hilos ("fork"o"isolated"). El valor predeterminado es"fork".
Mensajes
Prefijo de respuesta
Anulaciones por canal/cuenta:channels.<channel>.responsePrefix, channels.<channel>.accounts.<id>.responsePrefix.
Resolución (gana el más específico): cuenta → canal → global. "" desactiva y detiene la cascada. "auto" deriva [{identity.name}].
Variables de plantilla:
| Variable | Descripción | Ejemplo |
|---|---|---|
{model} | Nombre corto del modelo | claude-opus-4-6 |
{modelFull} | Identificador completo del modelo | anthropic/claude-opus-4-6 |
{provider} | Nombre del proveedor | anthropic |
{thinkingLevel} | Nivel de razonamiento actual | high, low, off |
{identity.name} | Nombre de identidad del agente | (igual que "auto") |
{think} es un alias de {thinkingLevel}.
Reacción de confirmación
- El valor predeterminado es
identity.emojidel agente activo; de lo contrario,"👀". Configura""para desactivarla. - Anulaciones por canal:
channels.<channel>.ackReaction,channels.<channel>.accounts.<id>.ackReaction. - Orden de resolución: cuenta → canal →
messages.ackReaction→ respaldo de identidad. - Alcance:
group-mentions(predeterminado),group-all,direct,all. removeAckAfterReply: elimina la confirmación después de responder en canales con capacidad de reacción como Slack, Discord, Telegram, WhatsApp e iMessage.messages.statusReactions.enabled: activa reacciones de estado del ciclo de vida en Slack, Discord y Telegram. En Slack y Discord, si no se define, mantiene activas las reacciones de estado cuando las reacciones de confirmación están activas. En Telegram, configúralo explícitamente entruepara activar las reacciones de estado del ciclo de vida.
Debounce de entrada
Agrupa mensajes rápidos de solo texto del mismo remitente en un único turno del agente. Los medios/adjuntos se envían inmediatamente. Los comandos de control omiten el debounce.TTS (texto a voz)
autocontrola el modo TTS automático predeterminado:off,always,inboundotagged./tts on|offpuede anular las preferencias locales, y/tts statusmuestra el estado efectivo.summaryModelanulaagents.defaults.model.primarypara el resumen automático.modelOverridesestá activado de forma predeterminada;modelOverrides.allowProviderusafalsede forma predeterminada (activación explícita).- Las claves de API recurren a
ELEVENLABS_API_KEY/XI_API_KEYyOPENAI_API_KEY. - Los proveedores de voz incluidos son propiedad de plugins. Si
plugins.allowestá definido, incluye cada Plugin proveedor de TTS que quieras usar, por ejemplomicrosoftpara Edge TTS. El id de proveedor heredadoedgese acepta como alias demicrosoft. providers.openai.baseUrlanula el endpoint de TTS de OpenAI. El orden de resolución es configuración, luegoOPENAI_TTS_BASE_URL, luegohttps://api.openai.com/v1.- Cuando
providers.openai.baseUrlapunta a un endpoint que no es de OpenAI, OpenClaw lo trata como un servidor TTS compatible con OpenAI y relaja la validación de modelo/voz.
Talk
Valores predeterminados para el modo Talk (macOS/iOS/Android).talk.providerdebe coincidir con una clave entalk.providerscuando se configuran varios proveedores de Talk.- Las claves planas heredadas de Talk (
talk.voiceId,talk.voiceAliases,talk.modelId,talk.outputFormat,talk.apiKey) existen solo por compatibilidad. Ejecutaopenclaw doctor --fixpara reescribir la configuración persistida entalk.providers.<provider>. - Los IDs de voz recurren a
ELEVENLABS_VOICE_IDoSAG_VOICE_ID. providers.*.apiKeyacepta cadenas de texto sin formato u objetos SecretRef.- El respaldo
ELEVENLABS_API_KEYse aplica solo cuando no hay una clave de API de Talk configurada. providers.*.voiceAliasespermite que las directivas de Talk usen nombres descriptivos.providers.mlx.modelIdselecciona el repositorio de Hugging Face usado por el asistente local MLX de macOS. Si se omite, macOS usamlx-community/Soprano-80M-bf16.- La reproducción MLX de macOS se ejecuta mediante el asistente incluido
openclaw-mlx-ttscuando está presente, o mediante un ejecutable enPATH;OPENCLAW_MLX_TTS_BINanula la ruta del asistente para desarrollo. consultThinkingLevelcontrola el nivel de razonamiento para la ejecución completa del agente OpenClaw detrás de las llamadasopenclaw_agent_consulten tiempo real de Talk de la UI de control. Déjalo sin definir para conservar el comportamiento normal de sesión/modelo.consultFastModeestablece una anulación de modo rápido de un solo uso para las consultas en tiempo real de Talk de la UI de control sin cambiar la configuración normal de modo rápido de la sesión.speechLocaleestablece el id de configuración regional BCP 47 usado por el reconocimiento de voz de Talk en iOS/macOS. Déjalo sin definir para usar el valor predeterminado del dispositivo.silenceTimeoutMscontrola cuánto tiempo espera el modo Talk después del silencio del usuario antes de enviar la transcripción. Si no se define, mantiene la ventana de pausa predeterminada de la plataforma (700 ms on macOS and Android, 900 ms on iOS).realtime.instructionsagrega instrucciones de sistema orientadas al proveedor al prompt en tiempo real integrado de OpenClaw, para que el estilo de voz pueda configurarse sin perder la guía predeterminada deopenclaw_agent_consult.
Relacionado
- Referencia de configuración — todas las demás claves de configuración
- Configuración — tareas comunes y configuración rápida
- Ejemplos de configuración