pub struct AuthzContext {
pub kind: Cow<'static, str>,
pub payload: Value,
}Expand description
Open enforcement-site context attached to an AuthzRequest.
Replaces the previous closed enum so tenants can add their own enforcement sites (skill execution, order submission, file egress, …) without a core change.
kind is a dotted-namespaced literal. Core mints three:
"none"— no context (server-attach RBAC, etc)."gateway.invocation"— payload{ "model": "..." }."mcp.tool_call"— payload{ "tool": "..." }.
Tenants mint their own (e.g. "acme.order_submission") and recognise
them in their hook. Core never interprets payload.
Fields§
§kind: Cow<'static, str>§payload: ValueImplementations§
Source§impl AuthzContext
impl AuthzContext
pub const NONE_KIND: &'static str = "none"
pub const GATEWAY_INVOCATION_KIND: &'static str = "gateway.invocation"
pub const MCP_TOOL_CALL_KIND: &'static str = "mcp.tool_call"
pub const MARKETPLACE_FLOOR_KEY: &'static str = "marketplace.attribute_floor"
pub const fn none() -> Self
pub fn gateway_invocation(model: &ModelId) -> Self
pub fn mcp_tool_call(tool: &McpToolName) -> Self
Sourcepub fn extension(kind: impl Into<Cow<'static, str>>, payload: Value) -> Self
pub fn extension(kind: impl Into<Cow<'static, str>>, payload: Value) -> Self
kind must be dotted-namespaced (e.g. "acme.order_submission") so
kinds from independent extensions cannot collide.
pub fn gateway_invocation_model(&self) -> Option<ModelId>
pub fn mcp_tool_call_tool(&self) -> Option<McpToolName>
pub fn is_none(&self) -> bool
Sourcepub fn with_marketplace_floor(&self, floor: &BTreeMap<String, Value>) -> Self
pub fn with_marketplace_floor(&self, floor: &BTreeMap<String, Value>) -> Self
The floor is an opaque tenant-namespaced bag the ABAC hook interprets;
core copies it verbatim. Keyed under MARKETPLACE_FLOOR_KEY so it
never collides with the typed model / tool payload entries, and
kind plus any existing payload are preserved.
pub fn marketplace_floor(&self) -> Option<BTreeMap<String, Value>>
Trait Implementations§
Source§impl Clone for AuthzContext
impl Clone for AuthzContext
Source§fn clone(&self) -> AuthzContext
fn clone(&self) -> AuthzContext
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · 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 AuthzContext
impl Debug for AuthzContext
Source§impl Default for AuthzContext
impl Default for AuthzContext
Source§impl<'de> Deserialize<'de> for AuthzContext
impl<'de> Deserialize<'de> for AuthzContext
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl PartialEq for AuthzContext
impl PartialEq for AuthzContext
Source§fn eq(&self, other: &AuthzContext) -> bool
fn eq(&self, other: &AuthzContext) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl Serialize for AuthzContext
impl Serialize for AuthzContext
impl Eq for AuthzContext
impl StructuralPartialEq for AuthzContext
Auto Trait Implementations§
impl Freeze for AuthzContext
impl RefUnwindSafe for AuthzContext
impl Send for AuthzContext
impl Sync for AuthzContext
impl Unpin for AuthzContext
impl UnsafeUnpin for AuthzContext
impl UnwindSafe for AuthzContext
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§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<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 more