Перейти к основному содержанию

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.

plugin marketplace — это каталог, который позволяет вам распространять плагины другим пользователям. Marketplace обеспечивают централизованное обнаружение, отслеживание версий, автоматические обновления и поддержку нескольких типов источников (репозитории Git, локальные пути и многое другое). Это руководство показывает, как создать собственный marketplace для совместного использования плагинов с вашей командой или сообществом. Ищете способ установить плагины из существующего marketplace? См. Обнаружение и установка готовых плагинов.

Обзор

Создание и распространение marketplace включает:
  1. Создание плагинов: создайте один или несколько плагинов с skills, агентами, hooks, MCP servers или LSP servers. Это руководство предполагает, что у вас уже есть плагины для распространения; см. Создание плагинов для получения подробной информации о том, как их создавать.
  2. Создание файла marketplace: определите marketplace.json, который перечисляет ваши плагины и где их найти (см. Создание файла marketplace).
  3. Размещение marketplace: отправьте на GitHub, GitLab или другой хост Git (см. Размещение и распространение marketplace).
  4. Совместное использование с пользователями: пользователи добавляют ваш marketplace с помощью /plugin marketplace add и устанавливают отдельные плагины (см. Обнаружение и установка плагинов).
После того как ваш marketplace будет запущен, вы можете обновить его, отправив изменения в ваш репозиторий. Пользователи обновляют свою локальную копию с помощью /plugin marketplace update.

Пошаговое руководство: создание локального marketplace

Этот пример создает marketplace с одним плагином: skill quality-review для проверки кода. Вы создадите структуру каталогов, добавите skill, создадите манифест плагина и каталог marketplace, затем установите и протестируете его.
1

Создание структуры каталогов

mkdir -p my-marketplace/.claude-plugin
mkdir -p my-marketplace/plugins/quality-review-plugin/.claude-plugin
mkdir -p my-marketplace/plugins/quality-review-plugin/skills/quality-review
2

Создание skill

Создайте файл SKILL.md, который определяет, что делает skill quality-review.
my-marketplace/plugins/quality-review-plugin/skills/quality-review/SKILL.md
---
description: Проверка кода на ошибки, безопасность и производительность
disable-model-invocation: true
---

Проверьте выбранный мной код или недавние изменения на предмет:
- Потенциальных ошибок или граничных случаев
- Проблем безопасности
- Проблем производительности
- Улучшений читаемости

Будьте лаконичны и конкретны.
3

Создание манифеста плагина

Создайте файл plugin.json, который описывает плагин. Манифест находится в каталоге .claude-plugin/.
my-marketplace/plugins/quality-review-plugin/.claude-plugin/plugin.json
{
  "name": "quality-review-plugin",
  "description": "Добавляет skill quality-review для быстрой проверки кода",
  "version": "1.0.0"
}
Установка version означает, что пользователи получают обновления только при изменении этого поля, поэтому увеличивайте его при каждом выпуске. Если вы опустите version и разместите этот marketplace в git, каждый коммит автоматически считается новой версией. См. Разрешение версий, чтобы выбрать правильный подход.
4

Создание файла marketplace

Создайте каталог marketplace, который перечисляет ваш плагин.
my-marketplace/.claude-plugin/marketplace.json
{
  "name": "my-plugins",
  "owner": {
    "name": "Ваше имя"
  },
  "plugins": [
    {
      "name": "quality-review-plugin",
      "source": "./plugins/quality-review-plugin",
      "description": "Добавляет skill quality-review для быстрой проверки кода"
    }
  ]
}
5

Добавление и установка

Добавьте marketplace и установите плагин.
/plugin marketplace add ./my-marketplace
/plugin install quality-review-plugin@my-plugins
6

Попробуйте

Выберите некоторый код в вашем редакторе и запустите вашу новую skill. Plugin skills имеют пространство имен с именем плагина.
/quality-review-plugin:quality-review
Чтобы узнать больше о том, что могут делать плагины, включая hooks, агентов, MCP servers и LSP servers, см. Плагины.
Как устанавливаются плагины: Когда пользователи устанавливают плагин, Claude Code копирует каталог плагина в место кэша. Это означает, что плагины не могут ссылаться на файлы вне их каталога, используя пути вроде ../shared-utils, потому что эти файлы не будут скопированы.Если вам нужно совместно использовать файлы между плагинами, используйте символические ссылки. См. Кэширование плагинов и разрешение файлов для получения подробной информации.

