MCP from API
Enables users to expose arbitrary HTTP APIs as configurable MCP tools by defining tool specifications in a JSON configuration file.
README
MCP from API
A configurable Model Context Protocol (MCP) server that exposes arbitrary HTTP APIs as MCP tools, driven entirely by a JSON config.
Instead of hardcoding tools, you define them in src/config/tools.config.json. Each entry describes:
- Tool metadata:
name,description,inputSchema - HTTP call: method, path, optional query/body mapping, headers
- Response shaping: how to turn the HTTP response into MCP
result.content
The worker runtime is still Cloudflare Workers using Wrangler.

Environment configuration
This repo is set up to keep local configuration out of git:
wrangler.jsoncis gitignored (may contain personal/internal URLs and IDs)src/config/tools.config.jsonis gitignored (may contain internal tool definitions / headers)
For open-source publishing, commit the example files and copy them locally when developing.
The server uses the baseUrlEnvKey from the tool config to look up the base URL in the Worker environment (see wrangler.jsonc).
In the default config:
baseUrlEnvKeyisAPI_BASE_URLwrangler.jsonctypically provides different values per environment (examples shown inwrangler.jsonc.example).
Optional shared token (authTokenEnvKey)
You can protect the MCP endpoints and pass a secret through to your upstream API:
- In
tools.config.json, setauthTokenEnvKeyto the name of a Worker binding (same pattern asbaseUrlEnvKey). The example usesMCP_AUTH_TOKEN. - In
wrangler.jsonc, define that variable (or use a secret for production). If the value is missing or blank, token auth is disabled: clients do not need a token, and upstream calls do not get an extratokenquery parameter. - When the env value is non-empty, MCP clients must send the same string when connecting, either:
- as a path segment:
/mcp/<token>or/sse/<token>, or - as
Authorization: Bearer <token>.
- as a path segment:
- If the client token matches the configured secret, every upstream tool request appends
token=<that secret>as a query parameter (in addition to anyquerymapping from the tool config). Your API can read that parameter to authorize the call.
Static per-tool headers (for example Authorization: Bearer ... for the upstream API) are set only in each tool’s http.headers block; they are not derived from the MCP client token.
Quick start (local)
Copy the example configs:
cp wrangler.jsonc.example wrangler.jsonc
cp src/config/tools.config.json.example src/config/tools.config.json
Then edit wrangler.jsonc / src/config/tools.config.json with your own values.
Defining tools in JSON
Tools are defined in src/config/tools.config.json under the tools array.
For a commit-safe reference, see src/config/tools.config.json.example.
Example:
{
"server": {
"name": "mcp-from-api",
"version": "1.0.0",
"description": "Configurable MCP server that exposes HTTP APIs as tools."
},
"baseUrlEnvKey": "API_BASE_URL",
"authTokenEnvKey": "MCP_AUTH_TOKEN",
"tools": [
{
"name": "example_get_users",
"description": "Fetches a paginated list of users from the configured API.",
"inputSchema": {
"type": "object",
"properties": {
"page": {
"type": "integer",
"minimum": 1,
"default": 1
}
},
"required": [],
"additionalProperties": false
},
"http": {
"method": "GET",
"path": "/users",
"query": {
"page": "page"
},
"headers": {}
},
"response": {
"mode": "json",
"contentPath": null,
"wrap": {
"type": "text",
"template": "Users response:\\n\\n{{body}}"
}
}
}
]
}
HTTP mapping
In each tool’s http block:
method:"GET" | "POST" | "PUT" | "PATCH" | "DELETE"path: joined with the base URL from the environmentquery: map of query parameter name → argument key
(e.g."page": "page"meansargs.pagebecomes?page=...)headers: static headers to send on every call for that tool (from the config only).body(optional, for methods likePOST/PUT/PATCH):mode: "json"mapping:"full"– send the entireargumentsobject as JSON"properties"– send only selected properties, defined inproperties
properties(whenmappingis"properties"): map of body property → argument key
Response mapping
In each tool’s response block:
mode:"json"– parse the HTTP response body as JSON"text"– useresponse.text()
contentPath(optional):- When
modeis"json", treat this as a dotted path into the parsed JSON (e.g."data.items"). - If omitted or not found, the entire JSON is used.
- When
wrap(optional):- Currently supports
type: "text"with atemplatestring. - The placeholder
{{body}}is replaced with the stringified selected content.
- Currently supports
The final string is always returned to MCP clients as:
{
"content": [
{
"type": "text",
"text": "..."
}
]
}
Runtime behaviour
tools/listuses the JSON config to expose all tools with theirname,description, andinputSchema.tools/calllooks up the tool byname, constructs the HTTP request from the config and the providedarguments, calls the remote API, shapes the response, and returns it as MCP content./healthreflects the current config, returning:name,versionfromservertoolsas a list of tool namesendpointsfor/mcp,/sse, and/health
Development & deployment
The existing scripts still apply:
# Start development server
npm run dev
# Deploy to development environment
npm run deploy:dev
# Deploy to production environment
npm run deploy
# Test production configuration locally
npm run dev:prod
To add or change tools, edit src/config/tools.config.json and redeploy.
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.