Skip to content

Latest commit

 

History

History
234 lines (165 loc) · 7.41 KB

README.md

File metadata and controls

234 lines (165 loc) · 7.41 KB

Foreword

This is very experimental and possibly totally useless 😁. Join this discussion for feedback, that will be greatly appreciated.

Note: This might contradict this: "Cross-server interactions are controlled by the host". Or not...

Overview

This project is related to Anthropic's Model Context Protocol (MCP, see docs and spec).

MCProxy is a proxy between MCP Clients and MCP Servers, allowing new features in the workflow between them (a few examples are given below).

MCProxy provides the building blocks for such a proxy architecture, along with some basic features (TBD: List of basic features).

New features can be added, depending on the user's needs, with plug-in modules (TBD: Plug-in mechanism).

Global architecture

From an MCP Client's perspective, MCProxy behaves like an MCP Server. From an MCP Server's perspective, MCProxy behaves like an MCP Client.

In its simplest form:

flowchart LR
    client1[MCP Client]
    subgraph "MCProxy"
        server1[MCP Server]
        client2[MCP Client]
    end
    server2[MCP Server]

    client1 <--MCP--> server1
    client2 <--MCP--> server2
    server1 <--> client2
Loading

An MCProxy can connect to multiple servers:

flowchart LR
    client1[MCP Client]
    subgraph "MCProxy"
        server1[MCP Server]
        client2[MCP Client A]
        client3[MCP Client B]
    end
    server2[MCP Server A]
    server3[MCP Server B]

    client1 <--MCP--> server1
    client2 <--MCP--> server2
    client3 <--MCP--> server3
    server1 <--> client2
    server1 <--> client3
Loading

An MCP Host may connect to different MCProxies with very different configurations:

flowchart LR
    subgraph "Host"
        clientH1[MCP Client]
        clientH2[MCP Client]
    end
    subgraph "MCProxy A"
        serverPA[MCP Server]
        clientPA[MCP Client]
    end
    serverA[MCP Server A]
    subgraph "MCProxy B"
        serverPB[MCP Server]
        clientPB[MCP Client]
    end
    serverB[MCP Server B]

    clientH1 <--MCP--> serverPA
    clientH2 <--MCP--> serverPB
    clientPA <--MCP--> serverA
    clientPB <--MCP--> serverB
    serverPA <--> clientPA
    serverPB <--> clientPB
Loading

If of any use, MCProxies can be chained:

flowchart LR
    client1[MCP Client]
    subgraph "MCProxy A"
        server1[MCP Server]
        client2[MCP Client]
    end
    subgraph "MCProxy B"
        server2[MCP Server]
        client3[MCP Client]
    end
    server3[MCP Server]

    client1 <--MCP--> server1
    client2 <--MCP--> server2
    client3 <--MCP--> server3
    server1 <--> client2
    server2 <--> client3
Loading

Internal architecture

The basic components are:

  • The Server manager, that handles the communication with the MCP Client (Requests but also Responses/Errors/Notifications)
  • The Clients manager, that maintains a list of connected MCP Servers and handles the communication with them (Requests but also Responses/Errors/Notifications)

The Internal features component provides a list of basic features that are always available.

The Modules manager maintains a list of external modules, which provide extra-features, and interacts with them.

The core component is the Dispatcher, that:

  • Forwards messages between the MCP Client and the MCP Servers, back and forth
  • Applies the internal features, when applicable
  • Calls the external modules, when applicable
flowchart LR
    subgraph MCProxy
        subgraph servermanager[Server manager]
            server[MCP Server]
        end
        dispatcher[Dispatcher]
        internalfeatures[Internal features]
        modulesmanager[Modules manager]
        subgraph clientsmanager[Clients manager]
            direction TB
            clientA[MCP Client A]
            clientB[MCP Client B]
        end
    end
    moduleA[External module A]
    moduleB[External module B]

    servermanager <--> dispatcher
    dispatcher <--> clientsmanager
    dispatcher <--> internalfeatures
    dispatcher <--> modulesmanager
    modulesmanager <--> moduleA
    modulesmanager <--> moduleB
Loading

Identifiers

By default, MCProxy exposes all the resources/prompts/tools of the MCP Servers it connects to, using the same identifiers (names, URIs...). These identifiers can be renamed (see Features below).

Configuration

In order to connect to MCP Servers, MCProxy uses the same configuration file format as defined in the Quickstart section of the MCP docs.

Some more internal configuration is available for the MCProxy itself.

Finally, each module provides some configuration directives. Examples are given below.

Note: In MCP Hosts, like Claude Dekstop, the configuration file would point towards the MCProxy, not the different servers behind it.

Features

Here are a few examples of features an MCProxy could implement, internally of through external modules.

Logging

An MCProxy can log all messages going back and forth between an MCP Client and an MCP Server.

Configuration:

  • What to log
  • Where to log

Capabilities aggregation

An MCProxy can aggregate capabilities from different MCP Servers into a meaningful package.

Capabilities blocking

An MCProxy may expose only a subset of the capabilities provided by the MCP Server(s) it connects to.

Configuration:

  • Capabilities to be blocked

Capabilities disambiguation

With the fast-growing number of MCP Servers, me might end up with some name collisions. An MCProxy may rename capabilities, so that they appear unique to an MCP Client, and handle routing to the appropriate MCP Server.

Configuration:

  • List of Server / Identifier => New identifier

Content update

Textual content can be filtered or enriched while going through MCProxy.

On-the-fly internationalization (i18n)

The current version of the MCP Specification does not provide i18n (see my issue about this).

An MCProxy could translate some fields on the fly, using a translation API or an LLM.

Configuration:

  • Preferred language
  • Connection parameters to the translation tool

External modules

They provide extra-features on top of the basic features provided by MCProxy itself.

They are independent projects that plug into an MCProxy.

A list of such modules could be maintained, just like lists of MCP Clients/Servers are currently being built (see for instance here, here or here).

Hosting

They can be hosted locally or remotely as a service.

Capabilities

They declare their "capabilities", that it the types of MCP messages they are interested in.

They are called in the order in which they are declared in the configuration file.

Protocol

The protocol between MCProxy and an external module is strongly inspired by the MCP specification.

But the workflow is quite different: Mostly, a response usually has the same type as the message sent.

For instance:

  • a GetPromptRequest message sent to a module would return an updated GetPromptRequest message
  • a ListToolsResult message sent to a module would return an updated ListToolsResult message

(TBD: Specification of such a protocol)