Skip to main content

AI-native management hub for WordPress, WooCommerce, and self-hosted services via Model Context Protocol (MCP)

Project description

MCP Hub

The AI-native management hub for WordPress, WooCommerce, and self-hosted services.

Connect your sites, stores, repos, and databases — manage them all through Claude, ChatGPT, Cursor, or any MCP client.

License: MIT Python 3.11+ Tests: 289 passing Tools: 589 CI


Why MCP Hub?

WordPress powers 43% of the web. WooCommerce runs 36% of online stores. Yet no MCP server existed for managing them through AI — until now.

MCP Hub is the first MCP server that lets you manage WordPress, WooCommerce, and 7 other self-hosted services through any AI assistant. Instead of clicking through dashboards, just tell your AI what to do:

"Update the SEO meta description for all WooCommerce products that don't have one"

"Create a new blog post about our Black Friday sale and schedule it for next Monday"

"Check the health of all 12 WordPress sites and report any with slow response times"

What Makes MCP Hub Different

Feature ManageWP MainWP AI Content Plugins MCP Hub
Multi-site management Yes Yes No Yes
AI agent integration No No No Native (MCP)
Full WordPress API Dashboard Dashboard Content only 67 tools
WooCommerce management No Limited No 28 tools
Git/CI management No No No 56 tools (Gitea)
Automation workflows No No No 56 tools (n8n)
Self-hosted No Yes N/A Yes
Open source No Core only Varies Fully open
Price $0.70-8/site/mo $29-79/yr $19-79/mo Free

589 Tools Across 9 Plugins

Plugin Tools What You Can Do
WordPress 67 Posts, pages, media, users, menus, taxonomies, SEO (Rank Math/Yoast)
WooCommerce 28 Products, orders, customers, coupons, reports, shipping
WordPress Advanced 22 Database ops, bulk operations, WP-CLI, system management
Gitea 56 Repos, issues, pull requests, releases, webhooks, organizations
n8n 56 Workflows, executions, credentials, variables, audit
Supabase 70 Database, auth, storage, edge functions, realtime
OpenPanel 73 Events, funnels, profiles, dashboards, projects
Appwrite 100 Databases, auth, storage, functions, teams, messaging
Directus 100 Collections, items, users, files, flows, permissions
System 17 Health monitoring, API keys, project discovery
Total 589 Constant count — scales to unlimited sites

Quick Start

Option 1: Docker (Recommended)

git clone https://github.com/airano-ir/mcphub.git
cd mcphub
cp env.example .env
# Edit .env with your site credentials
docker compose up -d

Option 2: Python

git clone https://github.com/airano-ir/mcphub.git
cd mcphub
pip install -e .
cp env.example .env
# Edit .env with your site credentials
python server.py --transport sse --port 8000

Configure Your Sites

Add site credentials to .env:

# Master API Key (required)
MASTER_API_KEY=your-secure-key-here

# WordPress Site
WORDPRESS_SITE1_URL=https://myblog.com
WORDPRESS_SITE1_USERNAME=admin
WORDPRESS_SITE1_APP_PASSWORD=xxxx xxxx xxxx xxxx
WORDPRESS_SITE1_ALIAS=myblog

# WooCommerce Store
WOOCOMMERCE_STORE1_URL=https://mystore.com
WOOCOMMERCE_STORE1_CONSUMER_KEY=ck_xxxxx
WOOCOMMERCE_STORE1_CONSUMER_SECRET=cs_xxxxx
WOOCOMMERCE_STORE1_ALIAS=mystore

# Gitea Instance
GITEA_REPO1_URL=https://git.example.com
GITEA_REPO1_TOKEN=your_gitea_token
GITEA_REPO1_ALIAS=mygitea

Connect Your AI Client

Claude Desktop

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "mcphub": {
      "url": "https://your-server:8000/mcp",
      "headers": {
        "Authorization": "Bearer YOUR_MASTER_API_KEY"
      }
    }
  }
}
Claude Code

Add to .mcp.json in your project:

{
  "mcpServers": {
    "mcphub": {
      "type": "sse",
      "url": "https://your-server:8000/mcp",
      "headers": {
        "Authorization": "Bearer YOUR_MASTER_API_KEY"
      }
    }
  }
}
Cursor

Go to Settings > MCP Servers > Add Server:

  • Name: MCP Hub
  • URL: https://your-server:8000/mcp
  • Headers: Authorization: Bearer YOUR_MASTER_API_KEY
VS Code + Copilot

Add to .vscode/mcp.json:

