use bitwarden_crypto::{EncString, UnsignedSharedKey};
use serde::{Deserialize, Serialize};
use crate::login::api::response::TrustedDeviceUserDecryptionOptionApiResponse;
#[derive(Serialize, Deserialize, Debug, Clone, PartialEq)]
#[serde(rename_all = "camelCase")]
#[cfg_attr(feature = "uniffi", derive(uniffi::Record))]
#[cfg_attr(
feature = "wasm",
derive(tsify::Tsify),
tsify(into_wasm_abi, from_wasm_abi)
)]
pub struct TrustedDeviceUserDecryptionOption {
pub has_admin_approval: bool,
pub has_login_approving_device: bool,
pub has_manage_reset_password_permission: bool,
pub is_tde_offboarding: bool,
#[serde(skip_serializing_if = "Option::is_none")]
pub encrypted_private_key: Option<EncString>,
#[serde(skip_serializing_if = "Option::is_none")]
pub encrypted_user_key: Option<UnsignedSharedKey>,
}
impl From<TrustedDeviceUserDecryptionOptionApiResponse> for TrustedDeviceUserDecryptionOption {
fn from(api: TrustedDeviceUserDecryptionOptionApiResponse) -> Self {
Self {
has_admin_approval: api.has_admin_approval,
has_login_approving_device: api.has_login_approving_device,
has_manage_reset_password_permission: api.has_manage_reset_password_permission,
is_tde_offboarding: api.is_tde_offboarding,
encrypted_private_key: api.encrypted_private_key,
encrypted_user_key: api.encrypted_user_key,
}
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_trusted_device_conversion() {
let api = TrustedDeviceUserDecryptionOptionApiResponse {
has_admin_approval: true,
has_login_approving_device: false,
has_manage_reset_password_permission: true,
is_tde_offboarding: false,
encrypted_private_key: Some("2.pMS6/icTQABtulw52pq2lg==|XXbxKxDTh+mWiN1HjH2N1w==|Q6PkuT+KX/axrgN9ubD5Ajk2YNwxQkgs3WJM0S0wtG8=".parse().unwrap()),
encrypted_user_key: Some("4.ZheRb3PCfAunyFdQYPfyrFqpuvmln9H9w5nDjt88i5A7ug1XE0LJdQHCIYJl0YOZ1gCOGkhFu/CRY2StiLmT3iRKrrVBbC1+qRMjNNyDvRcFi91LWsmRXhONVSPjywzrJJXglsztDqGkLO93dKXNhuKpcmtBLsvgkphk/aFvxbaOvJ/FHdK/iV0dMGNhc/9tbys8laTdwBlI5xIChpRcrfH+XpSFM88+Bu03uK67N9G6eU1UmET+pISJwJvMuIDMqH+qkT7OOzgL3t6I0H2LDj+CnsumnQmDsvQzDiNfTR0IgjpoE9YH2LvPXVP2wVUkiTwXD9cG/E7XeoiduHyHjw==".parse().unwrap()),
};
let domain: TrustedDeviceUserDecryptionOption = api.clone().into();
assert_eq!(domain.has_admin_approval, api.has_admin_approval);
assert_eq!(
domain.has_login_approving_device,
api.has_login_approving_device
);
assert_eq!(
domain.has_manage_reset_password_permission,
api.has_manage_reset_password_permission
);
assert_eq!(domain.is_tde_offboarding, api.is_tde_offboarding);
assert_eq!(domain.encrypted_private_key, api.encrypted_private_key);
assert_eq!(domain.encrypted_user_key, api.encrypted_user_key);
}
}