X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=gui%2Fbacula-web%2Fbweb.inc.php;h=8e2c68ec5b0df09252d2088d674ff225532afed2;hb=e72734faae318b19fed76d4667bb9ca15ba4034f;hp=c697583eadf257a7359d9e184c2350698db2ffd4;hpb=30da9843847bc688130a4a9fb68466b64edfb29b;p=bacula%2Fbacula diff --git a/gui/bacula-web/bweb.inc.php b/gui/bacula-web/bweb.inc.php index c697583ead..8e2c68ec5b 100644 --- a/gui/bacula-web/bweb.inc.php +++ b/gui/bacula-web/bweb.inc.php @@ -14,13 +14,6 @@ | GNU General Public License for more details. | +-------------------------------------------------------------------------+ */ -// Last Err: 11 -define('CONFIG_DIR', "configs"); -define('CONFIG_FILE', "bacula.conf"); -define('BACULA_TYPE_BYTES_FILES', 1); -define('BACULA_TYPE_FILES_JOBID', 2); -define('BACULA_TYPE_BYTES_ENDTIME_ALLJOBS', 69); - require_once "paths.php"; require_once "DB.php"; // Pear DB require_once "config.inc.php"; @@ -180,49 +173,39 @@ class Bweb extends DB { $this->EndDate=$EndDateYear."-".$EndDateMonth."-".$EndDateDay." 23:59:59"; // last day full }//end function - - function GetDataVolumes() { - - $volume = array(); - $res = $this->db_link->query("SELECT Name FROM Pool"); - while ( $tmp =& $res->fetchRow() ) { - if ($this->driver == "mysql" ) - $result = $this->db_link->query("select Media.VolumeName, Media.VolBytes,Media.VolStatus,Pool.Name,Media.MediaType,Media.LastWritten,FROM_UNIXTIME(UNIX_TIMESTAMP(Media.LastWritten)+Media.VolRetention ) as expire from Pool LEFT JOIN Media ON Media.PoolId=Pool.PoolId where Name='$tmp[0]' order by Media.VolumeName"); - else if ($this->driver == "pgsql") - $result = $this->db_link->db_query("select Media.VolumeName, Media.VolBytes,Media.VolStatus,Pool.Name,Media.MediaType,Media.LastWritten, Media.LastWritten + Media.VolRetention * interval '1 second' as expire from Pool LEFT JOIN Media ON Media.PoolId=Pool.PoolId where Name='$tmp[0]' order by Media.VolumeName"); - while ( $tmp1 = $result->fetchRow() ) { - $pos = array_key_exists($tmp[0],$volume); - if ($pos != FALSE) - array_push($volume["$tmp[0]"],$tmp1); - else - $volume += array($tmp[0]=>array($tmp1)); - } - } - - $res->free(); - $result->free(); - return $volume; - } - - function human_file_size( $size, $decimal = 2 ) + + // Return humanized size with default unit of GB + // if auto provide for unit argument, automaticaly decide which unit + function human_file_size( $size, $decimal = 2, $unit = 'auto' ) { $unit_id = 0; $lisible = false; $units = array('B','KB','MB','GB','TB'); $hsize = $size; + + switch( $unit ) + { + case 'auto'; + while( !$lisible ) { + if ( $hsize >= 1024 ) { + $hsize = $hsize / 1024; + $unit_id += 1; + } + else { + $lisible = true; + } + } + break; - while( !$lisible ) { - if ( $hsize >= 1024 ) { - $hsize = $hsize / 1024; - $unit_id += 1; - } - else { - $lisible = true; - } - } - // Format human size + default: + $p = array_search( $unit, $units); + $hsize = $hsize / pow(1024,$p); + break; + } // end switch + $hsize = sprintf("%." . $decimal . "f", $hsize); - return $hsize . ' ' . $units[$unit_id]; + $hsize = $hsize . ' ' . $units[$unit_id]; + return $hsize; } // end function @@ -277,13 +260,13 @@ class Bweb extends DB { // Get the list of pools id $query = "SELECT Pool.poolid, Pool.name FROM Pool ORDER BY Pool.poolid"; - $this->db_link->setFetchMode(DB_FETCHMODE_ASSOC); + //$this->db_link->setFetchMode(DB_FETCHMODE_ASSOC); $pools = $this->db_link->query( $query ); if( PEAR::isError( $pools ) ) die("Error: Failed to get pool list
SQL Query: $query
" . $pools->getMessage() ); - while( $pool = $pools->fetchRow() ) { + while( $pool = $pools->fetchRow( DB_FETCHMODE_ASSOC ) ) { switch( $this->driver ) { case 'mysql': @@ -313,7 +296,7 @@ class Bweb extends DB { break; } // end switch - $this->db_link->setFetchMode(DB_FETCHMODE_ASSOC); + //$this->db_link->setFetchMode(DB_FETCHMODE_ASSOC); $medias = $this->db_link->query( $query ); if( PEAR::isError( $medias ) ) { @@ -326,7 +309,7 @@ class Bweb extends DB { { $volumes[ $pool['name'] ] = array(); } - while( $media = $medias->fetchRow() ) { + while( $media = $medias->fetchRow( DB_FETCHMODE_ASSOC ) ) { if( $debug ) { var_dump( $media ); } @@ -344,12 +327,16 @@ class Bweb extends DB { } // Media used bytes in a human format $media['volbytes'] = $this->human_file_size( $media['volbytes'] ); - //echo "volume " . $media['volumename'] . 'vol bytes' .$media['volbytes'] . '
'; } else { $media['lastwritten'] = "N/A"; $media['expire'] = "N/A"; $media['volbytes'] = "0 KB"; } + + // Odd or even row + if( count( $volumes[ $pool['name'] ] ) % 2) + $media['class'] = 'odd'; + // Add the media in pool array array_push( $volumes[ $pool['name']], $media); } @@ -359,71 +346,77 @@ class Bweb extends DB { return $volumes; } // end function GetVolumeList() - public function GetLastJobs( $delay = LAST_DAY ) + public function CountJobs( $delay = LAST_DAY, $status = 'any' ) { - $query = ""; - $start_date = ""; - $end_date = ""; + $query = "SELECT COUNT(JobId) AS job_nb FROM Job "; + $where_delay = ""; + $where_status = ""; - // Interval calculation - $end_date = mktime(); - $start_date = $end_date - $delay; + // Interval condition for SQL query + if( $delay != ALL ) { + $end_date = mktime(); + $start_date = $end_date - $delay; - $start_date = date( "Y-m-d H:m:s", $start_date ); - $end_date = date( "Y-m-d H:m:s", $end_date ); + $start_date = date( "Y-m-d H:i:s", $start_date ); + $end_date = date( "Y-m-d H:i:s", $end_date ); - switch( $this->driver ) - { - case 'mysql': - $query = 'SELECT COUNT(JobId) AS completed_jobs '; - $query .= 'FROM Job '; - $query .= "WHERE EndTime BETWEEN '$start_date' AND '$end_date' "; - $query .= "AND JobStatus = 'T'"; - break; + $where_delay = "WHERE EndTime BETWEEN '$start_date' AND '$end_date' "; } - + + if( $status != 'any' ) { + switch( $status ) + { + case 'completed': + $where_status = "JobStatus = 'T' "; + break; + case 'failed': + $where_status = "JobStatus IN ('f','E') "; + break; + case 'canceled': + $where_status = "JobStatus = 'A' "; + break; + case 'waiting': + $where_status = "JobStatus IN ('F','S','M','m','s','j','c','d','t') "; + break; + } // end switch + } + + if( !empty($where_delay) ) + $query = $query . $where_delay . 'AND ' . $where_status; + else { + if( !empty($where_status) ) + $query = $query . 'WHERE ' . $where_status; + } + $jobs = $this->db_link->query( $query ); if (PEAR::isError( $jobs ) ) { - die( "Unable to get last completed jobs status from catalog
" . $status->getMessage() ); + die( "Unable to get last $status jobs number from catalog
" . $jobs->getMessage() ); }else { - return $jobs->fetchRow(); + $jobs = $jobs->fetchRow( DB_FETCHMODE_ASSOC ); + return $jobs['job_nb']; } - } // end function GetLastJobStatus() + } - public function GetLastErrorJobs( $delay = LAST_DAY ) + // Return the list of Pools in a array + public function Get_Pools_List() { - $query = ""; - $start_date = ""; - $end_date = ""; - - // Interval calculation - $end_date = mktime(); - $start_date = $end_date - $delay; + $pool_list = array(); + $result = ""; - $start_date = date( "Y-m-d H:m:s", $start_date ); - $end_date = date( "Y-m-d H:m:s", $end_date ); + $query = "SELECT Name, PoolId FROM Pool"; - //echo "start date: $start_date
"; - //echo "end date: $end_date
"; - - switch( $this->driver ) - { - default: - $query = 'SELECT COUNT(JobId) AS failed_jobs '; - $query .= 'FROM Job '; - $query .= "WHERE EndTime BETWEEN '$start_date' AND '$end_date' "; - $query .= "AND JobStatus = 'f'"; - break; - } - $result = $this->db_link->query( $query ); - - if (PEAR::isError( $result ) ) { - die( "Unable to get last failed jobs status from catalog
query = $query
" . $result->getMessage() ); + $result = $this->db_link->query ( $query ); + + if( PEAR::isError( $result ) ) { + die( "Unable to get the pool list from catalog" ); }else { - return $result->fetchRow( DB_FETCHMODE_ASSOC ); - } // end if else - } // end function GetLastErrorJobs + while( $pool = $result->fetchRow(DB_FETCHMODE_ASSOC) ) { + array_push( $pool_list, array( $pool['Name'] => $pool['PoolId'] ) ); + } + return $pool_list; + } + } public function Get_BackupJob_Names() { @@ -442,6 +435,27 @@ class Bweb extends DB { } } + // Return elasped time string for a job + function Get_ElapsedTime( $start_time, $end_time ) + { + $diff = $end_time - $start_time; + + $daysDiff = sprintf("%02d", floor($diff/60/60/24) ); + $diff -= $daysDiff*60*60*24; + + $hrsDiff = sprintf("%02d", floor($diff/60/60) ); + $diff -= $hrsDiff*60*60; + + $minsDiff = sprintf("%02d", floor($diff/60) ); + $diff -= $minsDiff*60; + $secsDiff = sprintf("%02d", $diff ); + + if( $daysDiff > 0 ) + return $daysDiff . 'day(s) ' . $hrsDiff.':' . $minsDiff . ':' . $secsDiff; + else + return $hrsDiff . ':' . $minsDiff . ':' . $secsDiff; + } + public function Get_ElapsedTime_Job( $delay = LAST_DAY ) { $query = ""; @@ -451,8 +465,8 @@ class Bweb extends DB { $end_date = mktime(); $start_date = $end_date - $delay; - $start_date = date( "Y-m-d H:m:s", $start_date ); - $end_date = date( "Y-m-d H:m:s", $end_date ); + $start_date = date( "Y-m-d H:i:s", $start_date ); + $end_date = date( "Y-m-d H:i:s", $end_date ); switch( $this->driver ) { @@ -471,14 +485,189 @@ class Bweb extends DB { $total_elapsed += $time['elapsed']; } // Verify if elapsed time is more than 1 day - if ( $total_elapsed > 86400 ) { - return gmstrftime("%d days %H:%M:%S", $total_elapsed ); + if ( $total_elapsed > LAST_DAY ) { + return date("%d days H:i:s", $total_elapsed ); }else { - return gmstrftime("%H:%M:%S", $total_elapsed ); + return date("H:i:s", $total_elapsed ); } } } + + // Return Jobs statistics for a specific interval such as + // - Completed jobs number + // - Failed jobs number + // - Waiting jobs number + // The returned values will be used by a Bgraph classe + public function GetJobsStatistics( $type = 'completed', $delay = LAST_DAY ) + { + $query = ""; + $where = ""; + $jobs = ""; + $label = ""; + $res = ""; + + // Interval calculation + $end_date = mktime(); + $start_date = $end_date - $delay; + $start_date = date( "Y-m-d H:i:s", $start_date ); + $end_date = date( "Y-m-d H:i:s", $end_date ); + + // Job status + switch( $type ) + { + case 'completed': + $where = "AND JobStatus = 'T' "; + $label = "Completed"; + break; + case 'terminated_errors': + $where = $interval_where . "JobStatus = 'E' "; + $label = "Terminated with errors"; + break; + case 'failed': + $where = "AND JobStatus = 'f' "; + $label = "Failed"; + break; + case 'waiting': + $where = "AND JobStatus IN ('F','S','M','m','s','j','c','d','t') "; + $label = "Waiting"; + break; + case 'created': + $where = "AND JobStatus = 'C' "; + $label = "Created but not running"; + break; + case 'running': + $where = "AND JobStatus = 'R' "; + $label = "Running"; + break; + case 'error': + $where = "AND JobStatus IN ('e','f') "; + $label = "Errors"; + break; + } + + $query = 'SELECT COUNT(JobId) AS ' . $type . ' '; + $query .= 'FROM Job '; + $query .= "WHERE EndTime BETWEEN '$start_date' AND '$end_date' "; + $query .= $where; + + $jobs = $this->db_link->query( $query ); + + if (PEAR::isError( $jobs ) ) { + die( "Unable to get last $type jobs status from catalog
" . $status->getMessage() ); + }else { + $res = $jobs->fetchRow(); + return array( $label , current($res) ); + } + } // end function GetJobsStatistics() + + public function GetPoolsStatistics( $pools ) + { + foreach( $pools as $pool_name => $pool ) { + //var_dump( $pool ); + $query = "SELECT COUNT(*) AS nb_vol FROM Media WHERE PoolId = '$pool'"; + //echo $query . '
'; + //echo 'Pool name ' . $pool_name . '
'; + $result = $this->db_link->query( $query ); + + if( PEAR::isError( $result ) ) { + die("Unable to get volume number from catalog"); + }else{ + $nb_vol = $result->fetchRow(DB_FETCHMODE_ASSOC); + return array( $pool_name, $nb_vol['nb_vol'] ); + } + } + } + + public function GetStoredFiles() + { + $nbfiles = 0; + $query = "SELECT COUNT(FilenameId) AS nbfiles FROM Filename"; + $result = $this->db_link->query( $query ); + + if( !PEAR::isError($result) ) { + $nbfiles = $result->fetchRow(DB_FETCHMODE_ASSOC); + $nbfiles = $nbfiles['nbfiles']; + }else{ + die("Unable to get protected files from catalog"); + } + return $nbfiles; + } + + public function GetStoredBytes( $delay = LAST_DAY ) + { + $query = "SELECT SUM(JobBytes) as stored_bytes FROM Job "; + + // Interval calculation + $end_date = mktime(); + $start_date = $end_date - $delay; + + $start_date = date( "Y-m-d H:i:s", $start_date ); + $end_date = date( "Y-m-d H:i:s", $end_date ); + + if( $delay != ALL ) { + $query .= "WHERE EndTime BETWEEN '$start_date' AND '$end_date'"; + } + + $result = $this->db_link->query( $query ); + + if( PEAR::isError( $result ) ) { + die( "Unable to get Job Bytes from catalog" ); + }else{ + return $result->fetchRow( DB_FETCHMODE_ASSOC ); + } + } + public function GetStoredBytesByInterval( $start_date, $end_date ) + { + $query = "SELECT SUM(JobBytes) as stored_bytes, EndTime FROM Job WHERE EndTime BETWEEN '$start_date' AND '$end_date'"; + + $result = $this->db_link->query( $query ); + + if( PEAR::isError( $result ) ) { + die( "Unable to get Job Bytes from catalog" ); + }else{ + $stored_bytes = 0; + $tmp = $result->fetchRow( DB_FETCHMODE_ASSOC ); + + $day = date( "D d", strtotime($end_date) ); + + if( isset( $tmp['stored_bytes'] ) ) { + $hbytes = $this->human_file_size( $tmp['stored_bytes'], 3, 'GB'); + $hbytes = explode( " ", $hbytes ); + $stored_bytes = $hbytes[0]; + } + + return array( $day, $stored_bytes ); + } + } + + public function GetStoredBytesByJob( $jobname, $start_date, $end_date ) + { + $query = "SELECT SUM(JobBytes) as stored_bytes, EndTime FROM Job "; + $query .= "WHERE EndTime BETWEEN ( '$start_date' AND '$end_date' ) AND "; + $query .= "Name = '$jobname'"; + + echo 'query ' . $query . '
'; + + $result = $this->db_link->query( $query ); + + if( PEAR::isError( $result ) ) { + die( "Unable to get Job Bytes from catalog" ); + }else{ + $stored_bytes = 0; + $tmp = $result->fetchRow( DB_FETCHMODE_ASSOC ); + + $day = date( "D d", strtotime($end_date) ); + + if( isset( $tmp['stored_bytes'] ) ) { + $hbytes = $this->human_file_size( $tmp['stored_bytes'], 3, 'GB'); + $hbytes = explode( " ", $hbytes ); + $stored_bytes = $hbytes[0]; + } + + return array( $day, $stored_bytes ); + } + } } // end class Bweb ?>