From 637a3f6646f9f8a0de2d4b1abbbc98fb90affbe1 Mon Sep 17 00:00:00 2001 From: link2xt Date: Thu, 3 Oct 2024 03:44:21 +0000 Subject: [PATCH] fix: do not attempt to reference info messages Info messages are added at the beginning of unpromoted group chats ("Others will only see this group after you sent a first message."), may be created by WebXDC etc. They are not sent outside and have local Message-ID that is not known to other recipients so they should be skipped when constructing In-Reply-To and References. --- src/chat.rs | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/src/chat.rs b/src/chat.rs index a557df6e5b..53f0c9ed01 100644 --- a/src/chat.rs +++ b/src/chat.rs @@ -1228,6 +1228,7 @@ impl ChatId { AND ((state BETWEEN {} AND {}) OR (state >= {})) \ AND NOT hidden \ AND download_state={} \ + AND from_id != {} \ ORDER BY timestamp DESC, id DESC \ LIMIT 1;", MessageState::InFresh as u32, @@ -1236,6 +1237,9 @@ impl ChatId { // Do not reply to not fully downloaded messages. Such a message could be a group chat // message that we assigned to 1:1 chat. DownloadState::Done as u32, + // Do not reference info messages, they are not actually sent out + // and have Message-IDs unknown to other chat members. + ContactId::INFO.to_u32(), ); sql.query_row_optional(&query, (self,), f).await } @@ -4726,6 +4730,7 @@ mod tests { use super::*; use crate::chatlist::get_archived_cnt; use crate::constants::{DC_GCL_ARCHIVED_ONLY, DC_GCL_NO_SPECIALS}; + use crate::headerdef::HeaderDef; use crate::message::delete_msgs; use crate::receive_imf::receive_imf; use crate::test_utils::{sync, TestContext, TestContextManager}; @@ -7681,4 +7686,29 @@ mod tests { Ok(()) } + + /// Tests that info message is ignored when constructing `In-Reply-To`. + #[tokio::test(flavor = "multi_thread", worker_threads = 2)] + async fn test_info_not_referenced() -> Result<()> { + let mut tcm = TestContextManager::new(); + let alice = &tcm.alice().await; + let bob = &tcm.bob().await; + + let bob_received_message = tcm.send_recv_accept(alice, bob, "Hi!").await; + let bob_chat_id = bob_received_message.chat_id; + add_info_msg(bob, bob_chat_id, "Some info", create_smeared_timestamp(bob)).await?; + + // Bob sends a message. + // This message should reference Alice's "Hi!" message and not the info message. + let sent = bob.send_text(bob_chat_id, "Hi hi!").await; + let mime_message = alice.parse_msg(&sent).await; + + let in_reply_to = mime_message.get_header(HeaderDef::InReplyTo).unwrap(); + assert_eq!( + in_reply_to, + format!("<{}>", bob_received_message.rfc724_mid) + ); + + Ok(()) + } }