Skills (OpenClaw)
OpenClaw usa carpetas de Skills compatibles con AgentSkills para enseñar al agente a usar herramientas. Cada Skill es un directorio que contiene unSKILL.md con frontmatter YAML e instrucciones. OpenClaw carga Skills integradas más anulaciones locales opcionales, y las filtra en tiempo de carga según el entorno, la configuración y la presencia de binarios.
Ubicaciones y precedencia
OpenClaw carga Skills desde estas fuentes:- Carpetas de Skills adicionales: configuradas con
skills.load.extraDirs - Skills integradas: incluidas con la instalación (paquete npm o OpenClaw.app)
- Skills administradas/locales:
~/.openclaw/skills - Skills personales del agente:
~/.agents/skills - Skills del agente del proyecto:
<workspace>/.agents/skills - Skills del espacio de trabajo:
<workspace>/skills
<workspace>/skills (máxima) → <workspace>/.agents/skills → ~/.agents/skills → ~/.openclaw/skills → Skills integradas → skills.load.extraDirs (mínima)
Skills por agente frente a compartidas
En configuraciones de varios agentes, cada agente tiene su propio espacio de trabajo. Eso significa:- Las Skills por agente viven en
<workspace>/skillssolo para ese agente. - Las Skills del agente del proyecto viven en
<workspace>/.agents/skillsy se aplican a ese espacio de trabajo antes de la carpeta normalskills/del espacio de trabajo. - Las Skills personales del agente viven en
~/.agents/skillsy se aplican en todos los espacios de trabajo de esa máquina. - Las Skills compartidas viven en
~/.openclaw/skills(administradas/locales) y son visibles para todos los agentes de la misma máquina. - Las carpetas compartidas también pueden agregarse mediante
skills.load.extraDirs(precedencia mínima) si quieres un paquete común de Skills usado por varios agentes.
Listas de permitidos de Skills por agente
La ubicación de la Skill y la visibilidad de la Skill son controles separados.- La ubicación/precedencia decide qué copia gana cuando una Skill tiene el mismo nombre.
- Las listas de permitidos del agente deciden qué Skills visibles puede usar realmente un agente.
agents.defaults.skills para una base compartida y luego anula por agente con
agents.list[].skills:
- Omite
agents.defaults.skillspara que las Skills no tengan restricciones de forma predeterminada. - Omite
agents.list[].skillspara heredaragents.defaults.skills. - Establece
agents.list[].skills: []para no tener Skills. - Una lista no vacía en
agents.list[].skillses el conjunto final para ese agente; no se combina con los valores predeterminados.
Plugins + Skills
Los plugins pueden incluir sus propias Skills listando directoriosskills en
openclaw.plugin.json (rutas relativas a la raíz del plugin). Las Skills del plugin se cargan
cuando el plugin está habilitado. Hoy esos directorios se fusionan en la misma ruta de baja
precedencia que skills.load.extraDirs, por lo que una Skill integrada, administrada,
de agente o de espacio de trabajo con el mismo nombre las anula.
Puedes controlarlas mediante metadata.openclaw.requires.config en la entrada de configuración
del plugin. Consulta Plugins para descubrimiento/configuración y Herramientas para la
superficie de herramientas que enseñan esas Skills.
ClawHub (instalación + sincronización)
ClawHub es el registro público de Skills para OpenClaw. Explóralo en https://clawhub.ai. Usa los comandos nativosopenclaw skills
para descubrir/instalar/actualizar Skills, o la CLI separada clawhub cuando
necesites flujos de publicación/sincronización.
Guía completa: ClawHub.
Flujos comunes:
- Instalar una Skill en tu espacio de trabajo:
openclaw skills install <skill-slug>
- Actualizar todas las Skills instaladas:
openclaw skills update --all
- Sincronizar (analizar + publicar actualizaciones):
clawhub sync --all
openclaw skills install nativo instala en el directorio skills/
del espacio de trabajo activo. La CLI separada clawhub también instala en ./skills bajo tu
directorio de trabajo actual (o recurre al espacio de trabajo de OpenClaw configurado).
OpenClaw lo recogerá como <workspace>/skills en la siguiente sesión.
Notas de seguridad
- Trata las Skills de terceros como código no confiable. Léelas antes de habilitarlas.
- Prefiere ejecuciones con sandbox para entradas no confiables y herramientas riesgosas. Consulta Sandboxing.
- El descubrimiento de Skills en espacio de trabajo y directorios extra solo acepta raíces de Skills y archivos
SKILL.mdcuyo realpath resuelto permanezca dentro de la raíz configurada. - Las instalaciones de dependencias de Skills respaldadas por el gateway (
skills.install, onboarding y la UI de configuración de Skills) ejecutan el escáner integrado de código peligroso antes de ejecutar metadatos de instalación. Los hallazgoscriticalbloquean de forma predeterminada salvo que el llamador establezca explícitamente la anulación de peligro; los hallazgos sospechosos siguen siendo solo advertencias. openclaw skills install <slug>es diferente: descarga una carpeta de Skill de ClawHub al espacio de trabajo y no usa la ruta de metadatos de instalación anterior.skills.entries.*.envyskills.entries.*.apiKeyinyectan secretos en el proceso host para ese turno del agente (no en el sandbox). Mantén los secretos fuera de los prompts y registros.- Para un modelo de amenazas más amplio y listas de verificación, consulta Seguridad.
Formato (AgentSkills + compatible con Pi)
SKILL.md debe incluir al menos:
- Seguimos la especificación AgentSkills para el diseño/la intención.
- El analizador usado por el agente integrado admite claves de frontmatter de una sola línea únicamente.
metadatadebe ser un objeto JSON de una sola línea.- Usa
{baseDir}en las instrucciones para hacer referencia a la ruta de la carpeta de la Skill. - Claves opcionales de frontmatter:
-
homepage— URL mostrada como “Website” en la UI de Skills de macOS (también compatible mediantemetadata.openclaw.homepage). -
user-invocable—true|false(predeterminado:true). Cuando estrue, la Skill se expone como un comando slash de usuario. -
disable-model-invocation—true|false(predeterminado:false). Cuando estrue, la Skill se excluye del prompt del modelo (sigue disponible mediante invocación del usuario). -
command-dispatch—tool(opcional). Cuando se establece entool, el comando slash omite el modelo y se envía directamente a una herramienta. -
command-tool— nombre de la herramienta que se debe invocar cuandocommand-dispatch: toolestá establecido. -
command-arg-mode—raw(predeterminado). Para el envío a herramientas, reenvía la cadena de argumentos sin procesar a la herramienta (sin análisis del núcleo). La herramienta se invoca con parámetros:{ command: "<raw args>", commandName: "<slash command>", skillName: "<skill name>" }.
-
Control de acceso (filtros en tiempo de carga)
OpenClaw filtra Skills en tiempo de carga usandometadata (JSON de una sola línea):
metadata.openclaw:
always: true— siempre incluye la Skill (omite los demás controles).emoji— emoji opcional usado por la UI de Skills de macOS.homepage— URL opcional mostrada como “Website” en la UI de Skills de macOS.os— lista opcional de plataformas (darwin,linux,win32). Si se establece, la Skill solo es apta en esos sistemas operativos.requires.bins— lista; cada uno debe existir enPATH.requires.anyBins— lista; al menos uno debe existir enPATH.requires.env— lista; la variable de entorno debe existir o proporcionarse en la configuración.requires.config— lista de rutas deopenclaw.jsonque deben ser verdaderas.primaryEnv— nombre de la variable de entorno asociada conskills.entries.<name>.apiKey.install— arreglo opcional de especificaciones de instalador usado por la UI de Skills de macOS (brew/node/go/uv/download).
requires.binsse comprueba en el host en tiempo de carga de la Skill.- Si un agente usa sandbox, el binario también debe existir dentro del contenedor.
Instálalo mediante
agents.defaults.sandbox.docker.setupCommand(o una imagen personalizada).setupCommandse ejecuta una vez después de crear el contenedor. Las instalaciones de paquetes también requieren salida de red, un sistema de archivos raíz escribible y un usuario root en el sandbox. Ejemplo: la Skillsummarize(skills/summarize/SKILL.md) necesita la CLIsummarizeen el contenedor sandbox para ejecutarse allí.
- Si se listan varios instaladores, el gateway elige una única opción preferida (brew cuando está disponible; en caso contrario, node).
- Si todos los instaladores son
download, OpenClaw lista cada entrada para que puedas ver los artefactos disponibles. - Las especificaciones de instalador pueden incluir
os: ["darwin"|"linux"|"win32"]para filtrar opciones por plataforma. - Las instalaciones con Node respetan
skills.install.nodeManagerenopenclaw.json(predeterminado: npm; opciones: npm/pnpm/yarn/bun). Esto solo afecta a las instalaciones de Skills; el entorno de ejecución del Gateway debe seguir siendo Node (Bun no se recomienda para WhatsApp/Telegram). - La selección de instaladores respaldada por el gateway está guiada por preferencias, no solo por node:
cuando las especificaciones de instalación mezclan tipos, OpenClaw prefiere Homebrew cuando
skills.install.preferBrewestá habilitado ybrewexiste, luegouv, luego el gestor de node configurado y después otros respaldos comogoodownload. - Si todas las especificaciones de instalación son
download, OpenClaw muestra todas las opciones de descarga en lugar de reducirlas a un único instalador preferido. - Instalaciones con Go: si falta
goybrewestá disponible, el gateway instala primero Go mediante Homebrew y estableceGOBINenbinde Homebrew cuando es posible. - Instalaciones por descarga:
url(obligatorio),archive(tar.gz|tar.bz2|zip),extract(predeterminado: automático cuando se detecta archivo),stripComponents,targetDir(predeterminado:~/.openclaw/tools/<skillKey>).
metadata.openclaw, la Skill siempre es apta (salvo que
esté deshabilitada en la configuración o bloqueada por skills.allowBundled en el caso de Skills integradas).
Anulaciones de configuración (~/.openclaw/openclaw.json)
Las Skills integradas/administradas pueden activarse o desactivarse y recibir valores de entorno:
image_generate con agents.defaults.imageGenerationModel en lugar de una
Skill integrada. Los ejemplos de Skills aquí son para flujos personalizados o de terceros.
Para análisis nativo de imágenes, usa la herramienta image con agents.defaults.imageModel.
Para generación/edición nativa de imágenes, usa image_generate con
agents.defaults.imageGenerationModel. Si eliges openai/*, google/*,
fal/* u otro modelo de imagen específico de proveedor, añade también la autenticación/clave de API
de ese proveedor.
Las claves de configuración coinciden con el nombre de la Skill de forma predeterminada. Si una Skill define
metadata.openclaw.skillKey, usa esa clave bajo skills.entries.
Reglas:
enabled: falsedeshabilita la Skill incluso si está integrada/instalada.env: se inyecta solo si la variable aún no está establecida en el proceso.apiKey: comodidad para Skills que declaranmetadata.openclaw.primaryEnv. Admite cadena de texto sin formato u objeto SecretRef ({ source, provider, id }).config: contenedor opcional para campos personalizados por Skill; las claves personalizadas deben vivir aquí.allowBundled: lista de permitidos opcional solo para Skills integradas. Si se establece, solo las Skills integradas de la lista serán aptas (las Skills administradas/del espacio de trabajo no se ven afectadas).
Inyección de entorno (por ejecución de agente)
Cuando comienza una ejecución de agente, OpenClaw:- Lee los metadatos de la Skill.
- Aplica cualquier
skills.entries.<key>.envoskills.entries.<key>.apiKeyaprocess.env. - Construye el prompt del sistema con las Skills aptas.
- Restaura el entorno original cuando termina la ejecución.
claude-cli, OpenClaw también materializa la misma
instantánea apta como un plugin temporal de Claude Code y la pasa con
--plugin-dir. Claude Code puede entonces usar su resolvedor nativo de skills mientras
OpenClaw sigue siendo propietario de la precedencia, las listas de permitidos por agente, el control de acceso y la
inyección de env/claves de API de skills.entries.*. Los demás backends de CLI usan solo el catálogo del prompt.
Instantánea de sesión (rendimiento)
OpenClaw toma una instantánea de las Skills aptas cuando se inicia una sesión y reutiliza esa lista para los turnos posteriores de la misma sesión. Los cambios en Skills o configuración surten efecto en la siguiente sesión nueva. Las Skills también pueden actualizarse a mitad de sesión cuando el observador de Skills está habilitado o cuando aparece un nuevo nodo remoto apto (ver abajo). Piensa en esto como una recarga en caliente: la lista actualizada se recoge en el siguiente turno del agente. Si cambia la lista efectiva de Skills permitidas del agente para esa sesión, OpenClaw actualiza la instantánea para que las Skills visibles sigan alineadas con el agente actual.Nodos macOS remotos (gateway Linux)
Si el Gateway se ejecuta en Linux pero hay un nodo macOS conectado consystem.run permitido (la seguridad de aprobaciones de Exec no está establecida en deny), OpenClaw puede tratar las Skills exclusivas de macOS como aptas cuando los binarios requeridos están presentes en ese nodo. El agente debe ejecutar esas Skills mediante la herramienta exec con host=node.
Esto depende de que el nodo informe su compatibilidad de comandos y de una sonda de binarios mediante system.run. Si el nodo macOS se desconecta más tarde, las Skills siguen siendo visibles; las invocaciones pueden fallar hasta que el nodo vuelva a conectarse.
Observador de Skills (actualización automática)
De forma predeterminada, OpenClaw observa las carpetas de Skills y actualiza la instantánea de Skills cuando cambian los archivosSKILL.md. Configúralo en skills.load:
Impacto en tokens (lista de Skills)
Cuando las Skills son aptas, OpenClaw inyecta una lista XML compacta de las Skills disponibles en el prompt del sistema (medianteformatSkillsForPrompt en pi-coding-agent). El costo es determinista:
- Sobrecarga base (solo cuando hay ≥1 Skill): 195 caracteres.
- Por Skill: 97 caracteres + la longitud de los valores escapados en XML de
<name>,<description>y<location>.
- El escape XML expande
& < > " 'a entidades (&,<, etc.), aumentando la longitud. - El recuento de tokens varía según el tokenizador del modelo. Una estimación aproximada estilo OpenAI es ~4 caracteres/token, por lo que 97 caracteres ≈ 24 tokens por Skill más las longitudes reales de tus campos.
Ciclo de vida de Skills administradas
OpenClaw incluye un conjunto base de Skills como Skills integradas como parte de la instalación (paquete npm o OpenClaw.app).~/.openclaw/skills existe para
anulaciones locales (por ejemplo, fijar/parchear una Skill sin cambiar la copia
integrada). Las Skills del espacio de trabajo son propiedad del usuario y anulan a ambas cuando hay conflictos de nombre.
Referencia de configuración
Consulta Configuración de Skills para ver el esquema completo de configuración.¿Buscas más Skills?
Explora https://clawhub.ai.Relacionado
- Creación de Skills — crear Skills personalizadas
- Configuración de Skills — referencia de configuración de Skills
- Comandos slash — todos los comandos slash disponibles
- Plugins — resumen del sistema de plugins