Создание файла marketplace

Создайте .claude-plugin/marketplace.json в корне вашего репозитория. Этот файл определяет имя вашего marketplace, информацию о владельце и список плагинов с их источниками. Каждая запись плагина требует как минимум name и source (откуда его получить). См. полную схему ниже для всех доступных полей.
{
  "name": "company-tools",
  "owner": {
    "name": "DevTools Team",
    "email": "devtools@example.com"
  },
  "plugins": [
    {
      "name": "code-formatter",
      "source": "./plugins/formatter",
      "description": "Автоматическое форматирование кода при сохранении",
      "version": "2.1.0",
      "author": {
        "name": "DevTools Team"
      }
    },
    {
      "name": "deployment-tools",
      "source": {
        "source": "github",
        "repo": "company/deploy-plugin"
      },
      "description": "Инструменты автоматизации развертывания"
    }
  ]
}

Схема marketplace

Обязательные поля

ПолеТипОписаниеПример
namestringИдентификатор marketplace (kebab-case, без пробелов). Это общедоступное поле: пользователи видят его при установке плагинов (например, /plugin install my-tool@your-marketplace)."acme-tools"
ownerobjectИнформация о сопровождающем marketplace (см. поля ниже)
pluginsarrayСписок доступных плагиновСм. ниже
Зарезервированные имена: Следующие имена 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, также заблокированы.

Поля владельца

ПолеТипОбязательноОписание
namestringДаИмя сопровождающего или команды
emailstringНетКонтактный адрес электронной почты сопровождающего

Дополнительные поля

ПолеТипОписание
$schemastringURL JSON Schema для автодополнения редактора и валидации. Claude Code игнорирует это поле при загрузке.
descriptionstringКраткое описание marketplace
versionstringВерсия манифеста marketplace
metadata.pluginRootstringБазовый каталог, добавляемый к относительным путям источников плагинов (например, "./plugins" позволяет вам писать "source": "formatter" вместо "source": "./plugins/formatter")
allowCrossMarketplaceDependenciesOnarrayДругие marketplace, на которые плагины в этом marketplace могут зависеть. Зависимости от marketplace, не указанного здесь, блокируются при установке. См. Зависимость от плагина из другого marketplace.
description и version также принимаются в metadata для обратной совместимости.

Записи плагинов

Каждая запись плагина в массиве plugins описывает плагин и где его найти. Вы можете включить любое поле из схемы манифеста плагина (например, description, version, author, commands, hooks и т. д.), плюс эти поля, специфичные для marketplace: source, category, tags и strict.

Обязательные поля

ПолеТипОписание
namestringИдентификатор плагина (kebab-case, без пробелов). Это общедоступное поле: пользователи видят его при установке (например, /plugin install my-plugin@marketplace).
sourcestring|objectОткуда получить плагин (см. Источники плагинов ниже)

Дополнительные поля плагина

Поля стандартных метаданных:
ПолеТипОписание
displayNamestringУдобочитаемое имя, отображаемое в интерфейсе. Возвращается к name при отсутствии. Может содержать пробелы и любой регистр. Не используется для пространства имён или поиска. Требуется Claude Code v2.1.143 или позже.
descriptionstringКраткое описание плагина
versionstringВерсия плагина. Если установлено (здесь или в plugin.json), плагин закреплен на этой строке и пользователи получают обновления только при её изменении. Опустите, чтобы вернуться к SHA коммита git. См. Разрешение версий.
authorobjectИнформация об авторе плагина (name обязательно, email опционально)
homepagestringURL домашней страницы или документации плагина
repositorystringURL репозитория исходного кода
licensestringИдентификатор лицензии SPDX (например, MIT, Apache-2.0)
keywordsarrayТеги для обнаружения и категоризации плагинов
categorystringКатегория плагина для организации
tagsarrayТеги для поиска
strictbooleanКонтролирует, является ли plugin.json авторитетом для определений компонентов (по умолчанию: true). См. Strict mode ниже.
Поля конфигурации компонентов:
ПолеТипОписание
skillsstring|arrayПользовательские пути к каталогам skills, содержащим <name>/SKILL.md
commandsstring|arrayПользовательские пути к плоским файлам .md skills или каталогам
agentsstring|arrayПользовательские пути к файлам агентов
hooksstring|objectКонфигурация пользовательских hooks или путь к файлу hooks
mcpServersstring|objectКонфигурации MCP server или путь к конфигурации MCP
lspServersstring|objectКонфигурации LSP server или путь к конфигурации LSP

