diff --git a/src/account_manager.rs b/src/account_manager.rs index 635c66984..208c48f77 100644 --- a/src/account_manager.rs +++ b/src/account_manager.rs @@ -1,5 +1,6 @@ use base64::prelude::*; use phonenumber::PhoneNumber; +use rand::Rng; use reqwest::Method; use std::collections::HashMap; use std::convert::{TryFrom, TryInto}; @@ -641,7 +642,7 @@ impl AccountManager { /// Should be called as the primary device to migrate from pre-PNI to PNI. /// /// This is the equivalent of Android's PnpInitializeDevicesJob or iOS' PniHelloWorldManager. - #[tracing::instrument(skip(self, aci_protocol_store, pni_protocol_store, sender, local_aci, csprng), fields(local_aci = %local_aci.service_id_string()))] + #[tracing::instrument(skip(self, aci_protocol_store, pni_protocol_store, sender, local_aci), fields(local_aci = %local_aci.service_id_string()))] pub async fn pnp_initialize_devices< // XXX So many constraints here, all imposed by the MessageSender R: rand::Rng + rand::CryptoRng, @@ -652,11 +653,11 @@ impl AccountManager { &mut self, aci_protocol_store: &mut AciStore, pni_protocol_store: &mut PniStore, - mut sender: MessageSender, + mut sender: MessageSender, local_aci: Aci, e164: PhoneNumber, - csprng: &mut R, ) -> Result<(), MessageSenderError> { + let mut csprng = rand::thread_rng(); let pni_identity_key_pair = pni_protocol_store.get_identity_key_pair().await?; @@ -713,7 +714,7 @@ impl AccountManager { crate::pre_keys::replenish_pre_keys( pni_protocol_store, &pni_identity_key_pair, - csprng, + &mut csprng, true, 0, 0, @@ -721,12 +722,12 @@ impl AccountManager { .await? } else { // Generate a signed prekey - let signed_pre_key_pair = KeyPair::generate(csprng); + let signed_pre_key_pair = KeyPair::generate(&mut csprng); let signed_pre_key_public = signed_pre_key_pair.public_key; let signed_pre_key_signature = pni_identity_key_pair.private_key().calculate_signature( &signed_pre_key_public.serialize(), - csprng, + &mut csprng, )?; let signed_prekey_record = SignedPreKeyRecord::new( @@ -754,7 +755,7 @@ impl AccountManager { pni_protocol_store.get_local_registration_id().await? } else { loop { - let regid = generate_registration_id(csprng); + let regid = generate_registration_id(&mut csprng); if !pni_registration_ids.iter().any(|(_k, v)| *v == regid) { break regid; } @@ -802,7 +803,7 @@ impl AccountManager { e164.format().mode(phonenumber::Mode::E164).to_string(), ), }), - padding: Some(random_length_padding(csprng, 512)), + padding: Some(random_length_padding(&mut csprng, 512)), ..SyncMessage::default() }; let content: ContentBody = msg.into(); diff --git a/src/cipher.rs b/src/cipher.rs index 46a175858..56ab4f8a5 100644 --- a/src/cipher.rs +++ b/src/cipher.rs @@ -13,7 +13,6 @@ use libsignal_protocol::{ SignalMessage, SignalProtocolError, SignedPreKeyStore, Timestamp, }; use prost::Message; -use rand::{CryptoRng, Rng}; use uuid::Uuid; use crate::{ @@ -29,15 +28,14 @@ use crate::{ /// /// Equivalent of SignalServiceCipher in Java. #[derive(Clone)] -pub struct ServiceCipher { +pub struct ServiceCipher { protocol_store: S, - csprng: R, trust_root: PublicKey, local_uuid: Uuid, local_device_id: u32, } -impl fmt::Debug for ServiceCipher { +impl fmt::Debug for ServiceCipher { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { f.debug_struct("ServiceCipher") .field("protocol_store", &"...") @@ -70,21 +68,18 @@ fn debug_envelope(envelope: &Envelope) -> String { } } -impl ServiceCipher +impl ServiceCipher where S: ProtocolStore + SenderKeyStore + SessionStoreExt + Clone, - R: Rng + CryptoRng, { pub fn new( protocol_store: S, - csprng: R, trust_root: PublicKey, local_uuid: Uuid, local_device_id: u32, ) -> Self { Self { protocol_store, - csprng, trust_root, local_uuid, local_device_id, @@ -180,7 +175,7 @@ where &mut self.protocol_store.clone(), &self.protocol_store.clone(), &mut self.protocol_store.clone(), - &mut self.csprng, + &mut rand::thread_rng(), ) .await? .as_slice() @@ -236,7 +231,7 @@ where &sender, &mut self.protocol_store.clone(), &mut self.protocol_store.clone(), - &mut self.csprng, + &mut rand::thread_rng(), ) .await? .as_slice() @@ -357,7 +352,7 @@ where &mut self.protocol_store.clone(), &mut self.protocol_store, SystemTime::now(), - &mut self.csprng, + &mut rand::thread_rng(), ) .await?; diff --git a/src/sender.rs b/src/sender.rs index 84db7764d..d8ff4c97f 100644 --- a/src/sender.rs +++ b/src/sender.rs @@ -6,7 +6,6 @@ use libsignal_protocol::{ ProtocolStore, SenderCertificate, SenderKeyStore, ServiceId, SignalProtocolError, }; -use rand::{CryptoRng, Rng}; use tracing::{debug, error, info, trace, warn}; use tracing_futures::Instrument; use uuid::Uuid; @@ -86,12 +85,11 @@ pub struct AttachmentSpec { } #[derive(Clone)] -pub struct MessageSender { +pub struct MessageSender { identified_ws: SignalWebSocket, unidentified_ws: SignalWebSocket, service: PushService, - cipher: ServiceCipher, - csprng: R, + cipher: ServiceCipher, protocol_store: S, local_aci: Aci, local_pni: Pni, @@ -153,18 +151,16 @@ pub struct EncryptedMessages { used_identity_key: IdentityKey, } -impl MessageSender +impl MessageSender where S: ProtocolStore + SenderKeyStore + SessionStoreExt + Sync + Clone, - R: Rng + CryptoRng, { #[allow(clippy::too_many_arguments)] pub fn new( identified_ws: SignalWebSocket, unidentified_ws: SignalWebSocket, service: PushService, - cipher: ServiceCipher, - csprng: R, + cipher: ServiceCipher, protocol_store: S, local_aci: impl Into, local_pni: impl Into, @@ -177,7 +173,6 @@ where identified_ws, unidentified_ws, cipher, - csprng, protocol_store, local_aci: local_aci.into(), local_pni: local_pni.into(), @@ -632,7 +627,7 @@ where &mut self.protocol_store, &pre_key, SystemTime::now(), - &mut self.csprng, + &mut rand::thread_rng(), ) .await .map_err(|e| { @@ -845,7 +840,7 @@ where .expect("PNI key set when PNI signature requested") .sign_alternate_identity( self.aci_identity.identity_key(), - &mut self.csprng, + &mut rand::thread_rng(), )?; Ok(crate::proto::PniSignatureMessage { pni: Some(self.local_pni.service_id_binary()), @@ -1028,7 +1023,7 @@ where &mut self.protocol_store, &pre_key_bundle, SystemTime::now(), - &mut self.csprng, + &mut rand::thread_rng(), ) .await?; }