npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@playlist-tech/enterprise-skills

v1.5.10-enterprise.6

Published

An enterprise-customizable fork of Vercel Labs' skills CLI for internal skill registries.

Readme

@playlist-tech/enterprise-skills

Enterprise fork of Vercel Labs' skills CLI, adding support for private/internal skill registries and custom telemetry while we wait for those features upstream.

[!NOTE] This is Playlist Tech's fork of vercel-labs/skills. The main branch tracks upstream. Enterprise features and the published @playlist-tech/enterprise-skills npm package live on the enterprise branch.

Supports OpenCode, Claude Code, Codex, Cursor, and 51 more.

[!NOTE] This is a Playlist Tech enterprise fork. It is API-compatible with the upstream skills CLI — all commands and flags work the same way. Use it instead of npx skills when you need to pull skills from a private/internal registry or route telemetry to your own endpoint.

Upstream repo: vercel-labs/skills — we track upstream releases and version as <upstream-version>-enterprise.<n> (e.g. 1.5.6-enterprise.0).

Install a Skill

npx @playlist-tech/enterprise-skills add your-org/your-skills-repo

Source Formats

# GitHub shorthand (owner/repo)
npx @playlist-tech/enterprise-skills add your-org/your-skills-repo

# Full GitHub URL
npx @playlist-tech/enterprise-skills add https://github.com/your-org/your-skills-repo

# Direct path to a skill in a repo
npx @playlist-tech/enterprise-skills add https://github.com/your-org/your-skills-repo/tree/main/skills/my-skill

# GitLab URL
npx @playlist-tech/enterprise-skills add https://gitlab.com/org/repo

# Any git URL
npx @playlist-tech/enterprise-skills add [email protected]:your-org/your-skills-repo.git

# Local path
npx @playlist-tech/enterprise-skills add ./my-local-skills

The skills and add-skill binary aliases are also available for drop-in compatibility with scripts written against the upstream CLI.

Options

| Option | Description | | ------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------- | | -g, --global | Install to user directory instead of project | | -a, --agent <agents...> | Target specific agents (e.g., claude-code, codex). See Supported Agents | | -s, --skill <skills...> | Install specific skills by name (use '*' for all skills) | | -l, --list | List available skills without installing | | --copy | Copy files instead of symlinking to agent directories | | -y, --yes | Skip all confirmation prompts | | --all | Install all skills to all agents without prompts |

Examples

# List skills in a repository
npx @playlist-tech/enterprise-skills add your-org/your-skills-repo --list

# Install specific skills
npx @playlist-tech/enterprise-skills add your-org/your-skills-repo --skill my-skill --skill another-skill

# Install a skill with spaces in the name (must be quoted)
npx @playlist-tech/enterprise-skills add owner/repo --skill "Convex Best Practices"

# Install to specific agents
npx @playlist-tech/enterprise-skills add your-org/your-skills-repo -a claude-code -a opencode

# Non-interactive installation (CI/CD friendly)
npx @playlist-tech/enterprise-skills add your-org/your-skills-repo --skill my-skill -g -a claude-code -y

# Install all skills from a repo to all agents
npx @playlist-tech/enterprise-skills add your-org/your-skills-repo --all

# Install all skills to specific agents
npx @playlist-tech/enterprise-skills add your-org/your-skills-repo --skill '*' -a claude-code

# Install specific skills to all agents
npx @playlist-tech/enterprise-skills add your-org/your-skills-repo --agent '*' --skill my-skill

Installation Scope

| Scope | Flag | Location | Use Case | | ----------- | --------- | ------------------- | --------------------------------------------- | | Project | (default) | ./<agent>/skills/ | Committed with your project, shared with team | | Global | -g | ~/<agent>/skills/ | Available across all projects |

Installation Methods

When installing interactively, you can choose:

| Method | Description | | ------------------------- | ------------------------------------------------------------------------------------------- | | Symlink (Recommended) | Creates symlinks from each agent to a canonical copy. Single source of truth, easy updates. | | Copy | Creates independent copies for each agent. Use when symlinks aren't supported. |

Other Commands

| Command | Description | | ------------------------------------------------------------- | --------------------------------------------- | | npx @playlist-tech/enterprise-skills list | List installed skills (alias: ls) | | npx @playlist-tech/enterprise-skills find [query] | Search for skills interactively or by keyword | | npx @playlist-tech/enterprise-skills remove [skills] | Remove installed skills from agents | | npx @playlist-tech/enterprise-skills update [skills] | Update installed skills to latest versions | | npx @playlist-tech/enterprise-skills init [name] | Create a new SKILL.md template |

