pub enum EnforcementTier {
KernelDeny,
ObserveOnly,
ProxyOnly,
}Expand description
The platform’s enforcement tier, so operators don’t over-trust a weaker OS (PRODUCT.md W0 table). The proxy itself is cross-platform; what differs is whether kernel deny backs it up.
Variants§
KernelDeny
Inline kernel deny available (Linux LSM-BPF).
ObserveOnly
Observe-only kernel layer (macOS Endpoint Security is mostly observe); the proxy is the sole hard deny and MUST be fail-closed.
ProxyOnly
Proxy-only — no kernel layer wired at all; fully reliant on this PEP.
Implementations§
Source§impl EnforcementTier
impl EnforcementTier
Sourcepub fn current() -> Self
pub fn current() -> Self
The tier of the host this binary is running on.
macOS gets EnforcementTier::ObserveOnly: Endpoint Security is mostly
observe, so the cross-platform proxy is the only hard deny (PRODUCT.md W0).
Trait Implementations§
Source§impl Clone for EnforcementTier
impl Clone for EnforcementTier
Source§fn clone(&self) -> EnforcementTier
fn clone(&self) -> EnforcementTier
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 EnforcementTier
impl Debug for EnforcementTier
Source§impl PartialEq for EnforcementTier
impl PartialEq for EnforcementTier
Source§fn eq(&self, other: &EnforcementTier) -> bool
fn eq(&self, other: &EnforcementTier) -> bool
Tests for
self and other values to be equal, and is used by ==.impl Copy for EnforcementTier
impl Eq for EnforcementTier
impl StructuralPartialEq for EnforcementTier
Auto Trait Implementations§
impl Freeze for EnforcementTier
impl RefUnwindSafe for EnforcementTier
impl Send for EnforcementTier
impl Sync for EnforcementTier
impl Unpin for EnforcementTier
impl UnsafeUnpin for EnforcementTier
impl UnwindSafe for EnforcementTier
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<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