CertChainRef

Struct CertChainRef 

Source
pub struct CertChainRef<'a> { /* private fields */ }
Available on crate feature manifest only.
Expand description

A reference to a byte slice that is expected to be a valid sequence of DER-encoded X.509 certificates.

This is used to store a chain of certificates in an Image4 manifests without actually parsing them. There are two reasons for this:

  1. The library currently uses the x509_cert crate to decode the certificates and that means the original signed TBS certificates are lost when a manifest is decoded. Verifying the manifest’s certificate chain isn’t possible in that case.
  2. Parsing the certificates requires processing time and memory. There is no reason to do this, for example, when all you want to do is to encode them back into DER and write to another file.

Implementations§

Source§

impl<'a> CertChainRef<'a>

Source

pub fn as_bytes(&self) -> &'a [u8]

Returns the contents of the body as a byte slice.

Source

pub fn len(&self) -> Length

Returns the length of the body.

Source

pub fn is_empty(&self) -> bool

Returns true if the body is empty.

Source§

impl CertChainRef<'_>

Source

pub fn decode_body(&self) -> Result<Vec<Certificate>>

Available on crate feature x509-cert only.

Decodes the body as a vector of Certificates.

Source§

impl CertChainRef<'_>

Source

pub fn iter(&self) -> CertIter<'_>

Returns iterator over individual certificates in the chain.

Trait Implementations§

Source§

impl<'a> Clone for CertChainRef<'a>

Source§

fn clone(&self) -> CertChainRef<'a>

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<'a> Debug for CertChainRef<'a>

Source§

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

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

impl<'a> DecodeValue<'a> for CertChainRef<'a>

Source§

fn decode_value<R: Reader<'a>>(reader: &mut R, header: Header) -> Result<Self>

Attempt to decode this message using the provided Reader.
Source§

impl EncodeValue for CertChainRef<'_>

Source§

fn value_len(&self) -> Result<Length>

Compute the length of this value (sans [Tag]+Length header) when encoded as ASN.1 DER.
Source§

fn encode_value(&self, encoder: &mut impl Writer) -> Result<()>

Encode value (sans [Tag]+Length header) as ASN.1 DER using the provided Writer.
Source§

fn header(&self) -> Result<Header, Error>
where Self: Tagged,

Get the Header used to encode this value.
Source§

impl FixedTag for CertChainRef<'_>

Source§

const TAG: Tag = ::der::Tag::Sequence

ASN.1 tag
Source§

impl<'a> From<&'a CertChain> for CertChainRef<'a>

Available on crate feature alloc only.
Source§

fn from(value: &'a CertChain) -> Self

Converts to this type from the input type.
Source§

impl From<&CertChainRef<'_>> for CertChain

Available on crate feature alloc only.
Source§

fn from(value: &CertChainRef<'_>) -> Self

Converts to this type from the input type.
Source§

impl From<CertChainRef<'_>> for CertChain

Available on crate feature alloc only.
Source§

fn from(value: CertChainRef<'_>) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for CertChainRef<'_>

Source§

fn eq(&self, other: &Self) -> 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<'a> RefToOwned<'a> for CertChainRef<'a>

Available on crate feature alloc only.
Source§

type Owned = CertChain

The resulting type after obtaining ownership.
Source§

fn ref_to_owned(&self) -> Self::Owned

Creates a new object taking ownership of the data
Source§

impl<'a> Eq for CertChainRef<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for CertChainRef<'a>

§

impl<'a> RefUnwindSafe for CertChainRef<'a>

§

impl<'a> Send for CertChainRef<'a>

§

impl<'a> Sync for CertChainRef<'a>

§

impl<'a> Unpin for CertChainRef<'a>

§

impl<'a> UnwindSafe for CertChainRef<'a>

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<'a, T> Choice<'a> for T
where T: Decode<'a> + FixedTag,

Source§

fn can_decode(tag: Tag) -> bool

Is the provided Tag decodable as a variant of this CHOICE?
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<'a, T> Decode<'a> for T
where T: DecodeValue<'a> + FixedTag,

Source§

fn decode<R>(reader: &mut R) -> Result<T, Error>
where R: Reader<'a>,

Attempt to decode this message using the provided decoder.
Source§

fn from_der(bytes: &'a [u8]) -> Result<Self, Error>

Parse Self from the provided DER-encoded byte slice.
Source§

impl<T> Encode for T
where T: EncodeValue + Tagged,

Source§

fn encoded_len(&self) -> Result<Length, Error>

Compute the length of this value in bytes when encoded as ASN.1 DER.

Source§

fn encode(&self, writer: &mut impl Writer) -> Result<(), Error>

Encode this value as ASN.1 DER using the provided Writer.

Source§

fn encode_to_slice<'a>(&self, buf: &'a mut [u8]) -> Result<&'a [u8], Error>

Encode this value to the provided byte slice, returning a sub-slice containing the encoded message.
Source§

fn encode_to_vec(&self, buf: &mut Vec<u8>) -> Result<Length, Error>

Encode this message as ASN.1 DER, appending it to the provided byte vector.
Source§

fn to_der(&self) -> Result<Vec<u8>, Error>

Encode this type as DER, returning a byte vector.
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> Tagged for T
where T: FixedTag,

Source§

fn tag(&self) -> Tag

Get the ASN.1 tag that this type is encoded with.
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<T> DecodeOwned for T
where T: for<'a> Decode<'a>,