Enum der::Tag

source ·
#[non_exhaustive]
pub enum Tag {
Show 20 variants Boolean, Integer, BitString, OctetString, Null, ObjectIdentifier, Enumerated, Utf8String, Sequence, Set, NumericString, PrintableString, Ia5String, UtcTime, GeneralizedTime, VisibleString, BmpString, Application { constructed: bool, number: TagNumber, }, ContextSpecific { constructed: bool, number: TagNumber, }, Private { constructed: bool, number: TagNumber, },
}
Expand description

ASN.1 tags.

Tags are the leading identifier octet of the Tag-Length-Value encoding used by ASN.1 DER and identify the type of the subsequent value.

They are described in X.690 Section 8.1.2: Identifier octets, and structured as follows:

| Class | P/C | Tag Number |
  • Bits 8/7: Class
  • Bit 6: primitive (0) or constructed (1)
  • Bits 5-1: tag number

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Boolean

BOOLEAN tag: 1.

§

Integer

INTEGER tag: 2.

§

BitString

BIT STRING tag: 3.

§

OctetString

OCTET STRING tag: 4.

§

Null

NULL tag: 5.

§

ObjectIdentifier

OBJECT IDENTIFIER tag: 6.

§

Enumerated

ENUMERATED tag: 10.

§

Utf8String

UTF8String tag: 12.

§

Sequence

SEQUENCE tag: 16.

§

Set

SET and SET OF tag: 17.

§

NumericString

NumericString tag: 18.

§

PrintableString

PrintableString tag: 19.

§

Ia5String

IA5String tag: 22.

§

UtcTime

UTCTime tag: 23.

§

GeneralizedTime

GeneralizedTime tag: 24.

§

VisibleString

VisibleString tag: 26.

§

BmpString

BMPString tag: 30.

§

Application

Application tag.

Fields

§constructed: bool

Is this tag constructed? (vs primitive).

§number: TagNumber

Tag number.

§

ContextSpecific

Context-specific tag.

Fields

§constructed: bool

Is this tag constructed? (vs primitive).

§number: TagNumber

Tag number.

§

Private

Private tag number.

Fields

§constructed: bool

Is this tag constructed? (vs primitive).

§number: TagNumber

Tag number.

Implementations§

source§

impl Tag

source

pub fn assert_eq(self, expected: Tag) -> Result<Tag>

Assert that this Tag matches the provided expected tag.

On mismatch, returns an Error with ErrorKind::TagUnexpected.

source

pub fn class(self) -> Class

Get the Class that corresponds to this Tag.

source

pub fn number(self) -> TagNumber

Get the TagNumber (lower 6-bits) for this tag.

source

pub fn is_constructed(self) -> bool

Does this tag represent a constructed (as opposed to primitive) field?

source

pub fn is_application(self) -> bool

Is this an application tag?

source

pub fn is_context_specific(self) -> bool

Is this a context-specific tag?

source

pub fn is_private(self) -> bool

Is this a private tag?

source

pub fn is_universal(self) -> bool

Is this a universal tag?

source

pub fn octet(self) -> u8

Get the octet encoding for this Tag.

source

pub fn length_error(self) -> Error

Create an Error for an invalid Length.

source

pub fn non_canonical_error(self) -> Error

Create an Error for an non-canonical value with the ASN.1 type identified by this tag.

source

pub fn unexpected_error(self, expected: Option<Self>) -> Error

Create an Error because the current tag was unexpected, with an optional expected tag.

source

pub fn value_error(self) -> Error

Create an Error for an invalid value with the ASN.1 type identified by this tag.

Trait Implementations§

source§

impl Clone for Tag

source§

fn clone(&self) -> Tag

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 Debug for Tag

source§

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

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

impl Decodable<'_> for Tag

source§

fn decode(decoder: &mut Decoder<'_>) -> Result<Self>

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 DerOrd for Tag

source§

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

Return an Ordering between self and other when serialized as ASN.1 DER.
source§

impl Display for Tag

source§

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

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

impl Encodable for Tag

source§

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

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

fn encode(&self, encoder: &mut Encoder<'_>) -> Result<()>

Encode this value as ASN.1 DER using the provided Encoder.
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§

impl From<&Tag> for u8

source§

fn from(tag: &Tag) -> u8

Converts to this type from the input type.
source§

impl From<Tag> for u8

source§

fn from(tag: Tag) -> u8

Converts to this type from the input type.
source§

impl Ord for Tag

source§

fn cmp(&self, other: &Tag) -> 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 + PartialOrd,

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

impl PartialEq for Tag

source§

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

source§

fn partial_cmp(&self, other: &Tag) -> 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 TryFrom<u8> for Tag

§

type Error = Error

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

fn try_from(byte: u8) -> Result<Tag>

Performs the conversion.
source§

impl Copy for Tag

source§

impl Eq for Tag

source§

impl StructuralPartialEq for Tag

Auto Trait Implementations§

§

impl Freeze for Tag

§

impl RefUnwindSafe for Tag

§

impl Send for Tag

§

impl Sync for Tag

§

impl Unpin for Tag

§

impl UnwindSafe for Tag

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§

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

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

impl<T> CloneToUninit for T
where T: Copy,

source§

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

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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, U> TryFrom<U> for T
where U: Into<T>,

§

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

§

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.