]> git.sur5r.net Git - bacula/bacula/blob - gui/baculum/protected/API/Pages/API/BVFSRestore.php
baculum: Add restore hardlinks support in api
[bacula/bacula] / gui / baculum / protected / API / Pages / API / BVFSRestore.php
1 <?php
2 /*
3  * Bacula(R) - The Network Backup Solution
4  * Baculum   - Bacula web interface
5  *
6  * Copyright (C) 2013-2017 Kern Sibbald
7  *
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.
11  *
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.
16  *
17  * This notice must be preserved when any source code is
18  * conveyed and/or propagated.
19  *
20  * Bacula(R) is a registered trademark of Kern Sibbald.
21  */
22  
23 class BVFSRestore extends BaculumAPIServer {
24
25         public function create($params) {
26                 $misc = $this->getModule('misc');
27                 $jobids = property_exists($params, 'jobids') ? $params->jobids : null;
28                 $fileids = property_exists($params, 'fileid') ? $params->fileid : null;
29                 $dirids = property_exists($params, 'dirid') ? $params->dirid : null;
30                 $findexes = property_exists($params, 'findex') ? $params->findex : null;
31                 $path = property_exists($params, 'path') ? $params->path : null;
32
33                 if (!is_null($jobids) && !$misc->isValidIdsList($jobids)) {
34                         $this->output = BVFSError::MSG_ERROR_INVALID_JOBID_LIST;
35                         $this->error = BVFSError::ERROR_INVALID_JOBID_LIST;
36                         return;
37                 }
38                 if (!is_null($fileids) && !$misc->isValidIdsList($fileids)) {
39                         $this->output = BVFSError::MSG_ERROR_INVALID_FILEID_LIST;
40                         $this->error = BVFSError::ERROR_INVALID_FILEID_LIST;
41                         return;
42                 }
43                 if (!is_null($dirids) && !$misc->isValidIdsList($dirids)) {
44                         $this->output = BVFSError::MSG_ERROR_INVALID_DIRID_LIST;
45                         $this->error = BVFSError::ERROR_INVALID_DIRID_LIST;
46                         return;
47                 }
48                 if (!is_null($findexes) && !$misc->isValidIdsList($findexes)) {
49                         $this->output = BVFSError::MSG_ERROR_INVALID_FILEINDEX_LIST;
50                         $this->error = BVFSError::ERROR_INVALID_FILEINDEX_LIST;
51                         return;
52                 }
53
54                 if (!is_null($path) && !$misc->isValidBvfsPath($path)) {
55                         $this->output = BVFSError::MSG_ERROR_INVALID_RPATH;
56                         $this->error = BVFSError::ERROR_INVALID_RPATH;
57                         return;
58                 }
59
60                 $cmd = array('.bvfs_restore', 'jobid="' .  $jobids . '"', 'path="' . $path . '"');
61                 if (is_string($fileids)) {
62                         array_push($cmd, 'fileid="' . $fileids . '"');
63                 }
64                 if (is_string($dirids)) {
65                         array_push($cmd, 'dirid="' . $dirids . '"');
66                 }
67                 if (is_string($findexes)) {
68                         array_push($cmd, 'hardlink="' . $findexes . '"');
69                 }
70
71                 $result = $this->getModule('bconsole')->bconsoleCommand($this->director, $cmd, $this->user);
72                 $this->output = $result->output;
73                 $this->error = $result->exitcode;
74         }
75 }
76 ?>