use ruma_events_macros::EventContent;
use ruma_identifiers::TransactionId;
use ruma_serde::Base64;
use serde::{Deserialize, Serialize};
use super::Relation;
#[derive(Clone, Debug, Deserialize, Serialize, EventContent)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
#[ruma_event(type = "m.key.verification.key", kind = ToDevice)]
pub struct ToDeviceKeyVerificationKeyEventContent {
pub transaction_id: Box<TransactionId>,
pub key: Base64,
}
impl ToDeviceKeyVerificationKeyEventContent {
pub fn new(transaction_id: Box<TransactionId>, key: Base64) -> Self {
Self { transaction_id, key }
}
}
#[derive(Clone, Debug, Deserialize, Serialize, EventContent)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
#[ruma_event(type = "m.key.verification.key", kind = Message)]
pub struct KeyVerificationKeyEventContent {
pub key: Base64,
#[serde(rename = "m.relates_to")]
pub relates_to: Relation,
}
impl KeyVerificationKeyEventContent {
pub fn new(key: Base64, relates_to: Relation) -> Self {
Self { key, relates_to }
}
}