MCP Servers

A collection of Model Context Protocol servers, templates, tools and more.

OpenAPI 3.x to MCP server bridge in TypeScript with stdio, StreamableHTTP, and SSE transports

Created 2/13/2026
Updated about 9 hours ago
Repository documentation and setup instructions

mcp-openapi

OpenAPI 3.x to MCP server bridge in TypeScript.

mcp-openapi takes an OpenAPI spec and turns it into an MCP server where each OpenAPI operation is an MCP tool. Tool calls are proxied to the original REST API with runtime validation and auth handling.

Capabilities

  • OpenAPI 3.0+ support (YAML/JSON, $ref dereference, operation compilation)
  • Proxy behavior to upstream REST API
  • Authentication via env vars:
    • API keys (in: header|query|cookie)
    • HTTP Bearer
    • HTTP Basic
    • OAuth2 / OpenID Connect (static token or client credentials token fetch)
  • Runtime validation:
    • Zod validation generated from OpenAPI-derived JSON Schema
    • AJV JSON Schema validation
    • Response schema validation by HTTP status
  • Typed TypeScript implementation
  • Strict lint mode for OpenAPI quality gates (--strict)
  • Configurable tool naming template (--tool-name-template)
  • Policy engine:
    • allow/deny tool patterns
    • allow methods/path prefixes
    • allow hosts
  • Optional response transform hook (--response-transform <module>)
  • Multiple transports:
    • stdio
    • streamable-http (Hono)
    • sse (legacy compatibility transport)
  • Transport hardening:
    • graceful shutdown
    • SSE session caps/TTL
  • Observability:
    • Prometheus metrics
    • status counters
    • latency histogram buckets
  • Built-in browser test clients:
    • /test/streamable
    • /test/sse
  • Project scaffold (init) that generates:
    • package.json
    • tsconfig.json
    • src/server.ts
    • .env.example
    • README.md
    • Dockerfile

Install

npm install

Run

stdio

npm run dev -- --spec ./openapi.yaml

StreamableHTTP

npm run dev -- --spec ./openapi.yaml --transport streamable-http --port 3000

Endpoints:

  • http://localhost:3000/health
  • http://localhost:3000/metrics
  • http://localhost:3000/mcp
  • http://localhost:3000/test/streamable

SSE (legacy)

npm run dev -- --spec ./openapi.yaml --transport sse --port 3000

Endpoints:

  • http://localhost:3000/health
  • http://localhost:3000/metrics
  • http://localhost:3000/sse
  • http://localhost:3000/messages?sessionId=...
  • http://localhost:3000/test/sse

CLI

mcp-openapi --spec <openapi-file> [options]
mcp-openapi init [dir]
mcp-openapi generate --spec <openapi-file> [--out-dir ./generated]

Options:

  • --server-url <url>
  • --cache-path <file>
  • --out-dir <dir>
  • --strict
  • --tool-name-template <template>
  • --print-tools
  • --validate-spec
  • --transport stdio|streamable-http|sse
  • --port <n>
  • --watch-spec
  • --timeout-ms <ms>
  • --retries <n>
  • --retry-delay-ms <ms>
  • --max-response-bytes <n>
  • --max-concurrency <n>
  • --allow-hosts host1,host2
  • --allow-tools pattern1,pattern2
  • --deny-tools pattern1,pattern2
  • --allow-methods GET,POST
  • --allow-path-prefixes /v1,/public
  • --response-transform <module-path>
  • --sse-max-sessions <n>
  • --sse-session-ttl-ms <ms>

Template placeholders for --tool-name-template:

  • {operationId}
  • {method}
  • {path}
  • {tag}

Response transform module example:

export default function transform({ operation, response }) {
  return { ...response.body, transformedBy: operation.operationId };
}

Auth env vars

  • MCP_OPENAPI_API_KEY
  • MCP_OPENAPI_BEARER_TOKEN
  • MCP_OPENAPI_BASIC_USERNAME
  • MCP_OPENAPI_BASIC_PASSWORD
  • MCP_OPENAPI_OAUTH2_ACCESS_TOKEN
  • MCP_OPENAPI_OAUTH2_CLIENT_ID
  • MCP_OPENAPI_OAUTH2_CLIENT_SECRET
  • MCP_OPENAPI_<SCHEME_NAME>_TOKEN
  • MCP_OPENAPI_<SCHEME_NAME>_CLIENT_ID
  • MCP_OPENAPI_<SCHEME_NAME>_CLIENT_SECRET

Build and verify

npm run check
npm run build
npm test
npm run smoke
Quick Setup
Installation guide for this server

Install Package (if required)

npx @modelcontextprotocol/server-mcp-openapi

Cursor configuration (mcp.json)

{ "mcpServers": { "haasonsaas-mcp-openapi": { "command": "npx", "args": [ "haasonsaas-mcp-openapi" ] } } }