plugin marketplace — это каталог, который позволяет вам распространять плагины другим пользователям. Marketplace обеспечивают централизованное обнаружение, отслеживание версий, автоматические обновления и поддержку нескольких типов источников (репозитории Git, локальные пути и многое другое). Это руководство показывает, как создать собственный marketplace для совместного использования плагинов с вашей командой или сообществом. Ищете способ установить плагины из существующего marketplace? См. Обнаружение и установка готовых плагинов.Documentation Index
Fetch the complete documentation index at: https://code.claude.com/docs/llms.txt
Use this file to discover all available pages before exploring further.
Обзор
Создание и распространение marketplace включает:- Создание плагинов: создайте один или несколько плагинов с skills, агентами, hooks, MCP servers или LSP servers. Это руководство предполагает, что у вас уже есть плагины для распространения; см. Создание плагинов для получения подробной информации о том, как их создавать.
- Создание файла marketplace: определите
marketplace.json, который перечисляет ваши плагины и где их найти (см. Создание файла marketplace). - Размещение marketplace: отправьте на GitHub, GitLab или другой хост Git (см. Размещение и распространение marketplace).
- Совместное использование с пользователями: пользователи добавляют ваш marketplace с помощью
/plugin marketplace addи устанавливают отдельные плагины (см. Обнаружение и установка плагинов).
/plugin marketplace update.
Пошаговое руководство: создание локального marketplace
Этот пример создает marketplace с одним плагином: skillquality-review для проверки кода. Вы создадите структуру каталогов, добавите skill, создадите манифест плагина и каталог marketplace, затем установите и протестируете его.
Создание skill
Создайте файл
SKILL.md, который определяет, что делает skill quality-review.my-marketplace/plugins/quality-review-plugin/skills/quality-review/SKILL.md
Создание манифеста плагина
Создайте файл
plugin.json, который описывает плагин. Манифест находится в каталоге .claude-plugin/.my-marketplace/plugins/quality-review-plugin/.claude-plugin/plugin.json
Установка
version означает, что пользователи получают обновления только при изменении этого поля, поэтому увеличивайте его при каждом выпуске. Если вы опустите version и разместите этот marketplace в git, каждый коммит автоматически считается новой версией. См. Разрешение версий, чтобы выбрать правильный подход.Создание файла marketplace
Создайте каталог marketplace, который перечисляет ваш плагин.
my-marketplace/.claude-plugin/marketplace.json
Как устанавливаются плагины: Когда пользователи устанавливают плагин, Claude Code копирует каталог плагина в место кэша. Это означает, что плагины не могут ссылаться на файлы вне их каталога, используя пути вроде
../shared-utils, потому что эти файлы не будут скопированы.Если вам нужно совместно использовать файлы между плагинами, используйте символические ссылки. См. Кэширование плагинов и разрешение файлов для получения подробной информации.Создание файла marketplace
Создайте.claude-plugin/marketplace.json в корне вашего репозитория. Этот файл определяет имя вашего marketplace, информацию о владельце и список плагинов с их источниками.
Каждая запись плагина требует как минимум name и source (откуда его получить). См. полную схему ниже для всех доступных полей.
Схема marketplace
Обязательные поля
| Поле | Тип | Описание | Пример |
|---|---|---|---|
name | string | Идентификатор marketplace (kebab-case, без пробелов). Это общедоступное поле: пользователи видят его при установке плагинов (например, /plugin install my-tool@your-marketplace). | "acme-tools" |
owner | object | Информация о сопровождающем marketplace (см. поля ниже) | |
plugins | array | Список доступных плагинов | См. ниже |
Зарезервированные имена: Следующие имена marketplace зарезервированы для официального использования Anthropic и не могут использоваться сторонними marketplace:
claude-code-marketplace, claude-code-plugins, claude-plugins-official, anthropic-marketplace, anthropic-plugins, agent-skills, anthropic-agent-skills, knowledge-work-plugins, life-sciences. Имена, которые выдают себя за официальные marketplace, такие как official-claude-plugins или anthropic-tools-v2, также заблокированы.Поля владельца
| Поле | Тип | Обязательно | Описание |
|---|---|---|---|
name | string | Да | Имя сопровождающего или команды |
email | string | Нет | Контактный адрес электронной почты сопровождающего |
Дополнительные поля
| Поле | Тип | Описание |
|---|---|---|
$schema | string | URL JSON Schema для автодополнения редактора и валидации. Claude Code игнорирует это поле при загрузке. |
description | string | Краткое описание marketplace |
version | string | Версия манифеста marketplace |
metadata.pluginRoot | string | Базовый каталог, добавляемый к относительным путям источников плагинов (например, "./plugins" позволяет вам писать "source": "formatter" вместо "source": "./plugins/formatter") |
allowCrossMarketplaceDependenciesOn | array | Другие marketplace, на которые плагины в этом marketplace могут зависеть. Зависимости от marketplace, не указанного здесь, блокируются при установке. См. Зависимость от плагина из другого marketplace. |
description и version также принимаются в metadata для обратной совместимости.
Записи плагинов
Каждая запись плагина в массивеplugins описывает плагин и где его найти. Вы можете включить любое поле из схемы манифеста плагина (например, description, version, author, commands, hooks и т. д.), плюс эти поля, специфичные для marketplace: source, category, tags и strict.
Обязательные поля
| Поле | Тип | Описание |
|---|---|---|
name | string | Идентификатор плагина (kebab-case, без пробелов). Это общедоступное поле: пользователи видят его при установке (например, /plugin install my-plugin@marketplace). |
source | string|object | Откуда получить плагин (см. Источники плагинов ниже) |
Дополнительные поля плагина
Поля стандартных метаданных:| Поле | Тип | Описание |
|---|---|---|
displayName | string | Удобочитаемое имя, отображаемое в интерфейсе. Возвращается к name при отсутствии. Может содержать пробелы и любой регистр. Не используется для пространства имён или поиска. Требуется Claude Code v2.1.143 или позже. |
description | string | Краткое описание плагина |
version | string | Версия плагина. Если установлено (здесь или в plugin.json), плагин закреплен на этой строке и пользователи получают обновления только при её изменении. Опустите, чтобы вернуться к SHA коммита git. См. Разрешение версий. |
author | object | Информация об авторе плагина (name обязательно, email опционально) |
homepage | string | URL домашней страницы или документации плагина |
repository | string | URL репозитория исходного кода |
license | string | Идентификатор лицензии SPDX (например, MIT, Apache-2.0) |
keywords | array | Теги для обнаружения и категоризации плагинов |
category | string | Категория плагина для организации |
tags | array | Теги для поиска |
strict | boolean | Контролирует, является ли plugin.json авторитетом для определений компонентов (по умолчанию: true). См. Strict mode ниже. |
| Поле | Тип | Описание |
|---|---|---|
skills | string|array | Пользовательские пути к каталогам skills, содержащим <name>/SKILL.md |
commands | string|array | Пользовательские пути к плоским файлам .md skills или каталогам |
agents | string|array | Пользовательские пути к файлам агентов |
hooks | string|object | Конфигурация пользовательских hooks или путь к файлу hooks |
mcpServers | string|object | Конфигурации MCP server или путь к конфигурации MCP |
lspServers | string|object | Конфигурации LSP server или путь к конфигурации LSP |
Источники плагинов
Источники плагинов указывают Claude Code, откуда получить каждый отдельный плагин, указанный в вашем marketplace. Они устанавливаются в полеsource каждой записи плагина в marketplace.json.
После того как плагин клонирован или скопирован на локальную машину, он копируется в локальный кэш плагинов с версией в ~/.claude/plugins/cache.
| Источник | Тип | Поля | Примечания |
|---|---|---|---|
| Относительный путь | string (например, "./my-plugin") | — | Локальный каталог в репозитории marketplace. Должен начинаться с ./. Разрешается относительно корня marketplace, а не каталога .claude-plugin/ |
github | object | repo, ref?, sha? | |
url | object | url, ref?, sha? | Источник URL Git |
git-subdir | object | url, path, ref?, sha? | Подкаталог в репозитории Git. Клонирует разреженно, чтобы минимизировать пропускную способность для монорепозиториев |
npm | object | package, version?, registry? | Установлено через npm install |
Источники marketplace и источники плагинов: Это разные концепции, которые контролируют разные вещи.
- Источник marketplace — откуда получить сам каталог
marketplace.json. Устанавливается, когда пользователи запускают/plugin marketplace addили в параметрахextraKnownMarketplaces. Поддерживаетref(ветка/тег), но неsha. - Источник плагина — откуда получить отдельный плагин, указанный в marketplace. Устанавливается в поле
sourceкаждой записи плагина внутриmarketplace.json. Поддерживает какref(ветка/тег), так иsha(точный коммит).
acme-corp/plugin-catalog (источник marketplace), может перечислять плагин, полученный из acme-corp/code-formatter (источник плагина). Источник marketplace и источник плагина указывают на разные репозитории и закреплены независимо.Относительные пути
Для плагинов в одном репозитории используйте путь, начинающийся с./:
.claude-plugin/. В приведенном выше примере ./plugins/my-plugin указывает на <repo>/plugins/my-plugin, даже если marketplace.json находится в <repo>/.claude-plugin/marketplace.json. Не используйте ../ для ссылки на пути вне корня marketplace.
Относительные пути работают только, когда пользователи добавляют ваш marketplace через Git (GitHub, GitLab или URL Git). Если пользователи добавляют ваш marketplace через прямой URL к файлу
marketplace.json, относительные пути не будут разрешены правильно. Для распространения на основе URL используйте вместо этого источники GitHub, npm или URL Git. См. Устранение неполадок для получения подробной информации.Репозитории GitHub
| Поле | Тип | Описание |
|---|---|---|
repo | string | Обязательно. Репозиторий GitHub в формате owner/repo |
ref | string | Опционально. Ветка или тег Git (по умолчанию ветка по умолчанию репозитория) |
sha | string | Опционально. Полный 40-символьный SHA коммита Git для закрепления на точной версии |
Репозитории Git
| Поле | Тип | Описание |
|---|---|---|
url | string | Обязательно. Полный URL репозитория Git (https:// или git@). Суффикс .git опционален, поэтому URL Azure DevOps и AWS CodeCommit без суффикса работают |
ref | string | Опционально. Ветка или тег Git (по умолчанию ветка по умолчанию репозитория) |
sha | string | Опционально. Полный 40-символьный SHA коммита Git для закрепления на точной версии |
Подкаталоги Git
Используйтеgit-subdir для указания плагина, который находится в подкаталоге репозитория Git. Claude Code использует разреженный, частичный клон для получения только подкаталога, минимизируя пропускную способность для больших монорепозиториев.
url также принимает сокращение GitHub (owner/repo) или SSH URL (git@github.com:owner/repo.git).
| Поле | Тип | Описание |
|---|---|---|
url | string | Обязательно. URL репозитория Git, сокращение GitHub owner/repo или SSH URL |
path | string | Обязательно. Путь подкаталога в репозитории, содержащий плагин (например, "tools/claude-plugin") |
ref | string | Опционально. Ветка или тег Git (по умолчанию ветка по умолчанию репозитория) |
sha | string | Опционально. Полный 40-символьный SHA коммита Git для закрепления на точной версии |
Пакеты npm
Плагины, распространяемые как пакеты npm, устанавливаются с помощьюnpm install. Это работает с любым пакетом в общедоступном реестре npm или в частном реестре, который размещает ваша команда.
version:
registry:
| Поле | Тип | Описание |
|---|---|---|
package | string | Обязательно. Имя пакета или область пакета (например, @org/plugin) |
version | string | Опционально. Версия или диапазон версий (например, 2.1.0, ^2.0.0, ~1.5.0) |
registry | string | Опционально. Пользовательский URL реестра npm. По умолчанию системный реестр npm (обычно npmjs.org) |
Расширенные записи плагинов
Этот пример показывает запись плагина, использующую множество дополнительных полей, включая пользовательские пути для команд, агентов, hooks и MCP servers:commandsиagents: Вы можете указать несколько каталогов или отдельные файлы. Пути относительны к корню плагина.${CLAUDE_PLUGIN_ROOT}: Используйте эту переменную в hooks и конфигурациях MCP server для ссылки на файлы в каталоге установки плагина. Это необходимо, потому что плагины копируются в место кэша при установке. Для зависимостей или состояния, которое должно сохраняться при обновлениях плагина, используйте${CLAUDE_PLUGIN_DATA}вместо этого.strict: false: Поскольку это установлено на false, плагину не нужен собственныйplugin.json. Запись marketplace определяет все. См. Strict mode ниже.
Strict mode
Полеstrict контролирует, является ли plugin.json авторитетом для определений компонентов (skills, агенты, hooks, MCP servers, стили вывода).
| Значение | Поведение |
|---|---|
true (по умолчанию) | plugin.json является авторитетом. Запись marketplace может дополнить его дополнительными компонентами, и оба источника объединяются. |
false | Запись marketplace является полным определением. Если плагин также имеет plugin.json, который объявляет компоненты, это конфликт и плагин не загружается. |
strict: true: плагин имеет собственныйplugin.jsonи управляет своими компонентами. Запись marketplace может добавить дополнительные skills или hooks сверху. Это значение по умолчанию и работает для большинства плагинов.strict: false: оператор marketplace хочет полный контроль. Репозиторий плагина предоставляет необработанные файлы, и запись marketplace определяет, какие из этих файлов открыты как skills, агенты, hooks и т. д. Полезно, когда оператор marketplace переструктурирует или курирует компоненты плагина иначе, чем предполагал автор плагина.
Размещение и распространение marketplace
Размещение на GitHub (рекомендуется)
GitHub обеспечивает самый простой метод распространения:- Создание репозитория: Установите новый репозиторий для вашего marketplace
- Добавление файла marketplace: Создайте
.claude-plugin/marketplace.jsonс определениями ваших плагинов - Совместное использование с командами: Пользователи добавляют ваш marketplace с помощью
/plugin marketplace add owner/repo
Размещение на других сервисах Git
Любой сервис хостинга Git работает, например GitLab, Bitbucket и самостоятельно размещаемые серверы. Пользователи добавляют с полным URL репозитория:Частные репозитории
Claude Code поддерживает установку плагинов из частных репозиториев. Для ручной установки и обновлений Claude Code использует ваши существующие помощники учетных данных Git, поэтому доступ HTTPS черезgh auth login, macOS Keychain или git-credential-store работает так же, как в вашем терминале. Доступ SSH работает, пока хост уже находится в вашем файле known_hosts и ключ загружен в ssh-agent, так как Claude Code подавляет интерактивные подсказки SSH для отпечатка хоста и пароля ключа.
Фоновые автоматические обновления запускаются при запуске без помощников учетных данных, так как интерактивные подсказки блокировали бы запуск Claude Code. Чтобы включить автоматические обновления для частных marketplace, установите соответствующий токен аутентификации в вашей среде:
| Поставщик | Переменные окружения | Примечания |
|---|---|---|
| GitHub | GITHUB_TOKEN или GH_TOKEN | Личный токен доступа или токен GitHub App |
| GitLab | GITLAB_TOKEN или GL_TOKEN | Личный токен доступа или токен проекта |
| Bitbucket | BITBUCKET_TOKEN | Пароль приложения или токен доступа к репозиторию |
.bashrc, .zshrc) или передайте его при запуске Claude Code:
Для сред CI/CD настройте токен как переменную окружения секрета. GitHub Actions автоматически предоставляет
GITHUB_TOKEN для репозиториев в одной организации.Тестирование локально перед распространением
Протестируйте ваш marketplace локально перед совместным использованием:Требование marketplace для вашей команды
Вы можете настроить ваш репозиторий так, чтобы члены команды автоматически получали предложение установить ваш marketplace, когда они доверяют папке проекта. Добавьте ваш marketplace в.claude/settings.json:
Если вы используете локальный источник
directory или file с относительным путем, путь разрешается относительно основного checkout вашего репозитория. Когда вы запускаете Claude Code из git worktree, путь все еще указывает на основной checkout, поэтому все worktrees совместно используют одно и то же расположение marketplace. Состояние marketplace хранится один раз для каждого пользователя в ~/.claude/plugins/known_marketplaces.json, а не для каждого проекта.Предварительное заполнение плагинов для контейнеров
Для образов контейнеров и сред CI вы можете предварительно заполнить каталог плагинов во время сборки, чтобы Claude Code запускался с уже доступными marketplace и плагинами, без клонирования во время выполнения. Установите переменную окруженияCLAUDE_CODE_PLUGIN_SEED_DIR на этот каталог.
Чтобы наслоить несколько каталогов seed, разделите пути с : на Unix или ; на Windows. Claude Code ищет каждый каталог по порядку, и первый seed, содержащий данный marketplace или кэш плагина, побеждает.
Каталог seed отражает структуру ~/.claude/plugins:
~/.claude/plugins в ваш образ и укажите CLAUDE_CODE_PLUGIN_SEED_DIR на него.
Чтобы пропустить шаг копирования, установите CLAUDE_CODE_PLUGIN_CACHE_DIR на путь целевого seed во время сборки, чтобы плагины устанавливались непосредственно туда:
CLAUDE_CODE_PLUGIN_SEED_DIR=/opt/claude-seed в среде выполнения вашего контейнера, чтобы Claude Code читал из seed при запуске.
При запуске Claude Code регистрирует marketplace, найденные в known_marketplaces.json seed, в основную конфигурацию и использует кэши плагинов, найденные под cache/, на месте без повторного клонирования. Это работает как в интерактивном режиме, так и в неинтерактивном режиме с флагом -p.
Детали поведения:
- Только для чтения: каталог seed никогда не записывается. Автоматические обновления отключены для seed marketplace, так как git pull не удастся на файловой системе только для чтения.
- Записи seed имеют приоритет: marketplace, объявленные в seed, перезаписывают любые совпадающие записи в конфигурации пользователя при каждом запуске. Чтобы отказаться от seed плагина, используйте
/plugin disableвместо удаления marketplace. - Разрешение пути: Claude Code находит содержимое marketplace, проверяя
$CLAUDE_CODE_PLUGIN_SEED_DIR/marketplaces/<name>/во время выполнения, а не доверяя путям, хранящимся внутри JSON seed. Это означает, что seed работает правильно, даже если он смонтирован по другому пути, чем где он был построен. - Мутация заблокирована: запуск
/plugin marketplace removeили/plugin marketplace updateпротив seed-управляемого marketplace не удается с указанием попросить вашего администратора обновить образ seed. - Компонуется с параметрами: если
extraKnownMarketplacesилиenabledPluginsобъявляют marketplace, который уже существует в seed, Claude Code использует копию seed вместо клонирования.
Ограничения управляемого marketplace
Для организаций, требующих строгого контроля над источниками плагинов, администраторы могут ограничить, какие marketplace плагинов пользователи могут добавлять, используя параметрstrictKnownMarketplaces в управляемых параметрах.
Когда strictKnownMarketplaces настроен в управляемых параметрах, поведение ограничения зависит от значения:
| Значение | Поведение |
|---|---|
| Не определено (по умолчанию) | Нет ограничений. Пользователи могут добавлять любой marketplace |
Пустой массив [] | Полная блокировка. Пользователи не могут добавлять новые marketplace |
| Список источников | Пользователи могут добавлять только marketplace, которые точно совпадают со списком разрешений |
Общие конфигурации
Отключение всех добавлений marketplace:".*" как pathPattern для разрешения любого пути файловой системы при одновременном контроле сетевых источников с помощью hostPattern.
strictKnownMarketplaces ограничивает то, что пользователи могут добавлять, но не регистрирует marketplace самостоятельно. Чтобы сделать разрешенные marketplace доступными автоматически без запуска пользователями /plugin marketplace add, объедините его с extraKnownMarketplaces в одном файле managed-settings.json. См. Использование обоих вместе.Как работают ограничения
Ограничения проверяются перед любой сетевой или файловой операцией. Проверка выполняется при добавлении marketplace и при установке, обновлении, обновлении и автоматическом обновлении плагина. Если marketplace был добавлен до настройки политики и его источник больше не совпадает со списком разрешений, Claude Code отказывает в установке или обновлении плагинов из него. То же самое применяется кblockedMarketplaces.
Список разрешений использует точное сопоставление для большинства типов источников. Чтобы marketplace был разрешен, все указанные поля должны совпадать точно:
- Для источников GitHub:
repoобязателен, иrefилиpathтакже должны совпадать, если указаны в списке разрешений - Для источников URL: полный URL должен совпадать точно
- Для источников
hostPattern: хост marketplace сопоставляется с шаблоном регулярного выражения - Для источников
pathPattern: путь файловой системы marketplace сопоставляется с шаблоном регулярного выражения
.git или форма ssh:// в сравнении с https:// рассматриваются как разные значения. Если marketplace вашей организации можно клонировать более чем одной формой URL, предпочтите запись hostPattern буквальному URL, чтобы все формы совпадали.
Поскольку strictKnownMarketplaces установлен в управляемых параметрах, отдельные пользователи и конфигурации проекта не могут переопределить эти ограничения.
Для полных деталей конфигурации, включая все поддерживаемые типы источников и сравнение с extraKnownMarketplaces, см. справку strictKnownMarketplaces.
Разрешение версий и каналы выпуска
Версии плагинов определяют пути кэша и обнаружение обновлений: если разрешенная версия совпадает с тем, что уже есть у пользователя,/plugin update и автоматическое обновление пропускают плагин.
Claude Code разрешает версию плагина из первого из этих параметров, который установлен:
versionвplugin.jsonплагинаversionв записи marketplace плагина- SHA коммита Git источника плагина
github, url, git-subdir и относительных путей внутри marketplace, размещенного на Git, вы можете полностью опустить version и каждый новый коммит будет рассматриваться как новая версия. Это самая простая установка для внутренних или активно разрабатываемых плагинов.
Установка каналов выпуска
Для поддержки каналов выпуска “stable” и “latest” для ваших плагинов вы можете установить два marketplace, которые указывают на разные refs или SHAs одного репозитория. Затем вы можете назначить два marketplace разным группам пользователей через управляемые параметры.Пример
Назначение каналов группам пользователей
Назначьте каждый marketplace соответствующей группе пользователей через управляемые параметры. Например, стабильная группа получает:latest-tools:
Закрепление версий зависимостей плагинов
Плагин может ограничить свои зависимости диапазоном semver, чтобы обновления зависимости не нарушили зависимый плагин. См. Ограничение версий зависимостей плагинов для соглашения о тегах Git{plugin-name}--v{version}, синтаксиса диапазона и того, как несколько ограничений на одну и ту же зависимость объединяются.
Валидация и тестирование
Протестируйте ваш marketplace перед совместным использованием. Проверьте синтаксис JSON вашего marketplace:Управление marketplace из CLI
Claude Code предоставляет неинтерактивные подкомандыclaude plugin marketplace для написания скриптов и автоматизации. Они эквивалентны командам /plugin marketplace, доступным в интерактивном сеансе.
Plugin marketplace add
Добавьте marketplace из репозитория GitHub, URL Git, удаленного URL или локального пути.<source>: Сокращение GitHubowner/repo, URL Git, удаленный URL к файлуmarketplace.jsonили путь локального каталога. Чтобы закрепить на ветке или теге, добавьте@refк сокращению GitHub или#refк URL Git
| Параметр | Описание | По умолчанию |
|---|---|---|
--scope <scope> | Где объявить marketplace: user, project или local. См. Области установки плагинов | user |
--sparse <paths...> | Ограничить checkout определенными каталогами через git sparse-checkout. Полезно для монорепозиториев |
owner/repo:
@ref:
marketplace.json напрямую:
.claude/settings.json:
Plugin marketplace list
Перечислите все настроенные marketplace.| Параметр | Описание |
|---|---|
--json | Вывести как JSON |
Plugin marketplace remove
Удалите настроенный marketplace. Также принимается псевдонимrm.
<name>: имя marketplace для удаления, как показано вclaude plugin marketplace list. Этоnameизmarketplace.json, а не источник, который вы передали вadd
Plugin marketplace update
Обновите marketplace из их источников, чтобы получить новые плагины и изменения версий.[name]: имя marketplace для обновления, как показано вclaude plugin marketplace list. Обновляет все marketplace, если опущено
remove и update не удаются при запуске против seed-управляемого marketplace, который доступен только для чтения. При обновлении всех marketplace записи, управляемые seed, пропускаются, и другие marketplace все еще обновляются. Чтобы изменить плагины, предоставленные seed, попросите вашего администратора обновить образ seed. См. Предварительное заполнение плагинов для контейнеров.
Устранение неполадок
Marketplace не загружается
Симптомы: Не удается добавить marketplace или увидеть плагины из него Решения:- Проверьте, что URL marketplace доступен
- Убедитесь, что
.claude-plugin/marketplace.jsonсуществует по указанному пути - Убедитесь, что синтаксис JSON действителен, используя
claude plugin validateили/plugin validate. Чтобы проверить frontmatter skill, agent и command, запустите команду для каждого каталога плагина - Для частных репозиториев подтвердите, что у вас есть разрешения доступа
Ошибки валидации marketplace
Запуститеclaude plugin validate . или /plugin validate . из каталога вашего marketplace, чтобы проверить наличие проблем. Когда валидатор указывает на каталог marketplace, он проверяет только marketplace.json: схему, дублирующиеся имена плагинов, обход пути источника и несоответствия версий для каждого упомянутого plugin.json.
Чтобы валидировать plugin.json отдельного плагина и его файлы skill, agent, command и hook, запустите команду для самого каталога плагина, например claude plugin validate ./plugins/my-plugin. Распространенные ошибки:
| Ошибка | Причина | Решение |
|---|---|---|
File not found: .claude-plugin/marketplace.json | Отсутствует манифест | Создайте .claude-plugin/marketplace.json с обязательными полями |
Invalid JSON syntax: Unexpected token... | Ошибка синтаксиса JSON в marketplace.json | Проверьте отсутствующие запятые, лишние запятые или неквотированные строки |
Duplicate plugin name "x" found in marketplace | Два плагина имеют одно имя | Дайте каждому плагину уникальное значение name |
plugins[0].source: Path contains ".." | Путь источника содержит .. | Используйте пути относительно корня marketplace без ... См. Относительные пути |
YAML frontmatter failed to parse: ... | Неверный YAML в файле skill, agent или command | Исправьте синтаксис YAML в блоке frontmatter. Во время выполнения этот файл загружается без метаданных. Сообщается только при валидации каталога плагина |
Invalid JSON syntax: ... (hooks.json) | Неправильный формат hooks/hooks.json | Исправьте синтаксис JSON. Неправильный hooks/hooks.json предотвращает загрузку всего плагина. Сообщается только при валидации каталога плагина |
Marketplace has no plugins defined: добавьте хотя бы один плагин в массивpluginsNo marketplace description provided: добавьте описание верхнего уровняdescription, чтобы помочь пользователям понять ваш marketplacePlugin name "x" is not kebab-case: имя плагина содержит прописные буквы, пробелы или специальные символы. Переименуйте в строчные буквы, цифры и дефисы только (например,my-plugin). Claude Code принимает другие формы, но синхронизация marketplace Claude.ai их отклоняет.
Ошибки установки плагина
Симптомы: Marketplace появляется, но установка плагина не удается Решения:- Проверьте, что URL источников плагинов доступны
- Убедитесь, что каталоги плагинов содержат необходимые файлы
- Для источников GitHub убедитесь, что репозитории являются общедоступными или у вас есть доступ
- Протестируйте источники плагинов вручную, клонируя/загружая их
Ошибка аутентификации частного репозитория
Симптомы: Ошибки аутентификации при установке плагинов из частных репозиториев Решения: Для ручной установки и обновлений:- Проверьте, что вы аутентифицированы у вашего поставщика Git (например, запустите
gh auth statusдля GitHub) - Проверьте, что ваш помощник учетных данных настроен правильно:
git config --global credential.helper - Попробуйте клонировать репозиторий вручную, чтобы проверить, что ваши учетные данные работают
- Установите соответствующий токен в вашей среде:
echo $GITHUB_TOKEN - Проверьте, что токен имеет необходимые разрешения (доступ на чтение к репозиторию)
- Для GitHub убедитесь, что токен имеет область
repoдля частных репозиториев - Для GitLab убедитесь, что токен имеет как минимум область
read_repository - Проверьте, что токен не истек
Обновления marketplace не работают в автономных средах
Симптомы: Marketplacegit pull не удается и Claude Code удаляет существующий кэш, что делает плагины недоступными.
Причина: По умолчанию, когда git pull не удается, Claude Code удаляет устаревший клон и пытается повторно клонировать. В автономных или изолированных средах повторное клонирование не удается так же, оставляя каталог marketplace пустым.
Решение: Установите CLAUDE_CODE_PLUGIN_KEEP_MARKETPLACE_ON_FAILURE=1, чтобы сохранить существующий кэш при сбое pull вместо его удаления:
git pull и продолжает использовать последнее известное хорошее состояние. Для полностью автономных развертываний, где репозиторий никогда не будет доступен, используйте CLAUDE_CODE_PLUGIN_SEED_DIR для предварительного заполнения каталога плагинов во время сборки вместо этого.
Операции Git истекают по времени
Симптомы: Установка плагина или обновление marketplace не удается с ошибкой истечения времени, например “Git clone timed out after 120s” или “Git pull timed out after 120s”. Причина: Claude Code использует 120-секундный таймаут для всех операций Git, включая клонирование репозиториев плагинов и извлечение обновлений marketplace. Большие репозитории или медленные сетевые соединения могут превысить этот лимит. Решение: Увеличьте таймаут, используя переменную окруженияCLAUDE_CODE_PLUGIN_GIT_TIMEOUT_MS. Значение указывается в миллисекундах:
Плагины с относительными путями не работают в marketplace на основе URL
Симптомы: Добавлен marketplace через URL (например,https://example.com/marketplace.json), но плагины с источниками относительных путей, такие как "./plugins/my-plugin", не устанавливаются с ошибками “path not found”.
Причина: Marketplace на основе URL загружают только сам файл marketplace.json. Они не загружают файлы плагинов с сервера. Относительные пути в записи marketplace ссылаются на файлы на удаленном сервере, которые не были загружены.
Решения:
- Используйте внешние источники: Измените записи плагинов, чтобы использовать источники GitHub, npm или URL Git вместо относительных путей:
- Используйте marketplace на основе Git: Разместите ваш marketplace в репозитории Git и добавьте его с URL Git. Marketplace на основе Git клонируют весь репозиторий, что делает относительные пути рабочими.
Файлы не найдены после установки
Симптомы: Плагин устанавливается, но ссылки на файлы не работают, особенно файлы вне каталога плагина Причина: Плагины копируются в каталог кэша, а не используются на месте. Пути, которые ссылаются на файлы вне каталога плагина (например,../shared-utils), не будут работать, потому что эти файлы не копируются.
Решения: См. Кэширование плагинов и разрешение файлов для обходных путей, включая символические ссылки и переструктурирование каталогов.
Для дополнительных инструментов отладки и распространенных проблем см. Инструменты отладки и разработки.
См. также
- Обнаружение и установка готовых плагинов - Установка плагинов из существующих marketplace
- Плагины - Создание собственных плагинов
- Справка плагинов - Полные технические спецификации и схемы
- Параметры плагинов - Параметры конфигурации плагинов
- Справка strictKnownMarketplaces - Ограничения управляемого marketplace