abortWithError(__('Invalid or missing cron data.')); set_time_limit(0); ignore_user_abort(); $this->daemon = CronHelper::getDaemon(); $this->token = CronHelper::createToken(); $this->data = unserialize(base64_decode($data)); $this->timer = microtime(true); } function run() { $daemon = $this->daemon; if(!$daemon) { $this->abortWithError(__('Daemon does not exist.')); } if(!isset($this->data['token']) || $this->data['token'] !== $daemon['token'] ) { $this->abortWithError(__('Invalid or missing token.')); } $this->abortIfStopped($daemon); try { $scheduler = new Scheduler(); $scheduler->process($this->timer); $queue = new SendingQueue(); $queue->process($this->timer); } catch(\Exception $e) { } $elapsed_time = microtime(true) - $this->timer; if($elapsed_time < CronHelper::daemon_execution_limit) { sleep(CronHelper::daemon_execution_limit - $elapsed_time); } // after each execution, re-read daemon data in case it was deleted or // its status has changed $daemon = CronHelper::getDaemon(); if(!$daemon || $daemon['token'] !== $this->data['token']) { exit; } $daemon['counter']++; $this->abortIfStopped($daemon); if($daemon['status'] === 'starting') { $daemon['status'] = 'started'; } $daemon['token'] = $this->token; CronHelper::saveDaemon($daemon); $this->callSelf(); } function abortIfStopped($daemon) { if($daemon['status'] === 'stopped') exit; if($daemon['status'] === 'stopping') { $daemon['status'] = 'stopped'; CronHelper::saveDaemon($daemon); exit; } } function abortWithError($message) { exit('[mailpoet_cron_error:' . base64_encode($message) . ']'); } function callSelf() { CronHelper::accessDaemon($this->token, self::daemon_request_timeout); exit; } }