]> git.sur5r.net Git - bacula/bacula/commitdiff
baculum: Use client name instead of clientid and start using fileset to prepare resto...
authorMarcin Haba <marcin.haba@bacula.pl>
Sun, 30 Jul 2017 13:00:06 +0000 (15:00 +0200)
committerMarcin Haba <marcin.haba@bacula.pl>
Sun, 30 Jul 2017 13:01:20 +0000 (15:01 +0200)
gui/baculum/protected/Web/Pages/RestoreWizard.page
gui/baculum/protected/Web/Pages/RestoreWizard.php

index 38b8c4da94dd25e3ad5dc80e96737197944a7855..df7c0d66ba9b401b2ad5e306d146fa5175817739 100644 (file)
                                                                                <prop:ItemTemplate>
                                                                                        <com:TDraggable ID="FileElementLeft" Revert="false" Handle="<%=$this->FileElementLeft->ClientID%>" Ghosting="true" CssClass="draggable">
                                                                                                <img src="<%=$this->getPage()->getTheme()->getBaseUrl()%>/<%=($this->getParent()->Data['type'] == 'dir' ? 'directory-icon' : 'file-icon')%>.png" alt="<%=$this->getParent()->Data['type'] == 'dir' ? 'directory' : 'file' %>" /> <%=($this->getParent()->Data['name'] != '/') ? preg_replace('/\/$/', '', $this->getParent()->Data['name']) : '/'%>
-                                                                                                               <com:TActiveLinkButton CssClass="link" Style="float: right;" OnCallback="Page.addFileToRestore" ActiveControl.CallbackParameter="<%=isset($this->getParent()->Data['fileid']) ? $this->getParent()->Data['fileid'] : null%>" ActiveControl.EnableUpdate="false" Visible="<%=!in_array($this->getParent()->Data['name'], $this->getPage()->excludedElementsFromAdd)%>" Text="<%[ Add ]%>" />
+                                                                                                               <com:TActiveLinkButton CssClass="link" Style="float: right;" OnCallback="Page.addFileToRestore" ActiveControl.CallbackParameter="<%=isset($this->getParent()->Data['fileid']) ? $this->getParent()->Data['fileid'] : null%>" ActiveControl.EnableUpdate="false" Visible="<%=!in_array($this->getParent()->Data['name'], $this->getPage()->excluded_elements_from_add)%>" Text="<%[ Add ]%>" />
                                                                                        </com:TDraggable>
                                                                                        <com:TCallback ID="FileElementCall" OnCallback="Page.getVersions" ActiveControl.CallbackParameter="<%=$this->getParent()->Data['name'] . '|' . @$this->getParent()->Data['pathid'] . '|' . @$this->getParent()->Data['filenameid'] . '|' . @$this->getParent()->Data['jobid']%>">
                                                                                                <prop:ClientSide.OnLoading>
                        <div class="line">
                                <div class="text"><com:TLabel ForControl="ReplaceFiles" Text="<%[ Replace files: ]%>" /></div>
                                <div class="field">
-                                       <com:TDropDownList ID="ReplaceFiles" CssClass="textbox" Width="350px" OnLoad="setRestoreClients" CausesValidation="false">
+                                       <com:TDropDownList ID="ReplaceFiles" CssClass="textbox" Width="350px" CausesValidation="false">
                                                <com:TListItem Value="never" Text="<%[ do not replace files ]%>" />
                                                <com:TListItem Value="ifolder" Text="<%[ if files from restore are older]%>" />
                                                <com:TListItem Value="ifnewer" Text="<%[ if files from restore are newer]%>" />
                                <legend><%[ Source parameters ]%></legend>
                                <div class="line">
                                        <div class="text"><%[ Backup data from client: ]%></div>
-                                       <div class="field bold"><%=$this->getModule('api')->get(array('clients', $this->BackupClientName->SelectedValue))->output->name%></div>
+                                       <div class="field bold"><%=$this->BackupClientName->SelectedValue%></div>
                                </div>
                                <div class="line">
                                        <div class="text"><%[ Backup selection method: ]%></div>
                                <legend><%[ Destination parameters ]%></legend>
                                <div class="line">
                                        <div class="text"><%[ Restore to client: ]%></div>
