pub enum ContentTrustLevel {
Trusted,
LocalUntrusted,
ExternalUntrusted,
}Expand description
Trust tier assigned to content entering the agent context.
Drives spotlighting intensity: Trusted content passes
through unchanged; ExternalUntrusted receives
the strongest warning header.
The tier is typically derived automatically from ContentSourceKind::default_trust_level,
but can be overridden via ContentSource::with_trust_level when the call-site has
more context about the actual origin of the content.
§Examples
use zeph_sanitizer::{ContentTrustLevel, ContentSource, ContentSourceKind};
// Web scrapes default to the strongest warning level.
let source = ContentSource::new(ContentSourceKind::WebScrape);
assert_eq!(source.trust_level, ContentTrustLevel::ExternalUntrusted);
// Trust level can be overridden.
let elevated = source.with_trust_level(ContentTrustLevel::Trusted);
assert_eq!(elevated.trust_level, ContentTrustLevel::Trusted);Variants§
Trusted
System prompt, hardcoded instructions, direct user input. No wrapping applied.
LocalUntrusted
Tool results from local executors (shell, file I/O). Lighter warning.
ExternalUntrusted
External sources: web scrape, MCP, A2A, memory retrieval. Strongest warning.
Trait Implementations§
Source§impl Clone for ContentTrustLevel
impl Clone for ContentTrustLevel
Source§fn clone(&self) -> ContentTrustLevel
fn clone(&self) -> ContentTrustLevel
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 ContentTrustLevel
impl Debug for ContentTrustLevel
Source§impl<'de> Deserialize<'de> for ContentTrustLevel
impl<'de> Deserialize<'de> for ContentTrustLevel
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<ContentTrustLevel, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<ContentTrustLevel, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl Hash for ContentTrustLevel
impl Hash for ContentTrustLevel
Source§impl PartialEq for ContentTrustLevel
impl PartialEq for ContentTrustLevel
Source§impl Serialize for ContentTrustLevel
impl Serialize for ContentTrustLevel
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 Copy for ContentTrustLevel
impl Eq for ContentTrustLevel
impl StructuralPartialEq for ContentTrustLevel
Auto Trait Implementations§
impl Freeze for ContentTrustLevel
impl RefUnwindSafe for ContentTrustLevel
impl Send for ContentTrustLevel
impl Sync for ContentTrustLevel
impl Unpin for ContentTrustLevel
impl UnsafeUnpin for ContentTrustLevel
impl UnwindSafe for ContentTrustLevel
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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