X-Git-Url: http://git.rot13.org/?p=BackupPC.git;a=blobdiff_plain;f=lib%2FBackupPC%2FCGI%2FHostInfo.pm;h=7af47e9e9bde6274d21984177eedae6e70ad8043;hp=cf58ad7efd400054bc034fdff4fe6fd06fe26ddb;hb=5c6a6cc4f333ce44a9df62ab828b0b9341579f7c;hpb=2c14784ad71874ec850d189060fe63d6eb9eba95 diff --git a/lib/BackupPC/CGI/HostInfo.pm b/lib/BackupPC/CGI/HostInfo.pm index cf58ad7..7af47e9 100644 --- a/lib/BackupPC/CGI/HostInfo.pm +++ b/lib/BackupPC/CGI/HostInfo.pm @@ -28,7 +28,7 @@ # #======================================================================== # -# Version 2.1.0_CVS, released 8 Feb 2004. +# Version 2.1.0beta1, released 9 Apr 2004. # # See http://backuppc.sourceforge.net. # @@ -287,16 +287,50 @@ EOF $statusStr .= eval("qq{$Lang->{priorStr_to_host_have_succeeded_StatusHostaliveCnt_consecutive_times}}"); if ( $StatusHost{aliveCnt} >= $Conf{BlackoutGoodCnt} - && $Conf{BlackoutGoodCnt} >= 0 && $Conf{BlackoutHourBegin} >= 0 - && $Conf{BlackoutHourEnd} >= 0 ) { + && $Conf{BlackoutGoodCnt} >= 0 ) { + # + # Handle backward compatibility with original separate scalar + # blackout parameters. + # + if ( defined($Conf{BlackoutHourBegin}) ) { + push(@{$Conf{BlackoutPeriods}}, + { + hourBegin => $Conf{BlackoutHourBegin}, + hourEnd => $Conf{BlackoutHourEnd}, + weekDays => $Conf{BlackoutWeekDays}, + } + ); + } + + # + # TODO: this string needs i18n. Also, comma-separated + # list with "and" for the last element might not translate + # correctly. + # my(@days) = qw(Sun Mon Tue Wed Thu Fri Sat); - my($days) = join(", ", @days[@{$Conf{BlackoutWeekDays}}]); - my($t0) = sprintf("%d:%02d", $Conf{BlackoutHourBegin}, - 60 * ($Conf{BlackoutHourBegin} - - int($Conf{BlackoutHourBegin}))); - my($t1) = sprintf("%d:%02d", $Conf{BlackoutHourEnd}, - 60 * ($Conf{BlackoutHourEnd} - - int($Conf{BlackoutHourEnd}))); + my $blackoutStr; + my $periodCnt = 0; + foreach my $p ( @{$Conf{BlackoutPeriods}} ) { + next if ( ref($p->{weekDays}) ne "ARRAY" + || !defined($p->{hourBegin}) + || !defined($p->{hourEnd}) + ); + my $days = join(", ", @days[@{$p->{weekDays}}]); + my $t0 = sprintf("%d:%02d", $p->{hourBegin}, + 60 * ($p->{hourBegin} - int($p->{hourBegin}))); + my $t1 = sprintf("%d:%02d", $p->{hourEnd}, + 60 * ($p->{hourEnd} - int($p->{hourEnd}))); + if ( $periodCnt ) { + $blackoutStr .= ", "; + if ( $periodCnt == @{$Conf{BlackoutPeriods}} - 1 ) { + $blackoutStr .= eval("qq{$Lang->{and}}"); + $blackoutStr .= " "; + } + } + $blackoutStr + .= eval("qq{$Lang->{__time0_to__time1_on__days}}"); + $periodCnt++; + } $statusStr .= eval("qq{$Lang->{Because__host_has_been_on_the_network_at_least__Conf_BlackoutGoodCnt_consecutive_times___}}"); } }