-                                       <div class="field bold"><%=$this->getModule('api')->get(array('clients', $this->RestoreClient->SelectedValue))->output->name%></div>
+                                       <div class="field bold"><%=$this->RestoreClient->SelectedValue%></div>
                                </div>
                                <div class="line">
                                        <div class="text"><%[ Restore to path: ]%></div>
index 7feb1dc1184bcc649cccfa24fcf30c9ab89aae71..63323e4f9000e811206c3569828e44dd72f5e473 100644 (file)
@@ -35,15 +35,15 @@ Prado::using('System.Web.UI.ActiveControls.TCallback');
 
 class RestoreWizard extends BaculumWebPage
 {
-       private $jobLevelsToRestore = array('F' => 'Full', 'I' => 'Incremental', 'D'=> 'Differential');
+       private $job_levels_to_restore = array('F' => 'Full', 'I' => 'Incremental', 'D'=> 'Differential');
        private $jobs = null;
        private $filesets = null;
        private $storages = null;
        private $clients = null;
-       private $browserRootDir = array('name' => '.', 'type' => 'dir');
-       private $browserUpDir = array('name' => '..', 'type' => 'dir');
+       private $browser_root_dir = array('name' => '.', 'type' => 'dir');
+       private $browser_up_dir = array('name' => '..', 'type' => 'dir');
 
-       public $excludedElementsFromAdd = array('.', '..');
+       public $excluded_elements_from_add = array('.', '..');
 
        const BVFS_PATH_PREFIX = 'b2';
 
@@ -101,7 +101,7 @@ class RestoreWizard extends BaculumWebPage
                        }
                        $fileProperties = $this->getBrowserFile($fileid);
                }
-               if($fileProperties['name'] != $this->browserRootDir['name'] && $fileProperties['name'] != $this->browserUpDir['name']) {
+               if($fileProperties['name'] != $this->browser_root_dir['name'] && $fileProperties['name'] != $this->browser_up_dir['name']) {
                        $this->markFileToRestore($fileid, $fileProperties);
                        $this->prepareFilesToRestore();
                }
@@ -119,13 +119,7 @@ class RestoreWizard extends BaculumWebPage
                        $this->setBrowserPath($filename);
                        return;
                }
-               $clientname = null;
-               foreach($this->clients as $client) {
-                       if($client->clientid == $this->BackupClientName->SelectedValue) {
-                               $clientname = $client->name;
-                               break;
-                       }
-               }
+               $clientname = $this->BackupClientName->SelectedValue;
                $versions = $this->getModule('api')->get(array('bvfs', 'versions', $clientname, $jobid, $pathid, $filenameid))->output;
                $fileVersions = $this->getModule('misc')->parseFileVersions($filename, $versions);
                $this->setFileVersions($fileVersions);
