pub struct TrustGateExecutor<T: ToolExecutor> { /* private fields */ }Expand description
Wraps an inner ToolExecutor and applies trust-level permission overlays.
Implementations§
Source§impl<T: ToolExecutor> TrustGateExecutor<T>
impl<T: ToolExecutor> TrustGateExecutor<T>
pub fn new(inner: T, policy: PermissionPolicy) -> Self
Sourcepub fn mcp_tool_ids_handle(&self) -> Arc<RwLock<HashSet<String>>>
pub fn mcp_tool_ids_handle(&self) -> Arc<RwLock<HashSet<String>>>
Returns the shared MCP tool ID set so the caller can populate it after
MCP servers have connected (and after TrustGateExecutor has been wrapped
in a DynExecutor).
pub fn set_effective_trust(&self, level: TrustLevel)
pub fn effective_trust(&self) -> TrustLevel
Trait Implementations§
Source§impl<T: ToolExecutor + Debug> Debug for TrustGateExecutor<T>
impl<T: ToolExecutor + Debug> Debug for TrustGateExecutor<T>
Source§impl<T: ToolExecutor> ToolExecutor for TrustGateExecutor<T>
impl<T: ToolExecutor> ToolExecutor for TrustGateExecutor<T>
async fn execute(&self, response: &str) -> Result<Option<ToolOutput>, ToolError>
Source§async fn execute_confirmed(
&self,
response: &str,
) -> Result<Option<ToolOutput>, ToolError>
async fn execute_confirmed( &self, response: &str, ) -> Result<Option<ToolOutput>, ToolError>
Execute bypassing confirmation checks (called after user approves).
Default: delegates to
execute.Source§fn tool_definitions(&self) -> Vec<ToolDef>
fn tool_definitions(&self) -> Vec<ToolDef>
Return tool definitions this executor can handle.
Source§async fn execute_tool_call(
&self,
call: &ToolCall,
) -> Result<Option<ToolOutput>, ToolError>
async fn execute_tool_call( &self, call: &ToolCall, ) -> Result<Option<ToolOutput>, ToolError>
Execute a structured tool call. Returns
None if tool_id is not handled.Source§async fn execute_tool_call_confirmed(
&self,
call: &ToolCall,
) -> Result<Option<ToolOutput>, ToolError>
async fn execute_tool_call_confirmed( &self, call: &ToolCall, ) -> Result<Option<ToolOutput>, ToolError>
Execute a structured tool call bypassing confirmation checks. Read more
Source§fn set_skill_env(&self, env: Option<HashMap<String, String>>)
fn set_skill_env(&self, env: Option<HashMap<String, String>>)
Inject environment variables for the currently active skill. No-op by default.
Source§fn set_effective_trust(&self, level: TrustLevel)
fn set_effective_trust(&self, level: TrustLevel)
Set the effective trust level for the currently active skill. No-op by default.
Auto Trait Implementations§
impl<T> !Freeze for TrustGateExecutor<T>
impl<T> RefUnwindSafe for TrustGateExecutor<T>where
T: RefUnwindSafe,
impl<T> Send for TrustGateExecutor<T>
impl<T> Sync for TrustGateExecutor<T>
impl<T> Unpin for TrustGateExecutor<T>where
T: Unpin,
impl<T> UnsafeUnpin for TrustGateExecutor<T>where
T: UnsafeUnpin,
impl<T> UnwindSafe for TrustGateExecutor<T>where
T: UnwindSafe,
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> ErasedToolExecutor for Twhere
T: ToolExecutor,
impl<T> ErasedToolExecutor for Twhere
T: ToolExecutor,
fn execute_erased<'a>( &'a self, response: &'a str, ) -> Pin<Box<dyn Future<Output = Result<Option<ToolOutput>, ToolError>> + Send + 'a>>
fn execute_confirmed_erased<'a>( &'a self, response: &'a str, ) -> Pin<Box<dyn Future<Output = Result<Option<ToolOutput>, ToolError>> + Send + 'a>>
fn tool_definitions_erased(&self) -> Vec<ToolDef>
fn execute_tool_call_erased<'a>( &'a self, call: &'a ToolCall, ) -> Pin<Box<dyn Future<Output = Result<Option<ToolOutput>, ToolError>> + Send + 'a>>
fn execute_tool_call_confirmed_erased<'a>( &'a self, call: &'a ToolCall, ) -> Pin<Box<dyn Future<Output = Result<Option<ToolOutput>, ToolError>> + Send + 'a>>
Source§fn set_skill_env(&self, env: Option<HashMap<String, String>>)
fn set_skill_env(&self, env: Option<HashMap<String, String>>)
Inject environment variables for the currently active skill. No-op by default.
Source§fn set_effective_trust(&self, level: TrustLevel)
fn set_effective_trust(&self, level: TrustLevel)
Set the effective trust level for the currently active skill. No-op by default.
Source§fn is_tool_retryable_erased(&self, tool_id: &str) -> bool
fn is_tool_retryable_erased(&self, tool_id: &str) -> bool
Whether the executor can safely retry this tool call on a transient error.