From 964dc9da3e6194da0a0d3f25eb2fdf8e58ed74d3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20Garc=C3=ADa?= Date: Mon, 29 Apr 2024 16:33:04 +0200 Subject: [PATCH] Implement Eq and PartialEq for Sensitive and their inner types (#747) ## Type of change ``` - [ ] Bug fix - [ ] New feature development - [x] Tech debt (refactoring, code cleanup, dependency upgrades, etc) - [ ] Build/deploy pipeline (DevOps) - [ ] Other ``` ## Objective With this, we can remove all the uses of .`expose()` from tests, which makes it much easier to see possible areas of improvement for Sensitive coverage. With this PR we can compare the following: - `Sensitive` == `Sensitive` - `Sensitive` == `V` - `Sensitive` == `&str` - `Sensitive>` == `&[u8]` I tried to replace the last two with a generic impl that would just take AsRef<> instead, but couldn't do it without conflicting implementations. Note that the position is important, for example `V` == `Sensitive` will not compile, and I don't think we can implement a blanket `Eq` for a generic `V` without running afoul of the orphan rules. --- .../src/enc_string/asymmetric.rs | 11 +++++---- .../src/enc_string/symmetric.rs | 6 ++--- .../src/keys/asymmetric_crypto_key.rs | 10 ++++---- .../bitwarden-crypto/src/keys/device_key.rs | 2 +- .../bitwarden-crypto/src/keys/master_key.rs | 10 ++++---- .../src/keys/shareable_key.rs | 4 ++-- crates/bitwarden-crypto/src/lib.rs | 2 +- .../src/sensitive/sensitive.rs | 23 ++++++++++++++++++- crates/bitwarden/src/auth/access_token.rs | 2 +- crates/bitwarden/src/auth/auth_request.rs | 21 +++++++++-------- crates/bitwarden/src/auth/mod.rs | 5 +--- .../bitwarden/src/auth/password/validate.rs | 7 ++---- crates/bitwarden/src/auth/tde.rs | 2 +- crates/bitwarden/src/mobile/crypto.rs | 9 +++----- crates/bitwarden/src/tool/exporters/mod.rs | 8 +++---- .../bitwarden/src/vault/cipher/attachment.rs | 2 +- crates/bitwarden/src/vault/cipher/cipher.rs | 22 +++++++++--------- crates/bitwarden/src/vault/cipher/login.rs | 2 +- crates/bitwarden/src/vault/send.rs | 6 ++--- 19 files changed, 84 insertions(+), 70 deletions(-) diff --git a/crates/bitwarden-crypto/src/enc_string/asymmetric.rs b/crates/bitwarden-crypto/src/enc_string/asymmetric.rs index f4c8b0f7c..f9d1921ee 100644 --- a/crates/bitwarden-crypto/src/enc_string/asymmetric.rs +++ b/crates/bitwarden-crypto/src/enc_string/asymmetric.rs @@ -10,6 +10,7 @@ use crate::{ error::{CryptoError, EncStringParseError, Result}, rsa::encrypt_rsa2048_oaep_sha1, AsymmetricCryptoKey, AsymmetricEncryptable, DecryptedString, DecryptedVec, KeyDecryptable, + SensitiveVec, }; // This module is a workaround to avoid deprecated warnings that come from the ZeroizeOnDrop @@ -146,10 +147,10 @@ impl serde::Serialize for AsymmetricEncString { impl AsymmetricEncString { /// Encrypt and produce a [AsymmetricEncString::Rsa2048_OaepSha1_B64] variant. pub fn encrypt_rsa2048_oaep_sha1( - data_dec: &[u8], + data_dec: SensitiveVec, key: &dyn AsymmetricEncryptable, ) -> Result { - let enc = encrypt_rsa2048_oaep_sha1(key.to_public_key(), data_dec)?; + let enc = encrypt_rsa2048_oaep_sha1(key.to_public_key(), data_dec.expose())?; Ok(AsymmetricEncString::Rsa2048_OaepSha1_B64 { data: enc }) } @@ -254,7 +255,7 @@ XKZBokBGnjFnTnKcs7nv/O8= assert_eq!(enc_string.enc_type(), 3); let res: DecryptedString = enc_string.decrypt_with_key(&private_key).unwrap(); - assert_eq!(res.expose(), "EncryptMe!"); + assert_eq!(res, "EncryptMe!"); } #[test] @@ -266,7 +267,7 @@ XKZBokBGnjFnTnKcs7nv/O8= assert_eq!(enc_string.enc_type(), 4); let res: DecryptedString = enc_string.decrypt_with_key(&private_key).unwrap(); - assert_eq!(res.expose(), "EncryptMe!"); + assert_eq!(res, "EncryptMe!"); } #[test] @@ -278,7 +279,7 @@ XKZBokBGnjFnTnKcs7nv/O8= assert_eq!(enc_string.enc_type(), 6); let res: DecryptedString = enc_string.decrypt_with_key(&private_key).unwrap(); - assert_eq!(res.expose(), "EncryptMe!"); + assert_eq!(res, "EncryptMe!"); } #[test] diff --git a/crates/bitwarden-crypto/src/enc_string/symmetric.rs b/crates/bitwarden-crypto/src/enc_string/symmetric.rs index e8c4c2d04..1a0c9f359 100644 --- a/crates/bitwarden-crypto/src/enc_string/symmetric.rs +++ b/crates/bitwarden-crypto/src/enc_string/symmetric.rs @@ -317,7 +317,7 @@ mod tests { let cipher = test_string.to_owned().encrypt_with_key(&key).unwrap(); let decrypted_str: SensitiveString = cipher.decrypt_with_key(&key).unwrap(); - assert_eq!(decrypted_str.expose(), test_string); + assert_eq!(decrypted_str, test_string); } #[test] @@ -415,7 +415,7 @@ mod tests { assert_eq!(enc_string.enc_type(), 0); let dec_str: SensitiveString = enc_string.decrypt_with_key(&key).unwrap(); - assert_eq!(dec_str.expose(), "EncryptMe!"); + assert_eq!(dec_str, "EncryptMe!"); } #[test] @@ -428,7 +428,7 @@ mod tests { assert_eq!(enc_string.enc_type(), 1); let dec_str: SensitiveString = enc_string.decrypt_with_key(&key).unwrap(); - assert_eq!(dec_str.expose(), "EncryptMe!"); + assert_eq!(dec_str, "EncryptMe!"); } #[test] diff --git a/crates/bitwarden-crypto/src/keys/asymmetric_crypto_key.rs b/crates/bitwarden-crypto/src/keys/asymmetric_crypto_key.rs index 9636defe1..c86b38b97 100644 --- a/crates/bitwarden-crypto/src/keys/asymmetric_crypto_key.rs +++ b/crates/bitwarden-crypto/src/keys/asymmetric_crypto_key.rs @@ -172,8 +172,8 @@ DnqOsltgPomWZ7xVfMkm9niL2OA= assert_eq!(pem_key.key, der_key.key); // Check that the keys can be converted back to DER - assert_eq!(&der_key.to_der().unwrap(), der_key_vec.expose()); - assert_eq!(&pem_key.to_der().unwrap(), der_key_vec.expose()); + assert_eq!(der_key_vec, der_key.to_der().unwrap().as_slice()); + assert_eq!(der_key_vec, pem_key.to_der().unwrap().as_slice()); } #[test] @@ -224,12 +224,12 @@ DnqOsltgPomWZ7xVfMkm9niL2OA= let private_key = AsymmetricCryptoKey::from_der(private_key).unwrap(); let public_key = AsymmetricPublicCryptoKey::from_der(public_key).unwrap(); - let plaintext = "Hello, world!"; + let plaintext = SensitiveString::test("Hello, world!"); let encrypted = - AsymmetricEncString::encrypt_rsa2048_oaep_sha1(plaintext.as_bytes(), &public_key) + AsymmetricEncString::encrypt_rsa2048_oaep_sha1(plaintext.clone().into(), &public_key) .unwrap(); let decrypted: DecryptedString = encrypted.decrypt_with_key(&private_key).unwrap(); - assert_eq!(plaintext, decrypted.expose()); + assert_eq!(plaintext, decrypted); } } diff --git a/crates/bitwarden-crypto/src/keys/device_key.rs b/crates/bitwarden-crypto/src/keys/device_key.rs index e54dbaa88..28425f5c5 100644 --- a/crates/bitwarden-crypto/src/keys/device_key.rs +++ b/crates/bitwarden-crypto/src/keys/device_key.rs @@ -38,7 +38,7 @@ impl DeviceKey { let data = user_key.to_vec(); let protected_user_key = - AsymmetricEncString::encrypt_rsa2048_oaep_sha1(data.expose(), &device_private_key)?; + AsymmetricEncString::encrypt_rsa2048_oaep_sha1(data, &device_private_key)?; let protected_device_public_key = device_private_key .to_public_der()? diff --git a/crates/bitwarden-crypto/src/keys/master_key.rs b/crates/bitwarden-crypto/src/keys/master_key.rs index b4d0677d8..0015d624d 100644 --- a/crates/bitwarden-crypto/src/keys/master_key.rs +++ b/crates/bitwarden-crypto/src/keys/master_key.rs @@ -190,11 +190,10 @@ mod tests { let master_key = MasterKey::derive(&password, salt, &kdf).unwrap(); assert_eq!( - "ZF6HjxUTSyBHsC+HXSOhZoXN+UuMnygV5YkWXCY4VmM=", master_key .derive_master_key_hash(&password, HashPurpose::ServerAuthorization) - .unwrap() - .expose(), + .unwrap(), + "ZF6HjxUTSyBHsC+HXSOhZoXN+UuMnygV5YkWXCY4VmM=", ); } @@ -211,11 +210,10 @@ mod tests { let master_key = MasterKey::derive(&password, salt, &kdf).unwrap(); assert_eq!( - "PR6UjYmjmppTYcdyTiNbAhPJuQQOmynKbdEl1oyi/iQ=", master_key .derive_master_key_hash(&password, HashPurpose::ServerAuthorization) - .unwrap() - .expose(), + .unwrap(), + "PR6UjYmjmppTYcdyTiNbAhPJuQQOmynKbdEl1oyi/iQ=", ); } diff --git a/crates/bitwarden-crypto/src/keys/shareable_key.rs b/crates/bitwarden-crypto/src/keys/shareable_key.rs index 490e6b56e..495aa8a9b 100644 --- a/crates/bitwarden-crypto/src/keys/shareable_key.rs +++ b/crates/bitwarden-crypto/src/keys/shareable_key.rs @@ -48,13 +48,13 @@ mod tests { "test_key", None, ); - assert_eq!(key.to_base64().expose(), "4PV6+PcmF2w7YHRatvyMcVQtI7zvCyssv/wFWmzjiH6Iv9altjmDkuBD1aagLVaLezbthbSe+ktR+U6qswxNnQ=="); + assert_eq!(key.to_base64(), "4PV6+PcmF2w7YHRatvyMcVQtI7zvCyssv/wFWmzjiH6Iv9altjmDkuBD1aagLVaLezbthbSe+ktR+U6qswxNnQ=="); let key = derive_shareable_key( Sensitive::new(Box::new(*b"67t9b5g67$%Dh89n")), "test_key", Some("test"), ); - assert_eq!(key.to_base64().expose(), "F9jVQmrACGx9VUPjuzfMYDjr726JtL300Y3Yg+VYUnVQtQ1s8oImJ5xtp1KALC9h2nav04++1LDW4iFD+infng=="); + assert_eq!(key.to_base64(), "F9jVQmrACGx9VUPjuzfMYDjr726JtL300Y3Yg+VYUnVQtQ1s8oImJ5xtp1KALC9h2nav04++1LDW4iFD+infng=="); } } diff --git a/crates/bitwarden-crypto/src/lib.rs b/crates/bitwarden-crypto/src/lib.rs index cf9910582..9ba3a7eee 100644 --- a/crates/bitwarden-crypto/src/lib.rs +++ b/crates/bitwarden-crypto/src/lib.rs @@ -23,7 +23,7 @@ //! let encrypted = data.clone().encrypt_with_key(&key)?; //! let decrypted: DecryptedString = encrypted.decrypt_with_key(&key)?; //! -//! assert_eq!(&data, decrypted.expose()); +//! assert_eq!(decrypted, data); //! Ok(()) //! } //! ``` diff --git a/crates/bitwarden-crypto/src/sensitive/sensitive.rs b/crates/bitwarden-crypto/src/sensitive/sensitive.rs index 327ff3a31..9aac81275 100644 --- a/crates/bitwarden-crypto/src/sensitive/sensitive.rs +++ b/crates/bitwarden-crypto/src/sensitive/sensitive.rs @@ -17,7 +17,7 @@ use crate::CryptoError; /// /// Internally [`Sensitive`] contains a [`Box`] which ensures the value is placed on the heap. It /// implements the [`Drop`] trait which calls `zeroize` on the inner value. -#[derive(PartialEq, Clone, Zeroize, ZeroizeOnDrop)] +#[derive(Eq, Clone, Zeroize, ZeroizeOnDrop)] pub struct Sensitive { pub(super) value: Box, } @@ -151,6 +151,27 @@ impl fmt::Debug for Sensitive { } } +impl> PartialEq> for Sensitive { + fn eq(&self, other: &Self) -> bool { + self.value.eq(&other.value) + } +} +impl> PartialEq for Sensitive { + fn eq(&self, other: &V) -> bool { + self.value.as_ref().eq(other) + } +} +impl PartialEq<&str> for SensitiveString { + fn eq(&self, other: &&str) -> bool { + self.value.as_ref().eq(other) + } +} +impl PartialEq<&[u8]> for SensitiveVec { + fn eq(&self, other: &&[u8]) -> bool { + self.value.as_ref().eq(other) + } +} + /// Unfortunately once we serialize a `SensitiveString` we can't control the future memory. impl Serialize for Sensitive { fn serialize(&self, serializer: S) -> Result { diff --git a/crates/bitwarden/src/auth/access_token.rs b/crates/bitwarden/src/auth/access_token.rs index 0bf43d29a..e074b4524 100644 --- a/crates/bitwarden/src/auth/access_token.rs +++ b/crates/bitwarden/src/auth/access_token.rs @@ -79,7 +79,7 @@ mod tests { "ec2c1d46-6a4b-4751-a310-af9601317f2d" ); assert_eq!(token.client_secret, "C2IgxjjLF7qSshsbwe8JGcbM075YXw"); - assert_eq!(token.encryption_key.to_base64().expose(), "H9/oIRLtL9nGCQOVDjSMoEbJsjWXSOCb3qeyDt6ckzS3FhyboEDWyTP/CQfbIszNmAVg2ExFganG1FVFGXO/Jg=="); + assert_eq!(token.encryption_key.to_base64(), "H9/oIRLtL9nGCQOVDjSMoEbJsjWXSOCb3qeyDt6ckzS3FhyboEDWyTP/CQfbIszNmAVg2ExFganG1FVFGXO/Jg=="); } #[test] diff --git a/crates/bitwarden/src/auth/auth_request.rs b/crates/bitwarden/src/auth/auth_request.rs index bb341bf4d..0fedc7a40 100644 --- a/crates/bitwarden/src/auth/auth_request.rs +++ b/crates/bitwarden/src/auth/auth_request.rs @@ -98,7 +98,7 @@ pub(crate) fn approve_auth_request( let key = enc.get_key(&None).ok_or(Error::VaultLocked)?; Ok(AsymmetricEncString::encrypt_rsa2048_oaep_sha1( - key.to_vec().expose(), + key.to_vec(), &public_key, )?) } @@ -107,22 +107,23 @@ pub(crate) fn approve_auth_request( fn test_auth_request() { let request = new_auth_request("test@bitwarden.com").unwrap(); - let secret: &[u8] = &[ + let secret = bitwarden_crypto::SensitiveVec::test(&[ 111, 32, 97, 169, 4, 241, 174, 74, 239, 206, 113, 86, 174, 68, 216, 238, 52, 85, 156, 27, 134, 149, 54, 55, 91, 147, 45, 130, 131, 237, 51, 31, 191, 106, 155, 14, 160, 82, 47, 40, 96, 31, 114, 127, 212, 187, 167, 110, 205, 116, 198, 243, 218, 72, 137, 53, 248, 43, 255, 67, 35, 61, 245, 93, - ]; + ]); let private_key = SensitiveString::new(Box::new(request.private_key.clone())); let private_key = AsymmetricCryptoKey::from_der(private_key.decode_base64(STANDARD).unwrap()).unwrap(); - let encrypted = AsymmetricEncString::encrypt_rsa2048_oaep_sha1(secret, &private_key).unwrap(); + let encrypted = + AsymmetricEncString::encrypt_rsa2048_oaep_sha1(secret.clone(), &private_key).unwrap(); let decrypted = auth_request_decrypt_user_key(request.private_key, encrypted).unwrap(); - assert_eq!(decrypted.to_vec().expose(), secret); + assert_eq!(decrypted.to_vec(), secret); } #[cfg(test)] @@ -171,11 +172,12 @@ mod tests { let dec = auth_request_decrypt_user_key(private_key.to_owned(), enc_user_key).unwrap(); assert_eq!( - dec.to_vec().expose(), - &[ + dec.to_vec(), + [ 201, 37, 234, 213, 21, 75, 40, 70, 149, 213, 234, 16, 19, 251, 162, 245, 161, 74, 34, 245, 211, 151, 211, 192, 95, 10, 117, 50, 88, 223, 23, 157 ] + .as_slice() ); } @@ -190,13 +192,14 @@ mod tests { .unwrap(); assert_eq!( - dec.to_vec().expose(), - &[ + dec.to_vec(), + [ 109, 128, 172, 147, 206, 123, 134, 95, 16, 36, 155, 113, 201, 18, 186, 230, 216, 212, 173, 188, 74, 11, 134, 131, 137, 242, 105, 178, 105, 126, 52, 139, 248, 91, 215, 21, 128, 91, 226, 222, 165, 67, 251, 34, 83, 81, 77, 147, 225, 76, 13, 41, 102, 45, 183, 218, 106, 89, 254, 208, 251, 101, 130, 10, ] + .as_slice() ); } diff --git a/crates/bitwarden/src/auth/mod.rs b/crates/bitwarden/src/auth/mod.rs index 34a14aaf1..48c56c6bd 100644 --- a/crates/bitwarden/src/auth/mod.rs +++ b/crates/bitwarden/src/auth/mod.rs @@ -59,9 +59,6 @@ mod tests { let result = determine_password_hash(email, &kdf, &password, purpose).unwrap(); - assert_eq!( - result.expose(), - "7kTqkF1pY/3JeOu73N9kR99fDDe9O1JOZaVc7KH3lsU=" - ); + assert_eq!(result, "7kTqkF1pY/3JeOu73N9kR99fDDe9O1JOZaVc7KH3lsU="); } } diff --git a/crates/bitwarden/src/auth/password/validate.rs b/crates/bitwarden/src/auth/password/validate.rs index b28e5aa63..f096dfd77 100644 --- a/crates/bitwarden/src/auth/password/validate.rs +++ b/crates/bitwarden/src/auth/password/validate.rs @@ -29,7 +29,7 @@ pub(crate) fn validate_password( HashPurpose::LocalAuthorization, )?; - Ok(hash.expose() == password_hash.expose()) + Ok(hash == password_hash) } } } else { @@ -146,10 +146,7 @@ mod tests { ) .unwrap(); - assert_eq!( - result.expose(), - "aOvkBXFhSdgrBWR3hZCMRoML9+h5yRblU3lFphCdkeA=" - ); + assert_eq!(result, "aOvkBXFhSdgrBWR3hZCMRoML9+h5yRblU3lFphCdkeA="); assert!(validate_password(&client, password.try_into().unwrap(), result).unwrap()) } diff --git a/crates/bitwarden/src/auth/tde.rs b/crates/bitwarden/src/auth/tde.rs index 9b21aaa18..00295262e 100644 --- a/crates/bitwarden/src/auth/tde.rs +++ b/crates/bitwarden/src/auth/tde.rs @@ -25,7 +25,7 @@ pub(super) fn make_register_tde_keys( let key_pair = user_key.make_key_pair()?; let admin_reset = - AsymmetricEncString::encrypt_rsa2048_oaep_sha1(user_key.0.to_vec().expose(), &public_key)?; + AsymmetricEncString::encrypt_rsa2048_oaep_sha1(user_key.0.to_vec(), &public_key)?; let device_key = if remember_device { Some(DeviceKey::trust_device(&user_key.0)?) diff --git a/crates/bitwarden/src/mobile/crypto.rs b/crates/bitwarden/src/mobile/crypto.rs index 1d74caa00..cea3ac1c5 100644 --- a/crates/bitwarden/src/mobile/crypto.rs +++ b/crates/bitwarden/src/mobile/crypto.rs @@ -315,7 +315,7 @@ pub(super) fn enroll_admin_password_reset( let key = enc.get_key(&None).ok_or(Error::VaultLocked)?; Ok(AsymmetricEncString::encrypt_rsa2048_oaep_sha1( - key.to_vec().expose(), + key.to_vec(), &public_key, )?) } @@ -381,10 +381,7 @@ mod tests { .await .unwrap(); - assert_eq!( - new_hash.expose(), - new_password_response.password_hash.expose() - ); + assert_eq!(new_hash, new_password_response.password_hash); assert_eq!( client @@ -540,6 +537,6 @@ mod tests { .unwrap() .get_key(&None) .unwrap(); - assert_eq!(decrypted.expose(), expected.to_vec().expose()); + assert_eq!(decrypted, expected.to_vec()); } } diff --git a/crates/bitwarden/src/tool/exporters/mod.rs b/crates/bitwarden/src/tool/exporters/mod.rs index 0094a3bf7..07057cced 100644 --- a/crates/bitwarden/src/tool/exporters/mod.rs +++ b/crates/bitwarden/src/tool/exporters/mod.rs @@ -227,7 +227,7 @@ mod tests { f.id, "fd411a1a-fec8-4070-985d-0e6560860e69".parse().unwrap() ); - assert_eq!(f.name.expose(), "test_name"); + assert_eq!(f.name, "test_name"); } #[test] @@ -274,7 +274,7 @@ mod tests { "fd411a1a-fec8-4070-985d-0e6560860e69".parse().unwrap() ); assert_eq!(cipher.folder_id, None); - assert_eq!(cipher.name.expose(), "My login"); + assert_eq!(cipher.name, "My login"); assert_eq!(cipher.notes, None); assert!(!cipher.favorite); assert_eq!(cipher.reprompt, 0); @@ -290,8 +290,8 @@ mod tests { assert_eq!(cipher.deleted_date, None); if let bitwarden_exporters::CipherType::Login(l) = cipher.r#type { - assert_eq!(l.username.unwrap().expose(), "test_username"); - assert_eq!(l.password.unwrap().expose(), "test_password"); + assert_eq!(l.username.unwrap(), "test_username"); + assert_eq!(l.password.unwrap(), "test_password"); assert!(l.login_uris.is_empty()); assert_eq!(l.totp, None); } else { diff --git a/crates/bitwarden/src/vault/cipher/attachment.rs b/crates/bitwarden/src/vault/cipher/attachment.rs index 84cf773fd..9c0fa6426 100644 --- a/crates/bitwarden/src/vault/cipher/attachment.rs +++ b/crates/bitwarden/src/vault/cipher/attachment.rs @@ -200,6 +200,6 @@ mod tests { .decrypt_with_key(&user_key) .unwrap(); - assert_eq!(dec.expose(), &original); + assert_eq!(dec, original); } } diff --git a/crates/bitwarden/src/vault/cipher/cipher.rs b/crates/bitwarden/src/vault/cipher/cipher.rs index fe9bd9e0d..fc4972107 100644 --- a/crates/bitwarden/src/vault/cipher/cipher.rs +++ b/crates/bitwarden/src/vault/cipher/cipher.rs @@ -618,7 +618,7 @@ mod tests { let cipher_enc = cipher.encrypt_with_key(org_key).unwrap(); let cipher_dec: CipherView = cipher_enc.decrypt_with_key(org_key).unwrap(); - assert_eq!(cipher_dec.name.expose(), "My test login"); + assert_eq!(cipher_dec.name, "My test login"); } #[test] @@ -650,7 +650,7 @@ mod tests { let number = Some(DecryptedString::test("4111111111111111")); let subtitle = build_subtitle_card(brand, number); - assert_eq!(subtitle.expose(), "Visa, *1111"); + assert_eq!(subtitle, "Visa, *1111"); } #[test] @@ -659,7 +659,7 @@ mod tests { let number = Some(DecryptedString::test("5555555555554444")); let subtitle = build_subtitle_card(brand, number); - assert_eq!(subtitle.expose(), "Mastercard, *4444"); + assert_eq!(subtitle, "Mastercard, *4444"); } #[test] @@ -668,7 +668,7 @@ mod tests { let number = Some(DecryptedString::test("378282246310005")); let subtitle = build_subtitle_card(brand, number); - assert_eq!(subtitle.expose(), "Amex, *10005"); + assert_eq!(subtitle, "Amex, *10005"); } #[test] @@ -677,7 +677,7 @@ mod tests { let number = Some(DecryptedString::test("4")); let subtitle = build_subtitle_card(brand, number); - assert_eq!(subtitle.expose(), "Mastercard"); + assert_eq!(subtitle, "Mastercard"); } #[test] @@ -686,7 +686,7 @@ mod tests { let number = None; let subtitle = build_subtitle_card(brand, number); - assert_eq!(subtitle.expose(), "Mastercard"); + assert_eq!(subtitle, "Mastercard"); } #[test] @@ -695,7 +695,7 @@ mod tests { let number = Some(DecryptedString::test("5555555555554444")); let subtitle = build_subtitle_card(brand, number); - assert_eq!(subtitle.expose(), "*4444"); + assert_eq!(subtitle, "*4444"); } #[test] @@ -704,7 +704,7 @@ mod tests { let last_name = Some(DecryptedString::test("Doe")); let subtitle = build_subtitle_identity(first_name, last_name); - assert_eq!(subtitle.expose(), "John Doe"); + assert_eq!(subtitle, "John Doe"); } #[test] @@ -713,7 +713,7 @@ mod tests { let last_name = None; let subtitle = build_subtitle_identity(first_name, last_name); - assert_eq!(subtitle.expose(), "John"); + assert_eq!(subtitle, "John"); } #[test] @@ -722,7 +722,7 @@ mod tests { let last_name = Some(DecryptedString::test("Doe")); let subtitle = build_subtitle_identity(first_name, last_name); - assert_eq!(subtitle.expose(), "Doe"); + assert_eq!(subtitle, "Doe"); } #[test] @@ -731,6 +731,6 @@ mod tests { let last_name = None; let subtitle = build_subtitle_identity(first_name, last_name); - assert_eq!(subtitle.expose(), ""); + assert_eq!(subtitle, ""); } } diff --git a/crates/bitwarden/src/vault/cipher/login.rs b/crates/bitwarden/src/vault/cipher/login.rs index bc474c573..456d6223b 100644 --- a/crates/bitwarden/src/vault/cipher/login.rs +++ b/crates/bitwarden/src/vault/cipher/login.rs @@ -62,7 +62,7 @@ impl LoginUriView { .finalize(), )); - uri_hash.expose().as_slice() == cs.expose() + cs == uri_hash.expose().as_slice() } pub(crate) fn generate_checksum(&mut self) { diff --git a/crates/bitwarden/src/vault/send.rs b/crates/bitwarden/src/vault/send.rs index 4c34f638e..dba36e44a 100644 --- a/crates/bitwarden/src/vault/send.rs +++ b/crates/bitwarden/src/vault/send.rs @@ -396,7 +396,7 @@ mod tests { // Get the send key let send_key = Send::get_key(&send_key, k).unwrap(); let send_key_b64 = send_key.to_base64(); - assert_eq!(send_key_b64.expose(), "IR9ImHGm6rRuIjiN7csj94bcZR5WYTJj5GtNfx33zm6tJCHUl+QZlpNPba8g2yn70KnOHsAODLcR0um6E3MAlg=="); + assert_eq!(send_key_b64, "IR9ImHGm6rRuIjiN7csj94bcZR5WYTJj5GtNfx33zm6tJCHUl+QZlpNPba8g2yn70KnOHsAODLcR0um6E3MAlg=="); } fn build_encryption_settings() -> EncryptionSettings { @@ -582,8 +582,8 @@ mod tests { let send: Send = view.encrypt_with_key(key).unwrap(); assert_eq!( - send.password.as_ref().map(|p| p.expose().as_str()), - Some("vTIDfdj3FTDbejmMf+mJWpYdMXsxfeSd1Sma3sjCtiQ=") + send.password.clone().unwrap(), + "vTIDfdj3FTDbejmMf+mJWpYdMXsxfeSd1Sma3sjCtiQ=" ); let v: SendView = send.decrypt_with_key(key).unwrap();