Creación de plugins
Los plugins amplían OpenClaw con nuevas capacidades: canales, proveedores de modelos, voz, transcripción en tiempo real, voz en tiempo real, comprensión de medios, generación de imágenes, generación de video, obtención web, búsqueda web, herramientas del agente o cualquier combinación. No necesitas añadir tu plugin al repositorio de OpenClaw. Publícalo en ClawHub o npm y los usuarios lo instalan conopenclaw plugins install <package-name>. OpenClaw intenta primero con ClawHub y
recurre automáticamente a npm.
Requisitos previos
- Node >= 22 y un gestor de paquetes (npm o pnpm)
- Familiaridad con TypeScript (ESM)
- Para plugins dentro del repositorio: repositorio clonado y
pnpm installejecutado
¿Qué tipo de plugin?
Plugin de canal
Conecta OpenClaw a una plataforma de mensajería (Discord, IRC, etc.)
Plugin de proveedor
Añade un proveedor de modelos (LLM, proxy o endpoint personalizado)
Plugin de herramienta / hook
Registra herramientas de agente, hooks de eventos o servicios — continúa abajo
createOptionalChannelSetupSurface(...) de
openclaw/plugin-sdk/channel-setup. Produce un adaptador de configuración + par de asistente
que anuncia el requisito de instalación y falla de forma cerrada en escrituras de configuración reales
hasta que el plugin esté instalado.
Inicio rápido: plugin de herramienta
Este recorrido crea un plugin mínimo que registra una herramienta de agente. Los plugins de canal y proveedor tienen guías específicas enlazadas arriba.Crear el paquete y el manifiesto
docs/snippets/plugin-publish/.Escribir el punto de entrada
definePluginEntry es para plugins que no son de canal. Para canales, usa
defineChannelPluginEntry; consulta Plugins de canal.
Para ver todas las opciones de puntos de entrada, consulta Puntos de entrada.Probar y publicar
Plugins externos: valida y publica con ClawHub, luego instala:OpenClaw también comprueba ClawHub antes que npm para especificaciones de paquete simples como
@myorg/openclaw-my-plugin.Plugins dentro del repositorio: colócalos dentro del árbol de workspace de plugins integrados; se detectan automáticamente.Capacidades del plugin
Un único plugin puede registrar cualquier número de capacidades mediante el objetoapi:
| Capacidad | Método de registro | Guía detallada |
|---|---|---|
| Inferencia de texto (LLM) | api.registerProvider(...) | Plugins de proveedor |
| Backend de inferencia de CLI | api.registerCliBackend(...) | Backends de CLI |
| Canal / mensajería | api.registerChannel(...) | Plugins de canal |
| Voz (TTS/STT) | api.registerSpeechProvider(...) | Plugins de proveedor |
| Transcripción en tiempo real | api.registerRealtimeTranscriptionProvider(...) | Plugins de proveedor |
| Voz en tiempo real | api.registerRealtimeVoiceProvider(...) | Plugins de proveedor |
| Comprensión de medios | api.registerMediaUnderstandingProvider(...) | Plugins de proveedor |
| Generación de imágenes | api.registerImageGenerationProvider(...) | Plugins de proveedor |
| Generación de video | api.registerVideoGenerationProvider(...) | Plugins de proveedor |
| Obtención web | api.registerWebFetchProvider(...) | Plugins de proveedor |
| Búsqueda web | api.registerWebSearchProvider(...) | Plugins de proveedor |
| Herramientas del agente | api.registerTool(...) | Abajo |
| Comandos personalizados | api.registerCommand(...) | Puntos de entrada |
| Hooks de eventos | api.registerHook(...) | Puntos de entrada |
| Rutas HTTP | api.registerHttpRoute(...) | Internals |
| Subcomandos de CLI | api.registerCli(...) | Puntos de entrada |
config.*,
exec.approvals.*, wizard.*, update.*) siguen estando reservados y siempre se resuelven a
operator.admin, incluso si un plugin solicita un ámbito más restringido.
Semántica de guardas de hooks que debes tener en cuenta:
before_tool_call:{ block: true }es terminal y detiene los controladores de menor prioridad.before_tool_call:{ block: false }se trata como si no hubiera decisión.before_tool_call:{ requireApproval: true }pausa la ejecución del agente y solicita aprobación al usuario mediante la superposición de aprobación de exec, botones de Telegram, interacciones de Discord o el comando/approveen cualquier canal.before_install:{ block: true }es terminal y detiene los controladores de menor prioridad.before_install:{ block: false }se trata como si no hubiera decisión.message_sending:{ cancel: true }es terminal y detiene los controladores de menor prioridad.message_sending:{ cancel: false }se trata como si no hubiera decisión.
/approve gestiona tanto aprobaciones de exec como de plugins con un respaldo acotado: cuando no se encuentra un ID de aprobación de exec, OpenClaw vuelve a intentar el mismo ID mediante aprobaciones de plugins. El reenvío de aprobaciones de plugins puede configurarse de forma independiente mediante approvals.plugin en la configuración.
Si la infraestructura personalizada de aprobaciones necesita detectar ese mismo caso de respaldo acotado,
prefiere isApprovalNotFoundError de openclaw/plugin-sdk/error-runtime
en lugar de buscar manualmente cadenas de vencimiento de aprobación.
Consulta Semántica de decisiones de hooks del resumen del SDK para más detalles.
Registrar herramientas de agente
Las herramientas son funciones tipadas que el LLM puede invocar. Pueden ser obligatorias (siempre disponibles) u opcionales (adhesión del usuario):- Los nombres de herramientas no deben entrar en conflicto con las herramientas del núcleo (los conflictos se omiten)
- Usa
optional: truepara herramientas con efectos secundarios o requisitos binarios adicionales - Los usuarios pueden habilitar todas las herramientas de un plugin añadiendo el ID del plugin a
tools.allow
Convenciones de importación
Importa siempre desde rutas específicasopenclaw/plugin-sdk/<subpath>:
api.ts, runtime-api.ts) para
importaciones internas; nunca importes tu propio plugin mediante su ruta del SDK.
Para plugins de proveedor, mantén los auxiliares específicos del proveedor en esos barrel
de la raíz del paquete, a menos que la interfaz sea realmente genérica. Ejemplos actuales integrados:
- Anthropic: envoltorios de flujo de Claude y auxiliares
service_tier/ beta - OpenAI: constructores de proveedor, auxiliares de modelo predeterminado, proveedores en tiempo real
- OpenRouter: constructor de proveedor más auxiliares de onboarding/configuración
openclaw/plugin-sdk/*.
Todavía existen algunas interfaces auxiliares generadas openclaw/plugin-sdk/<bundled-id>
para mantenimiento y compatibilidad de plugins integrados, por ejemplo
plugin-sdk/feishu-setup o plugin-sdk/zalo-setup. Trátalas como superficies reservadas,
no como el patrón predeterminado para nuevos plugins de terceros.
Lista de comprobación previa al envío
package.json tiene los metadatos
openclaw correctosEl manifiesto openclaw.plugin.json está presente y es válido
El punto de entrada usa
defineChannelPluginEntry o definePluginEntryTodas las importaciones usan rutas específicas
plugin-sdk/<subpath>Las importaciones internas usan módulos locales, no autoimportaciones del SDK
Las pruebas pasan (
pnpm test -- <bundled-plugin-root>/my-plugin/)pnpm check pasa (plugins dentro del repositorio)Pruebas de versiones beta
- Vigila las etiquetas de versiones de GitHub en openclaw/openclaw y suscríbete mediante
Watch>Releases. Las etiquetas beta tienen un aspecto comov2026.3.N-beta.1. También puedes activar notificaciones para la cuenta oficial de OpenClaw en X @openclaw para anuncios de versiones. - Prueba tu plugin con la etiqueta beta en cuanto aparezca. El margen antes de la versión estable suele ser de solo unas horas.
- Publica en el hilo de tu plugin en el canal
plugin-forumde Discord después de probarlo conall goodo con lo que se haya roto. Si todavía no tienes un hilo, crea uno. - Si algo se rompe, abre o actualiza una incidencia titulada
Beta blocker: <plugin-name> - <summary>y aplica la etiquetabeta-blocker. Pon el enlace de la incidencia en tu hilo. - Abre un PR a
maintituladofix(<plugin-id>): beta blocker - <summary>y enlaza la incidencia tanto en el PR como en tu hilo de Discord. Los colaboradores no pueden etiquetar PR, así que el título es la señal del lado del PR para mantenedores y automatización. Los bloqueos con PR se fusionan; los bloqueos sin PR podrían publicarse igualmente. Los mantenedores vigilan estos hilos durante las pruebas beta. - El silencio significa verde. Si pierdes la ventana, es probable que tu corrección llegue en el siguiente ciclo.
Siguientes pasos
Plugins de canal
Crea un plugin de canal de mensajería
Plugins de proveedor
Crea un plugin de proveedor de modelos
Resumen del SDK
Mapa de importaciones y referencia de la API de registro
Auxiliares de runtime
TTS, búsqueda, subagente mediante api.runtime
Pruebas
Utilidades y patrones de prueba
Manifiesto del plugin
Referencia completa del esquema del manifiesto
Relacionado
- Arquitectura de plugins — análisis detallado de la arquitectura interna
- Resumen del SDK — referencia del SDK de plugins
- Manifest — formato del manifiesto del plugin
- Plugins de canal — creación de plugins de canal
- Plugins de proveedor — creación de plugins de proveedor