SpyBara
Go Premium

agent-sdk/plugins.md 2026-06-09 06:34 UTC to 2026-06-10 23:57 UTC

83 added, 41 removed.

2026
Fri 12 03:59 Thu 11 23:01 Wed 10 23:57 Tue 9 06:34 Mon 8 06:52 Sat 6 06:24 Fri 5 06:45 Thu 4 06:52 Wed 3 06:53 Tue 2 06:51

Plugins en el SDK

Cargue plugins personalizados para extender Claude Code con skills, agentes, hooks y servidores MCP a través del Agent SDK

Los plugins le permiten extender Claude Code con funcionalidad personalizada que se puede compartir entre proyectos. A través del Agent SDK, puede cargar programáticamente plugins desde directorios locales para agregar skills, agentes, hooks y servidores MCP a sus sesiones de agente.

¿Qué son los plugins?

Los plugins son paquetes de extensiones de Claude Code que pueden incluir:

  • Skills: Capacidades invocadas por el modelo que Claude utiliza de forma autónoma (también se pueden invocar con /skill-name)
  • Agents: Subagentes especializados para tareas específicas
  • Hooks: Controladores de eventos que responden al uso de herramientas y otros eventos
  • MCP servers: Integraciones de herramientas externas a través del Model Context Protocol

Para obtener información completa sobre la estructura de plugins y cómo crear plugins, consulte Plugins.

Cargando plugins

Cargue plugins proporcionando sus rutas del sistema de archivos local en su configuración de opciones. El campo type debe ser "local", el único valor que acepta el SDK. Para usar un plugin distribuido a través de un marketplace o repositorio remoto, descárguelo primero y proporcione la ruta del directorio local. El SDK admite cargar múltiples plugins desde diferentes ubicaciones.

import { query } from "@anthropic-ai/claude-agent-sdk";

for await (const message of query({
prompt: "Hello",
options: {
plugins: [
{ type: "local", path: "./my-plugin" },
{ type: "local", path: "/absolute/path/to/another-plugin" }
]
}
})) {
// Plugin commands, agents, and other features are now available
}

Especificaciones de ruta

Las rutas de plugins pueden ser:

  • Rutas relativas: Se resuelven en relación con su directorio de trabajo actual (por ejemplo, "./plugins/my-plugin")
  • Rutas absolutas: Rutas completas del sistema de archivos (por ejemplo, "/home/user/plugins/my-plugin")

Verificando la instalación del plugin

Cuando los plugins se cargan correctamente, aparecen en el mensaje de inicialización del sistema. Puede verificar que sus plugins estén disponibles:

import { query } from "@anthropic-ai/claude-agent-sdk";

for await (const message of query({
prompt: "Hello",
options: {
plugins: [{ type: "local", path: "./my-plugin" }]
}
})) {
if (message.type === "system" && message.subtype === "init") {
// Verificar plugins cargados
console.log("Plugins:", message.plugins);
// Ejemplo: [{ name: "my-plugin", path: "./my-plugin" }]

// Las skills del plugin aparecen con el nombre del plugin como prefijo
console.log("Skills:", message.skills);
// Ejemplo: ["my-plugin:greet"]

// Los comandos del plugin usan el mismo prefijo, y las skills también aparecen aquí
console.log("Commands:", message.slash_commands);
// Ejemplo: ["compact", "context", "my-plugin:custom-command", "my-plugin:greet"]
}
}

Usando skills de plugins

Los skills de los plugins se espacian automáticamente con el nombre del plugin para evitar conflictos. Para invocar uno directamente, envíe /plugin-name:skill-name como el prompt.

import { query } from "@anthropic-ai/claude-agent-sdk";

// Load a plugin with a custom /greet skill
for await (const message of query({
prompt: "/my-plugin:greet", // Use plugin skill with namespace
options: {
plugins: [{ type: "local", path: "./my-plugin" }]
}
})) {
// Claude executes the custom greeting skill from the plugin
if (message.type === "assistant") {
console.log(message.message.content);
}
}

