pub struct GuardrailConfig {
pub enabled: bool,
pub provider: Option<String>,
pub model: Option<String>,
pub timeout_ms: u64,
pub action: GuardrailAction,
pub fail_strategy: GuardrailFailStrategy,
pub scan_tool_output: bool,
pub max_input_chars: usize,
}Expand description
Configuration for the LLM-based guardrail, nested under [security.guardrail].
Fields§
§enabled: boolEnable the guardrail (default: false).
provider: Option<String>Provider to use for guardrail classification (e.g. "ollama", "claude").
model: Option<String>Model to use (e.g. "llama-guard-3:1b").
timeout_ms: u64Timeout for each guardrail LLM call in milliseconds (default: 500).
action: GuardrailActionAction to take when a message is flagged (default: block).
fail_strategy: GuardrailFailStrategyWhat to do on timeout or LLM error (default: closed — block).
scan_tool_output: boolWhen true, also scan tool outputs before they enter message history (default: false).
max_input_chars: usizeMaximum number of characters to send to the guard model (default: 4096).
Trait Implementations§
Source§impl Clone for GuardrailConfig
impl Clone for GuardrailConfig
Source§fn clone(&self) -> GuardrailConfig
fn clone(&self) -> GuardrailConfig
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for GuardrailConfig
impl Debug for GuardrailConfig
Source§impl Default for GuardrailConfig
impl Default for GuardrailConfig
Source§fn default() -> GuardrailConfig
fn default() -> GuardrailConfig
Returns the “default value” for a type. Read more
Source§impl<'de> Deserialize<'de> for GuardrailConfig
impl<'de> Deserialize<'de> for GuardrailConfig
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<GuardrailConfig, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<GuardrailConfig, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl PartialEq for GuardrailConfig
impl PartialEq for GuardrailConfig
Source§impl Serialize for GuardrailConfig
impl Serialize for GuardrailConfig
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl StructuralPartialEq for GuardrailConfig
Auto Trait Implementations§
impl Freeze for GuardrailConfig
impl RefUnwindSafe for GuardrailConfig
impl Send for GuardrailConfig
impl Sync for GuardrailConfig
impl Unpin for GuardrailConfig
impl UnsafeUnpin for GuardrailConfig
impl UnwindSafe for GuardrailConfig
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> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request