Catch exceptions from background jobs and log them
This commit is contained in:
parent
c2e83e635d
commit
35bb6f7e3a
4 changed files with 30 additions and 9 deletions
6
cron.php
6
cron.php
|
@ -50,6 +50,8 @@ try {
|
|||
|
||||
session_write_close();
|
||||
|
||||
$logger = \OC_Log::$object;
|
||||
|
||||
// Don't do anything if ownCloud has not been installed
|
||||
if (!OC_Config::getValue('installed', false)) {
|
||||
exit(0);
|
||||
|
@ -98,7 +100,7 @@ try {
|
|||
$jobList = new \OC\BackgroundJob\JobList();
|
||||
$jobs = $jobList->getAll();
|
||||
foreach ($jobs as $job) {
|
||||
$job->execute($jobList);
|
||||
$job->execute($jobList, $logger);
|
||||
}
|
||||
} else {
|
||||
// We call cron.php from some website
|
||||
|
@ -109,7 +111,7 @@ try {
|
|||
// Work and success :-)
|
||||
$jobList = new \OC\BackgroundJob\JobList();
|
||||
$job = $jobList->getNext();
|
||||
$job->execute($jobList);
|
||||
$job->execute($jobList, $logger);
|
||||
$jobList->setLastJob($job);
|
||||
OC_JSON::success();
|
||||
}
|
||||
|
|
|
@ -9,16 +9,34 @@
|
|||
namespace OC\BackgroundJob;
|
||||
|
||||
abstract class Job {
|
||||
/**
|
||||
* @var int $id
|
||||
*/
|
||||
protected $id;
|
||||
|
||||
/**
|
||||
* @var int $lastRun
|
||||
*/
|
||||
protected $lastRun;
|
||||
|
||||
/**
|
||||
* @var mixed $argument
|
||||
*/
|
||||
protected $argument;
|
||||
|
||||
/**
|
||||
* @param JobList $jobList
|
||||
* @param \OC\Log $logger
|
||||
*/
|
||||
public function execute($jobList) {
|
||||
public function execute($jobList, $logger = null) {
|
||||
$jobList->setLastRun($this);
|
||||
$this->run($this->argument);
|
||||
try {
|
||||
$this->run($this->argument);
|
||||
} catch (\Exception $e) {
|
||||
if ($logger) {
|
||||
$logger->error('Error while running background job: ' . $e->getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
abstract protected function run($argument);
|
||||
|
|
|
@ -20,9 +20,10 @@ abstract class QueuedJob extends Job {
|
|||
* run the job, then remove it from the joblist
|
||||
*
|
||||
* @param JobList $jobList
|
||||
* @param \OC\Log $logger
|
||||
*/
|
||||
public function execute($jobList) {
|
||||
public function execute($jobList, $logger = null) {
|
||||
$jobList->remove($this);
|
||||
$this->run($this->argument);
|
||||
parent::execute($jobList, $logger);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -31,11 +31,11 @@ abstract class TimedJob extends Job {
|
|||
* run the job if
|
||||
*
|
||||
* @param JobList $jobList
|
||||
* @param \OC\Log $logger
|
||||
*/
|
||||
public function execute($jobList) {
|
||||
public function execute($jobList, $logger = null) {
|
||||
if ((time() - $this->lastRun) > $this->interval) {
|
||||
$jobList->setLastRun($this);
|
||||
$this->run($this->argument);
|
||||
parent::execute($jobList, $logger);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue