Catch exceptions from background jobs and log them

This commit is contained in:
Robin Appelman 2013-12-02 13:41:47 +01:00
parent c2e83e635d
commit 35bb6f7e3a
4 changed files with 30 additions and 9 deletions

View file

@ -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();
}

View file

@ -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);

View file

@ -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);
}
}

View file

@ -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);
}
}
}