From 59f0cb90ab1b3c3eceb537196220246070f1581b Mon Sep 17 00:00:00 2001 From: Stephen McMahon Date: Wed, 5 Jul 2017 18:05:53 +1000 Subject: [PATCH 1/2] Fix(defaultJobs) config now loads correctly. Add SS_Log of missing job. Change admin email queued_job_admin_email --- code/services/QueuedJobService.php | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/code/services/QueuedJobService.php b/code/services/QueuedJobService.php index 28514c88..1f54cf1a 100644 --- a/code/services/QueuedJobService.php +++ b/code/services/QueuedJobService.php @@ -88,7 +88,7 @@ class QueuedJobService { * Config controlled list of default/required jobs * @var Array */ - public $defaultJobs; + public $defaultJobs = array(); /** * Register our shutdown handler @@ -325,6 +325,9 @@ public function checkJobHealth($queue = null) { */ public function checkdefaultJobs($queue = null) { $queue = $queue ?: QueuedJob::QUEUED; + + $this->defaultJobs = !empty($this->defaultJobs) ? $this->defaultJobs : Config::inst()->get(__CLASS__, 'defaultJobs'); + if (count($this->defaultJobs)) { $activeJobs = QueuedJobDescriptor::get()->filter(array( @@ -349,8 +352,10 @@ public function checkdefaultJobs($queue = null) { )); if (!$job->count()) { + SS_Log::log("Default Job config: $title was missing from Queue and has been re-added", SS_Log::ERR); Email::create() - ->setTo(isset($jobConfig['email']) ? $jobConfig['email'] : Email::config()->admin_email) + ->setTo(isset($jobConfig['email']) ? $jobConfig['email'] : Config::inst()->get('Email', 'queued_job_admin_email')) + ->setFrom(Config::inst()->get('Email', 'queued_job_admin_email')) ->setSubject('Default Job "' . $title . '" missing') ->populateTemplate(array('Title' => $title, 'Site' => Director::absoluteBaseURL())) ->populateTemplate($jobConfig) @@ -358,7 +363,7 @@ public function checkdefaultJobs($queue = null) { ->send(); if (isset($jobConfig['recreate']) && $jobConfig['recreate']) { - if (!isset($jobConfig['construct']) || !isset($jobConfig['startDateFormat']) || !isset($jobConfig['startTimeString'])) { + if (!array_key_exists('construct', $jobConfig) || !isset($jobConfig['startDateFormat']) || !isset($jobConfig['startTimeString'])) { SS_Log::log("Default Job config: $title incorrectly set up. Please check the readme for examples", SS_Log::ERR); continue; } From 35d1ade3303c1eda4292366f8995d73f278be967 Mon Sep 17 00:00:00 2001 From: Stephen McMahon Date: Wed, 19 Jul 2017 10:27:51 +1000 Subject: [PATCH 2/2] Fix(defaultJobs) update readme and default jobs check to use injector correctly --- README.md | 49 +++++++++++++++--------------- code/services/QueuedJobService.php | 2 -- 2 files changed, 25 insertions(+), 26 deletions(-) diff --git a/README.md b/README.md index a887332b..69a19932 100644 --- a/README.md +++ b/README.md @@ -172,30 +172,31 @@ Default jobs are defined in yml config the sample below covers the options and e ``` Injector: QueuedJobService: - defaultJobs: - # This key is used as the title for error logs and alert emails - ArbitraryName: - # The job type should be the class name of a job REQUIRED - type: 'ScheduledExternalImportJob' - # This plus the job type is used to create the SQL query REQUIRED - filter: - # 1 or more Fieldname: 'value' sets that will be queried on REQUIRED - # These can be valid ORM filter - JobTitle: 'Scheduled import from Services' - # Sets whether the job will be recreated or not OPTIONAL - recreate: 1 - # Set the email address to send the alert to if not set site admin email is used OPTIONAL - email: 'admin@email.com' - # Parameters set on the recreated object OPTIONAL - construct: - # 1 or more Fieldname: 'value' sets be passed to the constructor OPTIONAL - repeat: 300 - title: 'Scheduled import from Services' - # Minimal implementation will send alerts but not recreate - AnotherTitle: - type: 'AJob' - filter: - JobTitle: 'A job' + properties: + defaultJobs: + # This key is used as the title for error logs and alert emails + ArbitraryName: + # The job type should be the class name of a job REQUIRED + type: 'ScheduledExternalImportJob' + # This plus the job type is used to create the SQL query REQUIRED + filter: + # 1 or more Fieldname: 'value' sets that will be queried on REQUIRED + # These can be valid ORM filter + JobTitle: 'Scheduled import from Services' + # Sets whether the job will be recreated or not OPTIONAL + recreate: 1 + # Set the email address to send the alert to if not set site admin email is used OPTIONAL + email: 'admin@email.com' + # Parameters set on the recreated object OPTIONAL + construct: + # 1 or more Fieldname: 'value' sets be passed to the constructor OPTIONAL + repeat: 300 + title: 'Scheduled import from Services' + # Minimal implementation will send alerts but not recreate + AnotherTitle: + type: 'AJob' + filter: + JobTitle: 'A job' ``` ## Configuring the CleanupJob diff --git a/code/services/QueuedJobService.php b/code/services/QueuedJobService.php index 1f54cf1a..04ae53b5 100644 --- a/code/services/QueuedJobService.php +++ b/code/services/QueuedJobService.php @@ -326,8 +326,6 @@ public function checkJobHealth($queue = null) { public function checkdefaultJobs($queue = null) { $queue = $queue ?: QueuedJob::QUEUED; - $this->defaultJobs = !empty($this->defaultJobs) ? $this->defaultJobs : Config::inst()->get(__CLASS__, 'defaultJobs'); - if (count($this->defaultJobs)) { $activeJobs = QueuedJobDescriptor::get()->filter(array(