skills list

List all installed skills. Similar to npm ls.

# List all installed skills (project and global)
npx @playlist-tech/enterprise-skills list

# List only global skills
npx @playlist-tech/enterprise-skills ls -g

# Filter by specific agents
npx @playlist-tech/enterprise-skills ls -a claude-code -a cursor

skills find

Search for skills interactively or by keyword.

# Interactive search (fzf-style)
npx @playlist-tech/enterprise-skills find

# Search by keyword
npx @playlist-tech/enterprise-skills find typescript

skills update

# Update all skills (interactive scope prompt)
npx @playlist-tech/enterprise-skills update

# Update a single skill by name
npx @playlist-tech/enterprise-skills update my-skill

# Update multiple specific skills
npx @playlist-tech/enterprise-skills update frontend-design web-design-guidelines

# Update only global or project skills
npx @playlist-tech/enterprise-skills update -g
npx @playlist-tech/enterprise-skills update -p

# Non-interactive (auto-detects scope: project if in a project, else global)
npx @playlist-tech/enterprise-skills update -y

| Option | Description | | --------------- | ------------------------------------------------------------------------- | | -g, --global | Only update global skills | | -p, --project | Only update project skills | | -y, --yes | Skip scope prompt (auto-detect: project if in a project dir, else global) | | [skills...] | Update specific skills by name instead of all |

skills init

# Create SKILL.md in current directory
npx @playlist-tech/enterprise-skills init

# Create a new skill in a subdirectory
npx @playlist-tech/enterprise-skills init my-skill

skills remove

Remove installed skills from agents.

# Remove interactively (select from installed skills)
npx @playlist-tech/enterprise-skills remove

# Remove specific skill by name
npx @playlist-tech/enterprise-skills remove web-design-guidelines

# Remove multiple skills
npx @playlist-tech/enterprise-skills remove frontend-design web-design-guidelines

# Remove from global scope
npx @playlist-tech/enterprise-skills remove --global web-design-guidelines

# Remove from specific agents only
npx @playlist-tech/enterprise-skills remove --agent claude-code cursor my-skill

# Remove all installed skills without confirmation
npx @playlist-tech/enterprise-skills remove --all

# Remove all skills from a specific agent
npx @playlist-tech/enterprise-skills remove --skill '*' -a cursor

# Remove a specific skill from all agents
npx @playlist-tech/enterprise-skills remove my-skill --agent '*'

# Use 'rm' alias
npx @playlist-tech/enterprise-skills rm my-skill

| Option | Description | | -------------- | ------------------------------------------------ | | -g, --global | Remove from global scope (~/) instead of project | | -a, --agent | Remove from specific agents (use '*' for all) | | -s, --skill | Specify skills to remove (use '*' for all) | | -y, --yes | Skip confirmation prompts | | --all | Shorthand for --skill '*' --agent '*' -y |

What are Agent Skills?

Agent skills are reusable instruction sets that extend your coding agent's capabilities. They're defined in SKILL.md files with YAML frontmatter containing a name and description.

Skills let agents perform specialized tasks like:

  • Generating release notes from git history
  • Creating PRs following your team's conventions
  • Integrating with external tools (Linear, Notion, etc.)

Discover public skills at skills.sh

Supported Agents

Skills can be installed to any of these agents:

