der::asn1

Struct AnyRef

Source
pub struct AnyRef<'a> { /* private fields */ }
Expand description

ASN.1 ANY: represents any explicitly tagged ASN.1 value.

This is a zero-copy reference type which borrows from the input data.

Technically ANY hasn’t been a recommended part of ASN.1 since the X.209 revision from 1988. It was deprecated and replaced by Information Object Classes in X.680 in 1994, and X.690 no longer refers to it whatsoever.

Nevertheless, this crate defines an ANY type as it remains a familiar and useful concept which is still extensively used in things like PKI-related RFCs.

Implementations§

Source§

impl<'a> AnyRef<'a>

Source

pub const NULL: Self

AnyRef representation of the ASN.1 NULL type.

Source

pub fn new(tag: Tag, bytes: &'a [u8]) -> Result<Self>

Create a new AnyRef from the provided Tag and DER bytes.

Source

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

Get the raw value for this AnyRef type as a byte slice.

Source

pub fn decode_into<T>(self) -> Result<T>
where T: DecodeValue<'a> + FixedTag,

Attempt to decode this AnyRef type into the inner value.

Source

pub fn is_null(self) -> bool

Is this value an ASN.1 NULL value?

Source

pub fn bit_string(self) -> Result<BitStringRef<'a>>

Attempt to decode an ASN.1 BIT STRING.

Source

pub fn context_specific<T>(self) -> Result<ContextSpecific<T>>
where T: Decode<'a>,

Attempt to decode an ASN.1 CONTEXT-SPECIFIC field.

Source

pub fn generalized_time(self) -> Result<GeneralizedTime>

Attempt to decode an ASN.1 GeneralizedTime.

Source

pub fn ia5_string(self) -> Result<Ia5StringRef<'a>>

Attempt to decode an ASN.1 IA5String.

Source

pub fn octet_string(self) -> Result<OctetStringRef<'a>>

Attempt to decode an ASN.1 OCTET STRING.

Source

pub fn oid(self) -> Result<ObjectIdentifier>

Attempt to decode an ASN.1 OBJECT IDENTIFIER.

Source

pub fn optional<T>(self) -> Result<Option<T>>
where T: Choice<'a> + TryFrom<Self, Error = Error>,

Attempt to decode an ASN.1 OPTIONAL value.

Source

pub fn printable_string(self) -> Result<PrintableStringRef<'a>>

Attempt to decode an ASN.1 PrintableString.

Source

pub fn teletex_string(self) -> Result<TeletexStringRef<'a>>

Attempt to decode an ASN.1 TeletexString.

Source

pub fn videotex_string(self) -> Result<VideotexStringRef<'a>>

Attempt to decode an ASN.1 VideotexString.

Source

pub fn sequence<F, T>(self, f: F) -> Result<T>
where F: FnOnce(&mut SliceReader<'a>) -> Result<T>,

Attempt to decode this value an ASN.1 SEQUENCE, creating a new nested reader and calling the provided argument with it.

Source

pub fn utc_time(self) -> Result<UtcTime>

Attempt to decode an ASN.1 UTCTime.

Source

pub fn utf8_string(self) -> Result<Utf8StringRef<'a>>

Attempt to decode an ASN.1 UTF8String.

Trait Implementations§

Source§

impl<'a> Choice<'a> for AnyRef<'a>

Source§

fn can_decode(_: Tag) -> bool

Is the provided Tag decodable as a variant of this CHOICE?
Source§

impl<'a> Clone for AnyRef<'a>

Source§

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

Returns a copy 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 AnyRef<'a>

Source§

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

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

impl<'a> Decode<'a> for AnyRef<'a>

Source§

fn decode<R: Reader<'a>>(reader: &mut R) -> Result<AnyRef<'a>>

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

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

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

impl EncodeValue for AnyRef<'_>

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, writer: &mut dyn Writer) -> Result<()>

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

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

Get the Header used to encode this value.
Source§

impl<'a> From<&'a Any> for AnyRef<'a>

Source§

fn from(any: &'a Any) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<&'a ObjectIdentifier> for AnyRef<'a>

Source§

fn from(oid: &'a ObjectIdentifier) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<()> for AnyRef<'a>

Source§

fn from(_: ()) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<Ia5StringRef<'a>> for AnyRef<'a>

Source§

fn from(printable_string: Ia5StringRef<'a>) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<Null> for AnyRef<'a>

Source§

fn from(_: Null) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<OctetStringRef<'a>> for AnyRef<'a>

Source§

fn from(octet_string: OctetStringRef<'a>) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<PrintableStringRef<'a>> for AnyRef<'a>

Source§

fn from(printable_string: PrintableStringRef<'a>) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<TeletexStringRef<'a>> for AnyRef<'a>

Source§

fn from(teletex_string: TeletexStringRef<'a>) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<Utf8StringRef<'a>> for AnyRef<'a>

Source§

fn from(printable_string: Utf8StringRef<'a>) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl<'a> From<VideotexStringRef<'a>> for AnyRef<'a>

Source§

fn from(printable_string: VideotexStringRef<'a>) -> AnyRef<'a>

Converts to this type from the input type.
Source§

impl From<bool> for AnyRef<'static>

Source§

fn from(value: bool) -> AnyRef<'static>

Converts to this type from the input type.
Source§

impl<'a> Ord for AnyRef<'a>

Source§

fn cmp(&self, other: &AnyRef<'a>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<'a> PartialEq for AnyRef<'a>

Source§

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

Source§

fn partial_cmp(&self, other: &AnyRef<'a>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

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

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

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

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

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

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

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

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Tagged for AnyRef<'_>

Source§

fn tag(&self) -> Tag

Get the ASN.1 tag that this type is encoded with.
Source§

impl<'a> TryFrom<&'a [u8]> for AnyRef<'a>

Source§

type Error = Error

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

fn try_from(bytes: &'a [u8]) -> Result<AnyRef<'a>>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for ()

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<()>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for GeneralizedTime

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<GeneralizedTime>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for Null

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Null>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for ObjectIdentifier

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<ObjectIdentifier>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for UtcTime

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<UtcTime>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for bool

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<bool>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for i128

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for i16

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for i32

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for i64

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for i8

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for u128

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for u16

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for u32

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for u64

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl TryFrom<AnyRef<'_>> for u8

Source§

type Error = Error

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

fn try_from(any: AnyRef<'_>) -> Result<Self>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for &'a str

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<&'a str>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for BitStringRef<'a>

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<BitStringRef<'a>>

Performs the conversion.
Source§

impl<'a, T> TryFrom<AnyRef<'a>> for ContextSpecific<T>
where T: Decode<'a>,

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<ContextSpecific<T>>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for Ia5StringRef<'a>

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<Ia5StringRef<'a>>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for OctetStringRef<'a>

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<OctetStringRef<'a>>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for PrintableStringRef<'a>

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<PrintableStringRef<'a>>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for String

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<String>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for TeletexStringRef<'a>

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<TeletexStringRef<'a>>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for UIntRef<'a>

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<UIntRef<'a>>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for Utf8StringRef<'a>

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<Utf8StringRef<'a>>

Performs the conversion.
Source§

impl<'a> TryFrom<AnyRef<'a>> for VideotexStringRef<'a>

Source§

type Error = Error

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

fn try_from(any: AnyRef<'a>) -> Result<VideotexStringRef<'a>>

Performs the conversion.
Source§

impl ValueOrd for AnyRef<'_>

Source§

fn value_cmp(&self, other: &Self) -> Result<Ordering>

Return an Ordering between value portion of TLV-encoded self and other when serialized as ASN.1 DER.
Source§

impl<'a> Copy for AnyRef<'a>

Source§

impl<'a> Eq for AnyRef<'a>

Source§

impl<'a> StructuralPartialEq for AnyRef<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for AnyRef<'a>

§

impl<'a> RefUnwindSafe for AnyRef<'a>

§

impl<'a> Send for AnyRef<'a>

§

impl<'a> Sync for AnyRef<'a>

§

impl<'a> Unpin for AnyRef<'a>

§

impl<'a> UnwindSafe for AnyRef<'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<T> CloneToUninit for T
where T: Clone,

Source§

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

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

impl<T> DerOrd for T

Source§

fn der_cmp(&self, other: &T) -> Result<Ordering, Error>

Return an Ordering between self and other when serialized as ASN.1 DER.
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 dyn 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]>

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>

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

fn to_vec(&self) -> Result<Vec<u8>>

Serialize this message as 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> 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.