Cree y aloje marketplaces de plugins para distribuir extensiones de Claude Code en equipos y comunidades.
Un marketplace de plugins es un catálogo que le permite distribuir plugins a otros. Los marketplaces proporcionan descubrimiento centralizado, seguimiento de versiones, actualizaciones automáticas y soporte para múltiples tipos de fuentes (repositorios git, rutas locales y más). Esta guía le muestra cómo crear su propio marketplace para compartir plugins con su equipo o comunidad.¿Busca instalar plugins desde un marketplace existente? Consulte Descubrir e instalar plugins precompilados.
Crear plugins: construya uno o más plugins con comandos, agentes, hooks, MCP servers o servidores LSP. Esta guía asume que ya tiene plugins para distribuir; consulte Crear plugins para obtener detalles sobre cómo crearlos.
Crear un archivo de marketplace: defina un marketplace.json que enumere sus plugins y dónde encontrarlos (consulte Crear el archivo de marketplace).
Compartir con usuarios: los usuarios agregan su marketplace con /plugin marketplace add e instalan plugins individuales (consulte Descubrir e instalar plugins).
Una vez que su marketplace esté activo, puede actualizarlo enviando cambios a su repositorio. Los usuarios actualizan su copia local con /plugin marketplace update.
Este ejemplo crea un marketplace con un plugin: una skill /quality-review para revisiones de código. Creará la estructura de directorios, agregará una skill, creará el manifiesto del plugin y el catálogo del marketplace, luego lo instalará y probará.
---description: Review code for bugs, security, and performancedisable-model-invocation: true---Review the code I've selected or the recent changes for:- Potential bugs or edge cases- Security concerns- Performance issues- Readability improvementsBe concise and actionable.
3
Crear el manifiesto del plugin
Cree un archivo plugin.json que describa el plugin. El manifiesto va en el directorio .claude-plugin/.
Seleccione algo de código en su editor y ejecute su nuevo comando.
Reportar código incorrecto
Copiar
Preguntar a la IA
/review
Para obtener más información sobre lo que los plugins pueden hacer, incluidos hooks, agentes, MCP servers y servidores LSP, consulte Plugins.
Cómo se instalan los plugins: Cuando los usuarios instalan un plugin, Claude Code copia el directorio del plugin a una ubicación de caché. Esto significa que los plugins no pueden hacer referencia a archivos fuera de su directorio usando rutas como ../shared-utils, porque esos archivos no se copiarán.Si necesita compartir archivos entre plugins, use enlaces simbólicos (que se siguen durante la copia). Consulte Plugin caching and file resolution para obtener detalles.
Cree .claude-plugin/marketplace.json en la raíz de su repositorio. Este archivo define el nombre de su marketplace, información del propietario y una lista de plugins con sus fuentes.Cada entrada de plugin necesita como mínimo un name y source (dónde obtenerlo). Consulte el esquema completo a continuación para todos los campos disponibles.
Identificador de marketplace (kebab-case, sin espacios). Esto es público: los usuarios lo ven al instalar plugins (por ejemplo, /plugin install my-tool@your-marketplace).
Nombres reservados: Los siguientes nombres de marketplace están reservados para uso oficial de Anthropic y no pueden ser utilizados por marketplaces de terceros: claude-code-marketplace, claude-code-plugins, claude-plugins-official, anthropic-marketplace, anthropic-plugins, agent-skills, life-sciences. Los nombres que se hacen pasar por marketplaces oficiales (como official-claude-plugins o anthropic-tools-v2) también están bloqueados.
Directorio base antepuesto a rutas de fuente de plugin relativas (por ejemplo, "./plugins" le permite escribir "source": "formatter" en lugar de "source": "./plugins/formatter")
Cada entrada de plugin en el array plugins describe un plugin y dónde encontrarlo. Puede incluir cualquier campo del esquema de manifiesto de plugin (como description, version, author, commands, hooks, etc.), más estos campos específicos del marketplace: source, category, tags y strict.
Identificador de plugin (kebab-case, sin espacios). Esto es público: los usuarios lo ven al instalar (por ejemplo, /plugin install my-plugin@marketplace).
Las fuentes de plugins le indican a Claude Code dónde obtener cada plugin individual listado en su marketplace. Estos se establecen en el campo source de cada entrada de plugin en marketplace.json.Una vez que un plugin se clona o copia en la máquina local, se copia en el caché de plugins versionado local en ~/.claude/plugins/cache.
Fuente
Tipo
Campos
Notas
Ruta relativa
string (p. ej. "./my-plugin")
—
Directorio local dentro del repositorio de marketplace. Debe comenzar con ./
github
object
repo, ref?, sha?
url
object
url (debe terminar en .git), ref?, sha?
Fuente de URL de Git
git-subdir
object
url, path, ref?, sha?
Subdirectorio dentro de un repositorio git. Clona escasamente para minimizar el ancho de banda para monorepos
npm
object
package, version?, registry?
Instalado vía npm install
pip
object
package, version?, registry?
Instalado vía pip
Fuentes de marketplace vs fuentes de plugins: Estos son conceptos diferentes que controlan cosas diferentes.
Fuente de marketplace — dónde obtener el catálogo marketplace.json en sí. Se establece cuando los usuarios ejecutan /plugin marketplace add o en la configuración extraKnownMarketplaces. Soporta ref (rama/etiqueta) pero no sha.
Fuente de plugin — dónde obtener un plugin individual listado en el marketplace. Se establece en el campo source de cada entrada de plugin dentro de marketplace.json. Soporta tanto ref (rama/etiqueta) como sha (commit exacto).
Por ejemplo, un marketplace alojado en acme-corp/plugin-catalog (fuente de marketplace) puede listar un plugin obtenido de acme-corp/code-formatter (fuente de plugin). La fuente de marketplace y la fuente de plugin apuntan a diferentes repositorios y se fijan independientemente.
Las rutas relativas solo funcionan cuando los usuarios agregan su marketplace a través de Git (GitHub, GitLab o URL de git). Si los usuarios agregan su marketplace a través de una URL directa al archivo marketplace.json, las rutas relativas no se resolverán correctamente. Para distribución basada en URL, use fuentes de GitHub, npm o URL de git en su lugar. Consulte Solución de problemas para obtener detalles.
Use git-subdir para apuntar a un plugin que vive dentro de un subdirectorio de un repositorio de git. Claude Code usa un clon parcial y escaso para obtener solo el subdirectorio, minimizando el ancho de banda para monorepos grandes.
Los plugins distribuidos como paquetes npm se instalan usando npm install. Esto funciona con cualquier paquete en el registro npm público o un registro privado que su equipo aloje.
Este ejemplo muestra una entrada de plugin usando muchos de los campos opcionales, incluidas rutas personalizadas para comandos, agentes, hooks y MCP servers:
commands y agents: Puede especificar múltiples directorios o archivos individuales. Las rutas son relativas a la raíz del plugin.
${CLAUDE_PLUGIN_ROOT}: Use esta variable en hooks y configuraciones de MCP server para hacer referencia a archivos dentro del directorio de instalación del plugin. Esto es necesario porque los plugins se copian a una ubicación de caché cuando se instalan.
strict: false: Dado que esto se establece en false, el plugin no necesita su propio plugin.json. La entrada del marketplace define todo. Consulte Modo estricto a continuación.
El campo strict controla si plugin.json es la autoridad para definiciones de componentes (comandos, agentes, hooks, skills, MCP servers, estilos de salida).
Valor
Comportamiento
true (predeterminado)
plugin.json es la autoridad. La entrada del marketplace puede complementarla con componentes adicionales, y ambas fuentes se fusionan.
false
La entrada del marketplace es la definición completa. Si el plugin también tiene un plugin.json que declara componentes, eso es un conflicto y el plugin falla al cargar.
Cuándo usar cada modo:
strict: true: el plugin tiene su propio plugin.json y gestiona sus propios componentes. La entrada del marketplace puede agregar comandos o hooks adicionales encima. Este es el predeterminado y funciona para la mayoría de los plugins.
strict: false: el operador del marketplace quiere control total. El repositorio del plugin proporciona archivos sin procesar, y la entrada del marketplace define cuáles de esos archivos se exponen como comandos, agentes, hooks, etc. Útil cuando el marketplace reestructura o cura los componentes de un plugin de manera diferente a la que el autor del plugin pretendía.
Cualquier servicio de alojamiento de git funciona, como GitLab, Bitbucket y servidores autohospedados. Los usuarios agregan con la URL completa del repositorio:
Claude Code soporta instalar plugins desde repositorios privados. Para instalación manual y actualizaciones, Claude Code usa sus ayudantes de credenciales de git existentes. Si git clone funciona para un repositorio privado en su terminal, funciona en Claude Code también. Los ayudantes de credenciales comunes incluyen gh auth login para GitHub, Keychain de macOS y git-credential-store.Las actualizaciones automáticas en segundo plano se ejecutan al inicio sin ayudantes de credenciales, ya que los mensajes interactivos bloquearían que Claude Code se inicie. Para habilitar actualizaciones automáticas para marketplaces privados, establezca el token de autenticación apropiado en su entorno:
Proveedor
Variables de entorno
Notas
GitHub
GITHUB_TOKEN o GH_TOKEN
Token de acceso personal o token de GitHub App
GitLab
GITLAB_TOKEN o GL_TOKEN
Token de acceso personal o token de proyecto
Bitbucket
BITBUCKET_TOKEN
Contraseña de aplicación o token de acceso al repositorio
Establezca el token en su configuración de shell (por ejemplo, .bashrc, .zshrc) o páselo al ejecutar Claude Code:
Reportar código incorrecto
Copiar
Preguntar a la IA
export GITHUB_TOKEN=ghp_xxxxxxxxxxxxxxxxxxxx
Para entornos de CI/CD, configure el token como una variable de entorno secreta. GitHub Actions proporciona automáticamente GITHUB_TOKEN para repositorios en la misma organización.
Puede configurar su repositorio para que los miembros del equipo sean automáticamente solicitados para instalar su marketplace cuando confíen en la carpeta del proyecto. Agregue su marketplace a .claude/settings.json:
Para organizaciones que requieren control estricto sobre las fuentes de plugins, los administradores pueden restringir qué marketplaces de plugins se permite a los usuarios agregar usando la configuración strictKnownMarketplaces en configuración administrada.Cuando strictKnownMarketplaces se configura en configuración administrada, el comportamiento de restricción depende del valor:
Valor
Comportamiento
Indefinido (predeterminado)
Sin restricciones. Los usuarios pueden agregar cualquier marketplace
Array vacío []
Bloqueo completo. Los usuarios no pueden agregar nuevos marketplaces
Lista de fuentes
Los usuarios solo pueden agregar marketplaces que coincidan exactamente con la lista de permitidos
Las restricciones se validan temprano en el proceso de instalación de plugins, antes de cualquier solicitud de red u operación del sistema de archivos. Esto previene intentos de acceso no autorizado a marketplaces.La lista de permitidos usa coincidencia exacta para la mayoría de tipos de fuente. Para que un marketplace sea permitido, todos los campos especificados deben coincidir exactamente:
Para fuentes de GitHub: repo es requerido, y ref o path también deben coincidir si se especifican en la lista de permitidos
Para fuentes de URL: la URL completa debe coincidir exactamente
Para fuentes hostPattern: el host del marketplace se compara contra el patrón regex
Para fuentes pathPattern: la ruta del sistema de archivos del marketplace se compara contra el patrón regex
Debido a que strictKnownMarketplaces se establece en configuración administrada, los usuarios individuales y las configuraciones del proyecto no pueden anular estas restricciones.Para detalles de configuración completos incluyendo todos los tipos de fuente soportados y comparación con extraKnownMarketplaces, consulte la referencia de strictKnownMarketplaces.
Las versiones de plugins determinan rutas de caché y detección de actualizaciones. Puede especificar la versión en el manifiesto del plugin (plugin.json) o en la entrada del marketplace (marketplace.json).
Cuando sea posible, evite establecer la versión en ambos lugares. El manifiesto del plugin siempre gana silenciosamente, lo que puede causar que la versión del marketplace sea ignorada. Para plugins de ruta relativa, establezca la versión en la entrada del marketplace. Para todas las otras fuentes de plugins, establézcala en el manifiesto del plugin.
Para soportar canales de lanzamiento “estable” y “último” para sus plugins, puede configurar dos marketplaces que apunten a diferentes refs o SHAs del mismo repositorio. Luego puede asignar los dos marketplaces a diferentes grupos de usuarios a través de configuración administrada.
El plugin.json del plugin debe declarar una version diferente en cada ref o commit fijado. Si dos refs o commits tienen la misma versión de manifiesto, Claude Code los trata como idénticos y omite la actualización.
Síntomas: La instalación del plugin o las actualizaciones del marketplace fallan con un error de tiempo de espera como “Git clone timed out after 120s” o “Git pull timed out after 120s”.Causa: Claude Code usa un tiempo de espera de 120 segundos para todas las operaciones de git, incluida la clonación de repositorios de plugins y la extracción de actualizaciones de marketplace. Los repositorios grandes o las conexiones de red lentas pueden exceder este límite.Solución: Aumente el tiempo de espera usando la variable de entorno CLAUDE_CODE_PLUGIN_GIT_TIMEOUT_MS. El valor está en milisegundos:
Los plugins con rutas relativas fallan en marketplaces basados en URL
Síntomas: Agregó un marketplace a través de URL (como https://example.com/marketplace.json), pero los plugins con fuentes de ruta relativa como "./plugins/my-plugin" fallan al instalar con errores “path not found”.Causa: Los marketplaces basados en URL solo descargan el archivo marketplace.json en sí. No descargan archivos de plugins del servidor. Las rutas relativas en la entrada del marketplace hacen referencia a archivos en el servidor remoto que no fueron descargados.Soluciones:
Use fuentes externas: Cambie las entradas de plugins para usar fuentes de GitHub, npm o URL de git en lugar de rutas relativas:
Use un marketplace basado en Git: Aloje su marketplace en un repositorio de Git y agréguelo con la URL de git. Los marketplaces basados en Git clonan el repositorio completo, haciendo que las rutas relativas funcionen correctamente.
Síntomas: El plugin se instala pero las referencias a archivos fallan, especialmente archivos fuera del directorio del pluginCausa: Los plugins se copian a un directorio de caché en lugar de usarse en el lugar. Las rutas que hacen referencia a archivos fuera del directorio del plugin (como ../shared-utils) no funcionarán porque esos archivos no se copian.Soluciones: Consulte Plugin caching and file resolution para soluciones alternativas incluyendo enlaces simbólicos y reestructuración de directorios.Para herramientas de depuración adicionales y problemas comunes, consulte Debugging and development tools.