Skip to main content

fastmcp.server.providers.proxy

ProxyProvider for proxying to remote MCP servers. This module provides the ProxyProvider class that proxies components from a remote MCP server via a client factory. It also provides proxy component classes that forward execution to remote servers.

Functions

default_proxy_roots_handler

default_proxy_roots_handler(context: RequestContext[ClientSession, LifespanContextT]) -> RootsList
Forward list roots request from remote server to proxy’s connected clients.

default_proxy_sampling_handler

default_proxy_sampling_handler(messages: list[mcp.types.SamplingMessage], params: mcp.types.CreateMessageRequestParams, context: RequestContext[ClientSession, LifespanContextT]) -> mcp.types.CreateMessageResult
Forward sampling request from remote server to proxy’s connected clients.

default_proxy_elicitation_handler

default_proxy_elicitation_handler(message: str, response_type: type, params: mcp.types.ElicitRequestParams, context: RequestContext[ClientSession, LifespanContextT]) -> ElicitResult
Forward elicitation request from remote server to proxy’s connected clients.

default_proxy_log_handler

default_proxy_log_handler(message: LogMessage) -> None
Forward log notification from remote server to proxy’s connected clients.

default_proxy_progress_handler

default_proxy_progress_handler(progress: float, total: float | None, message: str | None) -> None
Forward progress notification from remote server to proxy’s connected clients.

Classes

ProxyTool

A Tool that represents and executes a tool on a remote server. Methods:

model_copy

model_copy(self, **kwargs: Any) -> ProxyTool
Override to preserve _backend_name when name changes.

from_mcp_tool

from_mcp_tool(cls, client_factory: ClientFactoryT, mcp_tool: mcp.types.Tool) -> ProxyTool
Factory method to create a ProxyTool from a raw MCP tool schema.

run

run(self, arguments: dict[str, Any], context: Context | None = None) -> ToolResult
Executes the tool by making a call through the client.

ProxyResource

A Resource that represents and reads a resource from a remote server. Methods:

model_copy

model_copy(self, **kwargs: Any) -> ProxyResource
Override to preserve _backend_uri when uri changes.

from_mcp_resource

from_mcp_resource(cls, client_factory: ClientFactoryT, mcp_resource: mcp.types.Resource) -> ProxyResource
Factory method to create a ProxyResource from a raw MCP resource schema.

read

read(self) -> ResourceResult
Read the resource content from the remote server.

ProxyTemplate

A ResourceTemplate that represents and creates resources from a remote server template. Methods:

model_copy

model_copy(self, **kwargs: Any) -> ProxyTemplate
Override to preserve _backend_uri_template when uri_template changes.

from_mcp_template

from_mcp_template(cls, client_factory: ClientFactoryT, mcp_template: mcp.types.ResourceTemplate) -> ProxyTemplate
Factory method to create a ProxyTemplate from a raw MCP template schema.

create_resource

create_resource(self, uri: str, params: dict[str, Any], context: Context | None = None) -> ProxyResource
Create a resource from the template by calling the remote server.

ProxyPrompt

A Prompt that represents and renders a prompt from a remote server. Methods:

model_copy

model_copy(self, **kwargs: Any) -> ProxyPrompt
Override to preserve _backend_name when name changes.

from_mcp_prompt

from_mcp_prompt(cls, client_factory: ClientFactoryT, mcp_prompt: mcp.types.Prompt) -> ProxyPrompt
Factory method to create a ProxyPrompt from a raw MCP prompt schema.

render

render(self, arguments: dict[str, Any]) -> PromptResult
Render the prompt by making a call through the client.

ProxyProvider

Provider that proxies to a remote MCP server via a client factory. This provider fetches components from a remote server and returns Proxy* component instances that forward execution to the remote server. All components returned by this provider have task_config.mode=“forbidden” because tasks cannot be executed through a proxy. Methods:

list_tools

list_tools(self) -> Sequence[Tool]
List all tools from the remote server.

list_resources

list_resources(self) -> Sequence[Resource]
List all resources from the remote server.

list_resource_templates

list_resource_templates(self) -> Sequence[ResourceTemplate]
List all resource templates from the remote server.

list_prompts

list_prompts(self) -> Sequence[Prompt]
List all prompts from the remote server.

get_tasks

get_tasks(self) -> Sequence[FastMCPComponent]
Return empty list since proxy components don’t support tasks. Override the base implementation to avoid calling list_tools() during server lifespan initialization, which would open the client before any context is set. All Proxy* components have task_config.mode=“forbidden”.

FastMCPProxy

A FastMCP server that acts as a proxy to a remote MCP-compliant server. This is a convenience wrapper that creates a FastMCP server with a ProxyProvider. For more control, use FastMCP with add_provider(ProxyProvider(…)).

ProxyClient

A proxy client that forwards advanced interactions between a remote MCP server and the proxy’s connected clients. Supports forwarding roots, sampling, elicitation, logging, and progress.

StatefulProxyClient

A proxy client that provides a stateful client factory for the proxy server. The stateful proxy client bound its copy to the server session. And it will be disconnected when the session is exited. This is useful to proxy a stateful mcp server such as the Playwright MCP server. Note that it is essential to ensure that the proxy server itself is also stateful. Methods:

clear

clear(self)
Clear all cached clients and force disconnect them.

new_stateful

new_stateful(self) -> Client[ClientTransportT]
Create a new stateful proxy client instance with the same configuration. Use this method as the client factory for stateful proxy server.