pub struct JsonRpcService<S> { /* private fields */ }Expand description
Service that handles JSON-RPC framing.
Wraps an MCP service and handles JSON-RPC request/response conversion. Supports both single requests and batch requests.
Can be created directly via JsonRpcService::new or through the
JsonRpcLayer for ServiceBuilder composition.
§Example
use tower_mcp::{McpRouter, JsonRpcService};
let router = McpRouter::new().server_info("my-server", "1.0.0");
let service = JsonRpcService::new(router);Implementations§
Source§impl<S> JsonRpcService<S>
impl<S> JsonRpcService<S>
Sourcepub fn with_extensions(self, ext: Extensions) -> Self
pub fn with_extensions(self, ext: Extensions) -> Self
Set extensions to inject into every RouterRequest created by this service.
This is used by transports to bridge data (e.g., TokenClaims) from the
HTTP/WebSocket layer into the MCP request pipeline.
Sourcepub async fn call_single(
&mut self,
req: JsonRpcRequest,
) -> Result<JsonRpcResponse>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
pub async fn call_single(
&mut self,
req: JsonRpcRequest,
) -> Result<JsonRpcResponse>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
Process a single JSON-RPC request
Sourcepub async fn call_batch(
&mut self,
requests: Vec<JsonRpcRequest>,
) -> Result<Vec<JsonRpcResponse>>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
pub async fn call_batch(
&mut self,
requests: Vec<JsonRpcRequest>,
) -> Result<Vec<JsonRpcResponse>>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
Process a batch of JSON-RPC requests concurrently
Sourcepub async fn call_message(
&mut self,
msg: JsonRpcMessage,
) -> Result<JsonRpcResponseMessage>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
pub async fn call_message(
&mut self,
msg: JsonRpcMessage,
) -> Result<JsonRpcResponseMessage>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
Process a JSON-RPC message (single or batch)
Trait Implementations§
Source§impl<S> Clone for JsonRpcService<S>where
S: Clone,
impl<S> Clone for JsonRpcService<S>where
S: Clone,
Source§impl<S> Service<JsonRpcMessage> for JsonRpcService<S>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
Service implementation for JSON-RPC batch requests
impl<S> Service<JsonRpcMessage> for JsonRpcService<S>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
Service implementation for JSON-RPC batch requests
Source§type Response = JsonRpcResponseMessage
type Response = JsonRpcResponseMessage
Responses given by the service.
Source§type Future = Pin<Box<dyn Future<Output = Result<<JsonRpcService<S> as Service<JsonRpcMessage>>::Response, <JsonRpcService<S> as Service<JsonRpcMessage>>::Error>> + Send>>
type Future = Pin<Box<dyn Future<Output = Result<<JsonRpcService<S> as Service<JsonRpcMessage>>::Response, <JsonRpcService<S> as Service<JsonRpcMessage>>::Error>> + Send>>
The future response value.
Source§impl<S> Service<JsonRpcRequest> for JsonRpcService<S>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
impl<S> Service<JsonRpcRequest> for JsonRpcService<S>where
S: Service<RouterRequest, Response = RouterResponse, Error = Infallible> + Clone + Send + 'static,
S::Future: Send,
Source§type Response = JsonRpcResponse
type Response = JsonRpcResponse
Responses given by the service.
Source§type Future = Pin<Box<dyn Future<Output = Result<<JsonRpcService<S> as Service<JsonRpcRequest>>::Response, <JsonRpcService<S> as Service<JsonRpcRequest>>::Error>> + Send>>
type Future = Pin<Box<dyn Future<Output = Result<<JsonRpcService<S> as Service<JsonRpcRequest>>::Response, <JsonRpcService<S> as Service<JsonRpcRequest>>::Error>> + Send>>
The future response value.
Auto Trait Implementations§
impl<S> Freeze for JsonRpcService<S>where
S: Freeze,
impl<S> !RefUnwindSafe for JsonRpcService<S>
impl<S> Send for JsonRpcService<S>where
S: Send,
impl<S> Sync for JsonRpcService<S>where
S: Sync,
impl<S> Unpin for JsonRpcService<S>where
S: Unpin,
impl<S> !UnwindSafe for JsonRpcService<S>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T, Request> ServiceExt<Request> for T
impl<T, Request> ServiceExt<Request> for T
Source§fn ready(&mut self) -> Ready<'_, Self, Request>where
Self: Sized,
fn ready(&mut self) -> Ready<'_, Self, Request>where
Self: Sized,
Yields a mutable reference to the service when it is ready to accept a request.
Source§fn ready_oneshot(self) -> ReadyOneshot<Self, Request>where
Self: Sized,
fn ready_oneshot(self) -> ReadyOneshot<Self, Request>where
Self: Sized,
Yields the service when it is ready to accept a request.
Source§fn oneshot(self, req: Request) -> Oneshot<Self, Request>where
Self: Sized,
fn oneshot(self, req: Request) -> Oneshot<Self, Request>where
Self: Sized,
Consume this
Service, calling it with the provided request once it is ready.Source§fn and_then<F>(self, f: F) -> AndThen<Self, F>
fn and_then<F>(self, f: F) -> AndThen<Self, F>
Executes a new future after this service’s future resolves. This does
not alter the behaviour of the
poll_ready method. Read moreSource§fn map_response<F, Response>(self, f: F) -> MapResponse<Self, F>
fn map_response<F, Response>(self, f: F) -> MapResponse<Self, F>
Maps this service’s response value to a different value. This does not
alter the behaviour of the
poll_ready method. Read moreSource§fn map_err<F, Error>(self, f: F) -> MapErr<Self, F>
fn map_err<F, Error>(self, f: F) -> MapErr<Self, F>
Maps this service’s error value to a different value. This does not
alter the behaviour of the
poll_ready method. Read moreSource§fn map_result<F, Response, Error>(self, f: F) -> MapResult<Self, F>
fn map_result<F, Response, Error>(self, f: F) -> MapResult<Self, F>
Maps this service’s result type (
Result<Self::Response, Self::Error>)
to a different value, regardless of whether the future succeeds or
fails. Read moreSource§fn map_request<F, NewRequest>(self, f: F) -> MapRequest<Self, F>
fn map_request<F, NewRequest>(self, f: F) -> MapRequest<Self, F>
Composes a function in front of the service. Read more
Source§fn then<F, Response, Error, Fut>(self, f: F) -> Then<Self, F>
fn then<F, Response, Error, Fut>(self, f: F) -> Then<Self, F>
Composes an asynchronous function after this service. Read more
Source§fn map_future<F, Fut, Response, Error>(self, f: F) -> MapFuture<Self, F>
fn map_future<F, Fut, Response, Error>(self, f: F) -> MapFuture<Self, F>
Composes a function that transforms futures produced by the service. Read more