2020-10-21 18:17:55 +08:00
|
|
|
use num_enum::IntoPrimitive;
|
|
|
|
use num_enum::TryFromPrimitive;
|
|
|
|
|
2020-10-22 17:41:33 +08:00
|
|
|
use alloc::vec::Vec;
|
|
|
|
|
2020-10-21 18:17:55 +08:00
|
|
|
pub struct Certificate<'a> {
|
|
|
|
tbs_certificate: TBSCertificate<'a>,
|
|
|
|
signature_algorithm: AlgorithmIdentifier<'a>,
|
|
|
|
signature_value: &'a [u8]
|
|
|
|
}
|
|
|
|
|
|
|
|
pub struct TBSCertificate<'a> {
|
|
|
|
version: Version,
|
|
|
|
serial_number: &'a [u8],
|
|
|
|
signature: AlgorithmIdentifier<'a>,
|
|
|
|
issuer: &'a [u8],
|
|
|
|
validity: Validity<'a>,
|
|
|
|
subject: &'a [u8],
|
|
|
|
subject_public_key_info: SubjectPublicKeyInfo<'a>,
|
|
|
|
issuer_unique_id: Option<&'a [u8]>,
|
|
|
|
subject_unique_id: Option<&'a [u8]>,
|
2020-10-22 17:41:33 +08:00
|
|
|
extensions: Extensions<'a>,
|
2020-10-21 18:17:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug, PartialEq, Eq, Clone, Copy, IntoPrimitive, TryFromPrimitive)]
|
|
|
|
#[repr(u8)]
|
|
|
|
pub enum Version {
|
|
|
|
#[num_enum(default)]
|
|
|
|
v1 = 0,
|
|
|
|
v2 = 1,
|
|
|
|
v3 = 2,
|
|
|
|
}
|
|
|
|
|
|
|
|
pub struct Validity<'a> {
|
2020-10-22 17:41:33 +08:00
|
|
|
pub not_before: Time<'a>,
|
|
|
|
pub not_after: Time<'a>,
|
2020-10-21 18:17:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
pub enum Time<'a> {
|
|
|
|
UTCTime(&'a [u8]),
|
|
|
|
GeneralizedTime(&'a [u8]),
|
|
|
|
}
|
|
|
|
|
|
|
|
pub struct SubjectPublicKeyInfo<'a> {
|
2020-10-22 17:41:33 +08:00
|
|
|
pub algorithm: AlgorithmIdentifier<'a>,
|
|
|
|
pub subject_public_key: &'a [u8],
|
|
|
|
}
|
|
|
|
|
|
|
|
pub struct Extensions<'a> {
|
|
|
|
extensions: Vec<Extension<'a>>
|
2020-10-21 18:17:55 +08:00
|
|
|
}
|
|
|
|
|
2020-10-22 17:41:33 +08:00
|
|
|
pub enum Extension<'a> {
|
|
|
|
KeyUsage {
|
|
|
|
// Acceptable usage of this certificate
|
|
|
|
// Cross verify with ExtendedKeyUsage
|
|
|
|
usage: u8
|
|
|
|
},
|
|
|
|
CertificatePolicies {
|
|
|
|
// Policies listed in an extension
|
|
|
|
// Need to verify its validity
|
|
|
|
policies: Vec<&'a [u8]>
|
|
|
|
},
|
|
|
|
SubjectAlternativeName,
|
|
|
|
BasicConstraints {
|
|
|
|
is_ca: bool,
|
|
|
|
path_len_constraint: Option<u8>,
|
|
|
|
},
|
|
|
|
|
2020-10-21 18:17:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
pub struct AlgorithmIdentifier<'a> {
|
|
|
|
pub algorithm: &'a [u8],
|
|
|
|
pub parameters: &'a [u8],
|
|
|
|
}
|