Enum ComplianceRequest

Source
pub enum ComplianceRequest {
    EvalPolicies {
        source_policies: HashMap<String, HashMap<Resource, Policy>>,
        destination: Resource,
    },
    GetPolicy(Resource),
    GetPolicies(HashSet<Resource>),
    SetPolicy {
        resource: Resource,
        policy: Policy,
    },
    SetConfidentiality {
        resource: Resource,
        confidentiality: ConfidentialityPolicy,
    },
    SetIntegrity {
        resource: Resource,
        integrity: u32,
    },
    SetDeleted(Resource),
    SetConsent {
        resource: Resource,
        consent: bool,
    },
}
Expand description

Compliance service request types.

Internal API for the compliance service, which manages policies, evaluates authorization decisions, and enforces organizational and regulatory requirements for data flows.

Variants§

§

EvalPolicies

Evaluate whether a proposed data flow complies with all applicable policies.

Compares source resource policies against destination requirements to determine if the flow should be authorized. Considers confidentiality, integrity, consent, and other policy constraints.

Fields

§source_policies: HashMap<String, HashMap<Resource, Policy>>

Policies for source resources organized by authority node ID

§destination: Resource

Destination resource receiving the data

§

GetPolicy(Resource)

Retrieve the current compliance policy for a specific resource.

Returns the complete policy configuration including confidentiality, integrity, consent, and deletion status for the requested resource.

§

GetPolicies(HashSet<Resource>)

Retrieve current compliance policies for multiple resources.

Batch operation to efficiently query policy configurations for multiple resources in a single request.

§

SetPolicy

Set a complete compliance policy for a specific resource.

Replaces the existing policy with new configuration that defines all aspects of compliance requirements for the resource.

Fields

§resource: Resource

Target resource to apply the policy to

§policy: Policy

New complete policy configuration

§

SetConfidentiality

Update confidentiality requirements for a specific resource.

Modifies only the confidentiality aspects of the resource’s policy while preserving other policy components.

Fields

§resource: Resource

Target resource to update

§confidentiality: ConfidentialityPolicy

New confidentiality policy requirements

§

SetIntegrity

Update integrity level requirements for a specific resource.

Sets the minimum integrity level required for operations involving this resource, typically on a numerical scale.

Fields

§resource: Resource

Target resource to update

§integrity: u32

Minimum required integrity level

§

SetDeleted(Resource)

Mark a resource as deleted for compliance tracking.

Updates the resource’s policy to reflect its deletion status while maintaining historical records for audit purposes.

§

SetConsent

Update consent status for data processing operations on a resource.

Sets or revokes consent for operations that require explicit permission, typically for privacy and regulatory compliance.

Fields

§resource: Resource

Target resource to update consent for

§consent: bool

Consent status: true to grant, false to revoke

Trait Implementations§

Source§

impl Clone for ComplianceRequest

Source§

fn clone(&self) -> ComplianceRequest

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ComplianceRequest

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Service<ComplianceRequest> for ComplianceService<ConsentService>

Source§

type Response = ComplianceResponse

Responses given by the service.
Source§

type Error = TraceabilityError

Errors produced by the service.
Source§

type Future = Pin<Box<dyn Future<Output = Result<<ComplianceService as Service<ComplianceRequest>>::Response, <ComplianceService as Service<ComplianceRequest>>::Error>> + Send>>

The future response value.
Source§

fn poll_ready(&mut self, _: &mut Context<'_>) -> Poll<Result<(), Self::Error>>

Returns Poll::Ready(Ok(())) when the service is able to process requests. Read more
Source§

fn call(&mut self, request: ComplianceRequest) -> Self::Future

Process the request and return the response asynchronously. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for T
where T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
§

impl<L> LayerExt<L> for L

§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in [Layered].
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more