1 |
#============================================================= -*-perl-*- |
2 |
# |
3 |
# BackupPC::CGI::RestoreInfo package |
4 |
# |
5 |
# DESCRIPTION |
6 |
# |
7 |
# This module implements the RestoreInfo action for the CGI interface. |
8 |
# |
9 |
# AUTHOR |
10 |
# Craig Barratt <cbarratt@users.sourceforge.net> |
11 |
# |
12 |
# COPYRIGHT |
13 |
# Copyright (C) 2003 Craig Barratt |
14 |
# |
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. |
19 |
# |
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. |
24 |
# |
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 |
28 |
# |
29 |
#======================================================================== |
30 |
# |
31 |
# Version 2.1.0, released 20 Jun 2004. |
32 |
# |
33 |
# See http://backuppc.sourceforge.net. |
34 |
# |
35 |
#======================================================================== |
36 |
|
37 |
package BackupPC::CGI::RestoreInfo; |
38 |
|
39 |
use strict; |
40 |
use BackupPC::CGI::Lib qw(:all); |
41 |
|
42 |
sub action |
43 |
{ |
44 |
my $Privileged = CheckPermission($In{host}); |
45 |
my $host = $1 if ( $In{host} =~ /(.*)/ ); |
46 |
my $num = $In{num}; |
47 |
my $i; |
48 |
|
49 |
if ( !$Privileged ) { |
50 |
ErrorExit($Lang->{Only_privileged_users_can_view_restore_information}); |
51 |
} |
52 |
# |
53 |
# Find the requested restore |
54 |
# |
55 |
my @Restores = $bpc->RestoreInfoRead($host); |
56 |
for ( $i = 0 ; $i < @Restores ; $i++ ) { |
57 |
last if ( $Restores[$i]{num} == $num ); |
58 |
} |
59 |
if ( $i >= @Restores ) { |
60 |
ErrorExit(eval("qq{$Lang->{Restore_number__num_for_host__does_not_exist}}")); |
61 |
} |
62 |
|
63 |
%RestoreReq = (); |
64 |
do "$TopDir/pc/$host/RestoreInfo.$Restores[$i]{num}" |
65 |
if ( -f "$TopDir/pc/$host/RestoreInfo.$Restores[$i]{num}" ); |
66 |
|
67 |
my $startTime = timeStamp2($Restores[$i]{startTime}); |
68 |
my $reqTime = timeStamp2($RestoreReq{reqTime}); |
69 |
my $dur = $Restores[$i]{endTime} - $Restores[$i]{startTime}; |
70 |
$dur = 1 if ( $dur <= 0 ); |
71 |
my $duration = sprintf("%.1f", $dur / 60); |
72 |
my $MB = sprintf("%.1f", $Restores[$i]{size} / (1024*1024)); |
73 |
my $MBperSec = sprintf("%.2f", $Restores[$i]{size} / (1024*1024*$dur)); |
74 |
|
75 |
my $fileListStr = ""; |
76 |
foreach my $f ( @{$RestoreReq{fileList}} ) { |
77 |
my $targetFile = $f; |
78 |
(my $strippedShareSrc = $RestoreReq{shareSrc}) =~ s/^\///; |
79 |
(my $strippedShareDest = $RestoreReq{shareDest}) =~ s/^\///; |
80 |
substr($targetFile, 0, length($RestoreReq{pathHdrSrc})) |
81 |
= $RestoreReq{pathHdrDest}; |
82 |
$targetFile =~ s{//+}{/}g; |
83 |
$fileListStr .= <<EOF; |
84 |
<tr><td>$RestoreReq{hostSrc}:/$strippedShareSrc$f</td><td>$RestoreReq{hostDest}:/$strippedShareDest$targetFile</td></tr> |
85 |
EOF |
86 |
} |
87 |
my $content = eval("qq{$Lang->{Restore___num_details_for__host2}}"); |
88 |
Header(eval("qq{$Lang->{Restore___num_details_for__host}}"),$content); |
89 |
Trailer(); |
90 |
} |
91 |
|
92 |
1; |