Источники плагинов

Источники плагинов указывают Claude Code, откуда получить каждый отдельный плагин, указанный в вашем marketplace. Они устанавливаются в поле source каждой записи плагина в marketplace.json. После того как плагин клонирован или скопирован на локальную машину, он копируется в локальный кэш плагинов с версией в ~/.claude/plugins/cache.
ИсточникТипПоляПримечания
Относительный путьstring (например, "./my-plugin")Локальный каталог в репозитории marketplace. Должен начинаться с ./. Разрешается относительно корня marketplace, а не каталога .claude-plugin/
githubobjectrepo, ref?, sha?
urlobjecturl, ref?, sha?Источник URL Git
git-subdirobjecturl, path, ref?, sha?Подкаталог в репозитории Git. Клонирует разреженно, чтобы минимизировать пропускную способность для монорепозиториев
npmobjectpackage, version?, registry?Установлено через npm install
Источники marketplace и источники плагинов: Это разные концепции, которые контролируют разные вещи.
  • Источник marketplace — откуда получить сам каталог marketplace.json. Устанавливается, когда пользователи запускают /plugin marketplace add или в параметрах extraKnownMarketplaces. Поддерживает ref (ветка/тег), но не sha.
  • Источник плагина — откуда получить отдельный плагин, указанный в marketplace. Устанавливается в поле source каждой записи плагина внутри marketplace.json. Поддерживает как ref (ветка/тег), так и sha (точный коммит).
Например, marketplace, размещенный в acme-corp/plugin-catalog (источник marketplace), может перечислять плагин, полученный из acme-corp/code-formatter (источник плагина). Источник marketplace и источник плагина указывают на разные репозитории и закреплены независимо.

Относительные пути

Для плагинов в одном репозитории используйте путь, начинающийся с ./:
{
  "name": "my-plugin",
  "source": "./plugins/my-plugin"
}
Пути разрешаются относительно корня 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

{
  "name": "github-plugin",
  "source": {
    "source": "github",
    "repo": "owner/plugin-repo"
  }
}
Вы можете закрепить определенную ветку, тег или коммит:
{
  "name": "github-plugin",
  "source": {
    "source": "github",
    "repo": "owner/plugin-repo",
    "ref": "v2.0.0",
    "sha": "a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7f8a9b0"
  }
}
ПолеТипОписание
repostringОбязательно. Репозиторий GitHub в формате owner/repo
refstringОпционально. Ветка или тег Git (по умолчанию ветка по умолчанию репозитория)
shastringОпционально. Полный 40-символьный SHA коммита Git для закрепления на точной версии

Репозитории Git

