diff --git a/CRM/Core/JobManager.php b/CRM/Core/JobManager.php index e7008ea64517..fccfc18b8cf8 100644 --- a/CRM/Core/JobManager.php +++ b/CRM/Core/JobManager.php @@ -141,12 +141,15 @@ public function executeJob($job) { $params = $job->apiParams; } + CRM_Utils_Hook::preJob($job, $params); try { $result = civicrm_api($job->api_entity, $job->api_action, $params); } catch (Exception$e) { $this->logEntry('Error while executing ' . $job->name . ': ' . $e->getMessage()); + $result = $e; } + CRM_Utils_Hook::postJob($job, $params, $result); $this->logEntry('Finished execution of ' . $job->name . ' with result: ' . $this->_apiResultToMessage($result)); $this->currentJob = FALSE; diff --git a/CRM/Utils/Hook.php b/CRM/Utils/Hook.php index 0ad0debd39cd..1f75b3ab8dad 100644 --- a/CRM/Utils/Hook.php +++ b/CRM/Utils/Hook.php @@ -2418,4 +2418,36 @@ public static function alterEntityRefParams(&$params, $formName) { ); } + /** + * This hook is called before a scheduled job is executed + * + * @param CRM_Core_DAO_Job $job + * The job to be executed + * @param array $params + * The arguments to be given to the job + */ + public static function preJob($job, $params) { + return self::singleton()->invoke(array('job', 'params'), $job, $params, + self::$_nullObject, self::$_nullObject, self::$_nullObject, self::$_nullObject, + 'civicrm_preJob' + ); + } + + /** + * This hook is called after a scheduled job is executed + * + * @param CRM_Core_DAO_Job $job + * The job that was executed + * @param array $params + * The arguments given to the job + * @param array $result + * The result of the API call, or the thrown exception if any + */ + public static function postJob($job, $params, $result) { + return self::singleton()->invoke(array('job', 'params', 'result'), $job, $params, $result, + self::$_nullObject, self::$_nullObject, self::$_nullObject, + 'civicrm_postJob' + ); + } + }