Caitlyn OpenAPI MCP Server

Caitlyn OpenAPI MCP Server

Exposes OpenAPI specifications as queryable documentation resources for LLMs, enabling semantic search, endpoint details, and deep links to Scalar docs.

Category
Visit Server

README

Caitlyn OpenAPI MCP Server

MCP server that exposes OpenAPI specifications as queryable documentation resources for LLMs, with Scalar deep links.

Features

  • URL-based OpenAPI spec loading: Load specs from any URL, not just local files
  • $ref resolution: Automatically resolves all $ref references (including remote refs) using Prance
  • Semantic search: Vector-based endpoint search using sentence-transformers for better query understanding
  • Scalar deep links: Every endpoint, schema, and security scheme includes a docs_url pointing to Scalar documentation
  • MCP resources: Expose spec structure for introspection
  • MCP tools: Search and query endpoints, schemas, and security schemes
  • Streamable HTTP: Built for Bedrock AgentCore integration

Installation

Using uvx (recommended)

For isolated execution without global installation:

uvx caitlyn-openapi-mcp

Using pip

Install from PyPI:

pip install caitlyn-openapi-mcp

From source

For local development or testing:

git clone https://github.com/caitlyn-ai/caitlyn-openapi-mcp.git
cd caitlyn-openapi-mcp
pip install -e ".[dev]"

Configuration

The server is configured via environment variables:

Required

  • OPENAPI_SPEC_URL: Full URL to the OpenAPI JSON/YAML specification
    • Example: https://api.example.com/openapi.json
    • Example: https://raw.githubusercontent.com/org/repo/main/openapi.yaml

Optional

  • DOCS_RENDERER: Documentation renderer type (default: "scalar")

    • Currently only "scalar" is supported
  • DOCS_BASE_URL: Base URL of the Scalar documentation UI

    • Example: https://api.example.com/docs
    • Example: https://api.example.com/scalar
    • If not provided, docs_url fields will be null
  • MCP_TRANSPORT: Transport mode (default: "stdio")

    • "stdio": For local development and Claude Desktop (default)
    • "streamable-http": For AWS Bedrock AgentCore deployment

OpenTelemetry (Optional)

For observability in production environments. See TELEMETRY.md for complete documentation including local development setup with Jaeger.

Local Development:

The make dev command automatically starts an OTEL Collector with Jaeger UI for visualizing traces:

# Start dev environment with OTEL collector + Jaeger
make dev

# View traces and logs in Jaeger UI
open http://localhost:16686

General OTEL Configuration:

  • ENABLE_TELEMETRY: Enable/disable telemetry (default: "true")
  • OTEL_SERVICE_NAME: Service name for tracing (default: "caitlyn-openapi-mcp")
  • OTEL_EXPORTER_OTLP_ENDPOINT: OTLP endpoint for traces (e.g., "http://localhost:4317")

AWS Bedrock AgentCore (ADOT):

The Docker image includes AWS Distro for OpenTelemetry (ADOT) for native AgentCore integration. When deployed to AgentCore, traces are automatically exported to CloudWatch.

Pre-configured environment variables (already set in Dockerfile):

  • OTEL_PYTHON_DISTRO=aws_distro
  • OTEL_PYTHON_CONFIGURATOR=aws_configurator
  • OTEL_TRACES_EXPORTER=otlp
  • OTEL_EXPORTER_OTLP_PROTOCOL=http/protobuf

Additional variables for non-AgentCore hosted deployment:

  • AWS_DEFAULT_REGION, AWS_REGION: AWS region
  • AWS_ACCOUNT_ID, AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY: AWS credentials
  • ENABLE_TELEMETRY=true: Enable OpenTelemetry observability

Instrumented operations:

  • OpenAPI spec loading (with granular cache/fetch/parse/extract spans)
  • Vector search (model loading, embedding generation, cache operations)
  • Semantic search queries (encoding, similarity computation, ranking)
  • MCP protocol (list_tools, list_resources, call_tool)
  • All Python logging is captured as OTEL log records

Client Configuration

1. Claude Desktop with uvx (Recommended)

The easiest way to use this server with Claude Desktop. No installation required - uvx automatically downloads and runs the package.

Config file location:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json
{
  "mcpServers": {
    "openapi-docs": {
      "command": "uvx",
      "args": ["caitlyn-openapi-mcp"],
      "env": {
        "OPENAPI_SPEC_URL": "https://api.example.com/openapi.json",
        "DOCS_BASE_URL": "https://api.example.com/docs"
      }
    }
  }
}

2. Claude Desktop with Local Development

For testing local changes to the server code.

Prerequisites: Clone the repo and install in development mode (see Local Development)

{
  "mcpServers": {
    "openapi-docs": {
      "command": "python",
      "args": ["-m", "openapi_mcp.server"],
      "env": {
        "OPENAPI_SPEC_URL": "https://api.example.com/openapi.json",
        "DOCS_BASE_URL": "https://api.example.com/docs"
      }
    }
  }
}

Note: Use the full path to Python if it's not in your PATH: "/usr/local/bin/python3.11"