| Agent | --agent | Project Path | Global Path | | ------------------------------------- | ---------------------------------------- | ------------------------ | ------------------------------- | | AiderDesk | aider-desk | .aider-desk/skills/ | ~/.aider-desk/skills/ | | Amp, Kimi Code CLI, Replit, Universal | amp, kimi-cli, replit, universal | .agents/skills/ | ~/.config/agents/skills/ | | Antigravity | antigravity | .agents/skills/ | ~/.gemini/antigravity/skills/ | | Augment | augment | .augment/skills/ | ~/.augment/skills/ | | IBM Bob | bob | .bob/skills/ | ~/.bob/skills/ | | Claude Code | claude-code | .claude/skills/ | ~/.claude/skills/ | | OpenClaw | openclaw | skills/ | ~/.openclaw/skills/ | | Cline, Dexto, Warp | cline, dexto, warp | .agents/skills/ | ~/.agents/skills/ | | CodeArts Agent | codearts-agent | .codeartsdoer/skills/ | ~/.codeartsdoer/skills/ | | CodeBuddy | codebuddy | .codebuddy/skills/ | ~/.codebuddy/skills/ | | Codemaker | codemaker | .codemaker/skills/ | ~/.codemaker/skills/ | | Code Studio | codestudio | .codestudio/skills/ | ~/.codestudio/skills/ | | Codex | codex | .agents/skills/ | ~/.codex/skills/ | | Command Code | command-code | .commandcode/skills/ | ~/.commandcode/skills/ | | Continue | continue | .continue/skills/ | ~/.continue/skills/ | | Cortex Code | cortex | .cortex/skills/ | ~/.snowflake/cortex/skills/ | | Crush | crush | .crush/skills/ | ~/.config/crush/skills/ | | Cursor | cursor | .agents/skills/ | ~/.cursor/skills/ | | Deep Agents | deepagents | .agents/skills/ | ~/.deepagents/agent/skills/ | | Devin for Terminal | devin | .devin/skills/ | ~/.config/devin/skills/ | | Droid | droid | .factory/skills/ | ~/.factory/skills/ | | Firebender | firebender | .agents/skills/ | ~/.firebender/skills/ | | ForgeCode | forgecode | .forge/skills/ | ~/.forge/skills/ | | Gemini CLI | gemini-cli | .agents/skills/ | ~/.gemini/skills/ | | GitHub Copilot | github-copilot | .agents/skills/ | ~/.copilot/skills/ | | Goose | goose | .goose/skills/ | ~/.config/goose/skills/ | | Hermes Agent | hermes-agent | .hermes/skills/ | ~/.hermes/skills/ | | Junie | junie | .junie/skills/ | ~/.junie/skills/ | | iFlow CLI | iflow-cli | .iflow/skills/ | ~/.iflow/skills/ | | Kilo Code | kilo | .kilocode/skills/ | ~/.kilocode/skills/ | | Kiro CLI | kiro-cli | .kiro/skills/ | ~/.kiro/skills/ | | Kode | kode | .kode/skills/ | ~/.kode/skills/ | | MCPJam | mcpjam | .mcpjam/skills/ | ~/.mcpjam/skills/ | | Mistral Vibe | mistral-vibe | .vibe/skills/ | ~/.vibe/skills/ | | Mux | mux | .mux/skills/ | ~/.mux/skills/ | | OpenCode | opencode | .agents/skills/ | ~/.config/opencode/skills/ | | OpenHands | openhands | .openhands/skills/ | ~/.openhands/skills/ | | Pi | pi | .pi/skills/ | ~/.pi/agent/skills/ | | Qoder | qoder | .qoder/skills/ | ~/.qoder/skills/ | | Qwen Code | qwen-code | .qwen/skills/ | ~/.qwen/skills/ | | Rovo Dev | rovodev | .rovodev/skills/ | ~/.rovodev/skills/ | | Roo Code | roo | .roo/skills/ | ~/.roo/skills/ | | Tabnine CLI | tabnine-cli | .tabnine/agent/skills/ | ~/.tabnine/agent/skills/ | | Trae | trae | .trae/skills/ | ~/.trae/skills/ | | Trae CN | trae-cn | .trae/skills/ | ~/.trae-cn/skills/ | | Windsurf | windsurf | .windsurf/skills/ | ~/.codeium/windsurf/skills/ | | Zencoder | zencoder | .zencoder/skills/ | ~/.zencoder/skills/ | | Neovate | neovate | .neovate/skills/ | ~/.neovate/skills/ | | Pochi | pochi | .pochi/skills/ | ~/.pochi/skills/ | | AdaL | adal | .adal/skills/ | ~/.adal/skills/ |

[!NOTE] Kiro CLI users: The default agent automatically loads skills from .kiro/skills/ and ~/.kiro/skills/ — no configuration needed. If you use a custom agent, add skills to its resources in .kiro/agents/<agent>.json:

{
  "resources": ["skill://.kiro/skills/**/SKILL.md"]
}

The CLI automatically detects which coding agents you have installed. If none are detected, you'll be prompted to select which agents to install to.

Creating Skills

Skills are directories containing a SKILL.md file with YAML frontmatter:

---
name: my-skill
description: What this skill does and when to use it
---

# My Skill

Instructions for the agent to follow when this skill is activated.

## When to Use

Describe the scenarios where this skill should be used.

## Steps

1. First, do this
2. Then, do that

Required Fields

  • name: Unique identifier (lowercase, hyphens allowed)
  • description: Brief explanation of what the skill does

Optional Fields

  • metadata.internal: Set to true to hide the skill from normal discovery. Internal skills are only visible and installable when INSTALL_INTERNAL_SKILLS=1 is set. Useful for work-in-progress skills or skills meant only for internal tooling.
---
name: my-internal-skill
description: An internal skill not shown by default
metadata:
  internal: true
