rsa_msg_packets/communication/
key_reply_encrypted.rs1use uuid::Uuid;
2
3use crate::{util::{converter::uuid_to_vec, modes::Modes, tools::uuid_from_vec}, types::ByteMessage};
4
5pub struct EncryptedSymmKeyReplyMsg {
6 pub key: Vec<u8>,
7 pub user: Uuid,
8}
9
10impl ByteMessage for EncryptedSymmKeyReplyMsg {
11 fn serialize(&self) -> Vec<u8> {
12 let mut merged: Vec<u8> = Vec::new();
13 let mut b_user = uuid_to_vec(&self.user);
14 let mut b_key = self.key.clone();
15
16 merged.append(&mut b_user);
17 merged.append(&mut b_key);
18
19 return Modes::SymmKey.get_send(&merged);
20 }
21
22 fn deserialize(data: &Vec<u8>) -> anyhow::Result<Self> {
23 let mut data = data.clone();
24
25 let user = uuid_from_vec(&mut data)?;
26 return Ok(Self {
27 key: data,
28 user
29 });
30 }
31}