3 * Bacula(R) - The Network Backup Solution
4 * Baculum - Bacula web interface
6 * Copyright (C) 2013-2015 Marcin Haba
8 * The main author of Baculum is Marcin Haba.
9 * The original author of Bacula is Kern Sibbald, with contributions
10 * from many others, a complete list can be found in the file AUTHORS.
12 * You may use this file and others of this release according to the
13 * license defined in the LICENSE file, which includes the Affero General
14 * Public License, v3.0 ("AGPLv3") and some additional permissions and
15 * terms pursuant to its AGPLv3 Section 7.
17 * This notice must be preserved when any source code is
18 * conveyed and/or propagated.
20 * Bacula(R) is a registered trademark of Kern Sibbald.
23 class JobTasks extends BaculumAPI {
24 public function get() {
25 $limit = intval($this->Request['limit']);
26 $directors = $this->getModule('bconsole')->getDirectors();
27 if($directors->exitcode === 0) {
31 for($i = 0; $i < count($directors->output); $i++) {
32 $jobsList = $this->getModule('bconsole')->bconsoleCommand($directors->output[$i], array('.jobs'), $this->user);
33 if ($jobsList->exitcode != 0) {
34 $error_obj = $jobsList;
38 $jobsshow = $this->getModule('bconsole')->bconsoleCommand($directors->output[$i], array('show', 'jobs'), $this->user);
39 if ($jobsshow->exitcode != 0) {
40 $error_obj = $jobsshow;
44 $jobs[$directors->output[$i]] = array();
45 for($j = 0; $j < count($jobsList->output); $j++) {
47 * Checking by "show job" command is ugly way to be sure that is reading jobname but not some
48 * random output (eg. "You have messages." or debugging).
49 * For now I did not find nothing better for be sure that output contains job.
51 for($k = 0; $k < count($jobsshow->output); $k++) {
52 if(preg_match('/^Job: name=' . $jobsList->output[$j] . '.*/', $jobsshow->output[$k]) === 1) {
53 $jobs[$directors->output[$i]][] = $jobsList->output[$j];
57 // limit per director, not for entire elements
58 if($limit > 0 && count($jobs[$directors->output[$i]]) === $limit) {
63 if ($error === true) {
64 $this->output = $error_obj->output;
65 $this->error = $error_obj->exitcode;
67 $this->output = $jobs;
68 $this->error = BconsoleError::ERROR_NO_ERRORS;
71 $this->output = $directors->output;
72 $this->error = $directors->exitcode;