setLastRun($this); $logger = \OCP\Server::get(LoggerInterface::class); try { $jobDetails = get_class($this) . ' (id: ' . $this->getId() . ', arguments: ' . json_encode($this->getArgument()) . ')'; $jobStartTime = $this->time->getTime(); $logger->debug('Starting job ' . $jobDetails, ['app' => 'cron']); $this->run($this->argument); $timeTaken = $this->time->getTime() - $jobStartTime; $logger->debug('Finished job ' . $jobDetails . ' in ' . $timeTaken . ' seconds', ['app' => 'cron']); $jobList->setExecutionTime($this, $timeTaken); } catch (\Throwable $e) { if ($logger) { $logger->error('Error while running background job ' . $jobDetails, [ 'app' => 'core', 'exception' => $e, ]); } } } #[Override] final public function setId(string $id): void { $this->id = $id; } #[Override] final public function setLastRun(int $lastRun): void { $this->lastRun = $lastRun; } #[Override] public function setArgument(mixed $argument): void { $this->argument = $argument; } #[Override] final public function getId(): string { return $this->id; } #[Override] final public function getLastRun(): int { return $this->lastRun; } #[Override] public function getArgument(): mixed { return $this->argument; } #[Override] public function setAllowParallelRuns(bool $allow): void { $this->allowParallelRuns = $allow; } #[Override] public function getAllowParallelRuns(): bool { return $this->allowParallelRuns; } abstract protected function run($argument); }