MCP-Maker

MCP-Maker

Auto-generates MCP servers from any data source, enabling AI clients to query databases, spreadsheets, and APIs with zero code.

Category
Visit Server

README

⚒️ MCP-Maker

PyPI version Tests codecov Python 3.10+ License: MIT Downloads

Auto-generate MCP servers from any data source. Zero code required.

Point MCP-Maker at a database, spreadsheet, or API and get a fully functional MCP server in seconds — ready for Claude, ChatGPT, Cursor, and any MCP-compatible AI client.

pip install mcp-maker

What is MCP? The Model Context Protocol is the open standard for connecting AI to external tools and data. MCP-Maker auto-generates a complete MCP server from your data source — you don't write a single line of code.


Quick Start

Generate an MCP Server (for Claude, Cursor, ChatGPT)

pip install mcp-maker

# Generate from your database
mcp-maker init sqlite:///mydata.db

# Connect to Claude Desktop
mcp-maker config --install

# Restart Claude — your AI can now query your data

Chat directly in your terminal

No Claude needed — talk to your SQLite database right from the terminal:

pip install "mcp-maker[chat]"

# Chat with any SQLite database (no init required)
mcp-maker chat sqlite:///mydata.db

💡 init vs chat: init generates a server file for AI clients (Claude, Cursor) and supports all 13 connectors. chat lets you query directly from the terminal — currently supports SQLite only (PostgreSQL and MySQL coming soon).

╭──────────────────────────────────╮
│ 💬 MCP-Maker Chat                │
╰──────────── v0.2.6 ─────────────╯
📊 Connected: 3 tables (users, orders, products)
🔧 12 tools available (read-only)
🧠 Provider: OpenAI (gpt-4o-mini)

You > How many orders were placed this month?
🔧 count_orders(date_from='2026-03-01')
There were 47 orders placed this month.

You > Who is our top customer?
🔧 list_orders(order_by='total', order_dir='desc', limit=1)
Your top customer is Sarah Chen with $12,450 in orders.

LLM Providers: chat supports OpenAI and OpenRouter (500+ models including Claude, Gemini, Llama, DeepSeek):

# OpenAI (default)
mcp-maker chat sqlite:///data.db --api-key sk-xxx

# OpenRouter — auto-detected from key prefix
mcp-maker chat sqlite:///data.db --api-key sk-or-xxx --model anthropic/claude-sonnet-4
mcp-maker chat sqlite:///data.db --api-key sk-or-xxx --model google/gemini-2.5-flash
mcp-maker chat sqlite:///data.db --api-key sk-or-xxx --model deepseek/deepseek-chat

How It Works

Your Data Source          MCP-Maker              Output
┌──────────────┐    ┌──────────────────┐    ┌─────────────────────────┐
│ SQLite       │    │                  │    │ 📄 mcp_server.py        │
│ PostgreSQL   │    │                  │    │   ↳ Editable, yours     │
│ MySQL        │───▶│  mcp-maker init  │───▶│                         │
│ Airtable     │    │                  │    │ ⚙️  _autogen_tools.py    │
│ Google Sheets│    │  (auto-inspect)  │    │   ↳ list_users()        │
│ Notion       │    │  (auto-generate) │    │   ↳ search_orders()     │
│ CSV/JSON     │    │                  │    │   ↳ join_tasks_users()   │
│ +6 more      │    └──────────────────┘    └─────────────────────────┘
└──────────────┘                            Standalone Python file ✅
                                            Works forever, even after
                                            uninstalling MCP-Maker

MCP-Maker generates a standalone Python file. No runtime dependency on MCP-Maker — uninstall it after generation and your server keeps running.


Supported Connectors (13)

Connector URI Format Auth Install
SQLite sqlite:///my.db Built-in
Files (CSV/JSON) ./data/ Built-in
PostgreSQL postgres://user:pass@host/db DB creds pip install "mcp-maker[postgres]"
MySQL mysql://user:pass@host/db DB creds pip install "mcp-maker[mysql]"
Airtable airtable://appXXXX API key pip install "mcp-maker[airtable]"
Google Sheets gsheet://SPREADSHEET_ID Service acct pip install "mcp-maker[gsheets]"
Notion notion://DATABASE_ID Integration pip install "mcp-maker[notion]"
Excel excel:///path.xlsx pip install "mcp-maker[excel]"
MongoDB mongodb://user:pass@host/db DB creds pip install "mcp-maker[mongodb]"
Supabase supabase://PROJECT_REF API key pip install "mcp-maker[supabase]"
REST API openapi:///spec.yaml API token pip install "mcp-maker[openapi]"
Redis redis://host:6379/0 Password pip install "mcp-maker[redis]"
HubSpot hubspot://pat=TOKEN PAT pip install "mcp-maker[hubspot]"
# Install all connectors at once
pip install "mcp-maker[all]"

Generated Tools

For each table/collection, MCP-Maker generates:

Tool Description
list_{table} Paginated listing with filters, sorting, field selection, date ranges
get_{table} Lookup by primary key
search_{table} Full-text search across string columns
count_{table} Count with optional filters
insert_{table} Insert a single record (with --ops insert)
update_{table} Update by ID (with --ops update)
delete_{table} Delete by ID (with --ops delete)
batch_insert_{table} Bulk insert up to 1,000 records in a transaction
batch_delete_{table} Bulk delete by IDs
join_{from}_with_{to} Cross-table queries via auto-discovered foreign keys
export_{table}_csv Export to CSV
export_{table}_json Export to JSON

