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

anyapi-mcp-server

v1.8.1

Published

A universal MCP server that connects any REST API (via OpenAPI spec) to AI assistants, with GraphQL-style field selection and automatic schema inference.

Readme

anyapi-mcp-server

If it has an API, you can MCP it.

Traditional MCP servers hand-pick a handful of endpoints and call it a day — locking you into whatever subset someone decided was "enough." Why settle for a fraction of an API when you can have all of it?

anyapi-mcp-server is a universal MCP server that connects any REST API to AI assistants like Claude, Cursor, and other LLM-powered tools — just point it at an OpenAPI spec or Postman collection. Every endpoint the API provides becomes available instantly, with GraphQL-style field selection and automatic schema inference. No custom server code, no artificial limits.

npm

Quick start

1. Install

npm install -g anyapi-mcp-server

2. Add to your MCP client (Cursor, Claude Desktop, etc.)

{
  "mcpServers": {
    "your-api": {
      "command": "npx",
      "args": [
        "-y",
        "anyapi-mcp-server",
        "--name", "your-api",
        "--spec", "path/to/openapi.json",
        "--base-url", "https://api.example.com",
        "--header", "Authorization: Bearer ${API_KEY}"
      ],
      "env": {
        "API_KEY": "your-api-key"
      }
    }
  }
}

3. Use the tools — discover endpoints with list_api, inspect schemas with call_api, fetch data with query_api.

Provider examples

Ready-to-use configurations for popular APIs:

| Provider | Auth | |----------|------| | Cloudflare | API Token or Key + Email | | Datadog | API Key + App Key | | GitHub | Personal Access Token | | Google Workspace | OAuth 2.0 | | Metabase | API Key | | PostHog | Personal API Key | | Slack | Bot/User Token |

These work with any API that has an OpenAPI or Postman spec — the above are just examples. Stripe, Twilio, Shopify, HubSpot, and anything else with a REST API will work the same way.

CLI reference

Required flags

