* * @author Julius Härtl * * @license GNU AGPL version 3 or any later version * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * */ namespace OCA\Text\Cron; use OCA\Text\Db\Session; use OCA\Text\Exception\DocumentHasUnsavedChangesException; use OCA\Text\Service\DocumentService; use OCA\Text\Service\AttachmentService; use OCA\Text\Service\SessionService; use OCP\AppFramework\Utility\ITimeFactory; use OCP\BackgroundJob\TimedJob; use Psr\Log\LoggerInterface; class Cleanup extends TimedJob { private SessionService $sessionService; private DocumentService $documentService; private LoggerInterface $logger; private AttachmentService $attachmentService; public function __construct(ITimeFactory $time, SessionService $sessionService, DocumentService $documentService, AttachmentService $attachmentService, LoggerInterface $logger) { parent::__construct($time); $this->sessionService = $sessionService; $this->documentService = $documentService; $this->attachmentService = $attachmentService; $this->logger = $logger; $this->setInterval(SessionService::SESSION_VALID_TIME); } protected function run($argument) { $this->logger->debug('Run cleanup job for text sessions'); $inactive = $this->sessionService->findAllInactive(); /** @var Session $session */ foreach ($inactive as $session) { $activeSessions = $this->sessionService->getActiveSessions($session->getDocumentId()); if (count($activeSessions) > 0) { continue; } $this->documentService->unlock($session->getDocumentId()); try { $this->logger->debug('Resetting document ' . $session->getDocumentId() . ''); $this->documentService->resetDocument($session->getDocumentId()); $this->attachmentService->cleanupAttachments($session->getDocumentId()); $this->logger->debug('Resetting document ' . $session->getDocumentId() . ''); } catch (DocumentHasUnsavedChangesException $e) { $this->logger->info('Document ' . $session->getDocumentId() . ' has not been reset, as it has unsaved changes'); } catch (\Throwable $e) { $this->logger->error('Document ' . $session->getDocumentId() . ' has not been reset, as an error occured', ['exception' => $e]); } } $removedSessions = $this->sessionService->removeInactiveSessions(null); $this->logger->debug('Removed ' . $removedSessions . ' inactive sessions'); } }