Skip to main content

ContextConfig

Struct ContextConfig 

Source
pub struct ContextConfig {
    pub country: Option<String>,
    pub region: Option<String>,
    pub industry: Option<String>,
    pub compliance: Vec<String>,
}
Expand description

Optional per-project context loaded from rustio.context.json.

The 0.6.0 shape covers four axes:

  • country — ISO-3166-1 alpha-2 ("SE", "NO", …). Drives locale-aware naming (a Swedish project gets personnummer for “personal id”, not an i32).
  • region — supra-national grouping ("EU"). Mostly inferred from country; explicit setting is an override.
  • industry"housing", "healthcare", "banking". Picked up by the planner / review / executor so “patient id” under healthcare becomes a String rather than an i32, and removing a convention field raises a warning.
  • compliance — explicit list (["GDPR", "HIPAA"]). Empty by default; the helpers below treat region=EU as implying GDPR even when the list is empty.

#[serde(default, deny_unknown_fields)] keeps the wire contract tight: a typo is a loud error, not a silent miss.

Breaking change vs 0.5.x: the old domain key is gone. If your rustio.context.json still reads {"domain": "housing"}, rename the key to industry.

Fields§

§country: Option<String>§region: Option<String>§industry: Option<String>§compliance: Vec<String>

Implementations§

Source§

impl ContextConfig

Source

pub fn parse(json: &str) -> Result<Self, PlanError>

Source

pub fn effective_region(&self) -> Option<String>

Either the explicit region, or a best-effort inference from country. Today we only know the EU list; other regions (ASEAN, LATAM, MENA, …) fall through to None until projects ask for them.

Source

pub fn requires_gdpr(&self) -> bool

true if the project operates under the GDPR. Detected by either (a) compliance listing "GDPR" explicitly, or (b) the resolved region being "EU".

Source

pub fn industry_schema(&self) -> Option<IndustrySchema>

Look up the industry convention bundle for the selected industry (case-insensitive). None if the project didn’t set one or the name isn’t in the registry.

Source

pub fn pii_fields(&self) -> Vec<&'static str>

Field names considered personally-identifying under the current context. Returns a stable, deduplicated list. Used by the review layer to escalate risk on destructive primitives and by the executor to refuse them outright with ExecutionError::PolicyViolation.

Conservative by design: the list grows only as each rule is justified. A project needing stricter enforcement can still layer its own checks on top.

Source

pub fn is_empty(&self) -> bool

true when the context carries at least one useful signal. The CLI uses this to decide whether rustio context show has something to print.

Trait Implementations§

Source§

impl Clone for ContextConfig

Source§

fn clone(&self) -> ContextConfig

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 ContextConfig

Source§

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

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

impl Default for ContextConfig

Source§

fn default() -> ContextConfig

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for ContextConfig

Source§

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 ContextConfig

Source§

fn eq(&self, other: &ContextConfig) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for ContextConfig

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl StructuralPartialEq for ContextConfig

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.

Source§

impl<T> Instrument for T

Source§

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

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

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

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

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

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,