backend2mcp
Automatically converts Python web backends (FastAPI, Flask, Django) into MCP servers by exposing API routes as MCP tools with near-zero boilerplate.
README
backend2mcp
Convert any Python web backend into a fully functional MCP (Model Context Protocol) server automatically, with near-zero developer boilerplate.
What is this?
backend2mcp automatically exposes your existing Python web API routes as MCP tools. No HTTP servers, no proxies, no code generation—just import and run.
Installation
Install the core package:
pip install backend2mcp
Install with framework support:
pip install backend2mcp[fastapi] # FastAPI support
pip install backend2mcp[flask] # Flask support
pip install backend2mcp[django] # Django support
pip install backend2mcp[fastapi,flask] # Multiple frameworks
Quickstart
FastAPI
from fastapi import FastAPI
from backend2mcp.fastapi import MCPAdapter
app = FastAPI()
@app.get("/users/{id}")
async def get_user(id: int):
return {"id": id, "name": "Satyam"}
MCPAdapter(app).run()
Flask
from flask import Flask
from backend2mcp.flask import MCPAdapter
app = Flask(__name__)
@app.route("/users/<int:id>")
def get_user(id):
return {"id": id, "name": "Satyam"}
MCPAdapter(app).run()
Django
from django.urls import path
from backend2mcp.django import MCPAdapter
urlpatterns = [
path("users/<int:id>/", views.get_user),
]
MCPAdapter(urlpatterns=urlpatterns).run()
CLI Usage
# Auto-detect framework
backend2mcp run app:app
# Explicit framework
backend2mcp run app:app --framework fastapi
backend2mcp run app:app --framework flask
backend2mcp run app:app --framework django
Decorator Override
Customize tool behavior with @mcp_tool:
from backend2mcp.fastapi import MCPAdapter, mcp_tool
app = FastAPI()
@app.get("/users/{id}")
@mcp_tool(
name="get_user",
description="Get a user by their ID",
hidden=False
)
async def get_user(id: int):
return {"id": id}
Tool Naming
Tools are auto-named using a consistent convention:
| Route | Tool Name |
|---|---|
GET /users/{id} |
get_by_id |
POST /search |
post_search |
PUT /users/{id} |
put_by_id |
DELETE /users/{id} |
delete_by_id |
Authentication
backend2mcp provides flexible authentication support through pluggable AuthProvider classes.
No Authentication (Default)
Zero config, no auth required:
adapter = MCPAdapter(app) # Works without auth
Bearer Token Auth
from backend2mcp.core import BearerAuthProvider
auth = BearerAuthProvider(
token_header="Authorization", # Header name
token_prefix="Bearer", # Token prefix
validate_tokens=["secret1", "secr2"] # Optional whitelist
)
adapter = MCPAdapter(app, auth_provider=auth)
API Key Auth
from backend2mcp.core import APIKeyAuthProvider
auth = APIKeyAuthProvider(
header_name="X-API-Key", # Header name
query_param="api_key", # Query param name
valid_keys=["key1", "key2"] # Optional whitelist
)
adapter = MCPAdapter(app, auth_provider=auth)
Custom Headers Injection
from backend2mcp.core import HeaderInjectionAuthProvider
auth = HeaderInjectionAuthProvider(
static_headers={
"X-Custom-Header": "value",
"Authorization": "Bearer static-token"
}
)
adapter = MCPAdapter(app, auth_provider=auth)
Combining Providers
from backend2mcp.core import (
BearerAuthProvider,
APIKeyAuthProvider,
combine_providers
)
auth = combine_providers(
BearerAuthProvider(),
APIKeyAuthProvider()
)
adapter = MCPAdapter(app, auth_provider=auth)
Accessing Auth in Handlers
Auth context is injected into handlers:
from backend2mcp.fastapi import MCPAdapter
from backend2mcp.core import BearerAuthProvider, AuthContext
app = FastAPI()
auth = BearerAuthProvider()
@app.get("/users/{id}")
async def get_user(id: int, auth_context: AuthContext = None):
headers = auth_context.headers if auth_context else {}
user = get_user_from_db(id, headers=headers)
return user
adapter = MCPAdapter(app, auth_provider=auth)
Architecture
backend2mcp/
├── core/ # Shared implementation
│ ├── adapter.py # BaseAdapter abstract interface
│ ├── auth.py # Auth providers (Bearer, API Key, etc.)
│ ├── server.py # MCP server implementation
│ ├── schema.py # Schema conversion utilities
│ └── exceptions.py # Structured exceptions
├── fastapi/ # FastAPI adapter
├── flask/ # Flask adapter
├── django/ # Django adapter
└── cli/ # Typer CLI
Core Abstractions
BaseAdapter: Abstract interface all framework adapters implementAuthProvider/AuthContext: Pluggable authentication systemMCPServer: Handles MCP protocol using officialmcpSDK- Tool Execution: Direct handler invocation (no HTTP calls)
- Schema Generation: Pydantic-integrated JSON Schema extraction
Writing a New Adapter
To add support for another framework:
- Create
backend2mcp/framework/ - Implement
BaseAdapterinterface:get_routes()- Extract all routes from the frameworkintrospect_route()- Convert a route toToolInfoexecute_tool()- Call handler with resolved argumentsbuild_tool_name()- Generate MCP-safe tool names
- Export
MCPAdapterfrom the subpackage
from backend2mcp.core.adapter import BaseAdapter, ToolInfo
class MCPAdapter(BaseAdapter):
def get_routes(self) -> list[tuple]:
# Your route extraction logic
pass
def introspect_route(self, path, method, handler, config) -> ToolInfo:
# Your schema extraction logic
pass
def execute_tool(self, handler, arguments, context=None):
# Your handler invocation logic
pass
def get_app(self):
# Return underlying framework object
pass
def build_tool_name(self, http_method, path):
# Your naming convention
pass
Roadmap
| Phase | Frameworks |
|---|---|
| Phase 1 (this release) | FastAPI, Flask, Django |
| Phase 2 | Express, NestJS, Fastify |
| Phase 3 | Spring Boot, Quarkus |
| Phase 4 | Gin, Fiber, Echo |
License
MIT
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.