From 0379bf370e16c8ded924aedcadcbcd7edacb4c44 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gabriel=20F=C3=A9ron?= Date: Tue, 22 Oct 2024 23:39:17 +0200 Subject: [PATCH] Fix sending note to self as primary without secondary devices --- src/sender.rs | 49 +++++++++++++++++++++++++++++++++++-------------- 1 file changed, 35 insertions(+), 14 deletions(-) diff --git a/src/sender.rs b/src/sender.rs index 56f31d0fb..e8cb48888 100644 --- a/src/sender.rs +++ b/src/sender.rs @@ -1,4 +1,3 @@ -use core::time; use std::{collections::HashSet, time::SystemTime}; use chrono::prelude::*; @@ -142,6 +141,12 @@ pub enum ThreadIdentifier { Group(GroupV2Id), } +#[derive(Debug)] +pub struct EncryptedMessages { + messages: Vec, + used_identity_key: IdentityKey, +} + impl MessageSender where S: ProtocolStore + SenderKeyStore + SessionStoreExt + Sync + Clone, @@ -533,13 +538,23 @@ where let content_bytes = content.encode_to_vec(); for _ in 0..4u8 { - let (messages, used_identity_key) = self + let Some(EncryptedMessages { + messages, + used_identity_key, + }) = self .create_encrypted_messages( &recipient, unidentified_access.map(|x| &x.certificate), &content_bytes, ) - .await?; + .await? + else { + // this can happen for example when a device is primary, without any secondaries + // and we send a message to ourselves (which is only a SyncMessage { sent: ... }) + // addressed to self + debug!("no messages were encrypted: this should rarely happen"); + break; + }; let messages = OutgoingPushMessages { destination: recipient.uuid, @@ -839,8 +854,7 @@ where recipient: &ServiceAddress, unidentified_access: Option<&SenderCertificate>, content: &[u8], - ) -> Result<(Vec, IdentityKey), MessageSenderError> - { + ) -> Result, MessageSenderError> { let mut messages = vec![]; let mut devices: HashSet = self @@ -925,15 +939,22 @@ where } } - let identity_key = self - .protocol_store - .get_identity(&recipient.to_protocol_address(DEFAULT_DEVICE_ID)) - .await? - .ok_or(MessageSenderError::UntrustedIdentity { - address: *recipient, - })?; - - Ok((messages, identity_key)) + if messages.is_empty() { + Ok(None) + } else { + Ok(Some(EncryptedMessages { + messages, + used_identity_key: self + .protocol_store + .get_identity( + &recipient.to_protocol_address(DEFAULT_DEVICE_ID), + ) + .await? + .ok_or(MessageSenderError::UntrustedIdentity { + address: *recipient, + })?, + })) + } } /// Equivalent to `getEncryptedMessage`