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.
Esta es una guía para colaboradores para desarrolladores principales de OpenClaw. Si estás
creando un plugin externo, consulta Crear plugins
en su lugar. Para la referencia de arquitectura profunda (modelo de capacidades, propiedad,
canalización de carga, ayudantes de runtime), consulta Internos del Plugin.
- plugin = límite de propiedad
- capacidad = contrato compartido del núcleo
Cuándo crear una capacidad
Crea una nueva capacidad cuando todo lo siguiente sea cierto:- Más de un proveedor podría implementarla de forma plausible.
- Los canales, herramientas o plugins de funciones deberían consumirla sin preocuparse por el proveedor.
- El núcleo necesita poseer el comportamiento de fallback, política, configuración o entrega.
La secuencia estándar
- Define el contrato tipado del núcleo.
- Agrega el registro de plugins para ese contrato.
- Agrega un ayudante de runtime compartido.
- Conecta un plugin de proveedor real como prueba.
- Mueve los consumidores de funciones/canales al ayudante de runtime.
- Agrega pruebas de contrato.
- Documenta la configuración orientada al operador y el modelo de propiedad.
Qué va dónde
Núcleo:- Tipos de solicitud/respuesta.
- Registro de proveedores + resolución.
- Comportamiento de fallback.
- Esquema de configuración con metadatos de documentación
title/descriptionpropagados en nodos de objeto anidado, comodín, elemento de array y composición. - Superficie de ayudante de runtime.
- Llamadas a la API del proveedor.
- Manejo de autenticación del proveedor.
- Normalización de solicitudes específica del proveedor.
- Registro de la implementación de la capacidad.
- Llama a
api.runtime.*o al ayudanteplugin-sdk/*-runtimecorrespondiente. - Nunca llama directamente a una implementación de proveedor.
Seams de proveedor y arnés
Usa hooks de proveedor cuando el comportamiento pertenezca al contrato del proveedor de modelo en lugar del bucle genérico del agente. Algunos ejemplos incluyen parámetros de solicitud específicos del proveedor después de la selección de transporte, preferencia de perfil de autenticación, superposiciones de prompt y enrutamiento de fallback de seguimiento después de una conmutación por error de modelo/perfil. Usa hooks de arnés de agente cuando el comportamiento pertenezca al runtime que ejecuta un turno. Los arneses pueden clasificar resultados de intentos exitosos pero inutilizables, como respuestas vacías, solo de razonamiento o solo de planificación, para que la política externa de fallback de modelo pueda tomar la decisión de reintento. Mantén ambos seams estrechos:- El núcleo posee la política de reintento/fallback.
- Los plugins de proveedor poseen las pistas de solicitud/autenticación/enrutamiento específicas del proveedor.
- Los plugins de arnés poseen la clasificación de intentos específica del runtime.
- Los plugins de terceros devuelven pistas, no mutaciones directas del estado del núcleo.
Lista de comprobación de archivos
Para una nueva capacidad, espera tocar estas áreas:src/<capability>/types.tssrc/<capability>/...registry/runtime.tssrc/plugins/types.tssrc/plugins/registry.tssrc/plugins/captured-registration.tssrc/plugins/contracts/registry.tssrc/plugins/runtime/types-core.tssrc/plugins/runtime/index.tssrc/plugin-sdk/<capability>.tssrc/plugin-sdk/<capability>-runtime.ts- Uno o más paquetes de plugins incluidos.
- Configuración, documentación, pruebas.
Ejemplo trabajado: generación de imágenes
La generación de imágenes sigue la forma estándar:- El núcleo define
ImageGenerationProvider. - El núcleo expone
registerImageGenerationProvider(...). - El núcleo expone
runtime.imageGeneration.generate(...). - Los plugins
openai,google,falyminimaxregistran implementaciones respaldadas por proveedores. - Los futuros proveedores registran el mismo contrato sin cambiar canales/herramientas.
agents.defaults.imageModelanaliza imágenes.agents.defaults.imageGenerationModelgenera imágenes.
Lista de comprobación de revisión
Antes de publicar una nueva capacidad, verifica:- Ningún canal/herramienta importa directamente código de proveedor.
- El ayudante de runtime es la ruta compartida.
- Al menos una prueba de contrato afirma la propiedad incluida.
- La documentación de configuración nombra la nueva clave de modelo/configuración.
- La documentación de Plugin explica el límite de propiedad.
Relacionado
- Internos del Plugin — modelo de capacidades, propiedad, canalización de carga, ayudantes de runtime.
- Crear plugins — tutorial del primer plugin.
- Resumen del SDK — mapa de importaciones y referencia de la API de registro.
- Crear Skills — superficie complementaria para colaboradores.