* @author Morris Jobke * @author Noveen Sachdeva * @author Robin Appelman * @author Robin McCorkell * @author Côme Chilliet * * @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 * */ namespace OCP\BackgroundJob; /** * Interface IJobList * * This interface provides functions to register background jobs * * To create a new background job create a new class that inherits from either * \OC\BackgroundJob\Job, \OC\BackgroundJob\QueuedJob or * \OC\BackgroundJob\TimedJob and register it using ->add($job, $argument), * $argument will be passed to the run() function of the job when the job is * executed. * * A regular job will be executed every time cron.php is run, a QueuedJob will * only run once and a TimedJob will only run at a specific interval which is to * be specified in the constructor of the job by calling * $this->setInterval($interval) with $interval in seconds. * * This interface should be used directly and not implemented by an application. * The implementation is provided by the server. * * @since 7.0.0 */ interface IJobList { /** * Add a job to the list * * @param IJob|class-string $job * @param mixed $argument The argument to be passed to $job->run() when the job is executed * @since 7.0.0 */ public function add($job, $argument = null): void; /** * Add a job to the list but only run it after the given timestamp * * For cron background jobs this means the job will likely run shortly after the timestamp * has been reached. For ajax background jobs the job might only run when users are active * on the instance again. * * @param class-string $job * @param mixed $argument The serializable argument to be passed to $job->run() when the job is executed * @since 28.0.0 */ public function scheduleAfter(string $job, int $runAfter, $argument = null): void; /** * Remove a job from the list * * @param IJob|class-string $job * @param mixed $argument * @since 7.0.0 */ public function remove($job, $argument = null): void; /** * Remove a job from the list by id * * @param int $id * @since 28.0.8 */ public function removeById(int $id): void; /** * check if a job is in the list * * @param IJob|class-string $job * @param mixed $argument * @since 7.0.0 */ public function has($job, $argument): bool; /** * Get jobs matching the search * * @param IJob|class-string|null $job * @return array * @since 25.0.0 * @deprecated 26.0.0 Use getJobsIterator instead to avoid duplicated job objects */ public function getJobs($job, ?int $limit, int $offset): array; /** * Get jobs matching the search * * @param IJob|class-string|null $job * @return iterable * @since 26.0.0 */ public function getJobsIterator($job, ?int $limit, int $offset): iterable; /** * get the next job in the list * * @since 7.0.0 - In 24.0.0 parameter $onlyTimeSensitive got added */ public function getNext(bool $onlyTimeSensitive = false): ?IJob; /** * @since 7.0.0 */ public function getById(int $id): ?IJob; /** * @since 23.0.0 */ public function getDetailsById(int $id): ?array; /** * set the job that was last ran to the current time * * @since 7.0.0 */ public function setLastJob(IJob $job): void; /** * Remove the reservation for a job * * @since 9.1.0 */ public function unlockJob(IJob $job): void; /** * set the lastRun of $job to now * * @since 7.0.0 */ public function setLastRun(IJob $job): void; /** * set the run duration of $job * * @since 12.0.0 */ public function setExecutionTime(IJob $job, int $timeTaken): void; /** * Reset the $job so it executes on the next trigger * * @since 23.0.0 */ public function resetBackgroundJob(IJob $job): void; /** * Checks whether a job of the passed class was reserved to run * in the last 6h * * @param string|null $className * @return bool * @since 27.0.0 */ public function hasReservedJob(?string $className): bool; }