7 releases

0.2.1 Apr 27, 2020
0.2.0 Apr 26, 2020
0.1.2 Aug 23, 2019
0.0.9 Aug 6, 2019

#20 in #asn1

Download history 59/week @ 2023-11-30 69/week @ 2023-12-07 187/week @ 2023-12-14 61/week @ 2023-12-21 26/week @ 2023-12-28 62/week @ 2024-01-04 162/week @ 2024-01-11 130/week @ 2024-01-18 130/week @ 2024-01-25 73/week @ 2024-02-01 93/week @ 2024-02-08 80/week @ 2024-02-15 98/week @ 2024-02-22 95/week @ 2024-02-29 101/week @ 2024-03-07 58/week @ 2024-03-14

368 downloads per month
Used in 9 crates (3 directly)

AGPL-3.0

35KB
736 lines

Red ASN1

A little library to build/parse ASN1 DER

Examples

Parsing and building bool:

use red_asn1::Asn1Object;

assert_eq!(true, bool::parse(&[0x1, 0x1, 0xff]).unwrap().1);
assert_eq!(false, bool::parse(&[0x1, 0x1, 0x0]).unwrap().1);

assert_eq!(true.build(), vec![0x1, 0x1, 0xff]);
assert_eq!(false.build(), vec![0x1, 0x1, 0x0]);

Parsing and building Integer:

use red_asn1::{Integer, Asn1Object};

assert_eq!(2, Integer::parse(&[0x2, 0x1, 0x2]).unwrap().1);
assert_eq!(2.build(), vec![0x2, 0x1, 0x2]);

Parsing and building String:

use red_asn1::Asn1Object;

assert_eq!(
    "John".to_string(), 
    String::parse(&[0x1b, 0x4, 0x4a, 0x6f, 0x68, 0x6e]).unwrap().1
);

assert_eq!(
    "John".to_string().build(), 
    vec![0x1b, 0x4, 0x4a, 0x6f, 0x68, 0x6e]
);

Creating custom sequences:

/*
Person ::= [APPLICATION 1] SEQUENCE {
    name:       [0] GeneralString,
    age:        [1] Integer,
    address:    [2] GeneralString OPTIONAL,
}
*/

use red_asn1::*;
use red_asn1_derive::Sequence;

#[derive(Sequence, Default)]
#[seq(application_tag = 1)]
struct Person {
    #[seq_field(context_tag = 0)]
    pub name: GeneralString,
    #[seq_field(context_tag = 1)]
    pub age: Integer,
    #[seq_field(context_tag = 2)]
    pub address: Option<GeneralString>
}

let john = Person{
    name: GeneralString::from("John").into(),
    age: Integer::from(18).into(),
    address: None
};

assert_eq!(
    vec![
        0x61, 0xf, 0x30, 0xd,
        0xa0, 0x6, 0x1b, 0x4, 0x4a, 0x6f, 0x68, 0x6e, // "John"
        0xa1, 0x3, 0x2, 0x1, 0x12 // 18
    ]
    , john.build()
);

let (_, rachel) = Person::parse(&[
    0x61, 0x1b, 0x30, 0x19,
    0xa0, 0x8, 0x1b, 0x6, 0x52, 0x61, 0x63, 0x68, 0x65, 0x6c, // "Rachel"
    0xa1, 0x3, 0x2, 0x1, 0x1e, // 30
    0xa2, 0x8, 0x1b, 0x6, 0x48, 0x61, 0x77, 0x61, 0x69, 0x69 // "Hawaii"
]).unwrap();

assert_eq!("Rachel", rachel.name);
assert_eq!(30, rachel.age);
assert_eq!(Some("Hawaii".to_string()), rachel.address);

Implemented types

ASN1 red_asn1 type Rust type
BOOLEAN Boolean bool
INTEGER Integer i128, i64, i32, i16, u32
BIT STRING BitSring
OCTET STRING OctetString Vec<u8>
GeneralString GeneralString String
IA5String IA5String ascii::AsciiString
GeneralizedTime GeneralizedTime
SEQUENCE OF SequenceOf Vec<T: Asn1Object>
SEQUENCE struct with #[derive(Sequence, Default)]
OPTIONAL Optional Option

Dependencies

~1.5MB
~37K SLoC