Skip to content

evalops/mcp-openapi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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

Consume as a library from GitHub:

npm install github:evalops/mcp-openapi

Library Usage

import { parseSpec, generateToolsWithTags } from "mcp-openapi";

const normalized = await parseSpec("./openapi.yaml");
const generated = generateToolsWithTags(normalized, { prefix: "github" });

console.log(generated.tools[0]?.name);

The library entrypoint exports:

  • parseSpec
  • generateTools
  • generateToolsWithTags
  • NormalizedSpec

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

About

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

Topics

Resources

Stars

Watchers

Forks

Packages

 
 
 

Contributors