Additional tools based on flags: --semantic (vector search), --webhooks (event hooks), --audit (structured logging).


CLI Reference

# Core
mcp-maker init <source>                       # Generate MCP server
mcp-maker chat <source>                       # Chat with your database (NEW)
mcp-maker serve                               # Run the generated server
mcp-maker inspect <source>                    # Dry run — preview what would be generated

# Configuration
mcp-maker config --install                    # Auto-configure Claude Desktop
mcp-maker env set KEY VALUE                   # Store API keys in .env
mcp-maker env list                            # List stored keys (masked)
mcp-maker list-connectors                     # Show available connectors

# Deployment
mcp-maker deploy --platform railway           # Generate Railway deployment files
mcp-maker deploy --platform render            # Render deployment
mcp-maker deploy --platform fly               # Fly.io deployment

# Generation Options
mcp-maker init <source> --ops read,insert     # Control what the LLM can do
mcp-maker init <source> --tables users,orders # Only expose specific tables
mcp-maker init <source> --async               # Async tools (aiosqlite/asyncpg)
mcp-maker init <source> --auth api-key        # Require MCP_API_KEY for access
mcp-maker init <source> --semantic            # Enable ChromaDB vector search
mcp-maker init <source> --webhooks            # Real-time event notifications
mcp-maker init <source> --audit               # Structured JSON audit logging
mcp-maker init <source> --cache 60            # Cache reads for N seconds
mcp-maker init <source> --no-ssl              # Disable SSL (local dev only)
mcp-maker init <source> --consolidate-threshold 10  # Consolidate large schemas

# Chat Options
mcp-maker chat <source> --api-key sk-xxx      # OpenAI key
mcp-maker chat <source> --api-key sk-or-xxx   # OpenRouter key (auto-detected)
mcp-maker chat <source> --model gpt-4o        # Choose model
mcp-maker chat <source> --provider openrouter # Explicit provider
mcp-maker chat <source> --tables users        # Limit to specific tables

Architecture & Security

Non-Destructive Generation

MCP-Maker generates two files:

  • mcp_server.py — Your editable entry point. Add custom tools, business logic, middleware. Never overwritten on re-generation.
  • _autogen_mcp_server.py — Auto-generated tools. Regenerated safely when you run init again.

Security Features

Feature Description
Credential Isolation Connection strings and API keys loaded from .env — never embedded in generated code
Granular Permissions --ops read (default) prevents writes. Explicitly enable insert, update, delete
API Key Auth --auth api-key gates every tool call behind MCP_API_KEY validation
SSL/TLS by Default PostgreSQL and MySQL connections enforce encrypted transport
SQL Injection Prevention Column whitelist validation on all dynamic queries
Batch Limits Bulk operations capped at 1,000 records to prevent resource exhaustion
Rate Limiting Built-in token bucket throttling for cloud APIs (Airtable, Notion, Sheets)

Schema Versioning

MCP-Maker generates a .mcp-maker.lock file tracking your schema fingerprint. On re-generation, it detects changes (added/removed tables and columns) and displays a color-coded migration diff before updating tools.

Large Schema Handling

For schemas with 20+ tables, the --consolidate-threshold flag switches from per-table tools to consolidated generic tools (e.g., query_database), preventing LLM context window overflow.


MCP Client Compatibility

The generated server works with any MCP-compatible client:

Client Setup
Claude Desktop mcp-maker config --install (automatic)
Cursor Add to Cursor Settings → MCP Servers
Windsurf Add to ~/.codeium/windsurf/mcp_config.json
VS Code + Continue Add to Continue's MCP config
ChatGPT Desktop OpenAI MCP support (rolling out)
Any MCP client Run mcp-maker serve and point to it

Installation

# Core (SQLite + Files + CLI)
pip install mcp-maker

# With chat support (OpenAI / OpenRouter)
pip install "mcp-maker[chat]"

# With specific connectors
pip install "mcp-maker[postgres]"
pip install "mcp-maker[airtable]"
pip install "mcp-maker[gsheets]"
pip install "mcp-maker[notion]"

# With async support
pip install "mcp-maker[async-sqlite]"
pip install "mcp-maker[async-postgres]"
pip install "mcp-maker[async-mysql]"

# Everything
pip install "mcp-maker[all]"

Requirements: Python 3.10+


📖 Documentation

Guide Description
Getting Started Installation, first server, Claude Desktop setup
CLI & Architecture Reference All commands, env vars, security details

Connector Guides

Each guide includes step-by-step setup, examples, and troubleshooting:

Connector Guide
SQLite docs/sqlite.md
Files (CSV/JSON) docs/files.md
PostgreSQL docs/postgresql.md
MySQL docs/mysql.md
Airtable docs/airtable.md
Google Sheets docs/google-sheets.md
Notion docs/notion.md
Excel docs/excel.md
MongoDB docs/mongodb.md
Supabase docs/supabase.md
REST API (OpenAPI) docs/openapi.md
Redis docs/redis.md
HubSpot docs/hubspot.md
Semantic Search docs/semantic-search.md

Contributing

MCP-Maker is designed for community contributions — each connector is a self-contained PR.

See CONTRIBUTING.md for a step-by-step guide.

git clone https://github.com/MrAliHasan/mcp-maker.git
cd mcp-maker
make install    # Set up dev environment
make check      # Run lint + tests (272 tests)

Security

Found a vulnerability? Please report it privately via SECURITY.md.

License

MIT License · Code of Conduct

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
Qdrant Server

Qdrant Server

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

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