Agent skill

marketplace-release

Use when creating releases for Claude Code plugin marketplaces. Supports independent plugin versioning - each plugin can be released separately. Triggered by "release", "bump version", "create release", "publish plugin".

Stars 232
Forks 15

Install this agent skill to your Project

npx add-skill https://github.com/aiskillstore/marketplace/tree/main/skills/emasoft/marketplace-release

SKILL.md

Marketplace Release Automation

A portable release script for Claude Code plugin marketplaces with independent plugin versioning. Each plugin in a marketplace maintains its own version and can be released separately.

Prerequisites

  1. GitHub CLI authenticated: gh auth status
  2. Clean git state (or acknowledge uncommitted changes)
  3. marketplace.json at .claude-plugin/marketplace.json
  4. Run from the marketplace root directory

Usage

bash
# Release a specific plugin
python "${CLAUDE_PLUGIN_ROOT}/scripts/release.py" <bump-type> <plugin-name> "<release-notes>"

# List all plugins and their versions
python "${CLAUDE_PLUGIN_ROOT}/scripts/release.py" --list

# Or copy script to marketplace and run from root
python scripts/release.py <bump-type> <plugin-name> "<release-notes>"

Examples

bash
# Patch release for ghe plugin
python "${CLAUDE_PLUGIN_ROOT}/scripts/release.py" patch ghe "Fix avatar loading issue"

# Minor release for marketplace-utils
python "${CLAUDE_PLUGIN_ROOT}/scripts/release.py" minor marketplace-utils "Add TOC generator"

# Major release with breaking changes
python "${CLAUDE_PLUGIN_ROOT}/scripts/release.py" major ghe "Breaking: New API structure"

# View all plugins and current versions
python "${CLAUDE_PLUGIN_ROOT}/scripts/release.py" --list

Version Bump Types

Type When to Use Example
patch Bug fixes, minor improvements 0.5.4 -> 0.5.5
minor New features, non-breaking changes 0.5.5 -> 0.6.0
major Breaking changes, major rewrites 0.6.0 -> 1.0.0

What It Does

  1. Validates prerequisites - Checks gh CLI, git repo, uncommitted changes
  2. Validates plugin - Runs claude plugin validate to ensure plugin is correct
  3. Bumps plugin version - In both marketplace.json and the plugin's plugin.json
  4. Updates script versions - Automatically updates __version__ in all scripts (marketplace-utils only)
  5. Updates READMEs - Plugin README badges + marketplace README version table
  6. Creates commit - With release message
  7. Creates git tag - Plugin-specific tag: <plugin-name>-v<version>
  8. Pushes to remote - Both commit and tag
  9. Creates GitHub release - With installation instructions

Plugin Validation

Before releasing, validate your plugin to catch errors early:

bash
# Validate a specific plugin
python "${CLAUDE_PLUGIN_ROOT}/scripts/validate_plugin.py" ghe

# Validate all plugins
python "${CLAUDE_PLUGIN_ROOT}/scripts/validate_plugin.py" --all

# Show version
python "${CLAUDE_PLUGIN_ROOT}/scripts/validate_plugin.py" --version

The validation script wraps claude plugin validate and provides:

  • Individual plugin validation
  • Batch validation with --all
  • Summary report of all results

Independent Versioning

Each plugin has its own version tracked in marketplace.json:

json
{
  "name": "my-marketplace",
  "plugins": [
    {
      "name": "ghe",
      "source": "./plugins/ghe",
      "version": "0.5.4"
    },
    {
      "name": "marketplace-utils",
      "source": "./plugins/marketplace-utils",
      "version": "1.0.0"
    }
  ]
}

When you release a plugin:

  • Only that plugin's version is bumped
  • Tags are plugin-specific: ghe-v0.5.4, marketplace-utils-v1.0.0
  • Other plugins remain unchanged

Configuration Files

marketplace.json (required)

Located at .claude-plugin/marketplace.json:

json
{
  "name": "my-marketplace",
  "plugins": [
    {
      "name": "plugin-a",
      "source": "./plugins/plugin-a",
      "version": "1.0.0"
    },
    {
      "name": "plugin-b",
      "source": "./plugins/plugin-b",
      "version": "2.3.1"
    }
  ]
}

plugin.json (auto-detected)

Located at plugins/<name>/.claude-plugin/plugin.json:

json
{
  "name": "plugin-a",
  "version": "1.0.0"
}

