BerObjectContent

Enum BerObjectContent 

Source
pub enum BerObjectContent<'a> {
Show 28 variants EndOfContent, Boolean(bool), Integer(&'a [u8]), BitString(u8, BitStringObject<'a>), OctetString(&'a [u8]), Null, Enum(u64), OID(Oid<'a>), RelativeOID(Oid<'a>), NumericString(&'a str), VisibleString(&'a str), PrintableString(&'a str), IA5String(&'a str), UTF8String(&'a str), T61String(&'a str), VideotexString(&'a str), BmpString(&'a [u8]), UniversalString(&'a [u8]), Sequence(Vec<BerObject<'a>>), Set(Vec<BerObject<'a>>), UTCTime(ASN1DateTime), GeneralizedTime(ASN1DateTime), ObjectDescriptor(&'a str), GraphicString(&'a str), GeneralString(&'a str), Optional(Option<Box<BerObject<'a>>>), Tagged(Class, Tag, Box<BerObject<'a>>), Unknown(Any<'a>),
}
Expand description

BER object content

Variants§

§

EndOfContent

EOC (no content)

§

Boolean(bool)

BOOLEAN: decoded value

§

Integer(&'a [u8])

INTEGER: raw bytes

Note: the reason to store the raw bytes is that integers have non-finite length in the spec, and also that the raw encoding is also important for some applications.

To extract the number, see the as_u64, as_u32, as_bigint and as_biguint methods.

§

BitString(u8, BitStringObject<'a>)

BIT STRING: number of unused bits, and object

§

OctetString(&'a [u8])

OCTET STRING: slice

§

Null

NULL (no content)

§

Enum(u64)

ENUMERATED: decoded enum number

§

OID(Oid<'a>)

OID

§

RelativeOID(Oid<'a>)

RELATIVE OID

§

NumericString(&'a str)

NumericString: decoded string

§

VisibleString(&'a str)

VisibleString: decoded string

§

PrintableString(&'a str)

PrintableString: decoded string

§

IA5String(&'a str)

IA5String: decoded string

§

UTF8String(&'a str)

UTF8String: decoded string

§

T61String(&'a str)

T61String: decoded string

§

VideotexString(&'a str)

VideotexString: decoded string

§

BmpString(&'a [u8])

BmpString: raw object bytes

Note: the string is stored as raw bytes because not all UTF-16 sequences can be stored as &str. To access content, use String::from_utf16 or String::from_utf16_lossy.

§

UniversalString(&'a [u8])

UniversalString: raw object bytes

§

Sequence(Vec<BerObject<'a>>)

SEQUENCE: list of objects

§

Set(Vec<BerObject<'a>>)

SET: list of objects

§

UTCTime(ASN1DateTime)

UTCTime: decoded string

§

GeneralizedTime(ASN1DateTime)

GeneralizedTime: decoded string

§

ObjectDescriptor(&'a str)

Object descriptor: decoded string

§

GraphicString(&'a str)

GraphicString: decoded string

§

GeneralString(&'a str)

GeneralString: decoded string

§

Optional(Option<Box<BerObject<'a>>>)

Optional object

§

Tagged(Class, Tag, Box<BerObject<'a>>)

Tagged object (EXPLICIT): class, tag and content of inner object

§

Unknown(Any<'a>)

Private or Unknown (for ex. unknown tag) object

Implementations§

Source§

impl<'a> BerObjectContent<'a>

Source

pub fn as_i64(&self) -> Result<i64, BerError>

Attempt to read a signed integer value from this object.

This can fail if the object is not an integer, or if it is too large.

§Examples
let der_int  = BerObject::from_int_slice(b"\x80");
assert_eq!(
    der_int.as_i64(),
    Ok(-128)
);
Source

pub fn as_i32(&self) -> Result<i32, BerError>

Attempt to read a signed integer value from this object.

This can fail if the object is not an integer, or if it is too large.

§Examples
let der_int  = BerObject::from_int_slice(b"\x80");
assert_eq!(
    der_int.as_i32(),
    Ok(-128)
);
Source

pub fn as_u64(&self) -> Result<u64, BerError>

Attempt to read integer value from this object.

This can fail if the object is not an unsigned integer, or if it is too large.

§Examples
let der_int  = BerObject::from_int_slice(b"\x01\x00\x01");
assert_eq!(
    der_int.as_u64(),
    Ok(0x10001)
);
Source

pub fn as_u32(&self) -> Result<u32, BerError>

Attempt to read integer value from this object.

This can fail if the object is not an unsigned integer, or if it is too large.

§Examples
let der_int  = BerObject::from_obj(BerObjectContent::Integer(b"\x01\x00\x01"));
assert_eq!(
    der_int.as_u32(),
    Ok(0x10001)
);
Source

pub fn as_bool(&self) -> Result<bool, BerError>

Source

pub fn as_oid(&self) -> Result<&Oid<'a>, BerError>

Source

pub fn as_oid_val(&self) -> Result<Oid<'a>, BerError>

Source

pub fn as_optional(&self) -> Result<Option<&BerObject<'a>>, BerError>

Source

pub fn as_tagged(&self) -> Result<(Class, Tag, &BerObject<'a>), BerError>

Source

pub fn as_bitstring_ref(&self) -> Result<&BitStringObject<'_>, BerError>

Source

pub fn as_bitstring(&self) -> Result<BitStringObject<'a>, BerError>

Source

pub fn as_sequence(&self) -> Result<&Vec<BerObject<'a>>, BerError>

Source

pub fn as_set(&self) -> Result<&Vec<BerObject<'a>>, BerError>

Source

pub fn as_slice(&self) -> Result<&'a [u8], BerError>

Source

pub fn as_str(&self) -> Result<&'a str, BerError>

Trait Implementations§

Source§

impl<'a> Clone for BerObjectContent<'a>

Source§

fn clone(&self) -> BerObjectContent<'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 BerObjectContent<'a>

Source§

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

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

impl<'a> From<BerObjectContent<'a>> for BerObject<'a>

Build a DER object from a BerObjectContent.

Source§

fn from(obj: BerObjectContent<'a>) -> BerObject<'a>

Converts to this type from the input type.
Source§

impl<'a> PartialEq for BerObjectContent<'a>

Source§

fn eq(&self, other: &BerObjectContent<'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> StructuralPartialEq for BerObjectContent<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for BerObjectContent<'a>

§

impl<'a> RefUnwindSafe for BerObjectContent<'a>

§

impl<'a> Send for BerObjectContent<'a>

§

impl<'a> Sync for BerObjectContent<'a>

§

impl<'a> Unpin for BerObjectContent<'a>

§

impl<'a> UnwindSafe for BerObjectContent<'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<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

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

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 64 bytes

Size for each variant:

  • EndOfContent: 0 bytes
  • Boolean: 9 bytes
  • Integer: 24 bytes
  • BitString: 32 bytes
  • OctetString: 24 bytes
  • Null: 0 bytes
  • Enum: 16 bytes
  • OID: 40 bytes
  • RelativeOID: 40 bytes
  • NumericString: 24 bytes
  • VisibleString: 24 bytes
  • PrintableString: 24 bytes
  • IA5String: 24 bytes
  • UTF8String: 24 bytes
  • T61String: 24 bytes
  • VideotexString: 24 bytes
  • BmpString: 24 bytes
  • UniversalString: 24 bytes
  • Sequence: 32 bytes
  • Set: 32 bytes
  • UTCTime: 24 bytes
  • GeneralizedTime: 24 bytes
  • ObjectDescriptor: 24 bytes
  • GraphicString: 24 bytes
  • GeneralString: 24 bytes
  • Optional: 16 bytes
  • Tagged: 24 bytes
  • Unknown: 64 bytes