1 #============================================================= -*-perl-*-
3 # BackupPC::CGI::RestoreInfo package
7 # This module implements the RestoreInfo action for the CGI interface.
10 # Craig Barratt <cbarratt@users.sourceforge.net>
13 # Copyright (C) 2003-2009 Craig Barratt
15 # This program is free software; you can redistribute it and/or modify
16 # it under the terms of the GNU General Public License as published by
17 # the Free Software Foundation; either version 2 of the License, or
18 # (at your option) any later version.
20 # This program is distributed in the hope that it will be useful,
21 # but WITHOUT ANY WARRANTY; without even the implied warranty of
22 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 # GNU General Public License for more details.
25 # You should have received a copy of the GNU General Public License
26 # along with this program; if not, write to the Free Software
27 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
29 #========================================================================
31 # Version 3.2.0, released 31 Jul 2010.
33 # See http://backuppc.sourceforge.net.
35 #========================================================================
37 package BackupPC::CGI::RestoreInfo;
40 use BackupPC::CGI::Lib qw(:all);
41 use Encode qw/decode_utf8/;
45 my $Privileged = CheckPermission($In{host});
46 my $host = $1 if ( $In{host} =~ /(.*)/ );
51 ErrorExit($Lang->{Only_privileged_users_can_view_restore_information});
54 # Find the requested restore
56 my @Restores = $bpc->RestoreInfoRead($host);
57 for ( $i = 0 ; $i < @Restores ; $i++ ) {
58 last if ( $Restores[$i]{num} == $num );
60 if ( $i >= @Restores ) {
61 ErrorExit(eval("qq{$Lang->{Restore_number__num_for_host__does_not_exist}}"));
65 do "$TopDir/pc/$host/RestoreInfo.$Restores[$i]{num}"
66 if ( -f "$TopDir/pc/$host/RestoreInfo.$Restores[$i]{num}" );
68 my $startTime = timeStamp2($Restores[$i]{startTime});
69 my $reqTime = timeStamp2($RestoreReq{reqTime});
70 my $dur = $Restores[$i]{endTime} - $Restores[$i]{startTime};
71 $dur = 1 if ( $dur <= 0 );
72 my $duration = sprintf("%.1f", $dur / 60);
73 my $MB = sprintf("%.1f", $Restores[$i]{size} / (1024*1024));
74 my $MBperSec = sprintf("%.2f", $Restores[$i]{size} / (1024*1024*$dur));
77 foreach my $f ( @{$RestoreReq{fileList}} ) {
79 (my $strippedShareSrc = $RestoreReq{shareSrc}) =~ s/^\///;
80 (my $strippedShareDest = $RestoreReq{shareDest}) =~ s/^\///;
81 substr($targetFile, 0, length($RestoreReq{pathHdrSrc}))
82 = $RestoreReq{pathHdrDest};
83 $targetFile =~ s{//+}{/}g;
84 $strippedShareDest = decode_utf8($strippedShareDest);
85 $targetFile = decode_utf8($targetFile);
86 $strippedShareSrc = decode_utf8($strippedShareSrc);
88 $fileListStr .= <<EOF;
89 <tr><td>$RestoreReq{hostSrc}:/$strippedShareSrc$f</td><td>$RestoreReq{hostDest}:/$strippedShareDest$targetFile</td></tr>
92 $RestoreReq{shareSrc} = decode_utf8($RestoreReq{shareSrc});
93 $RestoreReq{shareDest} = decode_utf8($RestoreReq{shareDest});
94 my $content = eval("qq{$Lang->{Restore___num_details_for__host2}}");
95 Header(eval("qq{$Lang->{Restore___num_details_for__host}}"),$content);