use super::*;
#[derive(Debug, serde::Serialize, serde::Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct LairApiReqCryptoBoxXSalsaBySignPubKey {
pub msg_id: Arc<str>,
pub sender_pub_key: Ed25519PubKey,
pub recipient_pub_key: Ed25519PubKey,
#[serde(skip_serializing_if = "Option::is_none", default)]
pub deep_lock_passphrase: Option<SecretDataSized<64, 81>>,
pub data: Arc<[u8]>,
}
impl LairApiReqCryptoBoxXSalsaBySignPubKey {
pub fn new(
sender_pub_key: Ed25519PubKey,
recipient_pub_key: Ed25519PubKey,
deep_lock_passphrase: Option<SecretDataSized<64, 81>>,
data: Arc<[u8]>,
) -> Self {
Self {
msg_id: new_msg_id(),
sender_pub_key,
recipient_pub_key,
deep_lock_passphrase,
data,
}
}
}
impl std::convert::TryFrom<LairApiEnum>
for LairApiReqCryptoBoxXSalsaBySignPubKey
{
type Error = one_err::OneErr;
fn try_from(e: LairApiEnum) -> Result<Self, Self::Error> {
if let LairApiEnum::ReqCryptoBoxXSalsaBySignPubKey(s) = e {
Ok(s)
} else {
Err(format!("Invalid response type: {e:?}").into())
}
}
}
impl AsLairCodec for LairApiReqCryptoBoxXSalsaBySignPubKey {
fn into_api_enum(self) -> LairApiEnum {
LairApiEnum::ReqCryptoBoxXSalsaBySignPubKey(self)
}
}
#[derive(Debug, serde::Serialize, serde::Deserialize)]
#[serde(rename_all = "camelCase")]
#[non_exhaustive]
pub struct LairApiResCryptoBoxXSalsaBySignPubKey {
pub msg_id: Arc<str>,
pub nonce: [u8; 24],
pub cipher: Arc<[u8]>,
}
impl std::convert::TryFrom<LairApiEnum>
for LairApiResCryptoBoxXSalsaBySignPubKey
{
type Error = one_err::OneErr;
fn try_from(e: LairApiEnum) -> Result<Self, Self::Error> {
if let LairApiEnum::ResCryptoBoxXSalsaBySignPubKey(s) = e {
Ok(s)
} else {
Err(format!("Invalid response type: {e:?}").into())
}
}
}
impl AsLairCodec for LairApiResCryptoBoxXSalsaBySignPubKey {
fn into_api_enum(self) -> LairApiEnum {
LairApiEnum::ResCryptoBoxXSalsaBySignPubKey(self)
}
}
impl AsLairRequest for LairApiReqCryptoBoxXSalsaBySignPubKey {
type Response = LairApiResCryptoBoxXSalsaBySignPubKey;
}
impl AsLairResponse for LairApiResCryptoBoxXSalsaBySignPubKey {
type Request = LairApiReqCryptoBoxXSalsaBySignPubKey;
}