3. MCP Inspector for Local Development

For interactive testing with a web UI before deploying to Claude Desktop.

Prerequisites:

  • Clone and install in development mode (see Local Development)
  • Node.js installed (npx comes with Node.js)

Quick start:

make dev

Or manually set your own API:

npx @modelcontextprotocol/inspector \
  -e OPENAPI_SPEC_URL="https://api.example.com/openapi.json" \
  -e DOCS_BASE_URL="https://api.example.com/docs" \
  python -m openapi_mcp.server

See Testing with MCP Inspector for more details.

4. AWS Bedrock AgentCore

Deploy as a containerized service with streamable-http transport and AWS Distro for OpenTelemetry (ADOT) for native observability.

Features:

  • 🚀 Fast cold-starts - Pre-cached embeddings for quick initialization
  • 📊 ADOT integration - Native CloudWatch tracing
  • 🔒 Secure - Non-root user, multi-stage builds
  • 📦 Production-ready - Health checks and resource optimization

Quick start:

  1. Copy .env.example to .env and configure:

    cp .env.example .env
    # Edit .env with your OPENAPI_SPEC_URL and AWS credentials
    
  2. Run with docker-compose:

    docker-compose up openapi-mcp-bedrock
    

See full examples:

Build and run:

docker build -t openapi-mcp .
docker run -p 8000:8000 openapi-mcp

Configure your Bedrock agent to connect to the HTTP endpoint.

5. Multiple APIs with Claude Desktop

Connect to multiple OpenAPI specifications simultaneously by running separate server instances.

{
  "mcpServers": {
    "production-api": {
      "command": "uvx",
      "args": ["caitlyn-openapi-mcp"],
      "env": {
        "OPENAPI_SPEC_URL": "https://api.prod.example.com/openapi.json",
        "DOCS_BASE_URL": "https://docs.prod.example.com"
      }
    },
    "staging-api": {
      "command": "uvx",
      "args": ["caitlyn-openapi-mcp"],
      "env": {
        "OPENAPI_SPEC_URL": "https://api.staging.example.com/openapi.json",
        "DOCS_BASE_URL": "https://docs.staging.example.com"
      }
    },
    "caitlyn-api": {
      "command": "uvx",
      "args": ["caitlyn-openapi-mcp"],
      "env": {
        "OPENAPI_SPEC_URL": "https://betty.getcaitlyn.ai/docs/openapi-v1.json",
        "DOCS_BASE_URL": "https://betty.getcaitlyn.ai/api/docs"
      }
    }
  }
}

Each server runs independently with its own OpenAPI specification.

Troubleshooting

Server fails to start in Claude Desktop

  • Verify Python is in your PATH: which python (macOS/Linux) or where python (Windows)
  • Use full path to Python: "/usr/local/bin/python3.11"
  • Check Claude Desktop logs: ~/Library/Logs/Claude/mcp*.log (macOS)
  • Ensure OPENAPI_SPEC_URL is accessible from your machine

"ModuleNotFoundError: No module named 'openapi_mcp'"

  • For uvx: This shouldn't happen - uvx installs automatically
  • For local Python: Run pip install caitlyn-openapi-mcp or pip install -e ".[dev]" in the repo
  • Verify installation: python -m openapi_mcp.server --help

Tools not appearing in Claude Desktop

  • Restart Claude Desktop completely (quit and reopen)
  • Verify your JSON configuration is valid (use a JSON validator)
  • Check the server is running in Activity Monitor (macOS) or Task Manager (Windows)
  • Check Claude Desktop logs for errors

OpenAPI spec fails to load

  • Verify the URL is accessible: curl https://your-api.com/openapi.json
  • Check server logs for detailed error messages
  • Ensure the spec is valid OpenAPI 3.x format
  • If the spec has broken $ref references, the server will load it anyway with warnings

MCP Resources

The server exposes one static resource:

api-specification

The complete OpenAPI 3.x specification in JSON format (fully resolved with all $refs expanded). Can be used with OpenAPI validation tools, code generators, or for reference.

MCP Tools

The server provides tools designed to help LLMs answer user questions about the API. Each tool includes contextual descriptions to guide when it should be used.

list_api_endpoints

Use for: Getting an overview of what the API can do, or finding endpoints by category.

Parameters:

  • tag (optional): Filter by API category/tag (e.g., "users", "posts", "auth")
  • search (optional): Search term to find endpoints (searches paths, descriptions, summaries)

Returns: List of endpoints with path, method, summary, description, tags, and docs_url

Example use cases:

  • User asks: "What can this API do?"
  • User asks: "Show me all user-related endpoints"

get_endpoint_details

Use for: Getting detailed information about a specific endpoint including parameters, request body, and responses.

Parameters:

  • method: HTTP method (GET, POST, PUT, DELETE, PATCH, etc.)
  • path: API path (e.g., "/api/v1/users" or "/users/{userId}")

Returns: Complete endpoint details including parameters, request body schema, response schemas, and docs_url