---

Skill Discovery

The CLI searches for skills in these locations within a repository. Each skill container directory is walked one level deep for the common flat layout (skills/<name>/SKILL.md) and one extra level deep for catalog layouts (skills/<category>/<name>/SKILL.md). A SKILL.md discovered at the shallower level shadows anything nested below it. Use --full-depth to also discover SKILL.md files outside these container directories (e.g. under examples/ or tests/).

  • Root directory (if it contains SKILL.md)
  • skills/
  • skills/.curated/
  • skills/.experimental/
  • skills/.system/
  • .aider-desk/skills/
  • .agents/skills/
  • .augment/skills/
  • .bob/skills/
  • .claude/skills/
  • .codeartsdoer/skills/
  • .codebuddy/skills/
  • .codemaker/skills/
  • .codestudio/skills/
  • .commandcode/skills/
  • .continue/skills/
  • .cortex/skills/
  • .crush/skills/
  • .devin/skills/
  • .factory/skills/
  • .forge/skills/
  • .goose/skills/
  • .hermes/skills/
  • .junie/skills/
  • .iflow/skills/
  • .kilocode/skills/
  • .kiro/skills/
  • .kode/skills/
  • .mcpjam/skills/
  • .vibe/skills/
  • .mux/skills/
  • .openhands/skills/
  • .pi/skills/
  • .qoder/skills/
  • .qwen/skills/
  • .rovodev/skills/
  • .roo/skills/
  • .tabnine/agent/skills/
  • .trae/skills/
  • .windsurf/skills/
  • .zencoder/skills/
  • .neovate/skills/
  • .pochi/skills/
  • .adal/skills/

Plugin Manifest Discovery

If .claude-plugin/marketplace.json or .claude-plugin/plugin.json exists, skills declared in those files are also discovered:

// .claude-plugin/marketplace.json
{
  "metadata": { "pluginRoot": "./plugins" },
  "plugins": [
    {
      "name": "my-plugin",
      "source": "my-plugin",
      "skills": ["./skills/review", "./skills/test"]
    }
  ]
}

This enables compatibility with the Claude Code plugin marketplace ecosystem. Skill paths declared in a manifest are searched at their declared depth and are not subject to the depth-2 catalog walk described above.

If no skills are found in standard locations, a recursive search is performed.

Compatibility

Skills are generally compatible across agents since they follow a shared Agent Skills specification. However, some features may be agent-specific:

| Feature | OpenCode | OpenHands | Claude Code | Cline | CodeBuddy | Codex | Command Code | Kiro CLI | Cursor | Antigravity | Roo Code | Github Copilot | Amp | OpenClaw | Neovate | Pi | Qoder | Zencoder | | --------------- | -------- | --------- | ----------- | ----- | --------- | ----- | ------------ | -------- | ------ | ----------- | -------- | -------------- | --- | -------- | ------- | --- | ----- | -------- | | Basic skills | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | | allowed-tools | Yes | Yes | Yes | Yes | Yes | Yes | Yes | No | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | Yes | No | | context: fork | No | No | Yes | No | No | No | No | No | No | No | No | No | No | No | No | No | No | No | | Hooks | No | No | Yes | Yes | No | No | No | Yes | No | No | No | No | No | No | No | No | No | No |

Troubleshooting

"No skills found"

Ensure the repository contains valid SKILL.md files with both name and description in the frontmatter.

Skill not loading in agent

  • Verify the skill was installed to the correct path
  • Check the agent's documentation for skill loading requirements
  • Ensure the SKILL.md frontmatter is valid YAML

Permission errors

Ensure you have write access to the target directory.

Environment Variables

| Variable | Description | | ------------------------- | -------------------------------------------------------------------------- | | INSTALL_INTERNAL_SKILLS | Set to 1 or true to show and install skills marked as internal: true | | DISABLE_TELEMETRY | Set to disable anonymous usage telemetry | | DO_NOT_TRACK | Alternative way to disable telemetry | | SKILLS_TELEMETRY_URL | Override the telemetry endpoint (e.g. for self-hosted/internal install metrics) | | SKILLS_TELEMETRY_ALLOW_PRIVATE | Set to 1 to allow install/remove events from private/internal sources (only honored with a custom endpoint) |

# Install internal skills
INSTALL_INTERNAL_SKILLS=1 npx @playlist-tech/enterprise-skills add your-org/your-skills-repo --list

Telemetry

This CLI collects anonymous usage data to help improve the tool. No personal information is collected.

Telemetry is automatically disabled in CI environments.

Related Links

License

MIT