Files
nextcloud-mail/lib/Send/CopySentMessageHandler.php
Christoph Wurst ed9c2cc92c refactor: add override attribute
Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>
2025-06-04 07:33:09 +02:00

86 lines
2.5 KiB
PHP

<?php
declare(strict_types=1);
/**
* SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace OCA\Mail\Send;
use Horde_Imap_Client_Exception;
use Horde_Imap_Client_Socket;
use OCA\Mail\Account;
use OCA\Mail\Db\LocalMessage;
use OCA\Mail\Db\MailboxMapper;
use OCA\Mail\IMAP\MessageMapper;
use OCP\AppFramework\Db\DoesNotExistException;
use Psr\Log\LoggerInterface;
class CopySentMessageHandler extends AHandler {
public function __construct(
private MailboxMapper $mailboxMapper,
private LoggerInterface $logger,
private MessageMapper $messageMapper,
) {
}
#[\Override]
public function process(
Account $account,
LocalMessage $localMessage,
Horde_Imap_Client_Socket $client,
): LocalMessage {
if ($localMessage->getStatus() === LocalMessage::STATUS_PROCESSED) {
return $this->processNext($account, $localMessage, $client);
}
$rawMessage = $localMessage->getRaw();
if ($rawMessage === null) {
$localMessage->setStatus(LocalMessage::STATUS_IMAP_SENT_MAILBOX_FAIL);
return $localMessage;
}
$sentMailboxId = $account->getMailAccount()->getSentMailboxId();
if ($sentMailboxId === null) {
// We can't write the "sent mailbox" status here bc that would trigger an additional send.
// Thus, we leave the "imap copy to sent mailbox" status.
$localMessage->setStatus(LocalMessage::STATUS_IMAP_SENT_MAILBOX_FAIL);
$this->logger->warning("No sent mailbox exists, can't save sent message");
return $localMessage;
}
// Save the message in the sent mailbox
try {
$sentMailbox = $this->mailboxMapper->findById(
$sentMailboxId
);
} catch (DoesNotExistException $e) {
// We can't write the "sent mailbox" status here bc that would trigger an additional send.
// Thus, we leave the "imap copy to sent mailbox" status.
$localMessage->setStatus(LocalMessage::STATUS_IMAP_SENT_MAILBOX_FAIL);
$this->logger->error('Sent mailbox could not be found', [
'exception' => $e,
]);
return $localMessage;
}
try {
$this->messageMapper->save(
$client,
$sentMailbox,
$rawMessage,
);
$localMessage->setStatus(LocalMessage::STATUS_PROCESSED);
} catch (Horde_Imap_Client_Exception $e) {
$localMessage->setStatus(LocalMessage::STATUS_IMAP_SENT_MAILBOX_FAIL);
$this->logger->error('Could not copy message to sent mailbox', [
'exception' => $e,
]);
return $localMessage;
}
return $this->processNext($account, $localMessage, $client);
}
}