Example use cases:

  • User asks: "How do I call the create user endpoint?"
  • User asks: "What parameters does the GET /users endpoint need?"
  • User asks: "What's the request body for creating a post?"

get_schema_definition

Use for: Understanding the structure of request/response data models.

Parameters:

  • schema_name: Name of the schema (e.g., "User", "CreateUserRequest", "PaginatedResponse")

Returns: Schema definition with properties, types, required fields, and docs_url

Example use cases:

  • User asks: "What fields does a User object have?"
  • User asks: "What's the structure of the CreatePostRequest?"
  • User asks: "What does the response look like?"

search_api_endpoints

Use for: Finding endpoints by functionality when you don't know the exact path.

Parameters:

  • query: What the user wants to do (e.g., "create knowledge base", "upload file", "get user profile")
  • max_results (optional, default: 20): Maximum number of results to return

Returns: Matching endpoints with path, method, summary, description, tags, and docs_url

Example use cases:

  • User asks: "How do I create a knowledge base through the API?"
  • User asks: "Can I upload files?"
  • User asks: "Is there an endpoint for user authentication?"

list_api_tags

Use for: Understanding how the API is organized into functional categories.

Parameters: None

Returns: List of tags/categories with endpoint counts

Example use cases:

  • User asks: "What functional areas does this API cover?"
  • User asks: "How is this API organized?"

Scalar Deep Links

When DOCS_BASE_URL is configured, the server generates deep links to Scalar documentation:

Endpoint links

Format: {base_url}#tag/{tag}/{method}/{path}

Example: https://api.example.com/docs#tag/users/get/api/v1/users

  • tag: The first tag on the operation (defaults to "default" if no tags)
  • method: HTTP method in lowercase (get, post, etc.)
  • path: OpenAPI path with leading slash stripped

Schema links

Format: {base_url}#schema/{schemaName}

Example: https://api.example.com/docs#schema/User

Security scheme links

Format: {base_url}#security/{schemeName}

Example: https://api.example.com/docs#security/bearerAuth

Local Development

Setup

Clone the repository and install in development mode:

git clone https://github.com/caitlyn-ai/caitlyn-openapi-mcp.git
cd caitlyn-openapi-mcp
pip install -e ".[dev]"

The installation automatically downloads the sentence-transformers model (~80MB) to ./models/ for semantic search.

Startup behavior:

  • Non-blocking startup: Server starts immediately without waiting for spec or model loading
  • Background loading: OpenAPI spec and ML model load in parallel background threads
  • First request handling: Automatically waits for loading to complete if still in progress

Caching strategy:

  • OpenAPI specs: Cached to disk for faster subsequent loads
  • ML model files: Downloaded once and cached locally
  • Embeddings: Pre-computed and cached per API specification
  • Cache invalidation: Automatic when API spec content changes
  • Manual management:
    • Download/update model: make setup-models
    • Clear all caches: make clean-models

Note: Docker images include pre-downloaded models for instant container startup.

Testing with MCP Inspector

The MCP Inspector provides a web-based UI for testing your MCP server locally with full observability.

Prerequisites:

  • Node.js installed (npx comes with Node.js)
  • Docker for OTEL Collector (optional but recommended)

Quick start with Make:

make dev

This launches:

  • OTEL Collector - Receives telemetry on localhost:4317
  • Jaeger UI - Visualize traces (auto-opens at http://localhost:16686)
  • MCP Inspector - Interactive testing interface

The inspector will open a web interface where you can:

  • Test all MCP tools interactively
  • View resources and their contents
  • Inspect endpoint details, schemas, and security schemes
  • Monitor performance with OpenTelemetry traces
  • Validate the server behavior before deployment

The Jaeger UI will automatically open in your browser to view traces and logs.

Manual usage with custom API:

npx @modelcontextprotocol/inspector \
  -e OPENAPI_SPEC_URL="https://api.example.com/openapi.json" \
  -e DOCS_BASE_URL="https://api.example.com/docs" \
  -e OTEL_EXPORTER_OTLP_ENDPOINT="http://localhost:4317" \
  python -m openapi_mcp.server

For complete telemetry documentation, see TELEMETRY.md.

Running Tests

# Run all tests
pytest

# Run with coverage
pytest --cov=src --cov-report=html

# Run specific test files
pytest tests/test_openapi_loader.py

Code Quality

# Format code
black src tests

# Lint code
ruff check src tests

# Type checking
pyright

# Run all checks
black src tests && ruff check src tests && pyright && pytest

Architecture

The server is built with the following components:

  • config.py: Environment-based configuration
  • model.py: Data models for endpoints, schemas, and the OpenAPI index
  • openapi_loader.py: URL-based OpenAPI spec loading using Prance and openapi-core
  • docs_links.py: Documentation deep link generation (currently Scalar only)
  • resources.py: MCP resource definitions
  • tools.py: MCP tool definitions
  • server.py: Main server wiring and entry point

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contributing

Contributions are welcome! Please see CONTRIBUTING.md for guidelines on how to contribute to this project.

For security issues, please refer to our Security Policy.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured