Skip to main content

InspectResult

Struct InspectResult 

Source
#[non_exhaustive]
pub struct InspectResult { pub issuer: Option<String>, pub subject: Option<String>, pub key_id: Option<Vec<u8>>, pub algorithm: Option<Algorithm>, pub x509_headers: X509Headers, pub expires_at: Option<i64>, pub cose_type: CoseType, }
Expand description

Metadata extracted from a credential without full verification or decoding.

Useful for determining which key to use before calling Decoder::decode(). This allows verifiers in multi-issuer scenarios to:

  1. Inspect the credential to find the issuer and key ID
  2. Look up the correct verification key
  3. Perform full decoding with the appropriate key

§Example

use claim169_core::inspect;

let info = inspect(qr_text)?;
println!("Issuer: {:?}, Key ID: {:?}", info.issuer, info.key_id);

// Use the metadata to select the right verification key
let public_key = key_store.get(&info.issuer, &info.key_id);
let result = Decoder::new(qr_text)
    .verify_with_ed25519(&public_key)?
    .decode()?;

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§issuer: Option<String>

Issuer from CWT claims (claim key 1).

§subject: Option<String>

Subject from CWT claims (claim key 2).

§key_id: Option<Vec<u8>>

Key ID from the COSE header.

§algorithm: Option<Algorithm>

COSE algorithm declared in the protected header.

§x509_headers: X509Headers

X.509 certificate headers from the COSE structure.

§expires_at: Option<i64>

Expiration time from CWT claims (Unix epoch seconds).

§cose_type: CoseType

COSE structure type (Sign1 or Encrypt0).

Trait Implementations§

Source§

impl Clone for InspectResult

Source§

fn clone(&self) -> InspectResult

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 InspectResult

Source§

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

Formats the value using the given formatter. 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.

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