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

skills-as-mcp

v0.2.0

Published

Expose Claude-style skills as an MCP server over stdio, Streamable HTTP, or legacy SSE.

Downloads

193

Readme

skills-as-mcp

skills-as-mcp is a TypeScript MCP server that turns Claude-style skill folders into MCP tools, resources, and prompts.

It is inspired by the Python project biocontext-ai/skill-to-mcp, but built for the TypeScript ecosystem and aligned with the official Model Context Protocol server guidance.

What it does

  • Recursively discovers SKILL.md files from one or many skill roots
  • Parses YAML frontmatter for name and description
  • Exposes three Python-compatible tools:
    • get_available_skills
    • get_skill_details
    • get_skill_related_file
  • Exposes MCP resources for the catalog and each discovered skill
  • Exposes a use_skill prompt for clients that support prompts
  • Supports:
    • stdio for local coding tools and desktop clients
    • http for Streamable HTTP on /mcp
    • sse for a compatibility server that exposes /mcp, /sse, and /messages

Installation

Run it directly with npx:

npx skills-as-mcp --skills-dir /absolute/path/to/skills --type stdio

Or install it into a project:

npm install skills-as-mcp

Quick Start

1. Create a skill directory

Your skills can live anywhere. Each skill needs its own directory and a SKILL.md file with frontmatter:

my-skills/
└── release-helper/
    ├── SKILL.md
    ├── references/
    └── scripts/
---
name: release-helper
description: Helps prepare package releases and changelogs.
---

# Release Helper

Instructions go here...

2. Run as a local MCP server

npx skills-as-mcp --skills-dir /absolute/path/to/my-skills --type stdio

3. Run as a remote server

Streamable HTTP only:

npx skills-as-mcp --skills-dir /absolute/path/to/my-skills --type http --host 0.0.0.0 --port 3000

Compatibility mode with legacy SSE:

npx skills-as-mcp --skills-dir /absolute/path/to/my-skills --type sse --host 0.0.0.0 --port 3000

In sse mode the server exposes:

  • /mcp for Streamable HTTP clients
  • /sse for legacy SSE clients
  • /messages for legacy POST requests

CLI Reference

npx skills-as-mcp --skills-dir <path> [--skills-dir <path> ...] --type <stdio|http|sse>

Options

  • --skills-dir <path>: Add a skill root. Repeat the flag to load multiple roots.
  • --type <stdio|http|sse>: Select the transport mode.
  • --host <host>: Host interface for HTTP modes. Default: 127.0.0.1.
  • --port <port>: Port for HTTP modes. Default: 3000.

Environment variables

  • SKILLS_DIR: Single skill root
  • SKILLS_DIRS: Multiple skill roots joined by your OS path delimiter
  • SKILLS_AS_MCP_TYPE: Same values as --type
  • SKILLS_AS_MCP_HOST: Same as --host
  • SKILLS_AS_MCP_PORT: Same as --port

SKILLS_DIRS uses : on macOS/Linux and ; on Windows.

MCP Surface Area

Tools

get_available_skills

  • Returns every discovered skill with name, description, and path

get_skill_details

  • Returns the SKILL.md content and the recursive file listing for a skill
  • Supports return_type values of content, file_path, and both

get_skill_related_file

  • Reads a specific file inside a skill directory
  • Blocks directory traversal outside the skill root
  • Supports return_type values of content, file_path, and both

Resources

  • skills://catalog
  • skills://<skill-name>

Prompts

  • use_skill

Example MCP Client Config

For clients that spawn local MCP servers over stdio, the shape is typically:

{
  "mcpServers": {
    "skills-as-mcp": {
      "command": "npx",
      "args": [
        "skills-as-mcp",
        "--skills-dir",
        "/absolute/path/to/my-skills",
        "--type",
        "stdio"
      ]
    }
  }
}

For multiple skill roots:

{
  "mcpServers": {
    "skills-as-mcp": {
      "command": "npx",
      "args": [
        "skills-as-mcp",
        "--skills-dir",
        "/absolute/path/to/team-skills",
        "--skills-dir",
        "/absolute/path/to/project-skills",
        "--type",
        "stdio"
      ]
    }
  }
}

Included Example

An example skill is included at examples/skills/example-skill/SKILL.md so you can try the package immediately:

npx skills-as-mcp --skills-dir ./examples/skills --type stdio

Library Usage

You can also import the core pieces directly:

import { SkillRegistry, createSkillsMcpServer } from "skills-as-mcp";

const registry = await SkillRegistry.fromSkillRoots(["./examples/skills"]);
const server = createSkillsMcpServer({ registry });

Development

npm install
npm run lint
npm test
npm run build

Useful commands:

  • npm run dev -- --skills-dir ./examples/skills --type stdio
  • npm run dev -- --skills-dir ./examples/skills --type http --port 3000
  • npm run dev -- --skills-dir ./examples/skills --type sse --port 3000

Publishing

The repo includes:

  • CI workflow for lint, test, and build on pushes and pull requests
  • Release workflow that publishes to npm on v* tags

To publish from GitHub Actions, set NPM_TOKEN in repository secrets.

Notes

  • Invalid skills are skipped with warnings instead of crashing the whole server.
  • Duplicate skill names across roots are treated as a startup error.
  • In stdio mode all human-readable logs go to stderr so MCP traffic on stdout stays clean.