aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJonas <jonas@freesources.org>2025-05-27 11:27:38 +0200
committerbackportbot[bot] <backportbot[bot]@users.noreply.github.com>2025-05-27 10:20:31 +0000
commit8f9aeeb5568f0df61f8f7e40ab8ddc13cfe8bfeb (patch)
tree45e56babc73d2aa0d9be5ee1ffecb80e9b1d2bc2
parent2cfaaffa477ae8bf777563f153ec66c4a1f353b9 (diff)
downloadnextcloud-server-backport/53131/stable31.tar.gz
nextcloud-server-backport/53131/stable31.zip
fix(FileReferenceEventListener): Invalidate cache after node was renamedbackport/53131/stable31
Fixes: nextcloud/collectives#1527 Signed-off-by: Jonas <jonas@freesources.org>
-rw-r--r--lib/private/Collaboration/Reference/File/FileReferenceEventListener.php5
1 files changed, 5 insertions, 0 deletions
diff --git a/lib/private/Collaboration/Reference/File/FileReferenceEventListener.php b/lib/private/Collaboration/Reference/File/FileReferenceEventListener.php
index e468ad4eb4c..9c18531c8e7 100644
--- a/lib/private/Collaboration/Reference/File/FileReferenceEventListener.php
+++ b/lib/private/Collaboration/Reference/File/FileReferenceEventListener.php
@@ -15,6 +15,7 @@ use OCP\EventDispatcher\Event;
use OCP\EventDispatcher\IEventDispatcher;
use OCP\EventDispatcher\IEventListener;
use OCP\Files\Events\Node\NodeDeletedEvent;
+use OCP\Files\Events\Node\NodeRenamedEvent;
use OCP\Share\Events\ShareCreatedEvent;
use OCP\Share\Events\ShareDeletedEvent;
@@ -27,6 +28,7 @@ class FileReferenceEventListener implements IEventListener {
public static function register(IEventDispatcher $eventDispatcher): void {
$eventDispatcher->addServiceListener(NodeDeletedEvent::class, FileReferenceEventListener::class);
+ $eventDispatcher->addServiceListener(NodeRenamedEvent::class, FileReferenceEventListener::class);
$eventDispatcher->addServiceListener(ShareDeletedEvent::class, FileReferenceEventListener::class);
$eventDispatcher->addServiceListener(ShareCreatedEvent::class, FileReferenceEventListener::class);
}
@@ -42,6 +44,9 @@ class FileReferenceEventListener implements IEventListener {
$this->manager->invalidateCache((string)$event->getNode()->getId());
}
+ if ($event instanceof NodeRenamedEvent) {
+ $this->manager->invalidateCache((string)$event->getTarget()->getId());
+ }
if ($event instanceof ShareDeletedEvent) {
$this->manager->invalidateCache((string)$event->getShare()->getNodeId());
}