openapi-to-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@openapi-to-mcplist all users from the API"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
openapi-to-mcp
A minimal MCP server that auto-generates tools from your OpenAPI spec. Optimized for Vercel's serverless architecture.
Quick Start
Fork this repo
Set
OPENAPI_SPEC_URLto your OpenAPI spec URLDeploy to Vercel
Configuration
Variable | Required | Description |
| Yes | URL or file path to your OpenAPI spec (YAML or JSON) |
| No | Override the API base URL (defaults to |
| No | Override the MCP server name (defaults to |
| No | Local dev server port (default: 3000) |
How It Works
On cold start, the server fetches and parses your OpenAPI spec
Each API endpoint becomes an MCP tool with a Zod-validated input schema
When a tool is called, the request is forwarded to your API with the caller's headers (API key, Bearer token, etc.) passed through unchanged
The spec and tools are cached in memory — warm invocations skip the fetch
Running Locally
1. Install dependencies
pnpm install2. Configure environment variables
Create .env and set OPENAPI_SPEC_URL to your OpenAPI spec. For local dev, this can be a remote URL or an absolute file path:
# Remote URL
OPENAPI_SPEC_URL=https://api.example.com/openapi.yaml
# Or an absolute file path (local dev only)
OPENAPI_SPEC_URL=/path/to/your/openapi.yml3. Start the dev server
pnpm devThe server starts at http://localhost:3000/mcp.
4. Connect your MCP client to the local server
How you connect to the MCP server depends on your client (Claude Code, Cursor, VS Code, etc.) — check your client's docs for where to add MCP servers. Most clients use a similar JSON format. Here's an example for Claude Code (.mcp.json):
{
"mcpServers": {
"my-api": {
"type": "http",
"url": "http://localhost:3000/mcp",
"headers": {
"Authorization": "Bearer <your-token>"
}
}
}
}The headers block above shows a Bearer token, but you can use any header your API requires. The MCP server forwards all headers from your client config to the target API on every tool call without modification — it doesn't validate, store, or care which header is "the auth header". See Auth for examples (API key, Bearer token, multiple headers).
Deploying to Vercel
Push this repo to GitHub
Import it at vercel.com/new
Add
OPENAPI_SPEC_URLunder Settings > Environment Variables.API_BASE_URLandMCP_SERVER_NAMEare optional overrides.
That's it. Your MCP server is live at https://your-project.vercel.app/mcp. Connect clients the same way as local — just swap the URL.
Auth
All headers from your MCP client config are forwarded to the target API on every tool call. The MCP server does not validate or store credentials — your API handles authentication.
Configure whatever headers your API expects in the client config:
// API key auth
"headers": { "X-Api-Key": "<your-key>" }
// Bearer token
"headers": { "Authorization": "Bearer <your-token>" }
// Multiple headers
"headers": { "Authorization": "Bearer <token>", "X-Org-Id": "org_123" }This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/kirkwat/openapi-to-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server