bc_components/symmetric/
authentication_tag.rs1use std::rc::Rc;
2
3use anyhow::{Error, Result, bail};
4use dcbor::prelude::*;
5
6#[derive(Clone, Eq, PartialEq)]
21pub struct AuthenticationTag([u8; Self::AUTHENTICATION_TAG_SIZE]);
22
23impl AuthenticationTag {
24 pub const AUTHENTICATION_TAG_SIZE: usize = 16;
25
26 pub const fn from_data(data: [u8; Self::AUTHENTICATION_TAG_SIZE]) -> Self { Self(data) }
28
29 pub fn from_data_ref(data: impl AsRef<[u8]>) -> Result<Self> {
31 let data = data.as_ref();
32 if data.len() != Self::AUTHENTICATION_TAG_SIZE {
33 bail!("Invalid authentication tag size");
34 }
35 let mut arr = [0u8; Self::AUTHENTICATION_TAG_SIZE];
36 arr.copy_from_slice(data.as_ref());
37 Ok(Self::from_data(arr))
38 }
39
40 pub fn data(&self) -> &[u8; Self::AUTHENTICATION_TAG_SIZE] { self.into() }
42}
43
44impl AsRef<AuthenticationTag> for AuthenticationTag {
46 fn as_ref(&self) -> &AuthenticationTag { self }
47}
48
49impl std::fmt::Debug for AuthenticationTag {
51 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
52 f.debug_tuple("AuthenticationTag")
53 .field(&hex::encode(self.data()))
54 .finish()
55 }
56}
57
58impl From<Rc<AuthenticationTag>> for AuthenticationTag {
61 fn from(value: Rc<AuthenticationTag>) -> Self { (*value).clone() }
62}
63
64impl<'a> From<&'a AuthenticationTag> for &'a [u8; AuthenticationTag::AUTHENTICATION_TAG_SIZE] {
67 fn from(value: &'a AuthenticationTag) -> Self { &value.0 }
68}
69
70impl From<&[u8]> for AuthenticationTag {
72 fn from(data: &[u8]) -> Self { Self::from_data_ref(data).unwrap() }
73}
74
75impl From<[u8; Self::AUTHENTICATION_TAG_SIZE]> for AuthenticationTag {
77 fn from(data: [u8; Self::AUTHENTICATION_TAG_SIZE]) -> Self { Self::from_data(data) }
78}
79
80impl From<Vec<u8>> for AuthenticationTag {
82 fn from(data: Vec<u8>) -> Self { Self::from_data_ref(data).unwrap() }
83}
84
85impl From<AuthenticationTag> for CBOR {
87 fn from(value: AuthenticationTag) -> Self { CBOR::to_byte_string(value.data()) }
88}
89
90impl TryFrom<CBOR> for AuthenticationTag {
92 type Error = Error;
93
94 fn try_from(cbor: CBOR) -> Result<Self, Self::Error> {
95 let data = CBOR::try_into_byte_string(cbor)?;
96 Self::from_data_ref(data)
97 }
98}