interval = $seconds; } /** * Whether the background job is time sensitive and needs to run soon after * the scheduled interval, of if it is okay to be delayed until a later time. * * @return bool * @since 24.0.0 */ public function isTimeSensitive(): bool { return $this->timeSensitivity === IJob::TIME_SENSITIVE; } /** * If your background job is not time sensitive (sending instant email * notifications, etc.) it would be nice to set it to IJob::TIME_INSENSITIVE * This way the execution can be delayed during high usage times. * * @param int $sensitivity * @psalm-param IJob::TIME_* $sensitivity * @return void * @since 24.0.0 */ public function setTimeSensitivity(int $sensitivity): void { if ($sensitivity !== IJob::TIME_SENSITIVE && $sensitivity !== IJob::TIME_INSENSITIVE) { throw new \InvalidArgumentException('Invalid sensitivity'); } $this->timeSensitivity = $sensitivity; } /** * Run the job if the last run is more than the interval ago * * @param IJobList $jobList * @param ILogger|null $logger * * @since 15.0.0 * @deprecated since 25.0.0 Use start() instead */ final public function execute(IJobList $jobList, ?ILogger $logger = null) { $this->start($jobList); } /** * Run the job if the last run is more than the interval ago * * @since 25.0.0 */ final public function start(IJobList $jobList): void { if (($this->time->getTime() - $this->lastRun) > $this->interval) { parent::start($jobList); } } }