pub struct WorkloadPrincipal {
pub workload_id: WorkloadId,
pub trust_domain: TrustDomain,
pub issuer: Issuer,
pub tenant_id: TenantId,
pub tenant_slug: String,
pub service_name: String,
pub attributes: BTreeMap<String, Value>,
}Expand description
A workload principal: a service, batch job, agent, or other non-human compute identity. Carries the SPIFFE-shaped workload id, its trust domain, the issuer that vouched for it, the tenant scope, and arbitrary attributes (empty today; populated from JWT claims when JWT-SVID resolution lands).
Fields§
§workload_id: WorkloadIdSPIFFE-shaped workload identifier.
trust_domain: TrustDomainTrust domain the workload belongs to. Redundant with the
authority component of workload_id but
surfaced explicitly for ergonomic policy access.
issuer: IssuerHow the workload’s identity was vouched for at resolution time.
tenant_id: TenantIdTenant the workload is scoped to.
tenant_slug: StringHuman-readable tenant slug (matches tenants.name in the
adopter’s storage). Carried alongside the typed
tenant_id for log lines and admin UIs that
need the readable form without a registry lookup.
service_name: StringService identifier: "compute-worker", "feed-worker", etc.
attributes: BTreeMap<String, Value>Arbitrary key-value attributes from the resolver. Empty for
CliResolver; populated from JWT claims by future federation
resolvers.
Trait Implementations§
Source§impl Clone for WorkloadPrincipal
impl Clone for WorkloadPrincipal
Source§fn clone(&self) -> WorkloadPrincipal
fn clone(&self) -> WorkloadPrincipal
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for WorkloadPrincipal
impl Debug for WorkloadPrincipal
Source§impl<'de> Deserialize<'de> for WorkloadPrincipal
impl<'de> Deserialize<'de> for WorkloadPrincipal
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<WorkloadPrincipal, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<WorkloadPrincipal, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Source§impl PartialEq for WorkloadPrincipal
impl PartialEq for WorkloadPrincipal
Source§fn eq(&self, other: &WorkloadPrincipal) -> bool
fn eq(&self, other: &WorkloadPrincipal) -> bool
self and other values to be equal, and is used by ==.Source§impl Serialize for WorkloadPrincipal
impl Serialize for WorkloadPrincipal
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,
Source§impl ToCedarEntity for WorkloadPrincipal
Available on crate feature authz only.
impl ToCedarEntity for WorkloadPrincipal
authz only.Source§fn cedar_entity_uid(&self) -> Result<EntityUid, AuthzError>
fn cedar_entity_uid(&self) -> Result<EntityUid, AuthzError>
EntityUid for this principal without
constructing the full entity. Useful when the caller only
needs the UID for an authorization request (entity attributes
supplied separately via an
AuthzEntityProvider).Source§fn to_cedar_entity(&self) -> Result<Entity, AuthzError>
fn to_cedar_entity(&self) -> Result<Entity, AuthzError>
Entity for this principal: UID plus
attribute record.impl Eq for WorkloadPrincipal
impl StructuralPartialEq for WorkloadPrincipal
Auto Trait Implementations§
impl Freeze for WorkloadPrincipal
impl RefUnwindSafe for WorkloadPrincipal
impl Send for WorkloadPrincipal
impl Sync for WorkloadPrincipal
impl Unpin for WorkloadPrincipal
impl UnsafeUnpin for WorkloadPrincipal
impl UnwindSafe for WorkloadPrincipal
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
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
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>
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>
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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.