From dabf475a900cc32633c78af6f5c4332564dfbb8b Mon Sep 17 00:00:00 2001 From: PT-ATA No One Date: Mon, 25 Nov 2024 08:52:43 +0000 Subject: [PATCH] Remove file from the cache before scanning. This will lead to the file not beeing available until the scan is done. --- lib/EventListener/FileEventsListener.php | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/lib/EventListener/FileEventsListener.php b/lib/EventListener/FileEventsListener.php index d03e1ee7..8383df89 100644 --- a/lib/EventListener/FileEventsListener.php +++ b/lib/EventListener/FileEventsListener.php @@ -4,33 +4,27 @@ use Exception; use OC_Template; -use OCP\IAppConfig; use OCA\GDataVaas\AppInfo\Application; -use OCA\Files_Versions\Versions\IVersionManager; +use OCA\GDataVaas\Exceptions\VirusFoundException; use OCA\GDataVaas\Service\FileService; +use OCA\GDataVaas\Service\MailService; use OCA\GDataVaas\Service\TagService; use OCA\GDataVaas\Service\VerdictService; -use OCA\GDataVaas\Exceptions\VirusFoundException; use OCP\AppFramework\Bootstrap\IRegistrationContext; use OCP\EventDispatcher\Event; use OCP\EventDispatcher\IEventListener; use OCP\Files\Events\Node\BeforeNodeWrittenEvent; use OCP\Files\Events\Node\NodeWrittenEvent; -use OCP\Files\IMimeTypeLoader; -use OCP\Files\IRootFolder; +use OCP\IAppConfig; use OCP\IConfig; use OCP\IRequest; use OCP\IUserSession; use Psr\Log\LoggerInterface; use Sabre\DAV\Server; -use OCA\GDataVaas\Service\MailService; /** @template-implements IEventListener */ class FileEventsListener implements IEventListener { public function __construct( - private IRootFolder $rootFolder, - private IVersionManager $versionManager, - private IMimeTypeLoader $mimeTypeLoader, private IUserSession $userSession, private LoggerInterface $logger, private IConfig $config, @@ -40,7 +34,7 @@ public function __construct( private FileService $fileService, private TagService $tagService, private IAppConfig $appConfig, - private MailService $mailService + private MailService $mailService, ) { } @@ -51,6 +45,8 @@ public static function register(IRegistrationContext $context): void { public function handle(Event $event): void { if ($event instanceof NodeWrittenEvent) { $node = $event->getNode(); + $filesCache = $node->getStorage()->getCache(); + $filesCache->remove($node->getId()); if ($node->getType() !== \OCP\Files\FileInfo::TYPE_FILE) { return; }