Files
webmin/webalizer/view_log.cgi
2007-04-12 20:24:50 +00:00

65 lines
1.6 KiB
Perl
Executable File

#!/usr/local/bin/perl
# view_log.cgi
# Display the report for some log file
require './webalizer-lib.pl';
&ReadParse();
if ($ENV{'PATH_INFO'} =~ /^\/([^\/]+)(\/[^\/]*)$/) {
# Proper path escaping
$escaped = $1;
$file = $2;
$log = &un_urlize($escaped);
}
elsif ($ENV{'PATH_INFO'} =~ /^(\/.*)(\/[^\/]*)$/) {
# Path has been decode somehow, perhaps by proxy.. deal
$log = $1;
$file = $2;
}
else {
&error($text{'view_epath'});
}
$file =~ /\.\./ || $file =~ /\<|\>|\||\0/ && &error($text{'view_efile'});
&can_edit_log($log) || &error($text{'view_ecannot'});
$lconf = &get_log_config($log) || &error($text{'view_elog'}." : $log");
$full = "$lconf->{'dir'}$file";
open(FILE, $full) || &error($text{'view_eopen'}." : $full");
# Display file contents
if ($full =~ /\.(html|htm)$/i && !$config{'naked'}) {
while(read(FILE, $buf, 1024)) {
$data .= $buf;
}
close(FILE);
$data =~ /<TITLE>(.*)<\/TITLE>/i;
$title = $1;
$data =~ s/^[\000-\377]*<BODY.*>//i;
$data =~ s/<\/BODY>[\000-\377]*$//i;
&ui_print_header(undef, $title || $text{'view_title'}, "");
print $data;
if ($access{'view'}) {
&ui_print_footer("", $text{'index_return'});
}
else {
&ui_print_footer(
"/$module_name/edit_log.cgi?file=$escaped",
$text{'edit_return'},
"", $text{'index_return'});
}
}
else {
print "Content-type: ",$full =~ /\.png$/i ? "image/png" :
$full =~ /\.gif$/i ? "image/gif" :
$full =~ /\.(jpg|jpeg)$/i ? "image/jpeg" :
$full =~ /\.(html|htm)$/i ? "text/html" :
"text/plain","\n";
print "\n";
while(read(FILE, $buf, 1024)) {
print $buf;
}
close(FILE);
}