Skip to main content

Centralized MCP Gateway for Cloudflare services

Project description

Cloudflare MCP Gateway

A centralized MCP (Model Context Protocol) gateway that aggregates multiple Cloudflare MCP services into a single unified server. Configure which services you need via environment variables and access them all through one MCP connection.

Features

  • Unified Access: Single MCP server for multiple Cloudflare services
  • Configurable Services: Enable only the services you need via ENABLED_SERVICES
  • Dual Transport Support: Works with both stdio (Claude Desktop) and streamable HTTP (web clients)
  • Tool Namespacing: Automatic prefixing prevents tool name collisions (e.g., bindings_kv_get, radar_scan)
  • Graceful Degradation: Continues operating if some upstream services are unavailable

Supported Services

Service ID Name Description
docs Documentation Get up to date reference information on Cloudflare
bindings Workers Bindings Build Workers applications with storage, AI, and compute primitives
builds Workers Builds Get insights and manage your Cloudflare Workers Builds
observability Observability Debug and get insight into your application's logs and analytics
radar Radar Get global Internet traffic insights, trends, URL scans, and other utilities
containers Containers Spin up a sandbox development environment
browser Browser Rendering Fetch web pages, convert them to markdown and take screenshots
logpush Logpush Get quick summaries for Logpush job health
ai-gateway AI Gateway Search your logs, get details about the prompts and responses
autorag AutoRAG List and search documents on your AutoRAGs
auditlogs Audit Logs Query audit logs and generate reports for review
dns-analytics DNS Analytics Optimize DNS performance and debug issues based on current set up
dex Digital Experience Monitoring Get quick insight on critical applications for your organization
casb CASB Quickly identify any security misconfigurations for SaaS applications
graphql GraphQL Analytics Get analytics data using Cloudflare's GraphQL API

Installation

# Using pip
pip install cf-mcp-gateway

# Using uv
uv pip install cf-mcp-gateway

Quick Start

1. Get Cloudflare Credentials

You'll need:

  • API Token: Create one at Cloudflare Dashboard
  • Account ID: Found in your Cloudflare dashboard URL or account settings

2. Configure Environment

Create a .env file or set environment variables:

# Required
CLOUDFLARE_API_TOKEN=your-api-token
CLOUDFLARE_ACCOUNT_ID=your-account-id
ENABLED_SERVICES=docs,bindings,observability

# Optional
TRANSPORT=stdio  # or streamable-http
LOG_LEVEL=info

3. Run the Gateway

# Using the CLI
cf-mcp-gateway

# Or as a Python module
python -m cf_mcp_gateway

Usage with MCP Clients

Claude Desktop

Add to your Claude Desktop configuration (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):

{
  "mcpServers": {
    "cloudflare": {
      "command": "python",
      "args": ["-m", "cf_mcp_gateway"],
      "env": {
        "CLOUDFLARE_API_TOKEN": "your-api-token",
        "CLOUDFLARE_ACCOUNT_ID": "your-account-id",
        "ENABLED_SERVICES": "docs,bindings,observability,radar",
        "TRANSPORT": "stdio"
      }
    }
  }
}

Cursor

Add to your Cursor MCP settings:

{
  "mcpServers": {
    "cloudflare": {
      "command": "cf-mcp-gateway",
      "env": {
        "CLOUDFLARE_API_TOKEN": "your-api-token",
        "CLOUDFLARE_ACCOUNT_ID": "your-account-id",
        "ENABLED_SERVICES": "docs,bindings,observability"
      }
    }
  }
}

Streamable HTTP (Remote/Web Access)

Start the gateway with HTTP transport:

CLOUDFLARE_API_TOKEN=xxx \
CLOUDFLARE_ACCOUNT_ID=yyy \
ENABLED_SERVICES=docs,bindings,radar \
TRANSPORT=streamable-http \
GATEWAY_HOST=0.0.0.0 \
GATEWAY_PORT=3000 \
cf-mcp-gateway

The server exposes:

  • POST /mcp - MCP JSON-RPC endpoint
  • GET /health - Health check endpoint

Configuration Reference

Required Environment Variables

Variable Description
CLOUDFLARE_API_TOKEN Your Cloudflare API token
CLOUDFLARE_ACCOUNT_ID Your Cloudflare account ID
ENABLED_SERVICES Comma-separated list of service IDs to enable

Optional Environment Variables

Variable Default Description
TRANSPORT stdio Transport mode: stdio or streamable-http
GATEWAY_HOST 0.0.0.0 HTTP bind host (streamable-http only)
GATEWAY_PORT 3000 HTTP port (streamable-http only)
LOG_LEVEL info Logging level: debug, info, warning, error

Tool Naming Convention

Tools from upstream services are prefixed with their service ID to avoid collisions:

  • bindings_kv_get - Get value from KV
  • bindings_kv_put - Put value to KV
  • bindings_r2_list - List R2 objects
  • radar_url_scan - Scan a URL
  • docs_search - Search Cloudflare documentation

Architecture

┌─────────────────┐     ┌─────────────────────────────────┐
│   MCP Client    │────▶│   Cloudflare MCP Gateway        │
│ (Claude, etc.)  │     │                                 │
└─────────────────┘     │  ┌─────────────────────────┐    │
                        │  │   Tool Aggregator       │    │
                        │  │   - Namespacing         │    │
                        │  │   - Request routing     │    │
                        │  └─────────────────────────┘    │
                        └──────────────┬──────────────────┘
                                       │
     ┌─────────────┬─────────────┬─────┴─────┬─────────────┬─────────────┐
     ▼             ▼             ▼           ▼             ▼             ▼
┌─────────┐  ┌─────────┐  ┌─────────┐  ┌─────────┐  ┌─────────┐  ┌─────────┐
│  docs   │  │bindings │  │  radar  │  │  builds │  │ logpush │  │  ...    │
└─────────┘  └─────────┘  └─────────┘  └─────────┘  └─────────┘  └─────────┘

License

MIT License - see LICENSE file for details.

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

cf_mcp_gateway-0.2.1.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

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

cf_mcp_gateway-0.2.1-py3-none-any.whl (15.0 kB view details)

Uploaded Python 3

File details

Details for the file cf_mcp_gateway-0.2.1.tar.gz.

File metadata

  • Download URL: cf_mcp_gateway-0.2.1.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.0

File hashes

Hashes for cf_mcp_gateway-0.2.1.tar.gz
Algorithm Hash digest
SHA256 c7eb72619484d9c527a07d674eff0f81e3fc9a92163082719aa674981b6c04b7
MD5 5b85daec3985a1d0d8bd160930be36a5
BLAKE2b-256 effe61ad2affeee5c96fbbb6896e23b13e7783329e93202d9f12e386ca14d434

See more details on using hashes here.

File details

Details for the file cf_mcp_gateway-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for cf_mcp_gateway-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b79576fa4497f86283b720697863ad4da1827df317800091be9cf38b8018fd5c
MD5 22f3d6d4d32de2dd28b8fe37c0ae7150
BLAKE2b-256 f9803d7cf0c334a8e6550a6c4be32adaf55e97cf52a3fcb807d6df8c66d8c63c

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