@@ -150,64 +144,60 @@ class RestoreWizard extends BaculumWebPage
        }
 
        public function setJobs($sender, $param) {
-               $jobsList = $jobsGroupList = $fileSetsList = array();
+               $jobs_list = $jobs_group_list = array();
+               $clientid = null;
+               for ($i = 0; $i < count($this->clients); $i++) {
+                       if ($this->clients[$i]->name === $this->BackupClientName->SelectedValue) {
+                               $clientid = $this->clients[$i]->clientid;
+                               break;
+                       }
+               }
                if(is_array($this->jobs)) {
                        foreach($this->jobs as $job) {
-                               if(array_key_exists($job->level, $this->jobLevelsToRestore) && $job->type == 'B' && $job->jobstatus == 'T' && $job->clientid == $this->BackupClientName->SelectedValue) {
-                                       $jobsList[$job->jobid] = sprintf('[%s] %s, %s, %s', $job->jobid, $job->name, $this->jobLevelsToRestore[$job->level], $job->endtime);
-                                       $jobsGroupList[$job->name] = $job->name;
-                                       //$fileSetsList[$job->filesetid] = $this->getFileSet($job->filesetid)->fileset;
+                               if(array_key_exists($job->level, $this->job_levels_to_restore) && $job->type == 'B' && $job->jobstatus == 'T' && $job->clientid == $clientid) {
+                                       $jobs_list[$job->jobid] = sprintf('[%s] %s, %s, %s', $job->jobid, $job->name, $this->job_levels_to_restore[$job->level], $job->endtime);
+                                       $jobs_group_list[$job->name] = $job->name;
                                }
                        }
                }
-               
+
+               $fileset_list = array();
                foreach($this->filesets as $director => $filesets) {
-                       $fileSetsList = array_merge($filesets, $fileSetsList);
+                       $fileset_list = array_merge($fileset_list, $filesets);
                }
 
-               $this->BackupToRestore->dataSource = $jobsList;
+               $this->BackupToRestore->dataSource = $jobs_list;
                $this->BackupToRestore->dataBind();
-               $this->GroupBackupToRestore->dataSource = $jobsGroupList;
+               $this->GroupBackupToRestore->dataSource = $jobs_group_list;
                $this->GroupBackupToRestore->dataBind();
-               $this->GroupBackupFileSet->dataSource = array_combine($fileSetsList, $fileSetsList);
+               $this->GroupBackupFileSet->dataSource = array_combine($fileset_list, $fileset_list);
                $this->GroupBackupFileSet->dataBind();
                $this->setRestoreClients($sender, $param);
        }
 
        public function setBackupClients($sender, $param) {
                if(!$this->IsPostBack) {
-                       $clientsList = array();
+                       $client_list = array();
                        foreach($this->clients as $client) {
-                               $clientsList[$client->clientid] = $client->name;
+                               $client_list[$client->name] = $client->name;
                        }
-                       $this->BackupClientName->dataSource = $clientsList;
+                       $this->BackupClientName->dataSource = $client_list;
                        $this->BackupClientName->dataBind();
                }
        }
 
        public function setRestoreClients($sender, $param) {
                if(!$this->IsPostBack || $sender->ID == $this->BackupClientName->ID) {
-                       $clientsList = array();
+                       $client_list = array();
                        foreach($this->clients as $client) {
-                               $clientsList[$client->clientid] = $client->name;
+                               $client_list[$client->name] = $client->name;
                        }
                        $this->RestoreClient->SelectedValue = $this->BackupClientName->SelectedValue;
-                       $this->RestoreClient->dataSource = $clientsList;
+                       $this->RestoreClient->dataSource = $client_list;
                        $this->RestoreClient->dataBind();
                }
        }
 
-       public function getFileSet($filesetId) {
-               $filesetObj = null;
-               foreach($this->filesets as $fileset) {
-                       if($fileset->filesetid == $filesetId) {
-                               $filesetObj = $fileset;
-                               break;
-                       }
-               }
-               return $filesetObj;
-       }
-
        public function setStorage($sender, $param) {
                if(!$this->IsPostBack) {
                        $storagesList = array();
@@ -246,17 +236,9 @@ class RestoreWizard extends BaculumWebPage
                $_SESSION['restore_path'] = array();
        }
 
-       /*public function setGroupBackup($sender, $param) {
-               foreach($this->jobs as $job) {
-                       if($job->name == $sender->SelectedValue) {
-                               $this->GroupBackupFileSet->SelectedValue = $job->filesetid;
-                       }
-               }
-       }*/
-
        public function resetFileBrowser($sender, $param) {
                $this->markFileToRestore(null, null);
-               $this->setBrowserPath($this->browserRootDir['name']);
+               $this->setBrowserPath($this->browser_root_dir['name']);
        }
 
        private function prepareBrowserFiles($files) {
@@ -277,9 +259,9 @@ class RestoreWizard extends BaculumWebPage
 
        private function setBrowserPath($path) {
                if(!empty($path)) {
-                       if($path == $this->browserUpDir['name']) {
+                       if($path == $this->browser_up_dir['name']) {
                                array_pop($_SESSION['restore_path']);
-                       } elseif($path == $this->browserRootDir['name']) {
+                       } elseif($path == $this->browser_root_dir['name']) {
                                $_SESSION['restore_path'] = array();
                        } else {
                                array_push($_SESSION['restore_path'], $path);
@@ -300,18 +282,20 @@ class RestoreWizard extends BaculumWebPage
 
        private function prepareBrowserContent() {
                $jobids = $this->getElementaryBackup();
-       
-               // generating Bvfs may takes a moment
-               $this->generateBvfsCacheByJobids($jobids);
-               $bvfsDirsList = $this->getModule('api')->set(array('bvfs', 'lsdirs'), array('jobids' => $jobids, 'path' => $this->getBrowserPath(true)));
-               $bvfsDirs = is_object($bvfsDirsList) ? $bvfsDirsList->output : array();
-               $dirs = $this->getModule('misc')->parseBvfsList($bvfsDirs);
-               $bvfsFilesList = $this->getModule('api')->set(array('bvfs', 'lsfiles'), array('jobids' => $jobids, 'path' => $this->getBrowserPath(true)));
-               $bvfsFiles = is_object($bvfsFilesList) ? $bvfsFilesList->output : array();
-               $files = $this->getModule('misc')->parseBvfsList($bvfsFiles);
-               $elements = array_merge($dirs, $files);
-               if(count($this->getBrowserPath()) > 0) {
-                       array_unshift($elements, $this->browserRootDir);
+               $elements = array();
+               if (!is_null($jobids)) {
+                       // generating Bvfs may takes a moment
+                       $this->generateBvfsCacheByJobids($jobids);
+                       $bvfs_dirs_list = $this->getModule('api')->set(array('bvfs', 'lsdirs'), array('jobids' => $jobids, 'path' => $this->getBrowserPath(true)));
+                       $bvfs_dirs = is_object($bvfs_dirs_list) ? $bvfs_dirs_list->output : array();
+                       $dirs = $this->getModule('misc')->parseBvfsList($bvfs_dirs);
+                       $bvfs_files_list = $this->getModule('api')->set(array('bvfs', 'lsfiles'), array('jobids' => $jobids, 'path' => $this->getBrowserPath(true)));
+                       $bvfs_files = is_object($bvfs_files_list) ? $bvfs_files_list->output : array();
+                       $files = $this->getModule('misc')->parseBvfsList($bvfs_files);
+                       $elements = array_merge($dirs, $files);
+                       if(count($this->getBrowserPath()) > 0) {
+                               array_unshift($elements, $this->browser_root_dir);
+                       }
                }
                $this->prepareBrowserFiles($elements);
        }
@@ -328,15 +312,22 @@ class RestoreWizard extends BaculumWebPage
                                }
                        }
                } else {
-                       $jobsRecent = $this->getModule('api')->get(array('jobs', 'recent', $this->GroupBackupToRestore->SelectedValue, $this->BackupClientName->SelectedValue));
-                       if(isset($jobsRecent->output) && count($jobsRecent->output) > 0) {
-                               $ids = $jobsRecent->output;
+                       $params = array(
+                               'jobs',
+                               'recent',
+                               $this->GroupBackupToRestore->SelectedValue,
+                               'client',
+                               $this->BackupClientName->SelectedValue,
+                               'fileset',
+                               $this->GroupBackupFileSet->SelectedValue
+                       );
+                       $jobs_recent = $this->getModule('api')->get($params);
+                       if(count($jobs_recent->output) > 0) {
+                               $ids = $jobs_recent->output;
                                $jobids = implode(',', $ids);
                        }
                }
-
-               $completeJobids = (!is_null($jobids)) ? $jobids : $this->BackupToRestore->SelectedValue;
-               return $completeJobids;
+               return $jobids;
        }
 
        private function generateBvfsCacheByJobids($jobids) {
@@ -376,7 +367,7 @@ class RestoreWizard extends BaculumWebPage
        private function markFileToRestore($fileid, $file) {
                if($fileid === null) {
                        $_SESSION['restore'] = array();
-               } elseif($file['name'] != $this->browserRootDir['name'] && $file['name'] != $this->browserUpDir['name']) {
+               } elseif($file['name'] != $this->browser_root_dir['name'] && $file['name'] != $this->browser_up_dir['name']) {
                        $_SESSION['restore'][$fileid] = $file;
                }
        }
@@ -427,8 +418,7 @@ class RestoreWizard extends BaculumWebPage
                $this->getModule('api')->create(array('bvfs', 'restore'), $cmd_props);
                $restore_props = array();
                $restore_props['rpath'] = $path;
-               $restore_props['clientid'] = intval($this->RestoreClient->SelectedValue);
-               $restore_props['fileset'] = $this->GroupBackupFileSet->SelectedValue;
+               $restore_props['client'] = $this->RestoreClient->SelectedValue;
                $restore_props['priority'] = intval($this->RestoreJobPriority->Text);
                $restore_props['where'] =  $this->RestorePath->Text;
                $restore_props['replace'] = $this->ReplaceFiles->SelectedValue;