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

@awssam/mcp-swagger

v1.0.1

Published

MCP server for exposing Swagger/OpenAPI documentation to AI models like Claude

Readme

@awssam/mcp-swagger

MCP (Model Context Protocol) server for exposing Swagger/OpenAPI documentation to AI models like Claude. This tool allows AI assistants to explore, understand, and interact with your API documentation seamlessly.

Features

  • 14 Powerful Tools for exploring API documentation
  • Automatic Caching for fast responses
  • OpenAPI 3.0 Support (Swagger 2.0 compatible)
  • Token-Optimized responses for efficient AI interactions
  • Search & Discovery with intelligent scoring
  • Path Validation with typo suggestions
  • Curl Generation with example payloads
  • Schema Analysis and reference tracking

Installation

npm install -g @awssam/mcp-swagger

Quick Start

Using with Claude Desktop

Add to your Claude Desktop configuration file:

MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json Windows: %APPDATA%\Claude\claude_desktop_config.json

{
  "mcpServers": {
    "swagger": {
      "command": "npx",
      "args": [
        "@awssam/mcp-swagger",
        "https://petstore.swagger.io/v2/swagger.json"
      ]
    }
  }
}

Using with Claude CLI (Claude Code)

Option 1: Using claude mcp add command (Recommended)

claude mcp add swagger npx @awssam/mcp-swagger https://petstore.swagger.io/v2/swagger.json

Option 2: Manual Configuration

Add to your Claude CLI configuration file:

Location: ~/.config/claude/config.yaml

mcpServers:
  swagger:
    command: npx
    args:
      - "@awssam/mcp-swagger"
      - "https://petstore.swagger.io/v2/swagger.json"

Or if installed globally:

mcpServers:
  swagger:
    command: mcp-swagger
    args:
      - "https://petstore.swagger.io/v2/swagger.json"

After adding the configuration, restart Claude CLI for the changes to take effect.

Using with Environment Variable

export API_URL=https://your-api.com/api-docs
npx @awssam/mcp-swagger

Using as CLI

npx @awssam/mcp-swagger https://your-api.com/api-docs

Available Tools

1. listEndpoints

Lists all available API endpoints with their HTTP methods and tags.

Parameters:

  • tag (optional): Filter by specific tag

Example:

{
  "tag": "users"
}

2. getEndpointDetails

Retrieves complete details of a specific endpoint including parameters, request body, responses, and schemas.

Parameters:

  • path (required): Endpoint path (e.g., /users/{id})
  • method (optional): HTTP method (get, post, put, delete, patch)

Example:

{
  "path": "/users/{id}",
  "method": "get"
}

3. searchEndpoints

Searches for endpoints by keyword in paths, descriptions, and tags. Results are sorted by relevance.

Parameters:

  • query (required): Search term

Example:

{
  "query": "authentication"
}

4. getSchemas

Retrieves data schemas (DTOs) defined in the API. Without parameters, lists all available schemas.

Parameters:

  • schemaName (optional): Specific schema name to retrieve

Example:

{
  "schemaName": "User"
}

5. listTags

Lists all tags used to categorize endpoints in the API.

6. getEndpointsByTag

Retrieves all endpoints associated with a specific tag.

Parameters:

  • tag (required): Tag name

Example:

{
  "tag": "authentication"
}

7. getApiInfo

Retrieves API metadata including title, version, description, servers, contact info, and license.

8. getSecuritySchemes

Lists authentication/authorization schemes available (OAuth2, API keys, Bearer tokens, etc.).

9. getServerUrls

Retrieves available server URLs and their environments (dev, staging, prod, etc.).

10. validateEndpointPath

Checks if an endpoint path exists. If not found, suggests similar paths to help with typos.

Parameters:

  • path (required): Endpoint path to validate

Example:

{
  "path": "/users/{id}"
}

11. getSchemaReferences

Finds all endpoints that use a specific schema. Useful for impact analysis when modifying schemas.

Parameters:

  • schemaName (required): Schema name to search for

Example:

{
  "schemaName": "User"
}

12. generateCurlExample

Generates a curl command example for a specific endpoint, including headers and sample request body.

Parameters:

  • path (required): Endpoint path
  • method (required): HTTP method

Example:

{
  "path": "/users",
  "method": "post"
}

13. getDeprecatedEndpoints

Lists all endpoints marked as deprecated. Useful for migration planning.

14. executeEndpoint

✨ NEW - Executes an API endpoint and returns the actual response. Automatically uses required headers from the Swagger spec. Perfect for testing endpoints and fetching real-time data.

Parameters:

  • path (required): Endpoint path (e.g., /users/{id})
  • method (required): HTTP method (get, post, put, delete, patch)
  • baseUrl (optional): Base server URL (uses Swagger default if not provided)
  • pathParams (optional): Path parameters object (e.g., {"id": "123"})
  • queryParams (optional): Query parameters object (e.g., {"page": 1, "perPage": 10})
  • headers (optional): Custom headers object (e.g., {"Authorization": "Bearer token"})
  • body (optional): Request body for POST/PUT/PATCH

Example:

{
  "path": "/admin/organizations",
  "method": "get",
  "baseUrl": "http://localhost:4000",
  "queryParams": {
    "page": 1,
    "perPage": 10
  },
  "headers": {
    "x-dev-code": "ILoveMom"
  }
}

Response includes:

  • success: Boolean indicating if request succeeded
  • status: HTTP status code
  • statusText: HTTP status message
  • data: Response body (parsed JSON or text)
  • headers: Response headers
  • url: Full URL that was called
  • method: HTTP method used

Project Structure

src/
├── index.js                 # Entry point & server setup
├── config.js               # Configuration management
├── swagger/
│   ├── fetcher.js          # Swagger doc fetching & caching
│   └── parser.js           # Endpoint, schema, and tag parsing
└── tools/
    ├── definitions.js      # Tool schemas & definitions
    └── handlers.js         # Tool request handlers

Configuration

The server accepts the API URL in three ways (in order of precedence):

  1. Command-line argument: npx @awssam/mcp-swagger <URL>
  2. Environment variable: export API_URL=<URL>
  3. Default: http://localhost:3000/api-json

Requirements

  • Node.js >= 18.0.0
  • Valid Swagger/OpenAPI JSON or YAML endpoint

Use Cases

  • API Exploration: Let AI understand and navigate your API
  • Documentation Assistance: Get instant answers about endpoints
  • Code Generation: Generate curl commands and examples
  • Migration Planning: Find deprecated endpoints
  • Impact Analysis: Track schema usage across endpoints
  • Developer Onboarding: Quick API discovery and learning

Development

# Clone the repository
git clone https://github.com/awssam/mcp-swagger.git
cd mcp-swagger

# Install dependencies
npm install

# Run locally
npm start https://petstore.swagger.io/v2/swagger.json

License

MIT

Contributing

Contributions are welcome! Please open an issue or submit a pull request.

Support

  • Issues: https://github.com/awssam/mcp-swagger/issues
  • Author: Awssam Saidi

Related Projects