From c59a1d89be4d8d06a172a242632c972b8eb10ef0 Mon Sep 17 00:00:00 2001 From: root Date: Fri, 13 Sep 2019 10:26:42 +0200 Subject: [PATCH] Init --- Check.pm | 156 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ README.md | 3 -- 2 files changed, 156 insertions(+), 3 deletions(-) create mode 100644 Check.pm delete mode 100644 README.md diff --git a/Check.pm b/Check.pm new file mode 100644 index 0000000..972955a --- /dev/null +++ b/Check.pm @@ -0,0 +1,156 @@ +#============================================================= -*-perl-*- +# +# BackupPC::CGI::Check package +# +# DESCRIPTION +# +# This module implements the Check action for the CGI interface. +# +# AUTHOR +# Heuze Florent +# +#======================================================================== +# +# Version 0.0.1, released 06 Sept 2019. +# +#======================================================================== + +package BackupPC::CGI::Check; + +use strict; +use BackupPC::CGI::Lib qw(:all); + +sub action +{ + my($fullTot, $fullSizeTot, $incrTot, $incrSizeTot, $str, + $strNone, $strGood, $hostCntGood, $hostCntNone); + + $hostCntGood = $hostCntNone = 0; + GetStatusInfo("hosts info"); + my $Privileged = CheckPermission(); + + foreach my $host ( GetUserHosts(1) ) { + my($fullDur, $incrCnt, $incrAge, $fullSize, $fullRate, $reasonHilite, + $lastAge, $tempState, $tempReason, $lastXferErrors); + my($shortErr); + my @Backups = $bpc->BackupInfoRead($host); + my $fullCnt = $incrCnt = 0; + my $fullAge = $incrAge = $lastAge = -1; + + $bpc->ConfigRead($host); + %Conf = $bpc->Conf(); + + next if ( $Conf{XferMethod} eq "archive" ); + next if ( !$Privileged && !CheckPermission($host) ); + + for ( my $i = 0 ; $i < @Backups ; $i++ ) { + if ( $Backups[$i]{type} eq "full" ) { + $fullCnt++; + if ( $fullAge < 0 || $Backups[$i]{startTime} > $fullAge ) { + $fullAge = $Backups[$i]{startTime}; + $fullSize = $Backups[$i]{size} / (1024 * 1024); + $fullDur = $Backups[$i]{endTime} - $Backups[$i]{startTime}; + } + $fullSizeTot += $Backups[$i]{size} / (1024 * 1024); + } elsif ( $Backups[$i]{type} eq "incr" ) { + $incrCnt++; + if ( $incrAge < 0 || $Backups[$i]{startTime} > $incrAge ) { + $incrAge = $Backups[$i]{startTime}; + } + $incrSizeTot += $Backups[$i]{size} / (1024 * 1024); + } + } + if ( $fullAge > $incrAge && $fullAge >= 0 ) { + $lastAge = $fullAge; + } else { + $lastAge = $incrAge; + } + if ( $lastAge < 0 ) { + $lastAge = ""; + } else { + $lastAge = sprintf("%.1f", (time - $lastAge) / (24 * 3600)); + } + if ( $fullAge < 0 ) { + $fullAge = ""; + $fullRate = ""; + } else { + $fullAge = sprintf("%.1f", (time - $fullAge) / (24 * 3600)); + $fullRate = sprintf("%.2f", + $fullSize / ($fullDur <= 0 ? 1 : $fullDur)); + } + if ( $incrAge < 0 ) { + $incrAge = ""; + } else { + $incrAge = sprintf("%.1f", (time - $incrAge) / (24 * 3600)); + } + $fullTot += $fullCnt; + $incrTot += $incrCnt; + $fullSize = sprintf("%.2f", $fullSize / 1024); + $incrAge = " " if ( $incrAge eq "" ); + $lastXferErrors = $Backups[@Backups-1]{xferErrs} if ( @Backups ); + $reasonHilite = $Conf{CgiStatusHilightColor}{$Status{$host}{reason}} + || $Conf{CgiStatusHilightColor}{$Status{$host}{state}}; + if ( $Conf{BackupsDisable} == 1 ) { + if ( $Status{$host}{state} ne "Status_backup_in_progress" + && $Status{$host}{state} ne "Status_restore_in_progress" ) { + $reasonHilite = $Conf{CgiStatusHilightColor}{Disabled_OnlyManualBackups}; + $tempState = "Disabled_OnlyManualBackups"; + $tempReason = ""; + } else { + $tempState = $Status{$host}{state}; + $tempReason = $Status{$host}{reason}; + } + } elsif ($Conf{BackupsDisable} == 2 ) { + $reasonHilite = $Conf{CgiStatusHilightColor}{Disabled_AllBackupsDisabled}; + $tempState = "Disabled_AllBackupsDisabled"; + $tempReason = ""; + } else { + $tempState = $Status{$host}{state}; + $tempReason = $Status{$host}{reason}; + } + $reasonHilite = " bgcolor=\"$reasonHilite\"" if ( $reasonHilite ne "" ); + if ( $tempState ne "Status_backup_in_progress" + && $tempState ne "Status_restore_in_progress" + && $Conf{BackupsDisable} == 0 + && $Status{$host}{error} ne "" ) { + ($shortErr = $Status{$host}{error}) =~ s/(.{48}).*/$1.../; + $shortErr = " ($shortErr)"; + } + + $str = <${HostLink($host)} + ${UserLink(defined($Hosts->{$host}) + ? $Hosts->{$host}{user} : "")} + ${EscHTML($Conf{ClientComment})} + $fullCnt + $fullAge + $fullSize + $fullRate + $incrCnt + $incrAge + $lastAge + $Lang->{$tempState} + $lastXferErrors + $Lang->{$tempReason}$shortErr +EOF + if ( @Backups == 0 ) { + $hostCntNone++; + $strNone .= $str; + } else { + $hostCntGood++; + $strGood .= $str; + } + } + $fullSizeTot = sprintf("%.2f", $fullSizeTot / 1024); + $incrSizeTot = sprintf("%.2f", $incrSizeTot / 1024); + my $now = timeStamp2(time); + my $DUlastTime = timeStamp2($Info{DUlastValueTime}); + my $DUmaxTime = timeStamp2($Info{DUDailyMaxTime}); + my $DUInodemaxTime = timeStamp2($Info{DUInodeDailyMaxTime}); + + my $content = eval ("qq{$Lang->{BackupPC_Summary}}"); + Header($Lang->{BackupPC__Server_Summary}, $content); + Trailer(); +} + +1; diff --git a/README.md b/README.md deleted file mode 100644 index 285762a..0000000 --- a/README.md +++ /dev/null @@ -1,3 +0,0 @@ -# BackupPC-Check - -Vérification des sauvegardes \ No newline at end of file