owncloud/core

View on GitHub
lib/private/BackgroundJob/TimedJob.php

Summary

Maintainability
A
25 mins
Test Coverage
<?php
/**
 * @author Morris Jobke <hey@morrisjobke.de>
 * @author Robin Appelman <icewind@owncloud.com>
 *
 * @copyright Copyright (c) 2018, ownCloud GmbH
 * @license AGPL-3.0
 *
 * This code is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License, version 3,
 * as published by the Free Software Foundation.
 *
 * 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, version 3,
 * along with this program.  If not, see <http://www.gnu.org/licenses/>
 *
 */

namespace OC\BackgroundJob;
use OCP\ILogger;

/**
 * Class QueuedJob
 *
 * create a background job that is to be executed at an interval
 *
 * @package OC\BackgroundJob
 */
abstract class TimedJob extends Job {
    protected $interval = 0;

    /**
     * set the interval for the job
     *
     * @param int $interval
     */
    public function setInterval($interval) {
        $this->interval = $interval;
    }

    /**
     * run the job if
     *
     * @param JobList $jobList
     * @param ILogger $logger
     */
    public function execute($jobList, ILogger $logger = null) {
        if ((\time() - $this->lastRun) > $this->interval) {
            if ($logger !== null) {
                $id = $this->getId();
                $class = \get_class($this);
                $lastRun = $this->getLastRun();
                $interval = $this->interval;
                $logger->debug(
                    "Running job with id $id and class $class. Last run $lastRun and interval $interval",
                    ['app' => 'cron']
                );
            }
            parent::execute($jobList, $logger);
        } else {
            if ($logger !== null) {
                $id = $this->getId();
                $class = \get_class($this);
                $lastRun = $this->getLastRun();
                $interval = $this->interval;
                $diff = $this->interval - (\time() - $this->lastRun);
                $logger->debug(
                    "Job with id $id and class $class not running due to interval. Last run $lastRun and interval $interval. Wait $diff seconds.",
                    ['app' => 'cron']
                );
            }
        }
    }
}