]>
git.ipfire.org Git - people/mfischer/ipfire-2.x.git/blob - html/cgi-bin/logs.cgi/calamaris.dat
3 # This code is distributed under the terms of the GPL
5 # (c) 2005,2006 marco.s
7 # $Id: calamaris.dat,v 2.1 2006/03/12 00:00:00 marco.s Exp $
12 # enable only the following on debugging purpose
14 #use CGI::Carp 'fatalsToBrowser';
19 require '/var/ipfire/general-functions.pl';
20 require "${General::swroot}/lang.pl";
21 require "${General::swroot}/header.pl";
25 my $squidlogdir = "/var/log/squid";
26 my $reportdir = "${General::swroot}/proxy/calamaris/reports";
27 my $sargdir = "/var/log/sarg";
29 unless (-e
$reportdir) { mkdir($reportdir) }
32 my %reportsettings=();
38 my $hintcolour='#FFFFCC';
42 my %monthidx = (qw(Jan 0 Feb 1 Mar 2 Apr 3 May 4 Jun 5 Jul 6 Aug 7 Sep 8 Oct 9 Nov 10 Dec 11));
44 my @longmonths = ( $Lang::tr
{'january'}, $Lang::tr
{'february'}, $Lang::tr
{'march'},
45 $Lang::tr
{'april'}, $Lang::tr
{'may'}, $Lang::tr
{'june'}, $Lang::tr
{'july'},
46 $Lang::tr
{'august'}, $Lang::tr
{'september'}, $Lang::tr
{'october'},
47 $Lang::tr
{'november'}, $Lang::tr
{'december'} );
49 my @now = localtime(time);
50 my $year = $now[5]+1900;
59 $reportsettings{'ACTION'} = '';
61 $reportsettings{'DAY_BEGIN'} = $now[3];
62 $reportsettings{'MONTH_BEGIN'} = $now[4];
63 $reportsettings{'YEAR_BEGIN'} = $now[5]+1900;
64 $reportsettings{'DAY_END'} = $now[3];
65 $reportsettings{'MONTH_END'} = $now[4];
66 $reportsettings{'YEAR_END'} = $now[5]+1900;
68 $reportsettings{'ENABLE_DOMAIN'} = 'off';
69 $reportsettings{'NUM_DOMAINS'} = '10';
70 $reportsettings{'ENABLE_PERFORMANCE'} = 'off';
71 $reportsettings{'PERF_INTERVAL'} = '60';
72 $reportsettings{'ENABLE_CONTENT'} = 'off';
73 $reportsettings{'NUM_CONTENT'} = '10';
74 $reportsettings{'ENABLE_REQUESTER'} = 'off';
75 $reportsettings{'ENABLE_USERNAME'} = 'off';
76 $reportsettings{'NUM_HOSTS'} = '10';
77 $reportsettings{'NUM_URLS'} = '0';
78 $reportsettings{'ENABLE_HISTOGRAM'} = 'off';
79 $reportsettings{'HIST_LEVEL'} = '10';
80 $reportsettings{'ENABLE_VERBOSE'} = 'off';
81 $reportsettings{'BYTE_UNIT'} = 'B';
82 $reportsettings{'SKIP_GZLOGS'} = 'off';
83 $reportsettings{'RUN_BACKGROUND'} = 'off';
85 &Header
::getcgihash
(\
%reportsettings);
87 if ($reportsettings{'ACTION'} eq $Lang::tr
{'calamaris create report'})
89 $cgiparams{'DAY_BEGIN'} = $reportsettings{'DAY_BEGIN'};
90 $cgiparams{'MONTH_BEGIN'} = $reportsettings{'MONTH_BEGIN'};
91 $cgiparams{'YEAR_BEGIN'} = $reportsettings{'YEAR_BEGIN'};
92 $cgiparams{'DAY_END'} = $reportsettings{'DAY_END'};
93 $cgiparams{'MONTH_END'} = $reportsettings{'MONTH_END'};
94 $cgiparams{'YEAR_END'} = $reportsettings{'YEAR_END'};
96 delete $reportsettings{'DAY_BEGIN'};
97 delete $reportsettings{'MONTH_BEGIN'};
98 delete $reportsettings{'YEAR_BEGIN'};
99 delete $reportsettings{'DAY_END'};
100 delete $reportsettings{'MONTH_END'};
101 delete $reportsettings{'YEAR_END'};
102 delete $reportsettings{'REPORT'};
104 &General
::writehash
("${General::swroot}/proxy/calamaris/settings", \
%reportsettings);
106 $reportsettings{'DAY_BEGIN'} = $cgiparams{'DAY_BEGIN'};
107 $reportsettings{'MONTH_BEGIN'} = $cgiparams{'MONTH_BEGIN'};
108 $reportsettings{'YEAR_BEGIN'} = $cgiparams{'YEAR_BEGIN'};
109 $reportsettings{'DAY_END'} = $cgiparams{'DAY_END'};
110 $reportsettings{'MONTH_END'} = $cgiparams{'MONTH_END'};
111 $reportsettings{'YEAR_END'} = $cgiparams{'YEAR_END'};
113 $day_begin = $reportsettings{'DAY_BEGIN'};
114 $month_begin = $reportsettings{'MONTH_BEGIN'};
115 $year_begin = $reportsettings{'YEAR_BEGIN'};
116 $day_end = $reportsettings{'DAY_END'};
117 $month_end = $reportsettings{'MONTH_END'};
118 $year_end = $reportsettings{'YEAR_END'};
120 if ($reportsettings{'SKIP_GZLOGS'} eq 'on') { $commandline.='nogz '; }
122 $commandline.="$day_begin $month_begin $year_begin $day_end $month_end $year_end";
124 if ($reportsettings{'ENABLE_DOMAIN'} eq 'on')
126 $commandline.=' -d ';
127 $commandline.=$reportsettings{'NUM_DOMAINS'};
129 if ($reportsettings{'ENABLE_PERFORMANCE'} eq 'on')
131 $commandline.=' -P ';
132 $commandline.=$reportsettings{'PERF_INTERVAL'};
134 if ($reportsettings{'ENABLE_CONTENT'} eq 'on')
136 $commandline.=' -t ';
137 $commandline.=$reportsettings{'NUM_CONTENT'};
139 if ($reportsettings{'ENABLE_HISTOGRAM'} eq 'on')
141 $commandline.=' -D ';
142 $commandline.=$reportsettings{'HIST_LEVEL'};
144 if ($reportsettings{'ENABLE_REQUESTER'} eq 'on')
146 if ($reportsettings{'ENABLE_USERNAME'} eq 'on')
150 $commandline.=' -r ';
151 $commandline.=$reportsettings{'NUM_HOSTS'};
153 unless ($reportsettings{'NUM_URLS'} eq '0')
155 $commandline.=' -R ';
156 $commandline.=$reportsettings{'NUM_URLS'};
159 unless ($reportsettings{'BYTE_UNIT'} eq 'B')
161 $commandline.=' -U ';
162 $commandline.=$reportsettings{'BYTE_UNIT'};
164 if ($reportsettings{'ENABLE_VERBOSE'} eq 'on')
169 $commandline.=' < /dev/null > /dev/null 2>&1';
171 if ($reportsettings{'RUN_BACKGROUND'} eq 'on') { $commandline.=" &"; }
173 system("${General::swroot}/proxy/calamaris/bin/mkreport $commandline")
176 if ($reportsettings{'ACTION'} eq $Lang::tr
{'export'})
178 print "Content-type: application/octet-stream\n";
179 print "Content-length: ";
180 print (-s
"$reportdir/$reportsettings{'REPORT'}");
182 print "Content-disposition: attachment; filename=$reportsettings{'REPORT'}\n\n";
184 open (FILE
, "$reportdir/$reportsettings{'REPORT'}");
185 while (<FILE
>) { print; }
191 if ($reportsettings{'ACTION'} eq $Lang::tr
{'delete'}) { unlink("$reportdir/$reportsettings{'REPORT'}"); }
193 if (-e
"${General::swroot}/proxy/calamaris/settings")
195 &General
::readhash
("${General::swroot}/proxy/calamaris/settings", \
%reportsettings);
198 &Header
::showhttpheaders
();
200 $checked{'ENABLE_DOMAIN'}{'off'} = '';
201 $checked{'ENABLE_DOMAIN'}{'on'} = '';
202 $checked{'ENABLE_DOMAIN'}{$reportsettings{'ENABLE_DOMAIN'}} = "checked='checked'";
203 $selected{'NUM_DOMAINS'}{$reportsettings{'NUM_DOMAINS'}} = "selected='selected'";
204 $checked{'ENABLE_PERFORMANCE'}{'off'} = '';
205 $checked{'ENABLE_PERFORMANCE'}{'on'} = '';
206 $checked{'ENABLE_PERFORMANCE'}{$reportsettings{'ENABLE_PERFORMANCE'}} = "checked='checked'";
207 $selected{'PERF_INTERVAL'}{$reportsettings{'PERF_INTERVAL'}} = "selected='selected'";
208 $checked{'ENABLE_CONTENT'}{'off'} = '';
209 $checked{'ENABLE_CONTENT'}{'on'} = '';
210 $checked{'ENABLE_CONTENT'}{$reportsettings{'ENABLE_CONTENT'}} = "checked='checked'";
211 $selected{'NUM_CONTENT'}{$reportsettings{'NUM_CONTENT'}} = "selected='selected'";
212 $checked{'ENABLE_REQUESTER'}{'off'} = '';
213 $checked{'ENABLE_REQUESTER'}{'on'} = '';
214 $checked{'ENABLE_REQUESTER'}{$reportsettings{'ENABLE_REQUESTER'}} = "checked='checked'";
215 $checked{'ENABLE_USERNAME'}{'off'} = '';
216 $checked{'ENABLE_USERNAME'}{'on'} = '';
217 $checked{'ENABLE_USERNAME'}{$reportsettings{'ENABLE_USERNAME'}} = "checked='checked'";
218 $selected{'NUM_HOSTS'}{$reportsettings{'NUM_HOSTS'}} = "selected='selected'";
219 $selected{'NUM_URLS'}{$reportsettings{'NUM_URLS'}} = "selected='selected'";
220 $checked{'ENABLE_HISTOGRAM'}{'off'} = '';
221 $checked{'ENABLE_HISTOGRAM'}{'on'} = '';
222 $checked{'ENABLE_HISTOGRAM'}{$reportsettings{'ENABLE_HISTOGRAM'}} = "checked='checked'";
223 $selected{'HIST_LEVEL'}{$reportsettings{'HIST_LEVEL'}} = "selected='selected'";
224 $checked{'ENABLE_VERBOSE'}{'off'} = '';
225 $checked{'ENABLE_VERBOSE'}{'on'} = '';
226 $checked{'ENABLE_VERBOSE'}{$reportsettings{'ENABLE_VERBOSE'}} = "checked='checked'";
227 $selected{'BYTE_UNIT'}{$reportsettings{'BYTE_UNIT'}} = "selected='selected'";
228 $checked{'SKIP_GZLOGS'}{'off'} = '';
229 $checked{'SKIP_GZLOGS'}{'on'} = '';
230 $checked{'SKIP_GZLOGS'}{$reportsettings{'SKIP_GZLOGS'}} = "checked='checked'";
231 $checked{'RUN_BACKGROUND'}{'off'} = '';
232 $checked{'RUN_BACKGROUND'}{'on'} = '';
233 $checked{'RUN_BACKGROUND'}{$reportsettings{'RUN_BACKGROUND'}} = "checked='checked'";
235 &Header
::openpage
($Lang::tr
{'calamaris proxy reports'}, 1, '');
237 &Header
::openbigbox
('100%', 'left', '', $errormessage);
240 &Header
::openbox
('100%', 'left', $Lang::tr
{'error messages'});
241 print "<font class='base'>$errormessage </font>\n";
247 &Header
::openbox
('100%', 'left', "$Lang::tr{'proxy reports'}:");
255 if (-e
"$sargdir/today") {
257 <td width="25%" align="center">
258 <a href="/proxy-reports/today" target="_blank">$Lang::tr{'proxy reports today'}</a>
263 <td width="25%" align="center">
264 $Lang::tr{'proxy reports today'}
270 if (-e
"$sargdir/daily") {
272 <td width="25%" align="center">
273 <a href="/proxy-reports/daily" target="_blank">$Lang::tr{'proxy reports daily'}</a>
278 <td width="25%" align="center">
279 $Lang::tr{'proxy reports daily'}
285 if (-e
"$sargdir/weekly") {
287 <td width="25%" align="center">
288 <a href="/proxy-reports/weekly" target="_blank">$Lang::tr{'proxy reports weekly'}</a>
293 <td width="25%" align="center">
294 $Lang::tr{'proxy reports weekly'}
300 if (-e
"$sargdir/monthly") {
302 <td width="25%" align="center">
303 <a href="/proxy-reports/monthly" target="_blank">$Lang::tr{'proxy reports monthly'}</a>
308 <td width="25%" align="center">
309 $Lang::tr{'proxy reports monthly'}
325 &Header
::openbox
('100%', 'left', "$Lang::tr{'settings'}:");
328 <form method='post' action='$ENV{'SCRIPT_NAME'}'>
329 <table width='100%' border='0'>
331 <td colspan='8' class='base'><b>$Lang::tr{'calamaris report period'}</b></td>
334 <td width='9%' class='base'>$Lang::tr{'from'}:</td>
336 <select name='MONTH_BEGIN'>
339 for ($month_begin = 0; $month_begin < 12; $month_begin++)
342 if ($month_begin == $reportsettings{'MONTH_BEGIN'}) {
343 print 'selected="selected" '; }
344 print "value='$month_begin'>$longmonths[$month_begin]</option>\n";
350 <select name='DAY_BEGIN'>
353 for ($day_begin = 1; $day_begin <= 31; $day_begin++)
356 if ($day_begin == $reportsettings{'DAY_BEGIN'}) {
357 print 'selected="selected" '; }
358 print "value='$day_begin'>$day_begin</option>\n";
364 <select name='YEAR_BEGIN'>
367 for ($year_begin = $year-2; $year_begin <= $year+1; $year_begin++)
370 if ($year_begin == $reportsettings{'YEAR_BEGIN'}) {
371 print 'selected="selected" '; }
372 print "value='$year_begin'>$year_begin</option>\n";
377 <td width='9%' class='base'>$Lang::tr{'to'}:</td>
379 <select name='MONTH_END'>
382 for ($month_end = 0; $month_end < 12; $month_end++)
385 if ($month_end == $reportsettings{'MONTH_END'}) {
386 print 'selected="selected" '; }
387 print "value='$month_end'>$longmonths[$month_end]</option>\n";
393 <select name='DAY_END'>
396 for ($day_end = 1; $day_end <= 31; $day_end++)
399 if ($day_end == $reportsettings{'DAY_END'}) {
400 print 'selected="selected" '; }
401 print "value='$day_end'>$day_end</option>\n";
407 <select name='YEAR_END'>
410 for ($year_end = $year-2; $year_end <= $year+1; $year_end++)
413 if ($year_end == $reportsettings{'YEAR_END'}) {
414 print 'selected="selected" '; }
415 print "value='$year_end'>$year_end</option>\n";
425 <table width='100%' border='0'>
427 <td colspan='4' class='base'><b>$Lang::tr{'calamaris report options'}</b></td>
430 <td width='30%' class='base'>$Lang::tr{'calamaris enable domain report'}:</td>
431 <td width='15%'><input type='checkbox' name='ENABLE_DOMAIN' $checked{'ENABLE_DOMAIN'}{'on'} /> [-d]</td>
432 <td width='30%' class='base'>$Lang::tr{'calamaris number of domains'}:</td>
433 <td width='25%'><select name='NUM_DOMAINS'>
434 <option value='10' $selected{'NUM_DOMAINS'}{'10'}>10</option>
435 <option value='25' $selected{'NUM_DOMAINS'}{'25'}>25</option>
436 <option value='100' $selected{'NUM_DOMAINS'}{'100'}>100</option>
437 <option value='-1' $selected{'NUM_DOMAINS'}{'-1'}>$Lang::tr{'calamaris unlimited'}</option>
441 <td class='base'>$Lang::tr{'calamaris enable performance report'}:</td>
442 <td><input type='checkbox' name='ENABLE_PERFORMANCE' $checked{'ENABLE_PERFORMANCE'}{'on'} /> [-P]</td>
443 <td class='base'>$Lang::tr{'calamaris report interval (in minutes)'}:</td>
444 <td><select name='PERF_INTERVAL'>
445 <option value='30' $selected{'PERF_INTERVAL'}{'30'}>30</option>
446 <option value='60' $selected{'PERF_INTERVAL'}{'60'}>60</option>
447 <option value='120' $selected{'PERF_INTERVAL'}{'120'}>120</option>
448 <option value='240' $selected{'PERF_INTERVAL'}{'240'}>240</option>
449 <option value='480' $selected{'PERF_INTERVAL'}{'480'}>480</option>
450 <option value='720' $selected{'PERF_INTERVAL'}{'720'}>720</option>
451 <option value='1440' $selected{'PERF_INTERVAL'}{'1440'}>1440</option>
455 <td class='base'>$Lang::tr{'calamaris enable content report'}:</td>
456 <td><input type='checkbox' name='ENABLE_CONTENT' $checked{'ENABLE_CONTENT'}{'on'} /> [-t]</td>
457 <td class='base'>$Lang::tr{'calamaris number of content types'}:</td>
458 <td><select name='NUM_CONTENT'>
459 <option value='10' $selected{'NUM_CONTENT'}{'10'}>10</option>
460 <option value='25' $selected{'NUM_CONTENT'}{'25'}>25</option>
461 <option value='100' $selected{'NUM_CONTENT'}{'100'}>100</option>
462 <option value='-1' $selected{'NUM_CONTENT'}{'-1'}>$Lang::tr{'calamaris unlimited'}</option>
466 <td class='base'>$Lang::tr{'calamaris enable requester report'}:</td>
467 <td><input type='checkbox' name='ENABLE_REQUESTER' $checked{'ENABLE_REQUESTER'}{'on'} /> [-r/-R]</td>
468 <td class='base'>$Lang::tr{'calamaris number of requesting hosts'}:</td>
469 <td><select name='NUM_HOSTS'>
470 <option value='10' $selected{'NUM_HOSTS'}{'10'}>10</option>
471 <option value='25' $selected{'NUM_HOSTS'}{'25'}>25</option>
472 <option value='100' $selected{'NUM_HOSTS'}{'100'}>100</option>
473 <option value='-1' $selected{'NUM_HOSTS'}{'-1'}>$Lang::tr{'calamaris unlimited'}</option>
476 <td class='base'>$Lang::tr{'calamaris show usernames'}:</td>
477 <td><input type='checkbox' name='ENABLE_USERNAME' $checked{'ENABLE_USERNAME'}{'on'} /> [-u]</td>
478 <td class='base'>$Lang::tr{'calamaris number of requested urls'}:</td>
479 <td><select name='NUM_URLS'>
480 <option value='0' $selected{'NUM_URLS'}{'0'}>$Lang::tr{'calamaris none'}</option>
481 <option value='10' $selected{'NUM_URLS'}{'10'}>10</option>
482 <option value='25' $selected{'NUM_URLS'}{'25'}>25</option>
483 <option value='100' $selected{'NUM_URLS'}{'100'}>100</option>
484 <option value='-1' $selected{'NUM_URLS'}{'-1'}>$Lang::tr{'calamaris unlimited'}</option>
488 <td class='base'>$Lang::tr{'calamaris enable distribution histogram'}:</td>
489 <td><input type='checkbox' name='ENABLE_HISTOGRAM' $checked{'ENABLE_HISTOGRAM'}{'on'} /> [-D]</td>
490 <td class='base'>$Lang::tr{'calamaris histogram resolution'}:</td>
491 <td><select name='HIST_LEVEL'>
492 <option value='1000' $selected{'HIST_LEVEL'}{'1000'}>$Lang::tr{'calamaris low'}</option>
493 <option value='10' $selected{'HIST_LEVEL'}{'10'}>$Lang::tr{'calamaris medium'}</option>
494 <option value='2' $selected{'HIST_LEVEL'}{'2'}>$Lang::tr{'calamaris high'}</option>
497 <td class='base'>$Lang::tr{'calamaris enable verbose reporting'}:</td>
498 <td><input type='checkbox' name='ENABLE_VERBOSE' $checked{'ENABLE_VERBOSE'}{'on'} /> [-s]</td>
499 <td class='base'>$Lang::tr{'calamaris byte unit'}:</td>
500 <td><select name='BYTE_UNIT'>
501 <option value='B' $selected{'BYTE_UNIT'}{'B'}>Byte</option>
502 <option value='K' $selected{'BYTE_UNIT'}{'K'}>KByte</option>
503 <option value='M' $selected{'BYTE_UNIT'}{'M'}>MByte</option>
504 <option value='G' $selected{'BYTE_UNIT'}{'G'}>GByte</option>
510 <table width='100%' border='0'>
512 <td colspan='4' class='base'><b>$Lang::tr{'calamaris performance options'}</b></td>
515 <td width='30%' class='base'>$Lang::tr{'calamaris skip archived logfiles'}:</td>
516 <td width='15%'><input type='checkbox' name='SKIP_GZLOGS' $checked{'SKIP_GZLOGS'}{'on'} /></td>
517 <td width='30%'class='base'>$Lang::tr{'calamaris run as background task'}:</td>
518 <td width='25%'><input type='checkbox' name='RUN_BACKGROUND' $checked{'RUN_BACKGROUND'}{'on'} /></td>
524 <table width='100%' border='0'>
526 <td align='left'> </td>
527 <td width='33%' align='center'><input type='submit' name='ACTION' value='$Lang::tr{'calamaris create report'}' /></td>
528 <td width='33%' align='right'> </td>
538 &Header
::openbox
('100%', 'left', "$Lang::tr{'calamaris available reports'}:");
547 foreach (<$reportdir/*>)
551 if ($content[3] =~ /^Report\speriod/)
553 $description = timelocal
(
554 substr($content[4],31,2),
555 substr($content[4],28,2),
556 substr($content[4],25,2),
557 substr($content[4],15,2),
558 $monthidx{substr($content[4],18,3)},
559 "20".substr($content[4],22,2));
560 push(@reports,join("#",$description,substr($_,rindex($_,"/")+1),$content[3],$content[4]));
565 @reports=reverse(sort(@reports));
570 <table width='100%' border='0'>
577 print "<td><select name='REPORT' size='5'>\n";
580 @reportdata=split(/#/);
582 if ($reportsettings{'REPORT'} eq $reportdata[1]) { print "selected ";}
583 print "value='$reportdata[1]'>$reportdata[2] - $reportdata[3]</option>\n";
585 print "</select></td>\n";
586 } else { print "<td><i>$Lang::tr{'calamaris no reports available'}</i></td>\n"; }
592 <table width='100%' cellpadding='5' border='0'>
594 <td><input type='submit' name='ACTION' value='$Lang::tr{'calamaris refresh list'}' /></td>
603 <td><input type='submit' name='ACTION' value='$Lang::tr{'calamaris view'}' /></td>
604 <td><input type='submit' name='ACTION' value='$Lang::tr{'export'}' /></td>
605 <td><input type='submit' name='ACTION' value='$Lang::tr{'delete'}' /></td>
606 <td width='95%'></td>
618 if (($reportsettings{'ACTION'} eq $Lang::tr
{'calamaris view'}) && (!($reportsettings{'REPORT'} eq '')))
621 &Header
::openbox
('100%', 'left', "$Lang::tr{'calamaris view report'}:");
623 open (FILE
, "$reportdir/$reportsettings{'REPORT'}");
637 &Header
::closebigbox
();
639 &Header
::closepage
();