From ea9fa4e0df8d45e06b1d7ead5e29813ea5025493 Mon Sep 17 00:00:00 2001 From: Linus Jahn Date: Mon, 27 Feb 2023 17:27:53 +0100 Subject: MamManager: Fix task is not finished when no message is encrypted --- src/client/QXmppMamManager.cpp | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'src/client') diff --git a/src/client/QXmppMamManager.cpp b/src/client/QXmppMamManager.cpp index f173aa01..c39a3411 100644 --- a/src/client/QXmppMamManager.cpp +++ b/src/client/QXmppMamManager.cpp @@ -264,11 +264,14 @@ QXmppTask QXmppMamManager::retrieveMessages(con if (auto *e2eeExt = client()->encryptionExtension()) { auto &messages = itr->second.messages; auto running = std::make_shared(0); + // handle case when no message is encrypted + auto hasEncryptedMessages = false; for (auto i = 0; i < messages.size(); i++) { if (!e2eeExt->isEncrypted(messages.at(i))) { continue; } + hasEncryptedMessages = true; auto message = messages.at(i); (*running)++; @@ -290,6 +293,12 @@ QXmppTask QXmppMamManager::retrieveMessages(con } }); } + + if (!hasEncryptedMessages) { + // finish here, no decryptMessage callback will do it + itr->second.finish(); + d->ongoingRequests.erase(itr); + } } else { itr->second.finish(); d->ongoingRequests.erase(itr); -- cgit v1.2.3