-
-
Notifications
You must be signed in to change notification settings - Fork 108
/
backuplog.cgi
executable file
·100 lines (92 loc) · 3.1 KB
/
backuplog.cgi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#!/usr/local/bin/perl
# Show logs of backups this user has permissions on
require './virtual-server-lib.pl';
&ReadParse();
&can_backup_log() || &error($text{'backuplg_ecannot'});
&ui_print_header(undef, $text{'backuplog_title'}, "");
# Show search form
print &ui_form_start("backuplog.cgi");
print "<b>$text{'backuplog_search'}</b>\n";
print &ui_textbox("search", $in{'search'}, 30);
print &ui_submit($text{'backuplog_ok'});
print &ui_form_end(),"<p>\n";
# Get backups to list
$days = $in{'sched'} ? 365 : ($config{'backuplog_days'} || 7);
@logs = &list_backup_logs($in{'search'} ? undef : time()-24*60*60*$days);
if ($in{'search'}) {
@logs = grep { $_->{'user'} eq $in{'search'} ||
$_->{'doms'} =~ /\Q$in{'search'}\E/i ||
$_->{'dest'} =~ /\Q$in{'search'}\E/i } @logs;
}
elsif ($in{'sched'}) {
($sched) = grep { $_->{'id'} eq $in{'sched'} }
&list_scheduled_backups();
$sched || &error($text{'backuplg_esched'});
@logs = grep { $_->{'sched'} eq $in{'sched'} } @logs;
}
$anylogs = scalar(@logs);
@logs = grep { &can_backup_log($_) } @logs;
# Tell the user what he is searching for
if ($in{'search'}) {
print &text('backuplog_match',
"<i>".&html_escape($in{'search'})."</i>"),"<br>\n";
}
elsif ($in{'sched'}) {
@dests = &get_scheduled_backup_dests($sched);
@nices = map { &nice_backup_url($_, 1) } @dests;
print &text('backuplog_sched', $nices[0]),"<br>\n";
}
else {
print &text('backuplog_days', $days),"<br>\n";
}
if (@logs) {
# Show in a table
@table = ( );
$hasdesc = 0;
foreach $log (@logs) {
$hasdesc++ if ($log->{'desc'});
}
foreach $log (sort { $b->{'start'} <=> $a->{'start'} } @logs) {
@dnames = &backup_log_own_domains($log);
next if (!@dnames);
$ddesc = scalar(@dnames) == 0 ?
$text{'backuplog_nodoms'} :
scalar(@dnames) <= 2 ?
join(", ", @dnames) :
&text('backuplog_doms', scalar(@dnames));
push(@table, [
"<a href='view_backuplog.cgi?id=".&urlize($log->{'id'}).
"&search=".&urlize($in{'search'})."'>".
&nice_backup_url($log->{'dest'}, 1)."</a>",
$ddesc,
$hasdesc ? ( &html_escape($log->{'desc'}) ) : ( ),
$log->{'user'} || "<i>root</i>",
&make_date($log->{'start'}),
&short_nice_hour_mins_secs(
$log->{'end'} - $log->{'start'}),
$log->{'increment'} == 1 ? $text{'viewbackup_inc1'} :
$text{'viewbackup_inc0'},
&nice_size($log->{'size'}),
$log->{'ok'} && !$log->{'errdoms'} ? $text{'backuplog_status_ok'} :
$log->{'ok'} && $log->{'errdoms'} ?
&ui_text_color($text{'backuplog_status_partial'}, 'warn') :
&ui_text_color($text{'backuplog_status_failed'}, 'danger')
]);
}
print &ui_columns_table([ $text{'sched_dest'}, $text{'sched_doms'},
$hasdesc ? ( $text{'backuplog_desc'} ) : ( ),
$text{'backuplog_who'},
$text{'backuplog_when'},
$text{'backuplog_len'},
$text{'backuplog_incr'},
$text{'backuplog_size'},
$text{'backuplog_status'} ],
100, \@table);
}
else {
# None found
print "<b>",($in{'search'} ? $text{'backuplog_nomatch'} :
$anylogs ? $text{'backuplog_none2'} :
$text{'backuplog_none'}),"</b><p>\n";
}
&ui_print_footer("", $text{'index'});