Both files are updated when releasing that specific plugin.

Version Suffix Handling

The script preserves version suffixes like -alpha, -beta:

  • Input version: 0.2.5-alpha
  • After patch: 0.2.6-alpha
  • Tag created: ghe-v0.2.6-alpha

Generated Release Body

markdown
## What's Changed

<your release notes>

## Installation

```bash
/plugin marketplace update my-marketplace
/plugin install ghe@my-marketplace

Full Changelog

https://github.com/owner/repo/compare/ghe-v0.5.3...ghe-v0.5.4


## Confirmation Prompt

The script prompts for confirmation before making changes:

Marketplace: my-marketplace Plugin: ghe Current version: 0.5.3 New version: 0.5.4

Proceed with release ghe-v0.5.4? [y/N]


## List Plugins Command

Use `--list` to see all plugins and their current versions:

```bash
$ python release.py --list

Marketplace: my-marketplace

Plugin                    Version         Source
----------------------------------------------------------------------
ghe                       0.5.4           ./plugins/ghe
marketplace-utils         1.0.0           ./plugins/marketplace-utils

Marketplace README Version Table

The release script automatically maintains a version table in the marketplace README.md:

markdown
<!-- PLUGIN-VERSIONS-START -->
## Plugin Versions

| Plugin | Version | Description |
|--------|---------|-------------|
| ghe | 0.5.4 | GHE (GitHub-Elements) - Automated project manag... |
| marketplace-utils | 1.0.0 | Portable utility tools for Claude Code plugin m... |

*Last updated: 2025-01-15*

<!-- PLUGIN-VERSIONS-END -->

This section is automatically:

  • Inserted before the Table of Contents (if no markers exist)
  • Updated in place (if markers already exist)
  • Kept current with each release

The main version badge in the README header is also updated to match the first plugin's version.

Troubleshooting

"Plugin validation failed"

The plugin has issues that must be fixed before release. Check the error message and fix the plugin.json or structure.

"marketplace.json not found"

Run from marketplace root directory, not plugin subdirectory.

"Unknown plugin: xyz"

Check plugin name matches exactly what's in marketplace.json. Use --list to see available plugins.

"Not authenticated with GitHub CLI"

Run gh auth login and authenticate.

"You have uncommitted changes"

Commit or stash changes, or proceed and include them in the release.

Portability

This script is fully portable:

  • All values read from JSON config files
  • GitHub repo info detected via gh repo view
  • No hardcoded paths, names, or user-specific values
  • Can be copied to any Claude Code marketplace project

Expand your agent's capabilities with these related and highly-rated skills.

aiskillstore/marketplace

perigon-backend

Perigon ASP.NET Core + EF Core + Aspire conventions

232 15
Explore
aiskillstore/marketplace

perigon-agent

Pointers for Copilot/agents to apply Perigon conventions

232 15
Explore
aiskillstore/marketplace

perigon-angular

Angular 21+ standalone/Material/signal conventions for Perigon WebApp

232 15
Explore
aiskillstore/marketplace

fastapi-mastery

Comprehensive FastAPI development skill covering REST API creation, routing, request/response handling, validation, authentication, database integration, middleware, and deployment. Use when working with FastAPI projects, building APIs, implementing CRUD operations, setting up authentication/authorization, integrating databases (SQL/NoSQL), adding middleware, handling WebSockets, or deploying FastAPI applications. Triggered by requests involving .py files with FastAPI code, API endpoint creation, Pydantic models, or FastAPI-specific features.

232 15
Explore
aiskillstore/marketplace

context7-efficient

Token-efficient library documentation fetcher using Context7 MCP with 86.8% token savings through intelligent shell pipeline filtering. Fetches code examples, API references, and best practices for JavaScript, Python, Go, Rust, and other libraries. Use when users ask about library documentation, need code examples, want API usage patterns, are learning a new framework, need syntax reference, or troubleshooting with library-specific information. Triggers include questions like "Show me React hooks", "How do I use Prisma", "What's the Next.js routing syntax", or any request for library/framework documentation.

232 15
Explore
aiskillstore/marketplace

browser-use

Browser automation using Playwright MCP. Navigate websites, fill forms, click elements, take screenshots, and extract data. Use when tasks require web browsing, form submission, web scraping, UI testing, or any browser interaction.

232 15
Explore

Didn't find tool you were looking for?

Be as detailed as possible for better results