#asn-1 #serde #asn1-der #no-panic

serde_asn1_der

A basic ASN.1-DER implementation for serde based upon asn1_der

7 releases

0.8.0 Mar 7, 2023
0.7.4 Mar 18, 2021
0.7.3 Jul 31, 2020
0.7.2 May 9, 2020
0.1.0 Mar 24, 2019

#1047 in Encoding

Download history 1/week @ 2024-01-03 41/week @ 2024-01-10 119/week @ 2024-01-17 76/week @ 2024-01-24 132/week @ 2024-01-31 146/week @ 2024-02-07 115/week @ 2024-02-14 101/week @ 2024-02-21 227/week @ 2024-02-28 180/week @ 2024-03-06 145/week @ 2024-03-13 186/week @ 2024-03-20 129/week @ 2024-03-27 154/week @ 2024-04-03 206/week @ 2024-04-10 152/week @ 2024-04-17

696 downloads per month
Used in rusty_vault

BSD-2-Clause OR MIT

35KB
680 lines

docs.rs License BSD-2-Clause License MIT crates.io Download numbers Travis CI AppVeyor CI dependency status

serde_asn1_der

Welcome to serde_asn1_der 🎉

This crate implements an ASN.1-DER subset for serde based upon asn1_der.

The following types are supported:

  • bool: The ASN.1-BOOLEAN-type
  • u8, u16, u32, u64, u128, usize: The ASN.1-INTEGER-type
  • (), Option: The ASN.1-NULL-type
  • &[u8], Vec<u8>: The ASN.1-OctetString-type
  • &str, String: The ASN.1-UTF8String-type
  • And everything sequence-like combined out of this types

With the serde_derive-crate you can derive Serialize and Deserialize for all non-primitive elements:

use serde_derive::{ Serialize, Deserialize };

#[derive(Serialize, Deserialize)] // Now our struct supports all DER-conversion-traits
struct Address {
    street: String,
    house_number: u128,
    postal_code: u128,
    state: String,
    country: String
}

#[derive(Serialize, Deserialize)] // Now our struct supports all DER-conversion-traits too
struct Customer {
    name: String,
    e_mail_address: String,
    postal_address: Address
}

Example

use serde_asn1_der::{ to_vec, from_bytes };
use serde_derive::{ Serialize, Deserialize };

#[derive(Serialize, Deserialize)]
struct TestStruct {
    number: u8,
    #[serde(with = "serde_bytes")]
    vec: Vec<u8>,
    tuple: (usize, ())
}

fn main() {
    let plain = TestStruct{ number: 7, vec: b"Testolope".to_vec(), tuple: (4, ()) };
    let serialized = to_vec(&plain).unwrap();
    let deserialized: TestStruct = from_bytes(&serialized).unwrap();
}

AnyObject

This crate also offers a type-erased AnyObject-trait, that allows you to use Box<dyn AnyObject> instead of a specific type. To enable AnyObject, use the "any"-feature.

Dependencies

~170–450KB