aboutsummaryrefslogtreecommitdiffstats
path: root/apps/files_reminders/lib/Dav/PropFindPlugin.php
diff options
context:
space:
mode:
Diffstat (limited to 'apps/files_reminders/lib/Dav/PropFindPlugin.php')
-rw-r--r--apps/files_reminders/lib/Dav/PropFindPlugin.php23
1 files changed, 14 insertions, 9 deletions
diff --git a/apps/files_reminders/lib/Dav/PropFindPlugin.php b/apps/files_reminders/lib/Dav/PropFindPlugin.php
index 014e636eb2d..7fa45a4b854 100644
--- a/apps/files_reminders/lib/Dav/PropFindPlugin.php
+++ b/apps/files_reminders/lib/Dav/PropFindPlugin.php
@@ -16,6 +16,7 @@ use OCA\FilesReminders\Service\ReminderService;
use OCP\Files\Folder;
use OCP\IUser;
use OCP\IUserSession;
+use Sabre\DAV\ICollection;
use Sabre\DAV\INode;
use Sabre\DAV\PropFind;
use Sabre\DAV\Server;
@@ -32,9 +33,22 @@ class PropFindPlugin extends ServerPlugin {
}
public function initialize(Server $server): void {
+ $server->on('preloadCollection', $this->preloadCollection(...));
$server->on('propFind', [$this, 'propFind']);
}
+ private function preloadCollection(
+ PropFind $propFind,
+ ICollection $collection,
+ ): void {
+ if ($collection instanceof Directory && $propFind->getStatus(
+ static::REMINDER_DUE_DATE_PROPERTY
+ ) !== null) {
+ $folder = $collection->getNode();
+ $this->cacheFolder($folder);
+ }
+ }
+
public function propFind(PropFind $propFind, INode $node) {
if (!in_array(static::REMINDER_DUE_DATE_PROPERTY, $propFind->getRequestedProperties())) {
return;
@@ -44,15 +58,6 @@ class PropFindPlugin extends ServerPlugin {
return;
}
- if (
- $node instanceof Directory
- && $propFind->getDepth() > 0
- && $propFind->getStatus(static::REMINDER_DUE_DATE_PROPERTY) !== null
- ) {
- $folder = $node->getNode();
- $this->cacheFolder($folder);
- }
-
$propFind->handle(
static::REMINDER_DUE_DATE_PROPERTY,
function () use ($node) {