From 21f0daee7456752469cc459234388aba09b1ea1d Mon Sep 17 00:00:00 2001 From: Joas Schilling Date: Fri, 20 Dec 2024 15:00:24 +0100 Subject: [PATCH] fix: Notifier::prepare() threw \InvalidArgumentException which is deprecated Signed-off-by: Joas Schilling --- lib/Notification/Notifier.php | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/lib/Notification/Notifier.php b/lib/Notification/Notifier.php index 25dfa36ba18..f9ac27cae39 100644 --- a/lib/Notification/Notifier.php +++ b/lib/Notification/Notifier.php @@ -8,15 +8,16 @@ namespace OCA\Text\Notification; -use InvalidArgumentException; use OC\User\NoUserException; use OCP\Files\IRootFolder; use OCP\Files\NotPermittedException; use OCP\IURLGenerator; use OCP\IUserManager; use OCP\L10N\IFactory; +use OCP\Notification\AlreadyProcessedException; use OCP\Notification\INotification; use OCP\Notification\INotifier; +use OCP\Notification\UnknownNotificationException; class Notifier implements INotifier { public const TYPE_MENTIONED = 'mentioned'; @@ -45,7 +46,7 @@ public function getName(): string { public function prepare(INotification $notification, string $languageCode): INotification { if ($notification->getApp() !== 'text') { - throw new InvalidArgumentException('Application should be text instead of ' . $notification->getApp()); + throw new UnknownNotificationException('Application should be text instead of ' . $notification->getApp()); } $l = $this->factory->get('text', $languageCode); @@ -59,18 +60,18 @@ public function prepare(INotification $notification, string $languageCode): INot $fileId = (int)$notification->getObjectId(); if ($sourceUserDisplayName === null) { - throw new InvalidArgumentException(); + throw new UnknownNotificationException(); } try { $userFolder = $this->rootFolder->getUserFolder($targetUser); } catch (NotPermittedException|NoUserException $e) { - throw new InvalidArgumentException(); + throw new UnknownNotificationException(); } $node = $userFolder->getFirstNodeById($fileId); if ($node === null) { - throw new InvalidArgumentException(); + throw new AlreadyProcessedException(); } $fileLink = $this->url->linkToRouteAbsolute('files.viewcontroller.showFile', ['fileid' => $node->getId()]); @@ -91,7 +92,7 @@ public function prepare(INotification $notification, string $languageCode): INot ]); break; default: - throw new InvalidArgumentException(); + throw new UnknownNotificationException(); } $notification->setIcon($this->url->getAbsoluteURL($this->url->imagePath('text', 'app-dark.svg'))); $notification->setLink($fileLink);