Ejemplo completo

Aquí hay un ejemplo completo que demuestra la carga y el uso de plugins:

import { query } from "@anthropic-ai/claude-agent-sdk";
import * as path from "path";

async function runWithPlugin() {
const pluginPath = path.join(__dirname, "plugins", "my-plugin");

console.log("Loading plugin from:", pluginPath);

for await (const message of query({
prompt: "What custom commands do you have available?",
options: {
plugins: [{ type: "local", path: pluginPath }],
maxTurns: 3
}
})) {
if (message.type === "system" && message.subtype === "init") {
console.log("Loaded plugins:", message.plugins);
console.log("Available skills:", message.skills);
console.log("Available commands:", message.slash_commands);
}

if (message.type === "assistant") {
console.log("Assistant:", message.message.content);
}
}
}

runWithPlugin().catch(console.error);

Referencia de estructura de plugin

Un directorio de plugin típicamente contiene un archivo de manifiesto .claude-plugin/plugin.json. El manifiesto es opcional. Cuando se omite, Claude Code descubre automáticamente los componentes desde el diseño del directorio. El directorio puede incluir:

my-plugin/
├── .claude-plugin/
│   └── plugin.json          # Manifiesto de plugin (opcional, componentes descubiertos automáticamente sin él)
├── skills/                   # Agent Skills (invocadas autónomamente o vía /skill-name)
│   └── my-skill/
│       └── SKILL.md
├── commands/                 # Heredado: usar skills/ en su lugar
│   └── custom-cmd.md
├── agents/                   # Agentes personalizados
│   └── specialist.md
├── hooks/                    # Manejadores de eventos
│   └── hooks.json
└── .mcp.json                # Definiciones de servidor MCP

Para obtener información detallada sobre cómo crear plugins, consulte:

Casos de uso comunes

Desarrollo y pruebas

Cargue plugins durante el desarrollo sin instalarlos globalmente:

plugins: [{ type: "local", path: "./dev-plugins/my-plugin" }];

Extensiones específicas del proyecto

Incluya plugins en su repositorio de proyecto para consistencia en todo el equipo:

plugins: [{ type: "local", path: "./project-plugins/team-workflows" }];

Múltiples fuentes de plugins

Combine plugins de diferentes ubicaciones:

plugins: [
  { type: "local", path: "./local-plugin" },
  { type: "local", path: "~/.claude/custom-plugins/shared-plugin" }
];

Troubleshooting

Plugin no se carga

Si su plugin no aparece en el mensaje de inicialización:

  1. Verifique la ruta: Asegúrese de que la ruta apunte al directorio raíz del plugin, el directorio padre de skills/, agents/, hooks/, commands/ (heredado), o .claude-plugin/
  2. Valide plugin.json: Si su plugin incluye un manifiesto, asegúrese de que tenga una sintaxis JSON válida
  3. Verifique los permisos de archivo: Asegúrese de que el directorio del plugin sea legible

Los skills no aparecen

Si los skills del plugin no funcionan:

  1. Use el espacio de nombres: Invoque los skills del plugin como /plugin-name:skill-name
  2. Verifique el mensaje de inicialización: Verifique que el skill aparezca en la lista skills con el espacio de nombres correcto
  3. Valide los archivos de skill: Asegúrese de que cada skill tenga un archivo SKILL.md en su propio subdirectorio bajo skills/, por ejemplo skills/my-skill/SKILL.md

Problemas de resolución de ruta

Si las rutas relativas no funcionan:

  1. Verifique el directorio de trabajo: Las rutas relativas se resuelven desde su directorio de trabajo actual
  2. Use rutas absolutas: Para mayor confiabilidad, considere usar rutas absolutas
  3. Normalice las rutas: Use utilidades de ruta para construir rutas correctamente

Ver también