| Flag | Description | |------|-------------| | --name | Server name (e.g. cloudflare) | | --spec | Path or HTTPS URL to an OpenAPI spec (JSON/YAML) or Postman Collection. Remote URLs are cached locally. Supports ${ENV_VAR}. | | --base-url | API base URL (e.g. https://api.example.com). Supports ${ENV_VAR}. |

Optional flags

| Flag | Description | |------|-------------| | --header | HTTP header as "Key: Value" (repeatable). Supports ${ENV_VAR} in values. | | --log | Path to NDJSON request/response log. Sensitive headers are masked automatically. |

OAuth flags

For APIs that use OAuth 2.0 instead of static tokens. If any of the three required flags is provided, all three are required. All flags support ${ENV_VAR}.

| Flag | Required | Description | |------|----------|-------------| | --oauth-client-id | Yes* | OAuth client ID | | --oauth-client-secret | Yes* | OAuth client secret | | --oauth-token-url | Yes* | Token endpoint URL | | --oauth-auth-url | No | Authorization endpoint (auto-detected from spec if available) | | --oauth-scopes | No | Comma-separated scopes | | --oauth-flow | No | authorization_code (default) or client_credentials | | --oauth-param | No | Extra token parameter as key=value (repeatable) |

See the Google Workspace guide for a complete OAuth example.

Tools

The server exposes four tools (plus auth when OAuth is configured):

list_api — Browse endpoints

Discover what the API offers. Call with no arguments to see all categories, provide category to list endpoints in a tag, or search to find endpoints by keyword.

call_api — Inspect an endpoint

Makes a real HTTP request and returns the inferred GraphQL schema (SDL) — not the data itself. Use this to discover the response shape and get suggestedQueries you can copy into query_api. Also returns per-field token costs (fieldTokenCosts) and a dataKey for cache reuse. For PUT/PATCH requests, automatically creates a pre-write backup (returns backupDataKey). Supports bodyFile for large payloads and blocks requests with detected placeholder values.

query_api — Fetch data

Fetches data and returns only the fields you select via a GraphQL query. Supports both reads and writes (mutations for POST/PUT/DELETE/PATCH). Pass a dataKey from call_api to reuse cached data with zero HTTP calls.

# Read
{ items { id name status } _count }

# Write
mutation { post_endpoint(input: { name: "example" }) { id } }

Key parameters:

  • maxTokens — token budget for the response (default 4000). Arrays are truncated to fit.
  • dataKey — reuse cached data from a previous call_api or query_api response.
  • jsonFilter — dot-path to extract nested values after the GraphQL query (e.g. "data[].attributes.name").
  • bodyFile — absolute path to a JSON file to use as request body (mutually exclusive with body). Use for large payloads that can't be sent inline.
  • skipBackup — skip the automatic pre-write backup for PUT/PATCH requests (default: false).

explain_api — Read the docs

Returns spec documentation for an endpoint (parameters, request body schema, response codes) without making an HTTP request.

auth — OAuth authentication

Only available when --oauth-* flags are configured. Manages the OAuth flow:

  • action: "start" — returns an authorization URL (or exchanges credentials for client_credentials)
  • action: "exchange" — completes the authorization code flow (callback is captured automatically)
  • action: "status" — shows current token status

Tokens are persisted and refreshed automatically.

Typical workflow

list_api          → discover what's available
     ↓
explain_api       → read the docs for an endpoint
     ↓
call_api          → inspect the response schema (returns dataKey)
     ↓
query_api         → fetch exactly the fields you need (pass dataKey for zero HTTP calls)
     ↓
query_api         → re-query with different fields using the same dataKey

How it works

OpenAPI/Postman spec
        │
        ▼
   ┌─────────┐  ┌─────────────┐  ┌──────────┐  ┌───────────┐
   │list_api │  │ explain_api │  │ call_api │  │ query_api │
   │(browse) │  │   (docs)    │  │ (schema) │  │  (data)   │
   └─────────┘  └─────────────┘  └──────────┘  └───────────┘
        │          │ no HTTP          │               │
        ▼          ▼ request          ▼               ▼
   Spec index   Spec index     REST API call    dataKey cache
   (tags,       (params,       (with retry)     hit → no HTTP
    paths)       responses,         │            miss → fetch
                 body schema)       ▼               │
                               Infer schema +       ▼
                               return dataKey   Execute GraphQL
                                                + token budget
                                                  truncation

Features

  • Any REST API — provide an OpenAPI (JSON/YAML) or Postman Collection v2.x spec as a file or URL
  • Remote spec caching — HTTPS specs are fetched once and cached to ~/.cache/anyapi-mcp/
  • GraphQL field selection — query only the fields you need from any response
  • Schema inference — automatically builds GraphQL schemas from live API responses
  • Multi-sample merging — samples up to 10 array elements for richer schemas
  • Mutation support — write operations get typed GraphQL mutations from OpenAPI body schemas
  • Smart suggestionscall_api returns ready-to-use queries based on the inferred schema
  • Response caching — filesystem-based cache with 5-min TTL; dataKey tokens let query_api reuse data with zero HTTP calls
  • Token budgetquery_api accepts maxTokens (default 4000) and truncates array results to fit via binary search
  • Per-field token costscall_api returns a fieldTokenCosts tree so the LLM can make informed field selections
  • Rate limit tracking — parses X-RateLimit-* headers and warns when limits are nearly exhausted
  • Pagination detection — auto-detects cursor, next-page-token, and link-based pagination patterns in responses
  • JSON filterquery_api accepts a jsonFilter dot-path for post-query extraction (e.g. "data[].name")
  • Retry with backoff — automatic retries for 429/5xx with exponential backoff and Retry-After support
  • Multi-format — parses JSON, XML, CSV, and plain text responses
  • Safe writes — PUT/PATCH requests automatically snapshot the resource before writing (backupDataKey); placeholder values (e.g. PLACEHOLDER, TODO, file://) are detected and blocked before sending
  • File-based bodybodyFile parameter accepts an absolute path to a JSON file, enabling large payloads that can't be sent inline
  • Rich errors — structured error messages with status-specific suggestions and spec context for self-correction
  • OAuth 2.0 — Authorization Code (with PKCE) and Client Credentials flows with automatic token refresh
  • Env var interpolation${ENV_VAR} in base URLs, headers, and spec paths
  • Request logging — optional NDJSON log with sensitive header masking

Supported spec formats

  • OpenAPI 3.x (JSON or YAML)
  • OpenAPI 2.0 / Swagger (JSON or YAML)
  • Postman Collection v2.x (JSON)

License

Proprietary Non-Commercial. Free for personal and educational use. Commercial use requires written permission. See LICENSE for details.