MCP Proxy Hub

Aggregates multiple MCP resource servers into a single interface using a JSON configuration file.

MCP Proxy Hub

An MCP proxy server that aggregates and serves multiple MCP resource servers through a single interface. This server acts as a central hub that can:

  • Connect to and manage multiple MCP resource servers
  • Expose their combined capabilities through a unified interface
  • Handle routing of requests to appropriate backend servers
  • Aggregate responses from multiple sources

Features

Resource Management

  • Discover and connect to multiple MCP resource servers
  • Aggregate resources from all connected servers
  • Maintain consistent URI schemes across servers
  • Handle resource routing and resolution

Tool Aggregation

  • Expose tools from all connected servers with server name prefixes
  • Apply tool filtering based on configuration (exposedTools/hiddenTools)
  • Support tool name remapping via configuration
  • Route tool calls to appropriate backend servers

Custom Tool Support

  • Define compound tools that combine functionality from multiple servers

  • Execute subtools using server and tool name specifications

  • Provide detailed documentation through tool descriptions

  • Specify execution with a standardized format:

    {
      "server": "server_name",
      "tool": "tool_name",
      "args": {
        // Tool-specific arguments
      }
    }
    

Environment Variable Support

  • Automatically expand environment variables in tool arguments
  • Automatically replace sensitive values with variable references in responses
  • Configure which variables should be expanded/unexpanded via configuration
  • Support for both global (all servers) and server-specific environment variables
  • Server-specific variables take precedence over global variables with the same name
  • Each variable can be independently configured for expansion and unexpansion
  • Environment variables are only expanded when using the ${VARIABLE_NAME} syntax (e.g., ${API_KEY}). The $VARIABLE_NAME syntax is not supported.
  • Secure handling of sensitive information like API keys

Prompt Handling

  • Aggregate prompts from all connected servers
  • Route prompt requests to appropriate backends
  • Handle multi-server prompt responses

Configuration

The server requires a JSON configuration file that specifies the MCP servers to connect to. Copy the example config(config.example.json) and modify it for your needs:

cp config.example.json config.json

Configuration Options

MCP Server Configuration

  • Stdio-type Server:

    • command: Command to execute (required)
    • args: Command line arguments (optional)
    • env: Environment variables (optional)
    • exposedTools: Array of tools to expose (optional)
    • hiddenTools: Array of tools to hide (optional)
    • envVars: Environment variable configuration for tool arguments and responses (optional)
  • SSE-type Server:

    • type: "sse" (required)
    • url: URL of the SSE server (required)
    • headers: Object of HTTP headers to send with the SSE connection (optional)
    • exposedTools: Array of tools to expose (optional)
    • hiddenTools: Array of tools to hide (optional)
    • envVars: Environment variable configuration for tool arguments and responses (optional)

Tool Filtering Configuration

  • exposedTools:

    • Only exposes specified tools
    • Array containing strings (original tool names) or {original, exposed} objects (for renaming)
  • hiddenTools:

    • Hides specified tools
    • Array of tool name strings to hide

Environment Variables Configuration

  • Server-specific envVars:

    • Array of environment variable configurations for a specific server

    • Each configuration has the following properties:

      • name: Name of the environment variable
      • value: Value of the environment variable
      • expand: Whether to expand this variable in tool arguments (optional, defaults to false)
      • unexpand: Whether to unexpand this variable in tool responses (optional, defaults to false)
    • Example:

      "envVars": [
        { "name": "API_KEY", "value": "my-api-key", "expand": true, "unexpand": true },
        { "name": "USER_ID", "value": "user123", "expand": true, "unexpand": false }
      ]
      
  • Global envVars:

    • Array of environment variable configurations applied to all servers

    • Uses the same configuration format as server-specific envVars

    • Server-specific variables with the same name override global variables

    • Defined at the root level of the configuration file

    • Example:

      "envVars": [
        { "name": "GLOBAL_API_KEY", "value": "global-api-key", "expand": true, "unexpand": true },
        { "name": "GLOBAL_ENV", "value": "production", "expand": true, "unexpand": false }
      ]
      

Custom Tool Configuration

  • tools:
    • Object with custom tool names as keys
    • Each tool has description and subtools
    • subtools is keyed by server name and contains each server's tool list

Environment Variables

  • MCP_PROXY_CONFIG_PATH: Path to the configuration file
  • MCP_PROXY_LOG_DIRECTORY_PATH: Path to the log directory
  • MCP_PROXY_LOG_LEVEL: Log level ("debug" or "info")
  • KEEP_SERVER_OPEN: Whether to keep the server open after client disconnection in SSE mode (set to "1" to enable)
  • PORT: Port for the SSE server (default: 3006)

Development

Install dependencies:

npm install

Build the server:

npm run build

For development with auto-rebuild:

npm run watch

For development with continuous run:

# Stdio
npm run dev
# SSE
npm run dev:sse

CLI

The CLI provides two modes of operation for interacting with the MCP Proxy Hub.

Direct Execution Mode

You can execute commands directly from your terminal. This is useful for scripting and automation.

  • List available tools:

    mcp-proxy-hub-cli list
    
  • Call a tool:

    mcp-proxy-hub-cli call <toolName> [args...]
    
    • toolName: The name of the tool to call.
    • args: Arguments for the tool in key=value format.
    • --output-dir <dir> or -o <dir>: Save the output to a directory.

    Example:

    mcp-proxy-hub-cli call my_tool param1=value1 -o output
    

Interactive Mode

If you run the CLI without any arguments, it will start in interactive mode. This provides a shell-like interface for running commands.

mcp-proxy-hub-cli

Once in interactive mode, you can use the following commands:

  • list: List available tools.
  • call <toolName> [args...]: Call a tool with arguments.
  • exit: Exit the interactive session.

Installation

To use with Claude Desktop, add the server config:

On MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json On Windows: %APPDATA%/Claude/claude_desktop_config.json

{
  "mcpServers": {
    "mcp-proxy-hub": {
      "command": "/path/to/mcp-proxy-hub/build/index.js",
      "env": {
        "MCP_PROXY_CONFIG_PATH": "/absolute/path/to/your/config.json",
        "KEEP_SERVER_OPEN": "1"
      }
    }
  }
}

KEEP_SERVER_OPEN will keep the SSE running even if a client disconnects. This is useful when multiple clients connect to the MCP proxy.

Debugging

Since MCP servers communicate over stdio, debugging can be challenging. We recommend using the MCP Inspector, which is available as a package script:

npm run inspector

The Inspector will provide a URL to access debugging tools in your browser.

Related Servers