Skip to main content

StdioTransport

Struct StdioTransport 

Source
pub struct StdioTransport { /* private fields */ }
Expand description

MCP stdio transport proxy.

Spawns the upstream MCP server as a child process and proxies MCP messages between the client (our stdin/stdout) and the server (child process stdin/stdout), applying policy evaluation on tool calls.

Implementations§

Source§

impl StdioTransport

Source

pub fn new( engine: Engine, audit: AuditLogger, command: String, args: Vec<String>, fail_open: bool, ) -> Self

Creates a new stdio transport proxy.

Source

pub fn with_shared_engine( engine: Arc<RwLock<Engine>>, audit: AuditLogger, command: String, args: Vec<String>, fail_open: bool, ) -> Self

Creates a new stdio transport proxy with a shared engine reference.

Use this when hot-reload is enabled — the caller retains a clone of the Arc<RwLock<Engine>> and can swap the engine atomically while the proxy is running.

Source

pub fn with_approval_backend(self, backend: Arc<dyn ApprovalBackend>) -> Self

Sets the approval backend for handling RequireApproval decisions.

Source

pub fn engine(&self) -> &Arc<RwLock<Engine>>

Returns a reference to the shared engine (for hot-reload wiring).

Source

pub async fn run(&self) -> Result<(), Box<dyn Error>>

Runs the stdio proxy with graceful shutdown.

Spawns the upstream MCP server as a child process, then proxies all MCP messages through the policy engine. This function blocks until the client disconnects (stdin EOF), the child process exits, or a shutdown signal (SIGTERM/SIGINT) is received.

On shutdown signal:

  1. Active proxy loop is allowed to drain (up to 30s by default)
  2. Audit log is flushed
  3. Upstream child process is terminated cleanly

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more