Referencia para el objetoDocumentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
api.runtime inyectado en cada plugin durante el registro. Usa estos helpers en lugar de importar directamente componentes internos del host.
Plugins de canales
Guía paso a paso que usa estos helpers en contexto para plugins de canales.
Plugins de proveedores
Guía paso a paso que usa estos helpers en contexto para plugins de proveedores.
Carga y escrituras de configuración
Prefiere la configuración que ya se pasó a la ruta de llamada activa, por ejemploapi.config durante el registro o un argumento cfg en callbacks de canal/proveedor. Esto mantiene una instantánea de proceso fluyendo por el trabajo en lugar de volver a analizar la configuración en rutas críticas.
Usa api.runtime.config.current() solo cuando un manejador de larga duración necesite la instantánea actual del proceso y no se haya pasado ninguna configuración a esa función. El valor devuelto es de solo lectura; clónalo o usa un helper de mutación antes de editarlo.
Las fábricas de herramientas reciben ctx.runtimeConfig además de ctx.getRuntimeConfig(). Usa el getter dentro del callback execute de una herramienta de larga duración cuando la configuración pueda cambiar después de que se haya creado la definición de la herramienta.
Persiste los cambios con api.runtime.config.mutateConfigFile(...) o api.runtime.config.replaceConfigFile(...). Cada escritura debe elegir una política explícita afterWrite:
afterWrite: { mode: "auto" }permite que el planificador de recarga del Gateway decida.afterWrite: { mode: "restart", reason: "..." }fuerza un reinicio limpio cuando el escritor sabe que la recarga en caliente no es segura.afterWrite: { mode: "none", reason: "..." }suprime la recarga o reinicio automático solo cuando el llamador se hace cargo del seguimiento.
afterWrite además de un resumen tipado followUp para que los llamadores puedan registrar o probar si solicitaron un reinicio. El Gateway sigue siendo responsable de cuándo ocurre realmente ese reinicio.
api.runtime.config.loadConfig() y api.runtime.config.writeConfigFile(...) son helpers de compatibilidad obsoletos bajo runtime-config-load-write. Emiten una advertencia una vez en tiempo de ejecución y siguen disponibles para plugins externos antiguos durante la ventana de migración. Los plugins incluidos no deben usarlos; las protecciones del límite de configuración fallan si el código del plugin los llama o importa esos helpers desde subrutas del SDK de plugins.
Para importaciones directas del SDK, usa las subrutas de configuración específicas en lugar del barril de compatibilidad amplio
openclaw/plugin-sdk/config-runtime: config-contracts para
tipos, plugin-config-runtime para aserciones de configuración ya cargada y búsqueda de entradas de plugin,
runtime-config-snapshot para instantáneas actuales del proceso, y
config-mutation para escrituras. Las pruebas de plugins incluidos deben simular directamente estas subrutas específicas en lugar de simular el barril de compatibilidad amplio.
El código interno de tiempo de ejecución de OpenClaw sigue la misma dirección: cargar la configuración una vez en el límite de CLI, Gateway o proceso, y luego pasar ese valor. Las escrituras de mutación correctas actualizan la instantánea de tiempo de ejecución del proceso y avanzan su revisión interna; las cachés de larga duración deben basarse en la clave de caché propiedad del tiempo de ejecución en lugar de serializar la configuración localmente. Los módulos de tiempo de ejecución de larga duración tienen un escáner de tolerancia cero para llamadas ambientales a loadConfig(); usa un cfg pasado, un context.getRuntimeConfig() de solicitud o getRuntimeConfig() en un límite de proceso explícito.
Las rutas de ejecución de proveedores y canales deben usar la instantánea activa de configuración de tiempo de ejecución, no una instantánea de archivo devuelta para lectura o edición de configuración. Las instantáneas de archivo preservan valores fuente como marcadores SecretRef para la UI y las escrituras; los callbacks de proveedor necesitan la vista de tiempo de ejecución resuelta. Cuando un helper pueda llamarse con la instantánea fuente activa o con la instantánea de tiempo de ejecución activa, enruta mediante selectApplicableRuntimeConfig() antes de leer credenciales.
Espacios de nombres de tiempo de ejecución
api.runtime.agent
api.runtime.agent
Identidad del agente, directorios y administración de sesiones.Prefiere
runEmbeddedAgent(...) es el helper neutral para iniciar un turno normal de agente de OpenClaw desde código de plugin. Usa la misma resolución de proveedor/modelo y selección de arnés de agente que las respuestas activadas por canales.runEmbeddedPiAgent(...) permanece como alias de compatibilidad.resolveThinkingPolicy(...) devuelve los niveles de razonamiento admitidos por el proveedor/modelo y el valor predeterminado opcional. Los plugins de proveedor son responsables del perfil específico del modelo mediante sus hooks de razonamiento, por lo que los plugins de herramientas deben llamar a este helper de tiempo de ejecución en lugar de importar o duplicar listas de proveedores.normalizeThinkingLevel(...) convierte texto de usuario como on, x-high o extra high al nivel almacenado canónico antes de comprobarlo contra la política resuelta.Los helpers del almacén de sesiones están bajo api.runtime.agent.session:updateSessionStore(...) o updateSessionStoreEntry(...) para escrituras en tiempo de ejecución. Enrutan por el escritor del almacén de sesiones propiedad del Gateway, preservan actualizaciones simultáneas y reutilizan la caché activa. saveSessionStore(...) sigue disponible para compatibilidad y reescrituras de estilo mantenimiento sin conexión.api.runtime.agent.defaults
api.runtime.agent.defaults
Constantes de modelo y proveedor predeterminadas:
api.runtime.llm
api.runtime.llm
Ejecuta una finalización de texto propiedad del host sin importar componentes internos del proveedor ni
duplicar la preparación de modelo/autenticación/URL base de OpenClaw.El helper usa la misma ruta de preparación de finalización simple que el tiempo de ejecución integrado de OpenClaw
y la instantánea de configuración de tiempo de ejecución propiedad del host. Los motores de contexto
reciben una capacidad
llm.complete vinculada a la sesión, de modo que las llamadas a modelos usan el
agente de la sesión activa y no recurren silenciosamente al agente predeterminado. El
resultado incluye atribución de proveedor/modelo/agente además de uso normalizado de tokens,
caché y costo estimado cuando esté disponible.api.runtime.subagent
api.runtime.subagent
Inicia y administra ejecuciones de subagentes en segundo plano.
deleteSession(...) puede eliminar sesiones creadas por el mismo plugin mediante api.runtime.subagent.run(...). Eliminar sesiones arbitrarias de usuarios u operadores todavía requiere una solicitud de Gateway con alcance de administrador.api.runtime.nodes
api.runtime.nodes
Lista los nodos conectados e invoca un comando alojado en un nodo desde código de plugin cargado por Gateway o desde comandos de CLI del plugin. Usa esto cuando un plugin es responsable de trabajo local en un dispositivo emparejado, por ejemplo un puente de navegador o audio en otra Mac.Dentro del Gateway, este tiempo de ejecución está en proceso. En comandos de CLI del plugin, llama al Gateway configurado mediante RPC, de modo que comandos como
openclaw googlemeet recover-tab pueden inspeccionar nodos emparejados desde la terminal. Los comandos de Node siguen pasando por el emparejamiento normal de nodos del Gateway, las listas de comandos permitidos, las políticas de invocación de nodos del plugin y el manejo de comandos locales del nodo.Los plugins que exponen comandos peligrosos alojados en nodos deben registrar una política de invocación de nodos con api.registerNodeInvokePolicy(...). La política se ejecuta en el Gateway después de las comprobaciones de la lista de comandos permitidos y antes de reenviar el comando al nodo, de modo que las llamadas directas a node.invoke y las herramientas de plugin de nivel superior comparten la misma ruta de cumplimiento.api.runtime.tasks.managedFlows
api.runtime.tasks.managedFlows
Vincula un tiempo de ejecución de flujo de tareas a una clave de sesión existente de OpenClaw o a un contexto de herramienta de confianza, y luego crea y administra flujos de tareas sin pasar un propietario en cada llamada.El flujo de tareas rastrea estado duradero de flujos de trabajo de varios pasos. No es un programador:
usa Cron o Usa
api.session.workflow.scheduleSessionTurn(...) para despertares
futuros, y luego usa managedFlows desde el turno programado cuando ese trabajo
necesite estado de flujo, tareas secundarias, esperas o cancelación.bindSession({ sessionKey, requesterOrigin }) cuando ya tengas una clave de sesión de OpenClaw de confianza desde tu propia capa de vinculación. No vincules desde la entrada sin procesar del usuario.api.runtime.tts
api.runtime.tts
Síntesis de texto a voz.Usa la configuración principal
messages.tts y la selección de proveedor. Devuelve un búfer de audio PCM + frecuencia de muestreo.api.runtime.mediaUnderstanding
api.runtime.mediaUnderstanding
Análisis de imágenes, audio y video.Devuelve
{ text: undefined } cuando no se produce ninguna salida (por ejemplo, entrada omitida).api.runtime.stt.transcribeAudioFile(...) sigue siendo un alias de compatibilidad para api.runtime.mediaUnderstanding.transcribeAudioFile(...).api.runtime.imageGeneration
api.runtime.imageGeneration
Generación de imágenes.
api.runtime.webSearch
api.runtime.webSearch
Búsqueda web.
api.runtime.media
api.runtime.media
Utilidades multimedia de bajo nivel.
api.runtime.config
api.runtime.config
Instantánea actual de configuración en tiempo de ejecución y escrituras transaccionales de configuración. Prefiere
la configuración que ya se pasó a la ruta de llamada activa; usa
current() solo cuando el controlador necesite directamente la instantánea del proceso.mutateConfigFile(...) y replaceConfigFile(...) devuelven un valor
followUp, por ejemplo { mode: "restart", requiresRestart: true, reason },
que registra la intención del escritor sin quitarle el control de reinicio al
gateway.api.runtime.system
api.runtime.system
Utilidades de nivel de sistema.
api.runtime.events
api.runtime.events
Suscripciones a eventos.
api.runtime.logging
api.runtime.logging
Registro.
api.runtime.modelAuth
api.runtime.modelAuth
Resolución de autenticación de modelos y proveedores.
api.runtime.state
api.runtime.state
Resolución del directorio de estado y almacenamiento con claves respaldado por SQLite.Los almacenes con claves sobreviven a los reinicios y están aislados por el id del plugin vinculado al tiempo de ejecución. Usa
registerIfAbsent(...) para reclamaciones atómicas de deduplicación: devuelve true cuando la clave faltaba o había expirado y se registró, o false cuando ya existe un valor activo sin sobrescribir su valor, hora de creación ni TTL. Límites: maxEntries por espacio de nombres, 1000 filas activas por plugin, valores JSON de menos de 64 KB y vencimiento TTL opcional.api.runtime.tools
api.runtime.tools
Fábricas de herramientas de memoria y CLI.
api.runtime.channel
api.runtime.channel
Ayudantes de tiempo de ejecución específicos del canal (disponibles cuando se carga un plugin de canal).Ayudantes de mención disponibles:
api.runtime.channel.mentions es la superficie compartida de política de menciones entrantes para los plugins de canal incluidos que usan inyección en tiempo de ejecución:buildMentionRegexesmatchesMentionPatternsmatchesMentionWithExplicitimplicitMentionKindWhenresolveInboundMentionDecision
api.runtime.channel.mentions no expone intencionalmente los ayudantes de compatibilidad antiguos resolveMentionGating*. Prefiere la ruta normalizada { facts, policy }.Almacenar referencias de tiempo de ejecución
UsacreatePluginRuntimeStore para almacenar la referencia de tiempo de ejecución y usarla fuera del callback register:
Prefiere
pluginId para la identidad del runtime-store. La forma de menor nivel key es para casos poco comunes en los que un plugin necesita intencionalmente más de una ranura de tiempo de ejecución.Otros campos api de nivel superior
Más allá de api.runtime, el objeto API también proporciona:
Id del Plugin.
Nombre visible del Plugin.
Instantánea de configuración actual (instantánea del runtime en memoria activo cuando está disponible).
Configuración específica del Plugin desde
plugins.entries.<id>.config.Logger con ámbito (
debug, info, warn, error).Modo de carga actual;
"setup-runtime" es la ventana ligera de inicio/configuración previa a la entrada completa.Resuelve una ruta relativa a la raíz del plugin.
Relacionado
- Elementos internos del Plugin — modelo de capacidades y registro
- Puntos de entrada del SDK — opciones de
definePluginEntry - Descripción general del SDK — referencia de subrutas