Skip to main content

ValidationOutcome

Enum ValidationOutcome 

Source
pub enum ValidationOutcome {
    Ok {
        contract: TokenContract,
        consumed: bool,
        effective_ttl: Duration,
    },
    Rejected(TokenLifecycleError),
}
Expand description

Outcome of a TokenValidator::validate call.

The validator always returns a ValidationOutcome — never a Result — so the caller can branch on the outcome without unwrapping. The error path embeds the structured InvalidationReason for diagnostic routing.

§Example

use stygian_charon::token_lifecycle::{
    ChallengeClass, TokenContract, TokenPolicyTable, TokenValidator,
    ValidationOutcome,
};
use stygian_charon::vendor_classifier::VendorId;
use std::time::Duration;

let validator = TokenValidator::with_defaults(TokenPolicyTable::with_builtin_defaults());
let contract = TokenContract {
    token_id: "x".to_string(),
    issued_at_unix_secs: 0,
    ttl: Duration::from_mins(5),
    nonce: "n".to_string(),
    vendor_family: VendorId::Cloudflare,
    challenge_class: ChallengeClass::Interstitial,
    single_use: true,
    bound_session: None,
    description: String::new(),
};
let outcome = validator.validate(&contract, None, 60);
assert!(matches!(outcome, ValidationOutcome::Ok { .. }));

Variants§

§

Ok

Validator accepted the submission.

Fields

§contract: TokenContract

Contract that was accepted (with the TTL the validator actually applied — possibly clamped to the per-vendor max_ttl).

§consumed: bool

true when the nonce was newly observed by this submission (i.e. the validator marked it consumed). false for multi-use tokens whose nonce was already in the NonceBook.

§effective_ttl: Duration

Effective TTL the validator applied after clamping.

§

Rejected(TokenLifecycleError)

Validator rejected the submission. The error carries the structured InvalidationReason and a human-readable message suitable for operator logs.

Implementations§

Source§

impl ValidationOutcome

Source

pub const fn is_ok(&self) -> bool

true when the validator accepted the submission.

§Example
use stygian_charon::token_lifecycle::{ValidationOutcome};

let outcome = ValidationOutcome::Ok {
    contract: stygian_charon::token_lifecycle::TokenContract {
        token_id: "x".to_string(),
        issued_at_unix_secs: 0,
        ttl: std::time::Duration::from_mins(1),
        nonce: "n".to_string(),
        vendor_family: stygian_charon::vendor_classifier::VendorId::Unknown,
        challenge_class: stygian_charon::token_lifecycle::ChallengeClass::None,
        single_use: false,
        bound_session: None,
        description: String::new(),
    },
    consumed: true,
    effective_ttl: std::time::Duration::from_mins(1),
};
assert!(outcome.is_ok());
Source

pub const fn is_rejected(&self) -> bool

true when the validator rejected the submission.

Source

pub const fn error(&self) -> Option<&TokenLifecycleError>

Borrow the underlying error when Rejected.

Source

pub fn invalidation_kind(&self) -> Option<InvalidationKind>

Invalidation kind when Rejected.

Trait Implementations§

Source§

impl Clone for ValidationOutcome

Source§

fn clone(&self) -> ValidationOutcome

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 ValidationOutcome

Source§

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

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

impl PartialEq for ValidationOutcome

Source§

fn eq(&self, other: &ValidationOutcome) -> 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 Eq for ValidationOutcome

Source§

impl StructuralPartialEq for ValidationOutcome

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
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

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.

§

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

§

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
§

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