From 77820824e66ba6a0e0056262f974532c596ce2b5 Mon Sep 17 00:00:00 2001 From: Robin Appelman Date: Wed, 10 Apr 2024 13:54:43 +0200 Subject: [PATCH] fix: filter more paths from being sent to the daemon Signed-off-by: Robin Appelman --- lib/Listener.php | 50 ++++++++++++++++++++++++++++++++---------------- 1 file changed, 33 insertions(+), 17 deletions(-) diff --git a/lib/Listener.php b/lib/Listener.php index 8870dda2..e5f8f1b3 100644 --- a/lib/Listener.php +++ b/lib/Listener.php @@ -30,6 +30,7 @@ use OCP\EventDispatcher\Event; use OCP\Files\Cache\ICacheEvent; use OCP\Files\IHomeStorage; +use OCP\Files\Storage\IStorage; use OCP\Group\Events\UserAddedEvent; use OCP\Group\Events\UserRemovedEvent; use OCP\Notification\IApp; @@ -48,18 +49,6 @@ public function __construct(IQueue $queue) { public function cacheListener(Event $event): void { if ($event instanceof ICacheEvent) { - // ignore files in home storage but outside home directory (trashbin, versions, etc) - if ( - $event->getStorage()->instanceOfStorage(IHomeStorage::class) && !( - $event->getPath() === 'files' || strpos($event->getPath(), "files/") === 0 - ) - ) { - return; - } - // ignore appdata - if (strpos($event->getPath(), 'appdata_') === 0) { - return; - } $path = $event->getPath(); $storage = $event->getStorage(); @@ -69,11 +58,13 @@ public function cacheListener(Event $event): void { $storage = $storage->getUnjailedStorage(); } - $this->queue->push('notify_storage_update', [ - 'storage' => $event->getStorageId(), - 'path' => $path, - 'file_id' => $event->getFileId(), - ]); + if ($this->shouldNotifyPath($event->getStorage(), $path)) { + $this->queue->push('notify_storage_update', [ + 'storage' => $event->getStorageId(), + 'path' => $path, + 'file_id' => $event->getFileId(), + ]); + } } } @@ -134,4 +125,29 @@ public function dismissNotification(INotification $notification): void { 'user' => $notification->getUser(), ]); } + + private function shouldNotifyPath(IStorage $storage, string $path): bool { + // ignore files in home storage but outside home directory (trashbin, versions, etc) + if ( + $storage->instanceOfStorage(IHomeStorage::class)) { + return $path === 'files' || str_starts_with($path, "files/"); + } + + // ignore appdata + if (str_starts_with($path, 'appdata_')) { + return false; + } + + if ($path === '__groupfolders') { + return false; + } + if (str_starts_with($path, '__groupfolders/versions')) { + return false; + } + if (str_starts_with($path, '__groupfolders/trash')) { + return false; + } + + return true; + } }