{
  "servers": {
    "mcphub": {
      "type": "sse",
      "url": "https://your-server:8000/mcp",
      "headers": {
        "Authorization": "Bearer YOUR_MASTER_API_KEY"
      }
    }
  }
}
ChatGPT (Remote MCP)

MCP Hub supports Open Dynamic Client Registration (RFC 7591). ChatGPT can auto-register as an OAuth client:

  1. Deploy MCP Hub with OAUTH_BASE_URL set
  2. In ChatGPT, add MCP server: https://your-server:8000/mcp
  3. ChatGPT auto-discovers OAuth metadata and registers

Architecture

/mcp                        → Admin endpoint (all 589 tools)
/system/mcp                 → System tools only (17 tools)
/wordpress/mcp              → WordPress tools (67 tools)
/woocommerce/mcp            → WooCommerce tools (28 tools)
/gitea/mcp                  → Gitea tools (56 tools)
/n8n/mcp                    → n8n tools (56 tools)
/supabase/mcp               → Supabase tools (70 tools)
/openpanel/mcp              → OpenPanel tools (73 tools)
/appwrite/mcp               → Appwrite tools (100 tools)
/directus/mcp               → Directus tools (100 tools)
/project/{alias}/mcp        → Per-project endpoint (auto-injects site)

Multi-endpoint architecture: Give each team member or AI agent access to only the tools they need.

Security

  • OAuth 2.1 + PKCE (RFC 8414, 7591, 7636) with auto-registration for Claude/ChatGPT
  • Per-project API keys with scoped permissions (read/write/admin)
  • Rate limiting: 60/min, 1,000/hr, 10,000/day per client
  • GDPR-compliant audit logging with automatic sensitive data filtering
  • Web dashboard with real-time health monitoring (8 pages, EN/FA i18n)

Compatibility Note: MCP Hub requires FastMCP 2.x (>=2.14.0,<3.0.0). FastMCP 3.0 introduced breaking changes and is not yet supported. If you install dependencies manually, ensure you don't upgrade to FastMCP 3.x.


Documentation

Guide Description
Getting Started Full setup walkthrough
Architecture System design and module reference
API Keys Guide Per-project API key management
OAuth Guide OAuth 2.1 setup for Claude/ChatGPT
Gitea Guide Gitea plugin configuration
Deployment Guide Docker and Coolify deployment
Troubleshooting Common issues and solutions
Plugin Development Build your own plugin

Development

# Install with dev dependencies
pip install -e ".[dev]"

# Run tests (289 tests)
pytest

# Format and lint
black . && ruff check --fix .

# Run server locally
python server.py --transport sse --port 8000

Support This Project

MCP Hub is free and open-source. Development is funded by community donations.

Donate with Crypto (NOWPayments) — Global, no geographic restrictions.

Goal Monthly Enables
Infrastructure $50/mo Demo hosting, CI/CD, domain
Part-time maintenance $500/mo Updates, security patches, issue triage
Active development $2,000/mo New plugins, features, community support

Contributing

We welcome contributions! See CONTRIBUTING.md for guidelines.

Priority areas:

  • New plugin development
  • Client setup guides
  • Workflow templates and examples
  • Test coverage expansion
  • Translations (i18n)

License

MIT License. See LICENSE.


Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcphub_server-3.0.0.tar.gz (343.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcphub_server-3.0.0-py3-none-any.whl (402.4 kB view details)

Uploaded Python 3

File details

Details for the file mcphub_server-3.0.0.tar.gz.

File metadata

  • Download URL: mcphub_server-3.0.0.tar.gz
  • Upload date:
  • Size: 343.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.6

File hashes

Hashes for mcphub_server-3.0.0.tar.gz
Algorithm Hash digest
SHA256 0d4b88cfbdd0c0dba9d39aebf383a520dd1d5f3fd689bc01243da0cd4868fb88
MD5 ab9af9d82fe0ba383d6fc470b3f9e082
BLAKE2b-256 426b8458328875cedefcd7817de4ee0124aaca760284ad0368ca94a0ecbde64f

See more details on using hashes here.

File details

Details for the file mcphub_server-3.0.0-py3-none-any.whl.

File metadata

  • Download URL: mcphub_server-3.0.0-py3-none-any.whl
  • Upload date:
  • Size: 402.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.6

File hashes

Hashes for mcphub_server-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 779a4cbdbfd187d037a403f644e99c4cff7ad6befca0553faf88e755b64ceada
MD5 4b478a5ab1301d5acbb10c65b2200524
BLAKE2b-256 a4dffb29232f4c171d5a8a8207b9913909002fd7e659847a7b5de2653df7d8a6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page