mls_rs_core/identity/
x509.rs1use core::{
6 convert::Infallible,
7 fmt::{self, Debug},
8 ops::{Deref, DerefMut},
9};
10
11use alloc::vec::Vec;
12use mls_rs_codec::{MlsDecode, MlsEncode, MlsSize};
13
14use super::{Credential, CredentialType, MlsCredential};
15
16#[derive(Clone, PartialEq, Eq, Hash, PartialOrd, Ord, MlsSize, MlsEncode, MlsDecode)]
17#[cfg_attr(feature = "arbitrary", derive(arbitrary::Arbitrary))]
18#[cfg_attr(
19 all(feature = "ffi", not(test)),
20 safer_ffi_gen::ffi_type(clone, opaque)
21)]
22#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
23pub struct DerCertificate(
25 #[mls_codec(with = "mls_rs_codec::byte_vec")]
26 #[cfg_attr(feature = "serde", serde(with = "crate::vec_serde"))]
27 Vec<u8>,
28);
29
30impl Debug for DerCertificate {
31 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
32 crate::debug::pretty_bytes(&self.0)
33 .named("DerCertificate")
34 .fmt(f)
35 }
36}
37
38#[cfg_attr(all(feature = "ffi", not(test)), safer_ffi_gen::safer_ffi_gen)]
39impl DerCertificate {
40 pub fn new(data: Vec<u8>) -> DerCertificate {
42 DerCertificate(data)
43 }
44
45 pub fn into_vec(self) -> Vec<u8> {
47 self.0
48 }
49}
50
51impl From<Vec<u8>> for DerCertificate {
52 fn from(data: Vec<u8>) -> Self {
53 DerCertificate(data)
54 }
55}
56
57impl Deref for DerCertificate {
58 type Target = [u8];
59
60 fn deref(&self) -> &Self::Target {
61 &self.0
62 }
63}
64
65impl AsRef<[u8]> for DerCertificate {
66 fn as_ref(&self) -> &[u8] {
67 &self.0
68 }
69}
70
71#[derive(Clone, Debug, PartialEq, Eq, Hash, PartialOrd, Ord, MlsSize, MlsEncode, MlsDecode)]
72#[cfg_attr(feature = "arbitrary", derive(arbitrary::Arbitrary))]
73#[cfg_attr(
74 all(feature = "ffi", not(test)),
75 safer_ffi_gen::ffi_type(clone, opaque)
76)]
77#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
78pub struct CertificateChain(Vec<DerCertificate>);
84
85impl Deref for CertificateChain {
86 type Target = Vec<DerCertificate>;
87
88 fn deref(&self) -> &Self::Target {
89 &self.0
90 }
91}
92
93impl DerefMut for CertificateChain {
94 fn deref_mut(&mut self) -> &mut Self::Target {
95 &mut self.0
96 }
97}
98
99impl From<Vec<DerCertificate>> for CertificateChain {
100 fn from(cert_data: Vec<DerCertificate>) -> Self {
101 CertificateChain(cert_data)
102 }
103}
104
105impl From<Vec<Vec<u8>>> for CertificateChain {
106 fn from(value: Vec<Vec<u8>>) -> Self {
107 CertificateChain(value.into_iter().map(DerCertificate).collect())
108 }
109}
110
111impl FromIterator<DerCertificate> for CertificateChain {
112 fn from_iter<T: IntoIterator<Item = DerCertificate>>(iter: T) -> Self {
113 CertificateChain::from(iter.into_iter().collect::<Vec<_>>())
114 }
115}
116
117impl CertificateChain {
118 pub fn leaf(&self) -> Option<&DerCertificate> {
120 self.0.first()
121 }
122
123 pub fn into_credential(self) -> Credential {
125 Credential::X509(self)
126 }
127}
128
129impl MlsCredential for CertificateChain {
130 type Error = Infallible;
131
132 fn credential_type() -> CredentialType {
133 CredentialType::X509
134 }
135
136 fn into_credential(self) -> Result<Credential, Self::Error> {
137 Ok(self.into_credential())
138 }
139}