From 82bbf8cc8dcb2fef37f4fbc7b4a6ca02aed152b9 Mon Sep 17 00:00:00 2001 From: dankito Date: Thu, 21 Nov 2024 23:03:53 +0100 Subject: [PATCH] Implemented parallel message downloading --- .../net/codinux/invoicing/mail/MailReader.kt | 21 ++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/e-invoicing-domain/src/main/kotlin/net/codinux/invoicing/mail/MailReader.kt b/e-invoicing-domain/src/main/kotlin/net/codinux/invoicing/mail/MailReader.kt index 8237be3..2036cb0 100644 --- a/e-invoicing-domain/src/main/kotlin/net/codinux/invoicing/mail/MailReader.kt +++ b/e-invoicing-domain/src/main/kotlin/net/codinux/invoicing/mail/MailReader.kt @@ -94,9 +94,24 @@ class MailReader( return emptyList() } - // tried to parallelize reading messages by reading them on multiple thread but that had no effect on process duration (don't know why) - private fun listAllMessagesWithEInvoiceInFolder(folder: Folder): List = folder.messages.mapNotNull { message -> - findEInvoice(message) + private fun listAllMessagesWithEInvoiceInFolder(folder: Folder): List = runBlocking { + val messageCount = folder.messageCount + if (messageCount <= 0) { + return@runBlocking emptyList() + } + + IntRange(1, messageCount).mapNotNull { messageNumber -> // message numbers start at 1 + async(mailDispatcher) { + try { + findEInvoice(folder.getMessage(messageNumber)) + } catch (e: Throwable) { + log.error(e) { "Could not get message with messageNumber $messageNumber" } + null + } + } + } + .awaitAll() + .filterNotNull() } private fun findEInvoice(message: Message): MailWithInvoice? {