aboutsummaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorChristopher Ng <chrng8@gmail.com>2023-08-09 10:20:32 -0700
committerChristopher Ng <chrng8@gmail.com>2023-08-09 10:41:18 -0700
commit86db2d7f15f8507e9c563507491b7dba3c63e932 (patch)
tree2b0c48e72ae44ce00e5cb828cdcda7b3e93aab93 /apps
parent38e4ba211d4816b401556939a30401b602088677 (diff)
downloadnextcloud-server-86db2d7f15f8507e9c563507491b7dba3c63e932.tar.gz
nextcloud-server-86db2d7f15f8507e9c563507491b7dba3c63e932.zip
enh: pass params in subject
Signed-off-by: Christopher Ng <chrng8@gmail.com>
Diffstat (limited to 'apps')
-rw-r--r--apps/files_reminders/lib/Notification/Notifier.php21
-rw-r--r--apps/files_reminders/lib/Service/ReminderService.php4
2 files changed, 11 insertions, 14 deletions
diff --git a/apps/files_reminders/lib/Notification/Notifier.php b/apps/files_reminders/lib/Notification/Notifier.php
index c528aa521b1..ce46aafb86c 100644
--- a/apps/files_reminders/lib/Notification/Notifier.php
+++ b/apps/files_reminders/lib/Notification/Notifier.php
@@ -28,10 +28,8 @@ namespace OCA\FilesReminders\Notification;
use InvalidArgumentException;
use OCA\FilesReminders\AppInfo\Application;
-use OCA\FilesReminders\Exception\NodeNotFoundException;
-use OCA\FilesReminders\Service\ReminderService;
-use OCP\AppFramework\Db\DoesNotExistException;
use OCP\Files\FileInfo;
+use OCP\Files\IRootFolder;
use OCP\IURLGenerator;
use OCP\L10N\IFactory;
use OCP\Notification\AlreadyProcessedException;
@@ -43,7 +41,7 @@ class Notifier implements INotifier {
public function __construct(
protected IFactory $l10nFactory,
protected IURLGenerator $urlGenerator,
- protected ReminderService $reminderService,
+ protected IRootFolder $root,
) {}
public function getID(): string {
@@ -67,18 +65,15 @@ class Notifier implements INotifier {
switch ($notification->getSubject()) {
case 'reminder-due':
- $reminderId = (int)$notification->getObjectId();
- try {
- $reminder = $this->reminderService->get($reminderId);
- } catch (DoesNotExistException $e) {
- throw new AlreadyProcessedException();
- }
+ $params = $notification->getSubjectParameters();
+ $fileId = $params['fileId'];
- try {
- $node = $reminder->getNode();
- } catch (NodeNotFoundException $e) {
+ $nodes = $this->root->getUserFolder($notification->getUser())->getById($fileId);
+ if (empty($nodes)) {
throw new InvalidArgumentException();
}
+ $node = reset($nodes);
+
$path = rtrim($node->getPath(), '/');
if (strpos($path, '/' . $notification->getUser() . '/files/') === 0) {
// Remove /user/files/...
diff --git a/apps/files_reminders/lib/Service/ReminderService.php b/apps/files_reminders/lib/Service/ReminderService.php
index 010f458e872..4bfa943cb04 100644
--- a/apps/files_reminders/lib/Service/ReminderService.php
+++ b/apps/files_reminders/lib/Service/ReminderService.php
@@ -155,7 +155,9 @@ class ReminderService {
->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('files', 'folder.svg')))
->setUser($user->getUID())
->setObject('reminder', (string)$reminder->getId())
- ->setSubject('reminder-due')
+ ->setSubject('reminder-due', [
+ 'fileId' => $reminder->getFileId(),
+ ])
->setDateTime($reminder->getDueDate());
try {