p2panda-rs 0.4.0

All the things a panda needs
Documentation
// SPDX-License-Identifier: AGPL-3.0-or-later

use openmls::group::GroupId;
use tls_codec::{TlsByteVecU8, TlsDeserialize, TlsSerialize, TlsSize};

use crate::hash::Hash;
use crate::secret_group::lts::{LongTermSecretEpoch, LongTermSecretError};

/// Data type holding encrypted application data from a sender with needed meta information for a
/// receiver to decrypt it again.
#[derive(Debug, Clone, PartialEq, TlsDeserialize, TlsSerialize, TlsSize)]
pub struct LongTermSecretCiphertext {
    /// Identifier of the related MLS group.
    group_id: GroupId,

    /// Epoch of the long-term secret which was used to encrypt data.
    long_term_epoch: LongTermSecretEpoch,

    /// Used nonce for AEAD encryption.
    nonce: TlsByteVecU8,

    /// Encrypted user data (ciphertext) + AEAD tag (HMAC).
    ciphertext_tag: TlsByteVecU8,
}

impl LongTermSecretCiphertext {
    /// Creates a new `LongTermSecretCiphertext` instance.
    pub fn new(
        group_instance_id: Hash,
        long_term_epoch: LongTermSecretEpoch,
        ciphertext: Vec<u8>,
        nonce: Vec<u8>,
    ) -> Self {
        Self {
            // Convert group instance id Hash to internal MLS GroupId struct which implements
            // required TLS encoding traits
            group_id: GroupId::from_slice(&group_instance_id.to_bytes()),
            long_term_epoch,
            nonce: nonce.into(),
            ciphertext_tag: ciphertext.into(),
        }
    }

    /// This method can throw an error when the secret contains an invalid secret group instance
    /// hash.
    pub fn group_instance_id(&self) -> Result<Hash, LongTermSecretError> {
        let hex_str = hex::encode(&self.group_id.as_slice());
        Ok(Hash::new(&hex_str)?)
    }

    /// Returns epoch of long-term secret used when data was encrypted.
    pub fn long_term_epoch(&self) -> LongTermSecretEpoch {
        self.long_term_epoch
    }

    /// Returns AEAD nonce when data was encrypted.
    pub fn nonce(&self) -> Vec<u8> {
        self.nonce.as_slice().to_vec()
    }

    /// Returns encrypted user data + AAD tag.
    pub fn ciphertext_with_tag(&self) -> Vec<u8> {
        self.ciphertext_tag.as_slice().to_vec()
    }
}