{
  "name": "git-plugin",
  "source": {
    "source": "url",
    "url": "https://gitlab.com/team/plugin.git"
  }
}
Вы можете закрепить определенную ветку, тег или коммит:
{
  "name": "git-plugin",
  "source": {
    "source": "url",
    "url": "https://gitlab.com/team/plugin.git",
    "ref": "main",
    "sha": "a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7f8a9b0"
  }
}
ПолеТипОписание
urlstringОбязательно. Полный URL репозитория Git (https:// или git@). Суффикс .git опционален, поэтому URL Azure DevOps и AWS CodeCommit без суффикса работают
refstringОпционально. Ветка или тег Git (по умолчанию ветка по умолчанию репозитория)
shastringОпционально. Полный 40-символьный SHA коммита Git для закрепления на точной версии

Подкаталоги Git

Используйте git-subdir для указания плагина, который находится в подкаталоге репозитория Git. Claude Code использует разреженный, частичный клон для получения только подкаталога, минимизируя пропускную способность для больших монорепозиториев.
{
  "name": "my-plugin",
  "source": {
    "source": "git-subdir",
    "url": "https://github.com/acme-corp/monorepo.git",
    "path": "tools/claude-plugin"
  }
}
Вы можете закрепить определенную ветку, тег или коммит:
{
  "name": "my-plugin",
  "source": {
    "source": "git-subdir",
    "url": "https://github.com/acme-corp/monorepo.git",
    "path": "tools/claude-plugin",
    "ref": "v2.0.0",
    "sha": "a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7f8a9b0"
  }
}
Поле url также принимает сокращение GitHub (owner/repo) или SSH URL (git@github.com:owner/repo.git).
ПолеТипОписание
urlstringОбязательно. URL репозитория Git, сокращение GitHub owner/repo или SSH URL
pathstringОбязательно. Путь подкаталога в репозитории, содержащий плагин (например, "tools/claude-plugin")
refstringОпционально. Ветка или тег Git (по умолчанию ветка по умолчанию репозитория)
shastringОпционально. Полный 40-символьный SHA коммита Git для закрепления на точной версии

Пакеты npm

Плагины, распространяемые как пакеты npm, устанавливаются с помощью npm install. Это работает с любым пакетом в общедоступном реестре npm или в частном реестре, который размещает ваша команда.
{
  "name": "my-npm-plugin",
  "source": {
    "source": "npm",
    "package": "@acme/claude-plugin"
  }
}
Чтобы закрепить определенную версию, добавьте поле version:
{
  "name": "my-npm-plugin",
  "source": {
    "source": "npm",
    "package": "@acme/claude-plugin",
    "version": "2.1.0"
  }
}
Для установки из частного или внутреннего реестра добавьте поле registry:
{
  "name": "my-npm-plugin",
  "source": {
    "source": "npm",
    "package": "@acme/claude-plugin",
    "version": "^2.0.0",
    "registry": "https://npm.example.com"
  }
}
ПолеТипОписание
packagestringОбязательно. Имя пакета или область пакета (например, @org/plugin)
versionstringОпционально. Версия или диапазон версий (например, 2.1.0, ^2.0.0, ~1.5.0)
registrystringОпционально. Пользовательский URL реестра npm. По умолчанию системный реестр npm (обычно npmjs.org)

Расширенные записи плагинов

Этот пример показывает запись плагина, использующую множество дополнительных полей, включая пользовательские пути для команд, агентов, hooks и MCP servers:
{
  "name": "enterprise-tools",
  "source": {
    "source": "github",
    "repo": "company/enterprise-plugin"
  },
  "description": "Инструменты автоматизации корпоративного рабочего процесса",
  "version": "2.1.0",
  "author": {
    "name": "Enterprise Team",
    "email": "enterprise@example.com"
  },
  "homepage": "https://docs.example.com/plugins/enterprise-tools",
  "repository": "https://github.com/company/enterprise-plugin",
  "license": "MIT",
  "keywords": ["enterprise", "workflow", "automation"],
  "category": "productivity",
  "commands": [
    "./commands/core/",
    "./commands/enterprise/",
    "./commands/experimental/preview.md"
  ],
  "agents": ["./agents/security-reviewer.md", "./agents/compliance-checker.md"],
  "hooks": {
    "PostToolUse": [
      {
        "matcher": "Write|Edit",
        "hooks": [
          {
            "type": "command",
            "command": "${CLAUDE_PLUGIN_ROOT}/scripts/validate.sh"
          }
        ]
      }
    ]
  },
  "mcpServers": {
    "enterprise-db": {
      "command": "${CLAUDE_PLUGIN_ROOT}/servers/db-server",
      "args": ["--config", "${CLAUDE_PLUGIN_ROOT}/config.json"]
    }
  },
  "strict": false
}
Ключевые моменты, на которые следует обратить внимание:
  • 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 обеспечивает самый простой метод распространения:
  1. Создание репозитория: Установите новый репозиторий для вашего marketplace
  2. Добавление файла marketplace: Создайте .claude-plugin/marketplace.json с определениями ваших плагинов
  3. Совместное использование с командами: Пользователи добавляют ваш marketplace с помощью /plugin marketplace add owner/repo
Преимущества: Встроенное управление версиями, отслеживание проблем и функции совместной работы команды.

Размещение на других сервисах Git

Любой сервис хостинга Git работает, например GitLab, Bitbucket и самостоятельно размещаемые серверы. Пользователи добавляют с полным URL репозитория:
/plugin marketplace add https://gitlab.com/company/plugins.git

Частные репозитории

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, установите соответствующий токен аутентификации в вашей среде:
ПоставщикПеременные окруженияПримечания
GitHubGITHUB_TOKEN или GH_TOKENЛичный токен доступа или токен GitHub App
GitLabGITLAB_TOKEN или GL_TOKENЛичный токен доступа или токен проекта
BitbucketBITBUCKET_TOKENПароль приложения или токен доступа к репозиторию
Установите токен в конфигурацию вашей оболочки (например, .bashrc, .zshrc) или передайте его при запуске Claude Code:
export GITHUB_TOKEN=ghp_xxxxxxxxxxxxxxxxxxxx
Для сред CI/CD настройте токен как переменную окружения секрета. GitHub Actions автоматически предоставляет GITHUB_TOKEN для репозиториев в одной организации.

Тестирование локально перед распространением

Протестируйте ваш marketplace локально перед совместным использованием:
/plugin marketplace add ./my-local-marketplace
/plugin install test-plugin@my-local-marketplace
Для полного диапазона команд добавления (GitHub, URL Git, локальные пути, удаленные URL), см. Добавление marketplace.

Требование marketplace для вашей команды

Вы можете настроить ваш репозиторий так, чтобы члены команды автоматически получали предложение установить ваш marketplace, когда они доверяют папке проекта. Добавьте ваш marketplace в .claude/settings.json:
{
  "extraKnownMarketplaces": {
    "company-tools": {
      "source": {
        "source": "github",
        "repo": "your-org/claude-plugins"
      }
    }
  }
}
Вы также можете указать, какие плагины должны быть включены по умолчанию:
{
  "enabledPlugins": {
    "code-formatter@company-tools": true,
    "deployment-tools@company-tools": true
  }
}
Для полных параметров конфигурации см. Параметры плагинов.
Если вы используете локальный источник 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_CODE_PLUGIN_SEED_DIR/
  known_marketplaces.json
  marketplaces/<name>/...
  cache/<marketplace>/<plugin>/<version>/...
Чтобы построить каталог seed, запустите Claude Code один раз во время сборки образа, установите нужные вам плагины, затем скопируйте полученный каталог ~/.claude/plugins в ваш образ и укажите CLAUDE_CODE_PLUGIN_SEED_DIR на него. Чтобы пропустить шаг копирования, установите CLAUDE_CODE_PLUGIN_CACHE_DIR на путь целевого seed во время сборки, чтобы плагины устанавливались непосредственно туда:
CLAUDE_CODE_PLUGIN_CACHE_DIR=/opt/claude-seed claude plugin marketplace add your-org/plugins
CLAUDE_CODE_PLUGIN_CACHE_DIR=/opt/claude-seed claude plugin install my-tool@your-plugins
Затем установите 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:
{
  "strictKnownMarketplaces": []
}
Разрешение только определенных marketplace:
{
  "strictKnownMarketplaces": [
    {
      "source": "github",
      "repo": "acme-corp/approved-plugins"
    },
    {
      "source": "github",
      "repo": "acme-corp/security-tools",
      "ref": "v2.0"
    },
    {
      "source": "url",
      "url": "https://plugins.example.com/marketplace.json"
    }
  ]
}
Разрешение всех marketplace с внутреннего сервера Git с использованием сопоставления шаблонов регулярных выражений на хосте. Это рекомендуемый подход для GitHub Enterprise Server или самостоятельно размещаемых экземпляров GitLab:
{
  "strictKnownMarketplaces": [
    {
      "source": "hostPattern",
      "hostPattern": "^github\\.example\\.com$"
    }
  ]
}
Разрешение marketplace на основе файловой системы из определенного каталога с использованием сопоставления шаблонов регулярных выражений на пути:
{
  "strictKnownMarketplaces": [
    {
      "source": "pathPattern",
      "pathPattern": "^/opt/approved/"
    }
  ]
}
Используйте ".*" как 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 сопоставляется с шаблоном регулярного выражения
Точное сопоставление не нормализует URL: конечная косая черта, суффикс .git или форма ssh:// в сравнении с https:// рассматриваются как разные значения. Если marketplace вашей организации можно клонировать более чем одной формой URL, предпочтите запись hostPattern буквальному URL, чтобы все формы совпадали. Поскольку strictKnownMarketplaces установлен в управляемых параметрах, отдельные пользователи и конфигурации проекта не могут переопределить эти ограничения. Для полных деталей конфигурации, включая все поддерживаемые типы источников и сравнение с extraKnownMarketplaces, см. справку strictKnownMarketplaces.

Разрешение версий и каналы выпуска

Версии плагинов определяют пути кэша и обнаружение обновлений: если разрешенная версия совпадает с тем, что уже есть у пользователя, /plugin update и автоматическое обновление пропускают плагин. Claude Code разрешает версию плагина из первого из этих параметров, который установлен:
  1. version в plugin.json плагина
  2. version в записи marketplace плагина
  3. SHA коммита Git источника плагина
Для типов источников на основе Git github, url, git-subdir и относительных путей внутри marketplace, размещенного на Git, вы можете полностью опустить version и каждый новый коммит будет рассматриваться как новая версия. Это самая простая установка для внутренних или активно разрабатываемых плагинов.
Установка version закрепляет плагин. Если plugin.json объявляет "version": "1.0.0", отправка новых коммитов без изменения этой строки ничего не делает для существующих пользователей, потому что Claude Code видит ту же версию и сохраняет кэшированную копию. Увеличивайте поле при каждом выпуске или опустите его, чтобы использовать SHA коммита.Избегайте установки version одновременно в plugin.json и в записи marketplace. Значение plugin.json всегда побеждает молча, поэтому устаревшая версия манифеста может скрыть версию, которую вы установили в marketplace.json.

Установка каналов выпуска

Для поддержки каналов выпуска “stable” и “latest” для ваших плагинов вы можете установить два marketplace, которые указывают на разные refs или SHAs одного репозитория. Затем вы можете назначить два marketplace разным группам пользователей через управляемые параметры.
Каждый канал должен разрешаться в другую версию. Если вы используете явные версии, plugin.json должен объявлять другую version в каждом закрепленном ref. Если вы опустите version, различные SHA коммитов уже различают каналы. Если два refs разрешаются в одну и ту же строку версии, Claude Code рассматривает их как идентичные и пропускает обновление.
Пример
{
  "name": "stable-tools",
  "plugins": [
    {
      "name": "code-formatter",
      "source": {
        "source": "github",
        "repo": "acme-corp/code-formatter",
        "ref": "stable"
      }
    }
  ]
}
{
  "name": "latest-tools",
  "plugins": [
    {
      "name": "code-formatter",
      "source": {
        "source": "github",
        "repo": "acme-corp/code-formatter",
        "ref": "latest"
      }
    }
  ]
}
Назначение каналов группам пользователей
Назначьте каждый marketplace соответствующей группе пользователей через управляемые параметры. Например, стабильная группа получает:
{
  "extraKnownMarketplaces": {
    "stable-tools": {
      "source": {
        "source": "github",
        "repo": "acme-corp/stable-tools"
      }
    }
  }
}
Группа ранних доступов получает вместо этого latest-tools:
{
  "extraKnownMarketplaces": {
    "latest-tools": {
      "source": {
        "source": "github",
        "repo": "acme-corp/latest-tools"
      }
    }
  }
}

Закрепление версий зависимостей плагинов

Плагин может ограничить свои зависимости диапазоном semver, чтобы обновления зависимости не нарушили зависимый плагин. См. Ограничение версий зависимостей плагинов для соглашения о тегах Git {plugin-name}--v{version}, синтаксиса диапазона и того, как несколько ограничений на одну и ту же зависимость объединяются.

Валидация и тестирование

Протестируйте ваш marketplace перед совместным использованием. Проверьте синтаксис JSON вашего marketplace:
claude plugin validate .
Или из Claude Code:
/plugin validate .
Добавьте marketplace для тестирования:
/plugin marketplace add ./path/to/marketplace
Установите тестовый плагин, чтобы проверить, что все работает:
/plugin install test-plugin@marketplace-name
Для полного диапазона рабочих процессов тестирования плагинов см. Тестирование ваших плагинов локально. Для технического устранения неполадок см. Справка плагинов.

Управление marketplace из CLI

Claude Code предоставляет неинтерактивные подкоманды claude plugin marketplace для написания скриптов и автоматизации. Они эквивалентны командам /plugin marketplace, доступным в интерактивном сеансе.

Plugin marketplace add

Добавьте marketplace из репозитория GitHub, URL Git, удаленного URL или локального пути.
claude plugin marketplace add <source> [options]
Аргументы:
  • <source>: Сокращение GitHub owner/repo, URL Git, удаленный URL к файлу marketplace.json или путь локального каталога. Чтобы закрепить на ветке или теге, добавьте @ref к сокращению GitHub или #ref к URL Git
Параметры:
ПараметрОписаниеПо умолчанию
--scope <scope>Где объявить marketplace: user, project или local. См. Области установки плагиновuser
--sparse <paths...>Ограничить checkout определенными каталогами через git sparse-checkout. Полезно для монорепозиториев
Добавьте marketplace из GitHub, используя сокращение owner/repo:
claude plugin marketplace add acme-corp/claude-plugins
Закрепите на определенной ветке или теге с помощью @ref:
claude plugin marketplace add acme-corp/claude-plugins@v2.0
Добавьте из URL Git на хосте, отличном от GitHub:
claude plugin marketplace add https://gitlab.example.com/team/plugins.git
Добавьте из удаленного URL, который служит файлом marketplace.json напрямую:
claude plugin marketplace add https://example.com/marketplace.json
Добавьте из локального каталога для тестирования:
claude plugin marketplace add ./my-marketplace
Объявите marketplace в области проекта, чтобы он был общим с вашей командой через .claude/settings.json:
claude plugin marketplace add acme-corp/claude-plugins --scope project
Для монорепозитория ограничьте checkout каталогами, содержащими содержимое плагина:
claude plugin marketplace add acme-corp/monorepo --sparse .claude-plugin plugins

Plugin marketplace list

Перечислите все настроенные marketplace.
claude plugin marketplace list [options]
Параметры:
ПараметрОписание
--jsonВывести как JSON

Plugin marketplace remove

Удалите настроенный marketplace. Также принимается псевдоним rm.
claude plugin marketplace remove <name>
Аргументы:
  • <name>: имя marketplace для удаления, как показано в claude plugin marketplace list. Это name из marketplace.json, а не источник, который вы передали в add
Удаление marketplace также удаляет все плагины, которые вы установили из него. Чтобы обновить marketplace без потери установленных плагинов, используйте claude plugin marketplace update вместо этого.

Plugin marketplace update

Обновите marketplace из их источников, чтобы получить новые плагины и изменения версий.
claude plugin marketplace update [name]
Аргументы:
  • [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: добавьте хотя бы один плагин в массив plugins
  • No marketplace description provided: добавьте описание верхнего уровня description, чтобы помочь пользователям понять ваш marketplace
  • Plugin 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 не работают в автономных средах

Симптомы: Marketplace git pull не удается и Claude Code удаляет существующий кэш, что делает плагины недоступными. Причина: По умолчанию, когда git pull не удается, Claude Code удаляет устаревший клон и пытается повторно клонировать. В автономных или изолированных средах повторное клонирование не удается так же, оставляя каталог marketplace пустым. Решение: Установите CLAUDE_CODE_PLUGIN_KEEP_MARKETPLACE_ON_FAILURE=1, чтобы сохранить существующий кэш при сбое pull вместо его удаления:
export CLAUDE_CODE_PLUGIN_KEEP_MARKETPLACE_ON_FAILURE=1
С этой переменной установленной, Claude Code сохраняет устаревший клон marketplace при сбое 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. Значение указывается в миллисекундах:
export CLAUDE_CODE_PLUGIN_GIT_TIMEOUT_MS=300000  # 5 минут

Плагины с относительными путями не работают в marketplace на основе URL

Симптомы: Добавлен marketplace через URL (например, https://example.com/marketplace.json), но плагины с источниками относительных путей, такие как "./plugins/my-plugin", не устанавливаются с ошибками “path not found”. Причина: Marketplace на основе URL загружают только сам файл marketplace.json. Они не загружают файлы плагинов с сервера. Относительные пути в записи marketplace ссылаются на файлы на удаленном сервере, которые не были загружены. Решения:
  • Используйте внешние источники: Измените записи плагинов, чтобы использовать источники GitHub, npm или URL Git вместо относительных путей:
    { "name": "my-plugin", "source": { "source": "github", "repo": "owner/repo" } }
    
  • Используйте marketplace на основе Git: Разместите ваш marketplace в репозитории Git и добавьте его с URL Git. Marketplace на основе Git клонируют весь репозиторий, что делает относительные пути рабочими.

Файлы не найдены после установки

Симптомы: Плагин устанавливается, но ссылки на файлы не работают, особенно файлы вне каталога плагина Причина: Плагины копируются в каталог кэша, а не используются на месте. Пути, которые ссылаются на файлы вне каталога плагина (например, ../shared-utils), не будут работать, потому что эти файлы не копируются. Решения: См. Кэширование плагинов и разрешение файлов для обходных путей, включая символические ссылки и переструктурирование каталогов. Для дополнительных инструментов отладки и распространенных проблем см. Инструменты отладки и разработки.

См. также