plugin-registry: Understanding Claude Code's plugin registry structure, installation scopes, and common issues. Use when troubleshooting plugin installation problems, understanding why plugins show as installed incorrectly, or manually fixing registry entries.
Installation
Details
Usage
After installing, this skill will be available to your AI coding assistant.
Verify installation:
npx agent-skills-cli listSkill Instructions
name: plugin-registry description: | Understanding Claude Code's plugin registry structure, installation scopes, and common issues. Use when troubleshooting plugin installation problems, understanding why plugins show as installed incorrectly, or manually fixing registry entries. user-invocable: false allowed-tools: Bash, Read, Write, Edit, Glob, Grep, TodoWrite created: 2026-02-04 modified: 2026-02-05 reviewed: 2026-02-05
Claude Code Plugin Registry
Expert knowledge for understanding and troubleshooting the Claude Code plugin registry.
When to Use This Skill
| Use this skill when... | Use something else when... |
|---|---|
| Plugin shows "installed" but isn't working | Setting up new plugins (use /configure:claude-plugins) |
| Need to understand plugin scopes | Configuring plugin permissions (use settings-configuration skill) |
| Fixing orphaned registry entries | Creating workflows with plugins (use github-actions-plugin) |
| Debugging installation failures |
Registry Location
The plugin registry is stored at:
~/.claude/plugins/installed_plugins.json
This file tracks all installed plugins across all projects.
Registry Structure (v2)
{
"version": 2,
"plugins": {
"plugin-name@marketplace-name": [
{
"scope": "project",
"projectPath": "/path/to/project",
"installPath": "~/.claude/plugins/cache/marketplace/plugin-name/1.0.0",
"version": "1.0.0",
"installedAt": "2024-01-15T10:30:00Z",
"lastUpdated": "2024-01-15T10:30:00Z",
"gitCommitSha": "abc123"
}
]
}
}
Each plugin key maps to an array of installations (supporting multiple scopes).
Field Reference
| Field | Required | Description |
|---|---|---|
scope | Yes | "project" or "user" (global) |
projectPath | project only | Directory where plugin is active |
installPath | Yes | Cache path for installed plugin files |
version | Yes | Installed version |
installedAt | Yes | ISO timestamp of installation |
lastUpdated | Yes | ISO timestamp of last update |
gitCommitSha | Yes | Git commit of installed version |
Installation Scopes
User Scope (global, default)
/plugin install my-plugin@marketplace
"scope": "user"in registry entry- No
projectPathfield - Available in all projects
Project Scope
/plugin install my-plugin@marketplace --scope project
"scope": "project"in registry entry- Has
projectPathset to installation directory - Should only be active in that project
- Bug #14202: Still shows as "installed" in other projects
Known Issue: #14202
Problem: Project-scoped plugins incorrectly appear as globally installed.
Root Cause: Inconsistent projectPath checking:
| Operation | Checks projectPath? | Result |
|---|---|---|
| Marketplaces "(installed)" | No | Shows installed everywhere |
/plugin install | No | Refuses to install |
| Installed tab listing | Yes | Correctly filtered |
Symptoms:
- Plugin shows "(installed)" checkmark in Marketplaces view
/plugin installsays "already installed"- Plugin doesn't appear in Installed tab for current project
- Plugin doesn't actually work in current project
Workaround: Manually edit the registry to add an entry for the current project.
Manual Registry Operations
View Registry
jq . ~/.claude/plugins/installed_plugins.json
List All Plugins
jq -r '.plugins | keys[]' ~/.claude/plugins/installed_plugins.json
Find Project-Scoped Plugins
jq '.plugins | to_entries[] | .value[] | select(.scope == "project") | {projectPath, version}' ~/.claude/plugins/installed_plugins.json
Find Orphaned Entries
Use the Read tool to read ~/.claude/plugins/installed_plugins.json, then check each projectPath with test -d.
Backup Registry
cp ~/.claude/plugins/installed_plugins.json ~/.claude/plugins/installed_plugins.json.backup
Fixing Registry Issues
Remove Orphaned Entry
- Read
~/.claude/plugins/installed_plugins.jsonwith the Read tool - Back up with
cp ~/.claude/plugins/installed_plugins.json ~/.claude/plugins/installed_plugins.json.backup - Remove the orphaned entry from the
pluginsobject - Write the updated JSON with the Write tool
Add Entry for Current Project
- Read the registry with Read tool
- Add a new entry to the plugin's array with
scope: "project"and currentprojectPath - Write the updated JSON with Write tool
Convert Project-Scoped to User (Global)
- Read the registry with Read tool
- Change
"scope": "project"to"scope": "user"and removeprojectPath - Write the updated JSON with Write tool
Project Settings Integration
Project-scoped plugins also need entries in .claude/settings.json:
{
"enabledPlugins": [
"plugin-name@marketplace"
]
}
Without this, even a correctly registered project-scoped plugin won't load.
Troubleshooting Checklist
-
Plugin shows installed but doesn't work
- Check if
projectPathmatches current directory - Check
.claude/settings.jsonforenabledPlugins - Run
/health:pluginsfor diagnosis
- Check if
-
Can't install plugin (already installed)
- Check registry for existing entry
- Check if entry has different
projectPath - Use
/health:plugins --fixor manual edit
-
Plugin works in one project but not another
- Likely a project-scoped plugin
- Need separate registry entry per project
- Or convert to global scope
-
Registry file is corrupted
- Restore from backup if available
- Or delete and reinstall plugins
- Location:
~/.claude/plugins/installed_plugins.json
Agentic Optimizations
| Context | Command |
|---|---|
| View registry | jq -c . ~/.claude/plugins/installed_plugins.json |
| List plugins | jq -r '.plugins | keys[]' ~/.claude/plugins/installed_plugins.json |
| Check specific | jq '.plugins."name@market"' ~/.claude/plugins/installed_plugins.json |
| Project plugins | jq '.plugins | to_entries[] | .value[] | select(.scope=="project")' ~/.claude/plugins/installed_plugins.json |
Quick Reference
Registry Path
~/.claude/plugins/installed_plugins.json
Key Format
{plugin-name}@{marketplace-name}
Scope Indicator
"scope": "project"+projectPath→ Project-scoped"scope": "user"→ Global (user-wide)
After Editing
Always restart Claude Code for registry changes to take effect.
More by laurigates
View allConfigure Claude Code security settings including permission wildcards, shell operator protections, and project-level access controls. Use when setting up project permissions, configuring allowed tools, or securing Claude Code workflows.
Craft PR titles using conventional commits format. Use when creating PRs or ensuring consistent PR naming. Covers type prefixes, scope, and subject writing.
Analyze and optimize GitHub Actions cache usage. Use when investigating cache bloat, identifying stale caches, optimizing cache keys, or comparing cache usage across repositories.
Release-please standards and configuration. Use when configuring release-please workflows, checking release automation compliance, or when the user mentions release-please, automated releases, or version management.
