]>
git.ipfire.org Git - people/ummeegge/ipfire-2.x.git/blob - html/cgi-bin/urlfilter.cgi
3316ff27122e41f184dd0cc1a437b102239b5fbf
3 # This code is distributed under the terms of the GPL
5 # (c) 2004-2007 marco.s - http://www.urlfilter.net
7 # $Id: urlfilter.cgi,v 1.9.1 2007/03/22 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" ;
27 my %filtersettings =();
31 my %updatesettings =();
46 my $tcfile = "${General::swroot}/urlfilter/timeconst" ;
47 my $uqfile = "${General::swroot}/urlfilter/userquota" ;
48 my $dbdir = "${General::swroot}/urlfilter/blacklists" ;
49 my $editdir = "${General::swroot}/urlfilter/editor" ;
50 my $repository = "/home/httpd/html/repository" ;
51 my $hintcolour = '#FFFFCC' ;
53 my $sourceurlfile = "${General::swroot}/urlfilter/autoupdate/autoupdate.urls" ;
54 my $updconffile = "${General::swroot}/urlfilter/autoupdate/autoupdate.conf" ;
55 my $updflagfile = "${General::swroot}/urlfilter/blacklists/.autoupdate.last" ;
56 my $upd_cron_dly = "${General::swroot}/urlfilter/autoupdate/cron.daily" ;
57 my $upd_cron_wly = "${General::swroot}/urlfilter/autoupdate/cron.weekly" ;
58 my $upd_cron_mly = "${General::swroot}/urlfilter/autoupdate/cron.monthly" ;
62 my $restoremessage = '' ;
68 my @repositorylist =();
69 my @repositoryfiles =();
71 my @selectedcategories =();
75 my @source_urllist =();
87 if (! - d
$dbdir ) { mkdir ( " $dbdir " ); }
88 if (! - e
$tcfile ) { system ( "touch $tcfile " ); }
89 if (! - e
$uqfile ) { system ( "touch $uqfile " ); }
90 if (! - e
$sourceurlfile ) { system ( "touch $sourceurlfile " ); }
92 & General
:: readhash
( "${General::swroot}/ethernet/settings" , \
%netsettings );
93 & General
:: readhash
( "${General::swroot}/main/settings" , \
%mainsettings );
94 & General
:: readhash
( "${General::swroot}/proxy/settings" , \
%proxysettings );
104 open ( FILE
, $sourceurlfile );
105 @source_urllist = < FILE
>;
108 $filtersettings { 'ENABLE_CUSTOM_BLACKLIST' } = 'off' ;
109 $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } = 'off' ;
110 $filtersettings { 'ENABLE_CUSTOM_EXPRESSIONS' } = 'off' ;
111 $filtersettings { 'BLOCK_EXECUTABLES' } = 'off' ;
112 $filtersettings { 'BLOCK_AUDIO-VIDEO' } = 'off' ;
113 $filtersettings { 'BLOCK_ARCHIVES' } = 'off' ;
114 $filtersettings { 'ENABLE_REWRITE' } = 'off' ;
115 $filtersettings { 'UNFILTERED_CLIENTS' } = '' ;
116 $filtersettings { 'BANNED_CLIENTS' } = '' ;
117 $filtersettings { 'SHOW_CATEGORY' } = 'off' ;
118 $filtersettings { 'SHOW_URL' } = 'off' ;
119 $filtersettings { 'SHOW_IP' } = 'off' ;
120 $filtersettings { 'ENABLE_DNSERROR' } = 'off' ;
121 $filtersettings { 'ENABLE_JPEG' } = 'off' ;
122 $filtersettings { 'REDIRECT_PAGE' } = '' ;
123 $filtersettings { 'MSG_TEXT_1' } = '' ;
124 $filtersettings { 'MSG_TEXT_2' } = '' ;
125 $filtersettings { 'MSG_TEXT_3' } = '' ;
126 $filtersettings { 'ENABLE_EXPR_LISTS' } = 'off' ;
127 $filtersettings { 'BLOCK_IP_ADDR' } = 'off' ;
128 $filtersettings { 'BLOCK_ALL' } = 'off' ;
129 $filtersettings { 'ENABLE_EMPTY_ADS' } = 'off' ;
130 $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } = 'off' ;
131 $filtersettings { 'ENABLE_SAFESEARCH' } = 'off' ;
132 $filtersettings { 'ENABLE_LOG' } = 'off' ;
133 $filtersettings { 'ENABLE_USERNAME_LOG' } = 'off' ;
134 $filtersettings { 'ENABLE_CATEGORY_LOG' } = 'off' ;
135 $filtersettings { 'CHILDREN' } = '5' ;
136 $filtersettings { 'ENABLE_AUTOUPDATE' } = 'off' ;
138 $filtersettings { 'ACTION' } = '' ;
139 $filtersettings { 'VALID' } = '' ;
141 & Header
:: getcgihash
( \
%filtersettings );
142 & Header
:: getcgihash
( \
%tcsettings );
143 & Header
:: getcgihash
( \
%uqsettings );
144 & Header
:: getcgihash
( \
%besettings );
146 if (( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'save' }) ||
147 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter save and restart' }) ||
148 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload file' }) ||
149 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter remove file' }) ||
150 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload background' }) ||
151 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload blacklist' }) ||
152 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter backup' }) ||
153 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter restore' }))
156 @clients = split ( /\n/ , $filtersettings { 'UNFILTERED_CLIENTS' });
159 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
160 if ( /.*-.*-.*/ ) { $errormessage = $Lang :: tr
{ 'urlfilter invalid ip or mask error' }; }
162 foreach ( @temp ) { unless ((& General
:: validipormask
( $_ )) || (& General
:: validipandmask
( $_ ))) { $errormessage = $Lang :: tr
{ 'urlfilter invalid ip or mask error' }; } }
164 @clients = split ( /\n/ , $filtersettings { 'BANNED_CLIENTS' });
167 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
168 if ( /.*-.*-.*/ ) { $errormessage = $Lang :: tr
{ 'urlfilter invalid ip or mask error' }; }
170 foreach ( @temp ) { unless ((& General
:: validipormask
( $_ )) || (& General
:: validipandmask
( $_ ))) { $errormessage = $Lang :: tr
{ 'urlfilter invalid ip or mask error' }; } }
172 if ( $errormessage ) { goto ERROR
; }
174 if (!( $filtersettings { 'CHILDREN' } =~ /^\d+$/ ) || ( $filtersettings { 'CHILDREN' } < 1 ))
176 $errormessage = $Lang :: tr
{ 'urlfilter invalid num of children' };
180 if ((!( $filtersettings { 'REDIRECT_PAGE' } eq '' )) && (!( $filtersettings { 'REDIRECT_PAGE' } =~ /^https?:\/ \
// )))
182 $filtersettings { 'REDIRECT_PAGE' } = "http://" . $filtersettings { 'REDIRECT_PAGE' };
185 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter remove file' })
187 if (- e
" $repository / $filtersettings {'ID'}" ) { unlink ( " $repository / $filtersettings {'ID'}" ); }
188 $filtersettings { 'ACTION' } = $Lang :: tr
{ 'urlfilter manage repository' };
191 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload file' })
193 & Header
:: getcgihash
( \
%filtersettings , { 'wantfile' => 1 , 'filevar' => 'UPLOADFILE' });
195 $filtersettings { 'ACTION' } = $Lang :: tr
{ 'urlfilter manage repository' };
196 $_ = $filtersettings { 'UPLOADFILE' };
198 $_ = substr ( $_ , rindex ( $_ , "/" )+ 1 );
200 if ( copy
( $filtersettings { 'UPLOADFILE' }, " $repository / $_ " ) != 1 )
209 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload background' })
211 & Header
:: getcgihash
( \
%filtersettings , { 'wantfile' => 1 , 'filevar' => 'BACKGROUND' });
213 if ( copy
( $filtersettings { 'BACKGROUND' }, "/home/httpd/html/images/urlfilter/background.jpg" ) != 1 )
220 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload blacklist' })
222 & Header
:: getcgihash
( \
%filtersettings , { 'wantfile' => 1 , 'filevar' => 'UPDATEFILE' });
224 if (!( $filtersettings { 'UPDATEFILE' } =~ /.tar.gz$/ ))
226 $errormessage = $Lang :: tr
{ 'urlfilter wrong filetype' };
230 if ( copy
( $filtersettings { 'UPDATEFILE' }, "${General::swroot}/urlfilter/blacklists.tar.gz" ) != 1 )
236 if (!(- d
"${General::swroot}/urlfilter/update" )) { mkdir ( "${General::swroot}/urlfilter/update" ); }
238 my $exitcode = system ( "/bin/tar --no-same-owner -xzf ${General::swroot}/urlfilter/blacklists.tar.gz -C ${General::swroot}/urlfilter/update" );
242 $errormessage = $Lang :: tr
{ 'urlfilter tar error' };
245 if (- d
"${General::swroot}/urlfilter/update/BL" )
247 system ( "mv ${General::swroot}/urlfilter/update/BL ${General::swroot}/urlfilter/update/blacklists" );
250 if (- d
"${General::swroot}/urlfilter/update/category" )
252 system ( "mv ${General::swroot}/urlfilter/update/category ${General::swroot}/urlfilter/update/blacklists" );
255 if (!(- d
"${General::swroot}/urlfilter/update/blacklists" ))
257 $errormessage = $Lang :: tr
{ 'urlfilter invalid content' };
259 system ( "cp -r ${General::swroot}/urlfilter/update/blacklists/* $dbdir " );
261 & readblockcategories
;
266 $updatemessage = $Lang :: tr
{ 'urlfilter upload success' };
267 system ( "${General::swroot}/urlfilter/bin/prebuild.pl &" );
268 system ( "logger -t installpackage[urlfilter] \" URL filter blacklist - Blacklist update from local source completed \" " );
271 if (- d
"${General::swroot}/urlfilter/update" ) { system ( "rm -rf ${General::swroot}/urlfilter/update" ); }
272 if (- e
"${General::swroot}/urlfilter/blacklists.tar.gz" ) { unlink ( "${General::swroot}/urlfilter/blacklists.tar.gz" ); }
273 if ( $errormessage ) { goto ERROR
; }
276 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter backup' })
278 $blistbackup = ( $filtersettings { 'ENABLE_FULLBACKUP' } eq 'on' ) ?
"blacklists" : "blacklists/custom" ;
279 if ( system ( "/bin/tar -C ${General::swroot}/urlfilter -czf ${General::swroot}/urlfilter/backup.tar.gz settings timeconst userquota autoupdate $blistbackup " ))
281 $errormessage = $Lang :: tr
{ 'urlfilter backup error' };
286 print "Content-type: application/gzip \n " ;
287 print "Content-length: " ;
288 print (- s
"${General::swroot}/urlfilter/backup.tar.gz" );
290 print "Content-disposition: attachment; filename=urlfilter-backup.tar.gz \n\n " ;
292 open ( FILE
, "${General::swroot}/urlfilter/backup.tar.gz" );
293 while (< FILE
>) { print ; }
296 if (- e
"${General::swroot}/urlfilter/backup.tar.gz" ) { unlink ( "${General::swroot}/urlfilter/backup.tar.gz" ); }
301 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter restore' })
303 & Header
:: getcgihash
( \
%filtersettings , { 'wantfile' => 1 , 'filevar' => 'UPDATEFILE' });
305 if (!( $filtersettings { 'UPDATEFILE' } =~ /.tar.gz$/ ))
307 $errormessage = $Lang :: tr
{ 'urlfilter wrong filetype' };
311 if (!(- d
"${General::swroot}/urlfilter/restore" )) { mkdir ( "${General::swroot}/urlfilter/restore" ); }
313 if ( copy
( $filtersettings { 'UPDATEFILE' }, "${General::swroot}/urlfilter/backup.tar.gz" ) != 1 )
318 my $exitcode = system ( "/bin/tar --no-same-owner --preserve-permissions -xzf ${General::swroot}/urlfilter/backup.tar.gz -C ${General::swroot}/urlfilter/restore" );
321 $errormessage = $Lang :: tr
{ 'urlfilter tar error' };
323 if (!(- e
"${General::swroot}/urlfilter/restore/settings" ))
325 $errormessage = $Lang :: tr
{ 'urlfilter invalid restore file' };
327 system ( "cp -rp ${General::swroot}/urlfilter/restore/* ${General::swroot}/urlfilter/" );
328 & readblockcategories
;
332 $restoremessage = $Lang :: tr
{ 'urlfilter restore success' };
336 if (- e
"${General::swroot}/urlfilter/backup.tar.gz" ) { unlink ( "${General::swroot}/urlfilter/backup.tar.gz" ); }
337 if (- d
"${General::swroot}/urlfilter/restore" ) { system ( "rm -rf ${General::swroot}/urlfilter/restore" ); }
338 if ( $errormessage ) { goto ERROR
; }
341 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'save' })
343 $filtersettings { 'VALID' } = 'yes' ;
347 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter save and restart' })
349 if ((!(- e
"${General::swroot}/proxy/enable" )) && (!(- e
"${General::swroot}/proxy/enable_blue" )))
351 $errormessage = $Lang :: tr
{ 'urlfilter web proxy service required' };
354 if (!( $proxysettings { 'ENABLE_FILTER' } eq 'on' ))
356 $errormessage = $Lang :: tr
{ 'urlfilter not enabled' };
360 $filtersettings { 'VALID' } = 'yes' ;
363 system ( "chown -R nobody.nobody $dbdir " );
365 if (- e
" $dbdir /custom/allowed/domains.db" ) { unlink ( " $dbdir /custom/allowed/domains.db" ); }
366 if (- e
" $dbdir /custom/allowed/urls.db" ) { unlink ( " $dbdir /custom/allowed/urls.db" ); }
367 if (- e
" $dbdir /custom/blocked/domains.db" ) { unlink ( " $dbdir /custom/blocked/domains.db" ); }
368 if (- e
" $dbdir /custom/blocked/urls.db" ) { unlink ( " $dbdir /custom/blocked/urls.db" ); }
370 & setpermissions
( $dbdir );
372 system ( '/usr/local/bin/squidctrl restart >/dev/null 2>&1' );
376 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter set time constraints' }) { $tcsettings { 'TCMODE' } = 'on' }
378 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'add' }))
380 $tcsettings { 'TCMODE' }= 'on' ;
382 if (! $tcsettings { 'DST' })
384 $errormessage = $Lang :: tr
{ 'urlfilter dst error' };
387 if (! $tcsettings { 'SRC' })
389 $errormessage = $Lang :: tr
{ 'urlfilter src error' };
392 if (!( $tcsettings { 'TO_HOUR' }. $tcsettings { 'TO_MINUTE' } gt $tcsettings { 'FROM_HOUR' }. $tcsettings { 'FROM_MINUTE' }))
394 $errormessage = $Lang :: tr
{ 'urlfilter timespace error' };
397 if (!(( $tcsettings { 'MON' } eq 'on' ) || ( $tcsettings { 'TUE' } eq 'on' ) || ( $tcsettings { 'WED' } eq 'on' ) || ( $tcsettings { 'THU' } eq 'on' ) || ( $tcsettings { 'FRI' } eq 'on' ) || ( $tcsettings { 'SAT' } eq 'on' ) || ( $tcsettings { 'SUN' } eq 'on' )))
399 $errormessage = $Lang :: tr
{ 'urlfilter weekday error' };
404 # transform to pre1.8 client definitions
405 @clients = split ( /\n/ , $tcsettings { 'SRC' });
406 undef $tcsettings { 'SRC' };
409 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
410 $tcsettings { 'SRC' } .= " $_ " ;
412 $tcsettings { 'SRC' } =~ s/\s+$// ;
414 if ( $tcsettings { 'DST' } =~ /^any/ ) { $tcsettings { 'DST' } = 'any' ; }
415 if ( $tcsettings { 'ENABLERULE' } eq 'on' ) { $tcsettings { 'ACTIVE' } = $tcsettings { 'ENABLERULE' }; } else { $tcsettings { 'ACTIVE' } = 'off' }
417 $tcsettings { 'ENABLERULE' } = 'on' ;
418 if ( $tcsettings { 'EDITING' } eq 'no' ) {
419 open ( FILE
, ">> $tcfile " );
421 print FILE
" $tcsettings {'DEFINITION'}, $tcsettings {'MON'}, $tcsettings {'TUE'}, $tcsettings {'WED'}, $tcsettings {'THU'}, $tcsettings {'FRI'}, $tcsettings {'SAT'}, $tcsettings {'SUN'}, $tcsettings {'FROM_HOUR'}, $tcsettings {'FROM_MINUTE'}, $tcsettings {'TO_HOUR'}, $tcsettings {'TO_MINUTE'}, $tcsettings {'SRC'}, $tcsettings {'DST'}, $tcsettings {'ACCESS'}, $tcsettings {'ACTIVE'}, $tcsettings {'COMMENT'} \n " ;
423 open ( FILE
, "> $tcfile " );
426 foreach $line ( @tclist )
429 if ( $tcsettings { 'EDITING' } eq $id ) {
430 print FILE
" $tcsettings {'DEFINITION'}, $tcsettings {'MON'}, $tcsettings {'TUE'}, $tcsettings {'WED'}, $tcsettings {'THU'}, $tcsettings {'FRI'}, $tcsettings {'SAT'}, $tcsettings {'SUN'}, $tcsettings {'FROM_HOUR'}, $tcsettings {'FROM_MINUTE'}, $tcsettings {'TO_HOUR'}, $tcsettings {'TO_MINUTE'}, $tcsettings {'SRC'}, $tcsettings {'DST'}, $tcsettings {'ACCESS'}, $tcsettings {'ACTIVE'}, $tcsettings {'COMMENT'} \n " ;
431 } else { print FILE
" $line " ; }
436 $tcsettings { 'CHANGED' }= 'yes' ;
437 $tcsettings { 'TCMODE' }= 'on' ;
440 if ( $tcsettings { 'EDITING' } ne 'no' )
442 $tcsettings { 'ACTION' } = $Lang :: tr
{ 'edit' };
443 $tcsettings { 'ID' } = $tcsettings { 'EDITING' };
448 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter copy rule' }) && (! $errormessage ))
451 foreach $line ( @tclist )
454 if ( $tcsettings { 'ID' } eq $id )
457 @temp = split ( /\,/ , $line );
458 $tcsettings { 'DEFINITION' } = $temp [ 0 ];
459 $tcsettings { 'MON' } = $temp [ 1 ];
460 $tcsettings { 'TUE' } = $temp [ 2 ];
461 $tcsettings { 'WED' } = $temp [ 3 ];
462 $tcsettings { 'THU' } = $temp [ 4 ];
463 $tcsettings { 'FRI' } = $temp [ 5 ];
464 $tcsettings { 'SAT' } = $temp [ 6 ];
465 $tcsettings { 'SUN' } = $temp [ 7 ];
466 $tcsettings { 'FROM_HOUR' } = $temp [ 8 ];
467 $tcsettings { 'FROM_MINUTE' } = $temp [ 9 ];
468 $tcsettings { 'TO_HOUR' } = $temp [ 10 ];
469 $tcsettings { 'TO_MINUTE' } = $temp [ 11 ];
470 $tcsettings { 'SRC' } = $temp [ 12 ];
471 $tcsettings { 'DST' } = $temp [ 13 ];
472 $tcsettings { 'ACCESS' } = $temp [ 14 ];
473 $tcsettings { 'ENABLERULE' } = $temp [ 15 ];
474 $tcsettings { 'COMMENT' } = $temp [ 16 ];
477 $tcsettings { 'TCMODE' }= 'on' ;
480 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'remove' }))
483 open ( FILE
, "> $tcfile " );
485 foreach $line ( @tclist )
488 unless ( $tcsettings { 'ID' } eq $id ) { print FILE
" $line " ; }
491 $tcsettings { 'CHANGED' }= 'yes' ;
492 $tcsettings { 'TCMODE' }= 'on' ;
495 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter restart' }))
497 if (!( $proxysettings { 'ENABLE_FILTER' } eq 'on' ))
499 $errormessage = $Lang :: tr
{ 'urlfilter not enabled' };
501 if ((!(- e
"${General::swroot}/proxy/enable" )) && (!(- e
"${General::swroot}/proxy/enable_blue" )))
503 $errormessage = $Lang :: tr
{ 'urlfilter web proxy service required' };
506 if (! $errormessage ) { system ( '/usr/local/bin/squidctrl restart >/dev/null 2>&1' ); }
507 $tcsettings { 'TCMODE' }= 'on' ;
510 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'toggle enable disable' }))
512 open ( FILE
, "> $tcfile " );
515 foreach $line ( @tclist )
518 unless ( $tcsettings { 'ID' } eq $id ) { print FILE
" $line " ; }
522 @temp = split ( /\,/ , $line );
523 if ( $temp [ 15 ] eq 'on' ) { $temp [ 15 ] = 'off' ; } else { $temp [ 15 ] = 'on' }
524 print FILE
" $temp [0], $temp [1], $temp [2], $temp [3], $temp [4], $temp [5], $temp [6], $temp [7], $temp [8], $temp [9], $temp [10], $temp [11], $temp [12], $temp [13], $temp [14], $temp [15], $temp [16] \n " ;
528 $tcsettings { 'CHANGED' }= 'yes' ;
529 $tcsettings { 'TCMODE' }= 'on' ;
532 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) && (! $errormessage ))
535 foreach $line ( @tclist )
538 if ( $tcsettings { 'ID' } eq $id )
541 @temp = split ( /\,/ , $line );
542 $tcsettings { 'DEFINITION' } = $temp [ 0 ];
543 $tcsettings { 'MON' } = $temp [ 1 ];
544 $tcsettings { 'TUE' } = $temp [ 2 ];
545 $tcsettings { 'WED' } = $temp [ 3 ];
546 $tcsettings { 'THU' } = $temp [ 4 ];
547 $tcsettings { 'FRI' } = $temp [ 5 ];
548 $tcsettings { 'SAT' } = $temp [ 6 ];
549 $tcsettings { 'SUN' } = $temp [ 7 ];
550 $tcsettings { 'FROM_HOUR' } = $temp [ 8 ];
551 $tcsettings { 'FROM_MINUTE' } = $temp [ 9 ];
552 $tcsettings { 'TO_HOUR' } = $temp [ 10 ];
553 $tcsettings { 'TO_MINUTE' } = $temp [ 11 ];
554 $tcsettings { 'SRC' } = $temp [ 12 ];
555 $tcsettings { 'DST' } = $temp [ 13 ];
556 $tcsettings { 'ACCESS' } = $temp [ 14 ];
557 $tcsettings { 'ENABLERULE' } = $temp [ 15 ];
558 $tcsettings { 'COMMENT' } = $temp [ 16 ];
561 $tcsettings { 'TCMODE' }= 'on' ;
564 if ((! $errormessage ) && (!( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter copy rule' })) && (!( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }))) {
565 $tcsettings { 'ENABLERULE' }= 'on' ;
566 $tcsettings { 'TO_HOUR' }= '24' ;
569 if ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter set user quota' }) { $uqsettings { 'UQMODE' } = 'on' }
571 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'add' }))
573 $uqsettings { 'UQMODE' }= 'on' ;
575 if ((!( $uqsettings { 'TIME_QUOTA' } =~ /^\d+/ )) || ( $uqsettings { 'TIME_QUOTA' } < '1' ))
577 $errormessage = $Lang :: tr
{ 'urlfilter quota time error' };
580 @temp = split ( /\n/ , $uqsettings { 'QUOTA_USERS' });
581 undef $uqsettings { 'QUOTA_USERS' };
584 s/^\s+//g ; s/\s+$//g ;
585 if ( $_ ) { $uqsettings { 'QUOTA_USERS' } .= $_ . " \n " ; }
588 if ( $uqsettings { 'QUOTA_USERS' } eq '' )
590 $errormessage = $Lang :: tr
{ 'urlfilter quota user error' };
593 $_ = $uqsettings { 'QUOTA_USERS' };
595 my $quota_users = $_ ;
597 if ( $uqsettings { 'QUOTA_USERS' } =~ /\\/ )
599 $errormessage = $Lang :: tr
{ 'urlfilter invalid user error' };
602 if (! $errormessage ) {
603 if ( $uqsettings { 'ENABLEQUOTA' } eq 'on' ) { $uqsettings { 'ACTIVE' } = $uqsettings { 'ENABLEQUOTA' }; } else { $uqsettings { 'ACTIVE' } = 'off' }
605 $uqsettings { 'ENABLERULE' } = 'on' ;
606 if ( $uqsettings { 'EDITING' } eq 'no' ) {
607 open ( FILE
, ">> $uqfile " );
609 print FILE
" $uqsettings {'TIME_QUOTA'}, $uqsettings {'SPORADIC'}, $uqsettings {'RENEWAL'}, $quota_users , $uqsettings {'ACTIVE'} \n " ;
611 open ( FILE
, "> $uqfile " );
614 foreach $line ( @uqlist )
617 if ( $uqsettings { 'EDITING' } eq $id ) {
618 print FILE
" $uqsettings {'TIME_QUOTA'}, $uqsettings {'SPORADIC'}, $uqsettings {'RENEWAL'}, $quota_users , $uqsettings {'ACTIVE'} \n " ;
619 } else { print FILE
" $line " ; }
624 $uqsettings { 'CHANGED' }= 'yes' ;
625 $uqsettings { 'MODE' }= 'USERQUOTA' ;
626 $uqsettings { 'UQMODE' }= 'on' ;
629 if ( $uqsettings { 'EDITING' } ne 'no' )
631 $uqsettings { 'ACTION' } = $Lang :: tr
{ 'edit' };
632 $uqsettings { 'ID' } = $uqsettings { 'EDITING' };
637 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'remove' }))
640 open ( FILE
, "> $uqfile " );
642 foreach $line ( @uqlist )
645 unless ( $uqsettings { 'ID' } eq $id ) { print FILE
" $line " ; }
648 $uqsettings { 'CHANGED' }= 'yes' ;
649 $uqsettings { 'UQMODE' }= 'on' ;
652 if (! $errormessage ) {
653 $uqsettings { 'ENABLEQUOTA' }= 'on' ;
656 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) && (! $errormessage ))
659 foreach $line ( @uqlist )
662 if ( $uqsettings { 'ID' } eq $id )
665 @temp = split ( /\,/ , $line );
666 $uqsettings { 'TIME_QUOTA' } = $temp [ 0 ];
667 $uqsettings { 'SPORADIC' } = $temp [ 1 ];
668 $uqsettings { 'RENEWAL' } = $temp [ 2 ];
669 $uqsettings { 'QUOTA_USERS' } = $temp [ 3 ];
670 $uqsettings { 'ENABLEQUOTA' } = $temp [ 4 ];
673 $uqsettings { 'UQMODE' }= 'on' ;
676 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'toggle enable disable' }))
678 open ( FILE
, "> $uqfile " );
681 foreach $line ( @uqlist )
684 unless ( $uqsettings { 'ID' } eq $id ) { print FILE
" $line " ; }
688 @temp = split ( /\,/ , $line );
689 if ( $temp [ 4 ] eq 'on' ) { $temp [ 4 ] = 'off' ; } else { $temp [ 4 ] = 'on' }
690 print FILE
" $temp [0], $temp [1], $temp [2], $temp [3], $temp [4] \n " ;
694 $uqsettings { 'CHANGED' }= 'yes' ;
695 $uqsettings { 'UQMODE' }= 'on' ;
698 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter restart' }))
700 if (!( $proxysettings { 'ENABLE_FILTER' } eq 'on' ))
702 $errormessage = $Lang :: tr
{ 'urlfilter not enabled' };
704 if ((!(- e
"${General::swroot}/proxy/enable" )) && (!(- e
"${General::swroot}/proxy/enable_blue" )))
706 $errormessage = $Lang :: tr
{ 'urlfilter web proxy service required' };
709 if (! $errormessage ) { system ( '/usr/local/bin/squidctrl restart >/dev/null 2>&1' ); }
710 $uqsettings { 'UQMODE' }= 'on' ;
713 if ( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter blacklist editor' }) { $besettings { 'BEMODE' } = 'on' ; }
715 if ( $besettings { 'MODE' } eq 'BLACKLIST_EDITOR' )
717 @temp = split ( /\n/ , $besettings { 'BE_DOMAINS' });
718 undef $besettings { 'BE_DOMAINS' };
721 s/^\s+//g ; s/\s+$//g ;
722 if ( $_ ) { $besettings { 'BE_DOMAINS' } .= $_ . " \n " ; }
724 chomp ( $besettings { 'BE_DOMAINS' });
725 @temp = split ( /\n/ , $besettings { 'BE_URLS' });
726 undef $besettings { 'BE_URLS' };
729 s/^\s+//g ; s/\s+$//g ;
730 if ( $_ ) { $besettings { 'BE_URLS' } .= $_ . " \n " ; }
732 chomp ( $besettings { 'BE_URLS' });
733 @temp = split ( /\n/ , $besettings { 'BE_EXPRESSIONS' });
734 undef $besettings { 'BE_EXPRESSIONS' };
737 s/^\s+//g ; s/\s+$//g ;
738 if ( $_ ) { $besettings { 'BE_EXPRESSIONS' } .= $_ . " \n " ; }
740 chomp ( $besettings { 'BE_EXPRESSIONS' });
743 if (( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter load blacklist' }) && ( $besettings { 'MODE' } = 'BLACKLIST_EDITOR' ))
745 $besettings { 'BEMODE' } = 'on' ;
747 $besettings { 'BE_NAME' } = $besettings { 'BE_BLACKLIST' };
749 delete $besettings { 'BE_DOMAINS' };
750 delete $besettings { 'BE_URLS' };
751 delete $besettings { 'BE_EXPRESSIONS' };
753 if (- e
" $dbdir / $besettings {'BE_NAME'}/domains" )
755 open ( FILE
, " $dbdir / $besettings {'BE_NAME'}/domains" );
756 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_DOMAINS' } .= $_ } };
758 chomp ( $besettings { 'BE_DOMAINS' });
760 if (- e
" $dbdir / $besettings {'BE_NAME'}/urls" )
762 open ( FILE
, " $dbdir / $besettings {'BE_NAME'}/urls" );
763 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_URLS' } .= $_ } };
765 chomp ( $besettings { 'BE_URLS' });
767 if (- e
" $dbdir / $besettings {'BE_NAME'}/expressions" )
769 open ( FILE
, " $dbdir / $besettings {'BE_NAME'}/expressions" );
770 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_EXPRESSIONS' } .= $_ } };
772 chomp ( $besettings { 'BE_EXPRESSIONS' });
776 if (( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter import blacklist' }) && ( $besettings { 'MODE' } = 'BLACKLIST_EDITOR' ))
778 $besettings { 'BEMODE' } = 'on' ;
780 & Header
:: getcgihash
( \
%besettings , { 'wantfile' => 1 , 'filevar' => 'IMPORTFILE' });
782 if (!( $besettings { 'IMPORTFILE' } =~ /.tar.gz$/ ))
784 $errormessage = $Lang :: tr
{ 'urlfilter wrong filetype' };
786 if (!- d
" $editdir " ) { mkdir ( " $editdir " ); }
788 if ( copy
( $besettings { 'IMPORTFILE' }, " $editdir /blacklist.tar.gz" ) != 1 )
793 my $exitcode = system ( "/bin/tar --no-same-owner --preserve-permissions -xzf $editdir /blacklist.tar.gz -C $editdir " );
796 $errormessage = $Lang :: tr
{ 'urlfilter tar error' };
799 foreach (< $editdir /blacklists/ *>)
804 $besettings { 'BE_NAME' } = substr ( $_ , rindex ( $_ , "/" )+ 1 );
810 $errormessage = $Lang :: tr
{ 'urlfilter invalid import file' };
812 delete $besettings { 'BE_DOMAINS' };
813 delete $besettings { 'BE_URLS' };
814 delete $besettings { 'BE_EXPRESSIONS' };
816 if (- e
" $editdir /blacklists/ $besettings {'BE_NAME'}/domains" )
818 open ( FILE
, " $editdir /blacklists/ $besettings {'BE_NAME'}/domains" );
819 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_DOMAINS' } .= $_ } };
821 chomp ( $besettings { 'BE_DOMAINS' });
823 if (- e
" $editdir /blacklists/ $besettings {'BE_NAME'}/urls" )
825 open ( FILE
, " $editdir /blacklists/ $besettings {'BE_NAME'}/urls" );
826 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_URLS' } .= $_ } };
828 chomp ( $besettings { 'BE_URLS' });
830 if (- e
" $editdir /blacklists/ $besettings {'BE_NAME'}/expressions" )
832 open ( FILE
, " $editdir /blacklists/ $besettings {'BE_NAME'}/expressions" );
833 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_EXPRESSIONS' } .= $_ } };
835 chomp ( $besettings { 'BE_EXPRESSIONS' });
840 if (- d
$editdir ) { system ( "rm -rf $editdir " ); }
846 if (( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter export blacklist' }) && ( $besettings { 'MODE' } = 'BLACKLIST_EDITOR' ))
848 $besettings { 'BEMODE' } = 'on' ;
850 if ( $besettings { 'BE_NAME' } eq '' )
852 $errormessage = $Lang :: tr
{ 'urlfilter category name error' };
853 } elsif ( $besettings { 'BE_DOMAINS' } || $besettings { 'BE_URLS' } || $besettings { 'BE_EXPRESSIONS' }) {
855 $_ = $besettings { 'BE_NAME' }; tr/A-Z/a-z/ ; $besettings { 'BE_NAME' } = $_ ;
857 if (!(- d
" $editdir " )) { mkdir ( " $editdir " ); }
858 if (!(- d
" $editdir /blacklists" )) { mkdir ( " $editdir /blacklists" ); }
859 if (!(- d
" $editdir /blacklists/ $besettings {'BE_NAME'}" )) { mkdir ( " $editdir /blacklists/ $besettings {'BE_NAME'}" ); }
861 open ( FILE
, "> $editdir /blacklists/ $besettings {'BE_NAME'}/domains" );
863 print FILE
" $besettings {'BE_DOMAINS'} \n " ;
865 open ( FILE
, "> $editdir /blacklists/ $besettings {'BE_NAME'}/urls" );
867 print FILE
" $besettings {'BE_URLS'} \n " ;
869 open ( FILE
, "> $editdir /blacklists/ $besettings {'BE_NAME'}/expressions" );
871 print FILE
" $besettings {'BE_EXPRESSIONS'} \n " ;
874 if ( system ( "/bin/tar -C $editdir -czf $editdir / $besettings {'BE_NAME'}.tar.gz blacklists" ))
876 $errormessage = $Lang :: tr
{ 'urlfilter export error' };
880 print "Content-type: application/gzip \n " ;
881 print "Content-length: " ;
882 print (- s
" $editdir / $besettings {'BE_NAME'}.tar.gz" );
884 print "Content-disposition: attachment; filename= $besettings {'BE_NAME'}.tar.gz \n\n " ;
886 open ( FILE
, " $editdir / $besettings {'BE_NAME'}.tar.gz" );
887 while (< FILE
>) { print ; }
890 if (- d
$editdir ) { system ( "rm -rf $editdir " ); }
894 $errormessage = $Lang :: tr
{ 'urlfilter category data error' };
898 if (( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter install blacklist' }) && ( $besettings { 'MODE' } = 'BLACKLIST_EDITOR' ))
900 $besettings { 'BEMODE' } = 'on' ;
902 if ( $besettings { 'BE_NAME' } eq '' )
904 $errormessage = $Lang :: tr
{ 'urlfilter category name error' };
905 } elsif ( $besettings { 'BE_DOMAINS' } || $besettings { 'BE_URLS' } || $besettings { 'BE_EXPRESSIONS' }) {
907 $_ = $besettings { 'BE_NAME' }; tr/A-Z/a-z/ ; $besettings { 'BE_NAME' } = $_ ;
909 if (!- d
" $editdir " ) { mkdir ( " $editdir " ); }
911 if (!- d
" $dbdir / $besettings {'BE_NAME'}" ) { mkdir ( " $dbdir / $besettings {'BE_NAME'}" ); }
913 if (- e
" $dbdir / $besettings {'BE_NAME'}/domains" ) { unlink ( " $dbdir / $besettings {'BE_NAME'}/domains" ); }
914 if ( $besettings { 'BE_DOMAINS' })
916 open ( FILE
, "> $dbdir / $besettings {'BE_NAME'}/domains" );
918 print FILE
" $besettings {'BE_DOMAINS'} \n " ;
921 if (- e
" $dbdir / $besettings {'BE_NAME'}/urls" ) { unlink ( " $dbdir / $besettings {'BE_NAME'}/urls" ); }
922 if ( $besettings { 'BE_URLS' })
924 open ( FILE
, "> $dbdir / $besettings {'BE_NAME'}/urls" );
926 print FILE
" $besettings {'BE_URLS'} \n " ;
929 if (- e
" $dbdir / $besettings {'BE_NAME'}/expressions" ) { unlink ( " $dbdir / $besettings {'BE_NAME'}/expressions" ); }
930 if ( $besettings { 'BE_EXPRESSIONS' })
932 open ( FILE
, "> $dbdir / $besettings {'BE_NAME'}/expressions" );
934 print FILE
" $besettings {'BE_EXPRESSIONS'} \n " ;
938 open ( FILE
, "> $editdir /install.conf" );
940 print FILE
"logdir /var/log/squidGuard \n " ;
941 print FILE
"dbhome $dbdir / $besettings {'BE_NAME'} \n\n " ;
942 print FILE
"dest $besettings {'BE_NAME'} { \n " ;
943 if ( $besettings { 'BE_DOMAINS' }) { print FILE
" domainlist domains \n " ; }
944 if ( $besettings { 'BE_URLS' }) { print FILE
" urllist urls \n " ; }
945 if ( $besettings { 'BE_EXPRESSIONS' }) { print FILE
" expressions expressions \n " ; }
947 print FILE
"acl { \n " ;
948 print FILE
" default { \n " ;
949 print FILE
" pass none \n " ;
954 system ( "rm -f $dbdir / $besettings {'BE_NAME'}/*.db" );
955 system ( "/usr/sbin/squidGuard -c $editdir /install.conf -C all" );
956 system ( "chmod a+w $dbdir / $besettings {'BE_NAME'}/*.db" );
958 & readblockcategories
;
963 system ( '/usr/local/bin/squidctrl restart >/dev/null 2>&1' ) unless ( $besettings { 'NORESTART' } eq 'on' );
965 if (- d
$editdir ) { system ( "rm -rf $editdir " ); }
967 $errormessage = $Lang :: tr
{ 'urlfilter category data error' };
971 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter save schedule' })
973 if (( $filtersettings { 'UPDATE_SOURCE' } eq 'custom' ) && ( $filtersettings { 'CUSTOM_UPDATE_URL' } eq '' ))
975 $errormessage = $Lang :: tr
{ 'urlfilter custom url required' };
977 open ( FILE
, "> $updconffile " );
978 print FILE
"ENABLE_AUTOUPDATE= $filtersettings {'ENABLE_AUTOUPDATE'} \n " ;
979 print FILE
"UPDATE_SCHEDULE= $filtersettings {'UPDATE_SCHEDULE'} \n " ;
980 print FILE
"UPDATE_SOURCE= $filtersettings {'UPDATE_SOURCE'} \n " ;
981 print FILE
"CUSTOM_UPDATE_URL= $filtersettings {'CUSTOM_UPDATE_URL'} \n " ;
984 if (- e
$upd_cron_dly ) { unlink ( $upd_cron_dly ); }
985 if (- e
$upd_cron_wly ) { unlink ( $upd_cron_wly ); }
986 if (- e
$upd_cron_mly ) { unlink ( $upd_cron_mly ); }
988 if (( $filtersettings { 'ENABLE_AUTOUPDATE' } eq 'on' ) && ( $filtersettings { 'UPDATE_SCHEDULE' } eq 'daily' ))
990 symlink ( "../bin/autoupdate.pl" , $upd_cron_dly )
992 symlink ( "/bin/false" , $upd_cron_dly )
995 if (( $filtersettings { 'ENABLE_AUTOUPDATE' } eq 'on' ) && ( $filtersettings { 'UPDATE_SCHEDULE' } eq 'weekly' ))
997 symlink ( "../bin/autoupdate.pl" , $upd_cron_wly )
999 symlink ( "/bin/false" , $upd_cron_wly )
1002 if (( $filtersettings { 'ENABLE_AUTOUPDATE' } eq 'on' ) && ( $filtersettings { 'UPDATE_SCHEDULE' } eq 'monthly' ))
1004 symlink ( "../bin/autoupdate.pl" , $upd_cron_mly )
1006 symlink ( "/bin/false" , $upd_cron_mly )
1011 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter update now' })
1013 if ( $filtersettings { 'UPDATE_SOURCE' } eq 'custom' )
1015 if ( $filtersettings { 'CUSTOM_UPDATE_URL' } eq '' )
1017 $errormessage = $Lang :: tr
{ 'urlfilter custom url required' };
1019 system ( "${General::swroot}/urlfilter/bin/autoupdate.pl $filtersettings {'CUSTOM_UPDATE_URL'} &" );
1022 system ( "${General::swroot}/urlfilter/bin/autoupdate.pl $filtersettings {'UPDATE_SOURCE'} &" );
1027 if (- e
"${General::swroot}/urlfilter/settings" ) { & General
:: readhash
( "${General::swroot}/urlfilter/settings" , \
%filtersettings ); }
1033 if ( $errormessage ) { $filtersettings { 'VALID' } = 'no' ; }
1035 $checked { 'ENABLE_CUSTOM_BLACKLIST' }{ 'off' } = '' ;
1036 $checked { 'ENABLE_CUSTOM_BLACKLIST' }{ 'on' } = '' ;
1037 $checked { 'ENABLE_CUSTOM_BLACKLIST' }{ $filtersettings { 'ENABLE_CUSTOM_BLACKLIST' }} = "checked='checked'" ;
1038 $checked { 'ENABLE_CUSTOM_WHITELIST' }{ 'off' } = '' ;
1039 $checked { 'ENABLE_CUSTOM_WHITELIST' }{ 'on' } = '' ;
1040 $checked { 'ENABLE_CUSTOM_WHITELIST' }{ $filtersettings { 'ENABLE_CUSTOM_WHITELIST' }} = "checked='checked'" ;
1041 $checked { 'ENABLE_CUSTOM_EXPRESSIONS' }{ 'off' } = '' ;
1042 $checked { 'ENABLE_CUSTOM_EXPRESSIONS' }{ 'on' } = '' ;
1043 $checked { 'ENABLE_CUSTOM_EXPRESSIONS' }{ $filtersettings { 'ENABLE_CUSTOM_EXPRESSIONS' }} = "checked='checked'" ;
1044 $checked { 'BLOCK_EXECUTABLES' }{ 'off' } = '' ;
1045 $checked { 'BLOCK_EXECUTABLES' }{ 'on' } = '' ;
1046 $checked { 'BLOCK_EXECUTABLES' }{ $filtersettings { 'BLOCK_EXECUTABLES' }} = "checked='checked'" ;
1047 $checked { 'BLOCK_AUDIO-VIDEO' }{ 'off' } = '' ;
1048 $checked { 'BLOCK_AUDIO-VIDEO' }{ 'on' } = '' ;
1049 $checked { 'BLOCK_AUDIO-VIDEO' }{ $filtersettings { 'BLOCK_AUDIO-VIDEO' }} = "checked='checked'" ;
1050 $checked { 'BLOCK_ARCHIVES' }{ 'off' } = '' ;
1051 $checked { 'BLOCK_ARCHIVES' }{ 'on' } = '' ;
1052 $checked { 'BLOCK_ARCHIVES' }{ $filtersettings { 'BLOCK_ARCHIVES' }} = "checked='checked'" ;
1053 $checked { 'ENABLE_REWRITE' }{ 'off' } = '' ;
1054 $checked { 'ENABLE_REWRITE' }{ 'on' } = '' ;
1055 $checked { 'ENABLE_REWRITE' }{ $filtersettings { 'ENABLE_REWRITE' }} = "checked='checked'" ;
1056 $checked { 'SHOW_CATEGORY' }{ 'off' } = '' ;
1057 $checked { 'SHOW_CATEGORY' }{ 'on' } = '' ;
1058 $checked { 'SHOW_CATEGORY' }{ $filtersettings { 'SHOW_CATEGORY' }} = "checked='checked'" ;
1059 $checked { 'SHOW_URL' }{ 'off' } = '' ;
1060 $checked { 'SHOW_URL' }{ 'on' } = '' ;
1061 $checked { 'SHOW_URL' }{ $filtersettings { 'SHOW_URL' }} = "checked='checked'" ;
1062 $checked { 'SHOW_IP' }{ 'off' } = '' ;
1063 $checked { 'SHOW_IP' }{ 'on' } = '' ;
1064 $checked { 'SHOW_IP' }{ $filtersettings { 'SHOW_IP' }} = "checked='checked'" ;
1065 $checked { 'ENABLE_DNSERROR' }{ 'off' } = '' ;
1066 $checked { 'ENABLE_DNSERROR' }{ 'on' } = '' ;
1067 $checked { 'ENABLE_DNSERROR' }{ $filtersettings { 'ENABLE_DNSERROR' }} = "checked='checked'" ;
1068 $checked { 'ENABLE_JPEG' }{ 'off' } = '' ;
1069 $checked { 'ENABLE_JPEG' }{ 'on' } = '' ;
1070 $checked { 'ENABLE_JPEG' }{ $filtersettings { 'ENABLE_JPEG' }} = "checked='checked'" ;
1071 $checked { 'ENABLE_EXPR_LISTS' }{ 'off' } = '' ;
1072 $checked { 'ENABLE_EXPR_LISTS' }{ 'on' } = '' ;
1073 $checked { 'ENABLE_EXPR_LISTS' }{ $filtersettings { 'ENABLE_EXPR_LISTS' }} = "checked='checked'" ;
1074 $checked { 'BLOCK_IP_ADDR' }{ 'off' } = '' ;
1075 $checked { 'BLOCK_IP_ADDR' }{ 'on' } = '' ;
1076 $checked { 'BLOCK_IP_ADDR' }{ $filtersettings { 'BLOCK_IP_ADDR' }} = "checked='checked'" ;
1077 $checked { 'BLOCK_ALL' }{ 'off' } = '' ;
1078 $checked { 'BLOCK_ALL' }{ 'on' } = '' ;
1079 $checked { 'BLOCK_ALL' }{ $filtersettings { 'BLOCK_ALL' }} = "checked='checked'" ;
1080 $checked { 'ENABLE_EMPTY_ADS' }{ 'off' } = '' ;
1081 $checked { 'ENABLE_EMPTY_ADS' }{ 'on' } = '' ;
1082 $checked { 'ENABLE_EMPTY_ADS' }{ $filtersettings { 'ENABLE_EMPTY_ADS' }} = "checked='checked'" ;
1083 $checked { 'ENABLE_GLOBAL_WHITELIST' }{ 'off' } = '' ;
1084 $checked { 'ENABLE_GLOBAL_WHITELIST' }{ 'on' } = '' ;
1085 $checked { 'ENABLE_GLOBAL_WHITELIST' }{ $filtersettings { 'ENABLE_GLOBAL_WHITELIST' }} = "checked='checked'" ;
1086 $checked { 'ENABLE_SAFESEARCH' }{ 'off' } = '' ;
1087 $checked { 'ENABLE_SAFESEARCH' }{ 'on' } = '' ;
1088 $checked { 'ENABLE_SAFESEARCH' }{ $filtersettings { 'ENABLE_SAFESEARCH' }} = "checked='checked'" ;
1089 $checked { 'ENABLE_LOG' }{ 'off' } = '' ;
1090 $checked { 'ENABLE_LOG' }{ 'on' } = '' ;
1091 $checked { 'ENABLE_LOG' }{ $filtersettings { 'ENABLE_LOG' }} = "checked='checked'" ;
1092 $checked { 'ENABLE_USERNAME_LOG' }{ 'off' } = '' ;
1093 $checked { 'ENABLE_USERNAME_LOG' }{ 'on' } = '' ;
1094 $checked { 'ENABLE_USERNAME_LOG' }{ $filtersettings { 'ENABLE_USERNAME_LOG' }} = "checked='checked'" ;
1095 $checked { 'ENABLE_CATEGORY_LOG' }{ 'off' } = '' ;
1096 $checked { 'ENABLE_CATEGORY_LOG' }{ 'on' } = '' ;
1097 $checked { 'ENABLE_CATEGORY_LOG' }{ $filtersettings { 'ENABLE_CATEGORY_LOG' }} = "checked='checked'" ;
1099 foreach $category ( @filtergroups ) {
1100 $checked { $category }{ 'off' } = '' ;
1101 $checked { $category }{ 'on' } = '' ;
1102 $checked { $category }{ $filtersettings { $category }} = "checked='checked'" ;
1105 $selected { 'DEFINITION' }{ $tcsettings { 'DEFINITION' }} = "selected='selected'" ;
1106 $selected { 'FROM_HOUR' }{ $tcsettings { 'FROM_HOUR' }} = "selected='selected'" ;
1107 $selected { 'FROM_MINUTE' }{ $tcsettings { 'FROM_MINUTE' }} = "selected='selected'" ;
1108 $selected { 'TO_HOUR' }{ $tcsettings { 'TO_HOUR' }} = "selected='selected'" ;
1109 $selected { 'TO_MINUTE' }{ $tcsettings { 'TO_MINUTE' }} = "selected='selected'" ;
1111 @selectedcategories = split ( /\|/ , $tcsettings { 'DST' });
1112 foreach ( @selectedcategories )
1114 $selected { 'DST' }{ $_ } = "selected='selected'" ;
1117 $selected { 'ACCESS' }{ $tcsettings { 'ACCESS' }} = "selected='selected'" ;
1119 $checked { 'ENABLERULE' }{ 'off' } = '' ;
1120 $checked { 'ENABLERULE' }{ 'on' } = '' ;
1121 $checked { 'ENABLERULE' }{ $tcsettings { 'ENABLERULE' }} = "checked='checked'" ;
1122 $checked { 'MON' }{ 'off' } = '' ;
1123 $checked { 'MON' }{ 'on' } = '' ;
1124 $checked { 'MON' }{ $tcsettings { 'MON' }} = "checked='checked'" ;
1125 $checked { 'TUE' }{ 'off' } = '' ;
1126 $checked { 'TUE' }{ 'on' } = '' ;
1127 $checked { 'TUE' }{ $tcsettings { 'TUE' }} = "checked='checked'" ;
1128 $checked { 'WED' }{ 'off' } = '' ;
1129 $checked { 'WED' }{ 'on' } = '' ;
1130 $checked { 'WED' }{ $tcsettings { 'WED' }} = "checked='checked'" ;
1131 $checked { 'THU' }{ 'off' } = '' ;
1132 $checked { 'THU' }{ 'on' } = '' ;
1133 $checked { 'THU' }{ $tcsettings { 'THU' }} = "checked='checked'" ;
1134 $checked { 'FRI' }{ 'off' } = '' ;
1135 $checked { 'FRI' }{ 'on' } = '' ;
1136 $checked { 'FRI' }{ $tcsettings { 'FRI' }} = "checked='checked'" ;
1137 $checked { 'SAT' }{ 'off' } = '' ;
1138 $checked { 'SAT' }{ 'on' } = '' ;
1139 $checked { 'SAT' }{ $tcsettings { 'SAT' }} = "checked='checked'" ;
1140 $checked { 'SUN' }{ 'off' } = '' ;
1141 $checked { 'SUN' }{ 'on' } = '' ;
1142 $checked { 'SUN' }{ $tcsettings { 'SUN' }} = "checked='checked'" ;
1144 $selected { 'SPORADIC' }{ $uqsettings { 'SPORADIC' }} = "selected='selected'" ;
1145 $selected { 'RENEWAL' } { $uqsettings { 'RENEWAL' }} = "selected='selected'" ;
1147 $checked { 'ENABLEQUOTA' }{ 'off' } = '' ;
1148 $checked { 'ENABLEQUOTA' }{ 'on' } = '' ;
1149 $checked { 'ENABLEQUOTA' }{ $uqsettings { 'ENABLEQUOTA' }} = "checked='checked'" ;
1151 $selected { 'BE_BLACKLIST' }{ $besettings { 'BE_BLACKLIST' }} = "selected='selected'" ;
1154 & Header
:: showhttpheaders
();
1156 & Header
:: openpage
( $Lang :: tr
{ 'urlfilter configuration' }, 1 , '' );
1158 & Header
:: openbigbox
( '100%' , 'left' , '' , $errormessage );
1160 if ( $errormessage ) {
1161 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'error messages' });
1162 print "<font class='base'> $errormessage </font> \n " ;
1163 & Header
:: closebox
();
1164 } elsif (( $tcsettings { 'CHANGED' } eq 'yes' ) || ( $uqsettings { 'CHANGED' } eq 'yes' ) ) {
1166 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}'> \n " ;
1167 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter restart notification'}:" );
1168 print "<class name='base'> $Lang ::tr{'urlfilter restart message'} \n " ;
1169 if ( $uqsettings { 'MODE' } eq 'USERQUOTA' ) { print "<p><class name='base'> $Lang ::tr{'urlfilter quota restart message'} \n " ; }
1171 print "<p><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter restart'}' />" ;
1172 if ( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) { print "<input type='hidden' name='MODE' value='TIMECONSTRAINT' />" ; }
1173 if ( $uqsettings { 'MODE' } eq 'USERQUOTA' ) { print "<input type='hidden' name='MODE' value='USERQUOTA' />" ; }
1174 & Header
:: closebox
();
1178 if ( $restoremessage ) {
1179 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter restore results'}:" );
1180 print "<class name='base'> $restoremessage \n " ;
1181 print " </class> \n " ;
1182 & Header
:: closebox
();
1185 if ((! $tcsettings { 'TCMODE' }) && (! $uqsettings { 'UQMODE' }) && (! $besettings { 'BEMODE' })) {
1187 if (!( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter manage repository' })) {
1189 #==========================================================
1191 # Section: Main Configuration
1193 #==========================================================
1195 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}' enctype='multipart/form-data'> \n " ;
1197 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter filter settings'}:" );
1199 <table width='100%'>
1201 <td colspan='4'><b> $Lang ::tr{'urlfilter block categories'}</b></td>
1206 if ( @categories == 0 ) {
1209 <td><i> $Lang ::tr{'urlfilter no categories'}</i></td>
1219 for ( $n = 0 ; $n <= @categories ; $n = $n + $i ) {
1220 for ( $i = 0 ; $i <= 3 ; $i ++) {
1221 if ( $i eq 0 ) { print "<tr> \n " ; }
1222 if (( $n + $i ) < @categories ) {
1223 print "<td width='15%'> @categories [ $n + $i ]:<\/td> \n " ;
1224 print "<td width='10%'><input type='checkbox' name= @filtergroups [ $n + $i ] $checked { @filtergroups [ $n + $i ]}{'on'} /></td> \n " ;
1226 if ( $i eq 3 ) { print "<\/tr> \n " ; }
1233 <table width='100%'>
1235 <td><b> $Lang ::tr{'urlfilter custom blacklist'}</b></td>
1241 <td colspan='2'> $Lang ::tr{'urlfilter blocked domains'} <img src='/blob.gif' alt='*' /></td>
1242 <td colspan='2'> $Lang ::tr{'urlfilter blocked urls'} <img src='/blob.gif' alt='*' /></td>
1245 <td colspan='2' width='50%'><textarea name='CUSTOM_BLACK_DOMAINS' cols='32' rows='6' wrap='off'>
1249 print $filtersettings { 'CUSTOM_BLACK_DOMAINS' };
1253 <td colspan='2' width='50%'><textarea name='CUSTOM_BLACK_URLS' cols='32' rows='6' wrap='off'>
1257 print $filtersettings { 'CUSTOM_BLACK_URLS' };
1263 <table width='100%'>
1265 <td class='base' width='25%'> $Lang ::tr{'urlfilter enable custom blacklist'}:</td>
1266 <td><input type='checkbox' name='ENABLE_CUSTOM_BLACKLIST' $checked {'ENABLE_CUSTOM_BLACKLIST'}{'on'} /></td>
1272 <table width='100%'>
1274 <td><b> $Lang ::tr{'urlfilter custom whitelist'}</b></td>
1280 <td colspan='2'> $Lang ::tr{'urlfilter allowed domains'} <img src='/blob.gif' alt='*' /></td>
1281 <td colspan='2'> $Lang ::tr{'urlfilter allowed urls'} <img src='/blob.gif' alt='*' /></td>
1284 <td colspan='2' width='50%'><textarea name='CUSTOM_WHITE_DOMAINS' cols='32' rows='6' wrap='off'>
1288 print $filtersettings { 'CUSTOM_WHITE_DOMAINS' };
1292 <td colspan='2' width='50%'><textarea name='CUSTOM_WHITE_URLS' cols='32' rows='6' wrap='off'>
1296 print $filtersettings { 'CUSTOM_WHITE_URLS' };
1302 <table width='100%'>
1304 <td class='base' width='25%'> $Lang ::tr{'urlfilter enable custom whitelist'}:</td>
1305 <td><input type='checkbox' name='ENABLE_CUSTOM_WHITELIST' $checked {'ENABLE_CUSTOM_WHITELIST'}{'on'} /></td>
1311 <table width='100%'>
1313 <td colspan='4'><b> $Lang ::tr{'urlfilter custom expression list'}</b></td>
1316 <td colspan='4'> $Lang ::tr{'urlfilter blocked expressions'} <img src='/blob.gif' alt='*' /></td>
1319 <td colspan='4'><textarea name='CUSTOM_EXPRESSIONS' cols='70' rows='3' wrap='off'>
1323 print $filtersettings { 'CUSTOM_EXPRESSIONS' };
1329 <td class='base' width='25%'> $Lang ::tr{'urlfilter enable custom expression list'}:</td>
1330 <td><input type='checkbox' name='ENABLE_CUSTOM_EXPRESSIONS' $checked {'ENABLE_CUSTOM_EXPRESSIONS'}{'on'} /></td>
1336 <table width='100%'>
1338 <td colspan='4'><b> $Lang ::tr{'urlfilter file ext block'}</b></td>
1341 <td width='25%' class='base'> $Lang ::tr{'urlfilter block executables'}:</td>
1342 <td width='12%'><input type='checkbox' name='BLOCK_EXECUTABLES' $checked {'BLOCK_EXECUTABLES'}{'on'} /></td>
1343 <td width='25%' class='base'> $Lang ::tr{'urlfilter block audio-video'}:</td>
1344 <td><input type='checkbox' name='BLOCK_AUDIO-VIDEO' $checked {'BLOCK_AUDIO-VIDEO'}{'on'} /></td>
1347 <td class='base'> $Lang ::tr{'urlfilter block archives'}:</td>
1348 <td><input type='checkbox' name='BLOCK_ARCHIVES' $checked {'BLOCK_ARCHIVES'}{'on'} /></td>
1354 <table width='100%'>
1356 <td colspan='4'><b> $Lang ::tr{'urlfilter local file redirection'}</b></td>
1359 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable rewrite rules'}:</td>
1360 <td width='12%'><input type='checkbox' name='ENABLE_REWRITE' $checked {'ENABLE_REWRITE'}{'on'} /></td>
1365 <td><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter manage repository'}'></td>
1372 <table width='100%'>
1374 <td colspan='2'><b> $Lang ::tr{'urlfilter network access control'}</b></td>
1379 <td colspan='2'> $Lang ::tr{'urlfilter unfiltered clients'} <img src='/blob.gif' alt='*' /></td>
1380 <td colspan='2'> $Lang ::tr{'urlfilter banned clients'} <img src='/blob.gif' alt='*' /></td>
1383 <td colspan='2' width='50%'><textarea name='UNFILTERED_CLIENTS' cols='32' rows='6' wrap='off'>
1387 # transform from pre1.8 client definitions
1388 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/^\s+//g ;
1389 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/\s+$//g ;
1390 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/\s+-\s+/-/g ;
1391 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/\s+/ /g ;
1393 @clients = split ( / / , $filtersettings { 'UNFILTERED_CLIENTS' });
1394 undef $filtersettings { 'UNFILTERED_CLIENTS' };
1395 foreach ( @clients ) { $filtersettings { 'UNFILTERED_CLIENTS' } .= " $_ \n " ; }
1397 print $filtersettings { 'UNFILTERED_CLIENTS' };
1401 <td colspan='2' width='50%'><textarea name='BANNED_CLIENTS' cols='32' rows='6' wrap='off'>
1405 # transform from pre1.8 client definitions
1406 $filtersettings { 'BANNED_CLIENTS' } =~ s/^\s+//g ;
1407 $filtersettings { 'BANNED_CLIENTS' } =~ s/\s+$//g ;
1408 $filtersettings { 'BANNED_CLIENTS' } =~ s/\s+-\s+/-/g ;
1409 $filtersettings { 'BANNED_CLIENTS' } =~ s/\s+/ /g ;
1411 @clients = split ( / / , $filtersettings { 'BANNED_CLIENTS' });
1412 undef $filtersettings { 'BANNED_CLIENTS' };
1413 foreach ( @clients ) { $filtersettings { 'BANNED_CLIENTS' } .= " $_ \n " ; }
1415 print $filtersettings { 'BANNED_CLIENTS' };
1422 <table width='100%'>
1424 <td colspan='4'><b> $Lang ::tr{'urlfilter timebased access control'}</b></td>
1427 <td width='25%'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter set time constraints'}'></td>
1428 <td width='25%'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter set user quota'}'></td>
1434 <table width='100%'>
1436 <td colspan='4'><b> $Lang ::tr{'urlfilter block settings'}</b></td>
1439 <td width='25%' class='base'> $Lang ::tr{'urlfilter show category'}:</td>
1440 <td width='12%'><input type='checkbox' name='SHOW_CATEGORY' $checked {'SHOW_CATEGORY'}{'on'} /></td>
1441 <td width='25%' class='base'> $Lang ::tr{'urlfilter redirectpage'}: <img src='/blob.gif' alt='*' /></td>
1442 <td><input type='text' name='REDIRECT_PAGE' value=' $filtersettings {'REDIRECT_PAGE'}' size='40' /></td>
1445 <td class='base'> $Lang ::tr{'urlfilter show url'}:</td>
1446 <td><input type='checkbox' name='SHOW_URL' $checked {'SHOW_URL'}{'on'} /></td>
1447 <td class='base'> $Lang ::tr{'urlfilter msg text 1'}: <img src='/blob.gif' alt='*' /></td>
1448 <td><input type='text' name='MSG_TEXT_1' value=' $filtersettings {'MSG_TEXT_1'}' size='40' /></td>
1451 <td class='base'> $Lang ::tr{'urlfilter show ip'}:</td>
1452 <td><input type='checkbox' name='SHOW_IP' $checked {'SHOW_IP'}{'on'} /></td>
1453 <td class='base'> $Lang ::tr{'urlfilter msg text 2'}: <img src='/blob.gif' alt='*' /></td>
1454 <td><input type='text' name='MSG_TEXT_2' value=' $filtersettings {'MSG_TEXT_2'}' size='40' /></td>
1457 <td class='base'> $Lang ::tr{'urlfilter show dnserror'}:</td>
1458 <td><input type='checkbox' name='ENABLE_DNSERROR' $checked {'ENABLE_DNSERROR'}{'on'} /></td>
1459 <td class='base'> $Lang ::tr{'urlfilter msg text 3'}: <img src='/blob.gif' alt='*' /></td>
1460 <td><input type='text' name='MSG_TEXT_3' value=' $filtersettings {'MSG_TEXT_3'}' size='40' /></td>
1463 <td class='base'> $Lang ::tr{'urlfilter enable jpeg'}:</td>
1464 <td><input type='checkbox' name='ENABLE_JPEG' $checked {'ENABLE_JPEG'}{'on'} /></td>
1469 <table width='100%'>
1471 <td class='base'><b> $Lang ::tr{'urlfilter background image'}</b></td>
1474 <td><br> $Lang ::tr{'urlfilter background text'}:</td>
1477 <td><input type='file' name='BACKGROUND' size='40' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter upload background'}' /></td>
1481 <table width='100%'>
1483 <td colspan='4'><b> $Lang ::tr{'urlfilter advanced settings'}</b></td>
1486 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable expression lists'}:</td>
1487 <td width='12%'><input type='checkbox' name='ENABLE_EXPR_LISTS' $checked {'ENABLE_EXPR_LISTS'}{'on'} /></td>
1488 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable log'}:</td>
1489 <td><input type='checkbox' name='ENABLE_LOG' $checked {'ENABLE_LOG'}{'on'} /></td>
1492 <td class='base'> $Lang ::tr{'urlfilter safesearch'}:</td>
1493 <td><input type='checkbox' name='ENABLE_SAFESEARCH' $checked {'ENABLE_SAFESEARCH'}{'on'} /></td>
1494 <td class='base'> $Lang ::tr{'urlfilter username log'}:</td>
1495 <td><input type='checkbox' name='ENABLE_USERNAME_LOG' $checked {'ENABLE_USERNAME_LOG'}{'on'} /></td>
1498 <td class='base'> $Lang ::tr{'urlfilter empty ads'}:</td>
1499 <td><input type='checkbox' name='ENABLE_EMPTY_ADS' $checked {'ENABLE_EMPTY_ADS'}{'on'} /></td>
1500 <td class='base'> $Lang ::tr{'urlfilter category log'}:</td>
1501 <td><input type='checkbox' name='ENABLE_CATEGORY_LOG' $checked {'ENABLE_CATEGORY_LOG'}{'on'} /></td>
1504 <td class='base'> $Lang ::tr{'urlfilter block ip'}:</td>
1505 <td><input type='checkbox' name='BLOCK_IP_ADDR' $checked {'BLOCK_IP_ADDR'}{'on'} /></td>
1506 <td class='base'> $Lang ::tr{'urlfilter children'}:</td>
1507 <td><input type='text' name='CHILDREN' value=' $filtersettings {'CHILDREN'}' size='5' /></td>
1510 <td class='base'> $Lang ::tr{'urlfilter block all'}:</td>
1511 <td><input type='checkbox' name='BLOCK_ALL' $checked {'BLOCK_ALL'}{'on'} /></td>
1512 <td class='base'> $Lang ::tr{'urlfilter whitelist always allowed'}:</td>
1513 <td><input type='checkbox' name='ENABLE_GLOBAL_WHITELIST' $checked {'ENABLE_GLOBAL_WHITELIST'}{'on'} /></td>
1517 <table width='100%'>
1520 <img src='/blob.gif' align='top' alt='*' />
1521 <font class='base'> $Lang ::tr{'this field may be blank'}</font>
1523 <td align='right'>
1527 <table width='100%'>
1530 <td align='center'><input type='submit' name='ACTION' value=' $Lang ::tr{'save'}' /></td>
1531 <td align='center'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter save and restart'}' /></td>
1538 & Header
:: closebox
();
1542 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}' enctype='multipart/form-data'> \n " ;
1544 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter maintenance'}:" );
1547 <table width='100%'>
1549 <td class='base'><b> $Lang ::tr{'urlfilter blacklist update'}</b></td>
1552 <td> $Lang ::tr{'urlfilter upload information'}<p> $Lang ::tr{'urlfilter upload text'}:</td>
1555 <td><input type='file' name='UPDATEFILE' size='40' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter upload blacklist'}' /></td>
1561 <table width='100%'>
1563 <td colspan='2' class='base'><b> $Lang ::tr{'urlfilter automatic blacklist update'}</b>
1566 if (- e
" $updflagfile " )
1568 $blacklistage = int (- M
" $updflagfile " );
1569 print " <b>[</b> <small><i> $Lang ::tr{'urlfilter blacklist age 1'} <b> $blacklistage </b> $Lang ::tr{'urlfilter blacklist age 2'}</i></small> <b>]</b>" ;
1572 $updatesettings { 'UPDATE_SCHEDULE' } = 'monthly' ;
1573 $updatesettings { 'CUSTOM_UPDATE_URL' } = '' ;
1575 if (- e
" $updconffile " ) { & General
:: readhash
( " $updconffile " , \
%updatesettings ); }
1577 $checked { 'ENABLE_AUTOUPDATE' }{ 'off' } = '' ;
1578 $checked { 'ENABLE_AUTOUPDATE' }{ 'on' } = '' ;
1579 $checked { 'ENABLE_AUTOUPDATE' }{ $updatesettings { 'ENABLE_AUTOUPDATE' }} = "checked='checked'" ;
1581 $selected { 'UPDATE_SCHEDULE' }{ $updatesettings { 'UPDATE_SCHEDULE' }} = "selected='selected'" ;
1583 $selected { 'UPDATE_SOURCE' }{ $updatesettings { 'UPDATE_SOURCE' }} = "selected='selected'" ;
1589 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable automatic blacklist update'}:</td>
1590 <td width='75%' class='base'><input type='checkbox' name='ENABLE_AUTOUPDATE' $checked {'ENABLE_AUTOUPDATE'}{'on'} /></td>
1593 <td class='base'> $Lang ::tr{'urlfilter automatic update schedule'}:</td>
1595 <select name='UPDATE_SCHEDULE'>
1596 <option value='daily' $selected {'UPDATE_SCHEDULE'}{'daily'}> $Lang ::tr{'urlfilter daily'}</option>
1597 <option value='weekly' $selected {'UPDATE_SCHEDULE'}{'weekly'}> $Lang ::tr{'urlfilter weekly'}</option>
1598 <option value='monthly' $selected {'UPDATE_SCHEDULE'}{'monthly'}> $Lang ::tr{'urlfilter monthly'}</option>
1603 <td class='base'> $Lang ::tr{'urlfilter select source'}:</td>
1604 <td class='base' colspan='2'>
1605 <select name='UPDATE_SOURCE'>
1609 foreach ( @source_urllist ) {
1611 $source_name = substr ( $_ , 0 , rindex ( $_ , "," ));
1612 $source_url = substr ( $_ , index ( $_ , "," )+ 1 );
1613 print " \t <option value=' $source_url ' $selected {'UPDATE_SOURCE'}{ $source_url }> $source_name </option> \n " ;
1617 <option value='custom' $selected {'UPDATE_SOURCE'}{'custom'}> $Lang ::tr{'urlfilter custom url'}</option>
1622 <td> $Lang ::tr{'urlfilter custom url'}:</td>
1623 <td><input type='text' name='CUSTOM_UPDATE_URL' value=' $updatesettings {'CUSTOM_UPDATE_URL'}' size='72' /></td>
1626 <table width='100%'>
1628 <td width='25%'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter save schedule'}'> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter update now'}'></td>
1634 <table width='100%'>
1636 <td class='base'><b> $Lang ::tr{'urlfilter blacklist editor'}</b></td>
1639 <td> $Lang ::tr{'urlfilter blacklist editor info'}</td>
1642 <td><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter blacklist editor'}' /></td>
1648 <table width='100%'>
1650 <td colspan='4' class='base'><b> $Lang ::tr{'urlfilter backup settings'}</b></td>
1653 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable full backup'}:</td>
1654 <td width='12%' class='base'><input type='checkbox' name='ENABLE_FULLBACKUP' $checked {'ENABLE_FULLBACKUP'}{'on'} /></td>
1659 <td colspan='4' class='base'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter backup'}' /></td>
1665 <table width='100%'>
1667 <td class='base'><b> $Lang ::tr{'urlfilter restore settings'}</b></td>
1670 <td> $Lang ::tr{'urlfilter restore text'}:</td>
1673 <td><input type='file' name='UPDATEFILE' size='40' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter restore'}' /></td>
1680 & Header
:: closebox
();
1684 #==========================================================
1686 # Section: Manage Repository
1688 #==========================================================
1690 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}' enctype='multipart/form-data'> \n " ;
1692 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter manage local file repository'}:" );
1694 <table width='100%'>
1696 <td> $Lang ::tr{'urlfilter repository information'}<br><br></td>
1699 <td> $Lang ::tr{'urlfilter upload file text'}:</td>
1702 <td><input type='file' name='UPLOADFILE' size='50' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter upload file'}' /></td>
1705 <td><br><b> $Lang ::tr{'urlfilter upload file information 1'}:</b> $Lang ::tr{'urlfilter upload file information 2'}</td>
1709 <table width='100%'>
1711 <td><input type='button' name='return2main' value=' $Lang ::tr{'urlfilter back to main page'}' onClick='self.location.href=" $ENV {'SCRIPT_NAME'}"'></td>
1718 & Header
:: closebox
();
1720 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter current files'}: </b>[ $repository ]" );
1722 @repositorylist = < $repository /*>;
1724 undef @repositoryfiles ;
1725 foreach ( @repositorylist )
1727 if (!- d
) { push ( @repositoryfiles , substr ( $_ , rindex ( $_ , "/" )+ 1 )); }
1730 if ( @repositoryfiles )
1733 <table width='100%'>
1735 <td align='center'><b> $Lang ::tr{'urlfilter filename'}</b></td>
1736 <td width='15%' align='center'><b> $Lang ::tr{'urlfilter filesize'}</b></td>
1737 <td width='10%'></td>
1742 foreach $line ( @repositoryfiles )
1746 print "<tr bgcolor=' $Header ::table1colour'> \n " ; }
1748 print "<tr bgcolor=' $Header ::table2colour'> \n " ; }
1749 $filesize = (- s
" $repository / $line " );
1750 1 while $filesize =~ s/^(-?\d+)(\d{3})/$1.$2/ ;
1753 <td> $line </td>
1754 <td align='right'> $filesize </td>
1757 <form method='post' name='frma $id ' action=' $ENV {'SCRIPT_NAME'}'>
1758 <input type='image' name=' $Lang ::tr{'remove'}' src='/images/delete.gif' title=' $Lang ::tr{'remove'}' alt=' $Lang ::tr{'remove'}' />
1759 <input type='hidden' name='ID' value=' $line ' />
1760 <input type='hidden' name='ACTION' value=' $Lang ::tr{'urlfilter remove file'}' />
1777 <td class='boldbase'> <b> $Lang ::tr{'legend'}:</b></td>
1778 <td> <img src='/images/delete.gif' alt=' $Lang ::tr{'remove'}' /></td>
1779 <td class='base'> $Lang ::tr{'remove'}</td>
1786 print "<i> $Lang ::tr{'urlfilter empty repository'}</i> \n " ;
1789 & Header
:: closebox
();
1793 } elsif ( $tcsettings { 'TCMODE' }) {
1795 #==========================================================
1797 # Section: Set Time Constraints
1799 #==========================================================
1801 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}'> \n " ;
1803 $buttontext = $Lang :: tr
{ 'urlfilter add rule' };
1804 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) {
1805 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter edit time constraint rule' }. ':' );
1806 $buttontext = $Lang :: tr
{ 'urlfilter update rule' };
1808 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter add new time constraint rule' }. ':' );
1812 <table width='100%'>
1814 <td width='2%'> $Lang ::tr{'urlfilter constraint definition'}</td>
1815 <td width='1%'> </td>
1816 <td width='2%' align='center'> $Lang ::tr{'urlfilter monday'}</td>
1817 <td width='2%' align='center'> $Lang ::tr{'urlfilter tuesday'}</td>
1818 <td width='2%' align='center'> $Lang ::tr{'urlfilter wednesday'}</td>
1819 <td width='2%' align='center'> $Lang ::tr{'urlfilter thursday'}</td>
1820 <td width='2%' align='center'> $Lang ::tr{'urlfilter friday'}</td>
1821 <td width='2%' align='center'> $Lang ::tr{'urlfilter saturday'}</td>
1822 <td width='2%' align='center'> $Lang ::tr{'urlfilter sunday'}</td>
1823 <td width='1%'> </td>
1824 <td width='7%' colspan=3> $Lang ::tr{'urlfilter from'}</td>
1825 <td width='1%'> </td>
1826 <td width='7%' colspan=3> $Lang ::tr{'urlfilter to'}</td>
1831 <select name='DEFINITION'>
1832 <option value='within' $selected {'DEFINITION'}{'within'}> $Lang ::tr{'urlfilter constraint within'}</option>
1833 <option value='outside' $selected {'DEFINITION'}{'outside'}> $Lang ::tr{'urlfilter constraint outside'}</option>
1837 <td class='base'><input type='checkbox' name='MON' $checked {'MON'}{'on'} /></td>
1838 <td class='base'><input type='checkbox' name='TUE' $checked {'TUE'}{'on'} /></td>
1839 <td class='base'><input type='checkbox' name='WED' $checked {'WED'}{'on'} /></td>
1840 <td class='base'><input type='checkbox' name='THU' $checked {'THU'}{'on'} /></td>
1841 <td class='base'><input type='checkbox' name='FRI' $checked {'FRI'}{'on'} /></td>
1842 <td class='base'><input type='checkbox' name='SAT' $checked {'SAT'}{'on'} /></td>
1843 <td class='base'><input type='checkbox' name='SUN' $checked {'SUN'}{'on'} /></td>
1846 <select name='FROM_HOUR'>
1849 for ( $i = 0 ; $i <= 24 ; $i ++) {
1850 $_ = sprintf ( " %02s " , $i );
1851 print "<option $selected {'FROM_HOUR'}{ $_ }> $_ </option> \n " ;
1858 <select name='FROM_MINUTE'>
1861 for ( $i = 0 ; $i <= 45 ; $i += 15 ) {
1862 $_ = sprintf ( " %02s " , $i );
1863 print "<option $selected {'FROM_MINUTE'}{ $_ }> $_ </option> \n " ;
1870 <select name='TO_HOUR'>
1873 for ( $i = 0 ; $i <= 24 ; $i ++) {
1874 $_ = sprintf ( " %02s " , $i );
1875 print "<option $selected {'TO_HOUR'}{ $_ }> $_ </option> \n " ;
1882 <select name='TO_MINUTE'>
1885 for ( $i = 0 ; $i <= 45 ; $i += 15 ) {
1886 $_ = sprintf ( " %02s " , $i );
1887 print "<option $selected {'TO_MINUTE'}{ $_ }> $_ </option> \n " ;
1898 <table width='100%'>
1900 <td width='5%'> $Lang ::tr{'urlfilter source'}</td>
1901 <td width='1%'> </td>
1902 <td width='5%'> $Lang ::tr{'urlfilter dst'} <img src='/blob.gif' alt='*'><img src='/blob.gif' alt='*'></td>
1903 <td width='1%'> </td>
1904 <td width='5%'> $Lang ::tr{'urlfilter access'}</td>
1908 <td rowspan='2'><textarea name='SRC' cols='28' rows='5' wrap='off'>
1912 # transform from pre1.8 client definitions
1913 $tcsettings { 'SRC' } =~ s/^\s+//g ;
1914 $tcsettings { 'SRC' } =~ s/\s+$//g ;
1915 $tcsettings { 'SRC' } =~ s/\s+-\s+/-/g ;
1916 $tcsettings { 'SRC' } =~ s/\s+/ /g ;
1918 @clients = split ( / / , $tcsettings { 'SRC' });
1919 undef $tcsettings { 'SRC' };
1920 foreach ( @clients ) { $tcsettings { 'SRC' } .= " $_ \n " ; }
1922 print $tcsettings { 'SRC' };
1928 <td class='base' rowspan='2' valign='top'>
1929 <select name='DST' size='6' multiple>
1930 <option value='any' $selected {'DST'}{'any'} = "selected='selected'"> $Lang ::tr{'urlfilter category all'}</option>
1931 <option value='in-addr' $selected {'DST'}{'in-addr'} = "selected='selected'">in-addr</option>
1935 & readblockcategories
;
1936 foreach ( @categories )
1938 print "<option value=' $_ ' $selected {'DST'}{ $_ }> $_ </option> \n " ;
1942 <option value='files' $selected {'DST'}{'files'} = "selected='selected'">files</option>
1943 <option value='custom-blocked' $selected {'DST'}{'custom-blocked'} = "selected='selected'">custom-blocked</option>
1944 <option value='custom-expressions' $selected {'DST'}{'custom-expressions'} = "selected='selected'">custom-expressions</option>
1948 <td class='base' valign='top'>
1949 <select name='ACCESS'>
1950 <option value='block' $selected {'ACCESS'}{'block'}> $Lang ::tr{'urlfilter mode block'}</option>
1951 <option value='allow' $selected {'ACCESS'}{'allow'}> $Lang ::tr{'urlfilter mode allow'}</option>
1963 <td> $Lang ::tr{'remark'} <img src='/blob.gif' alt='*'></td>
1971 <td><input type='text' name='COMMENT' value=' $tcsettings {'COMMENT'}' size='32' /></td>
1980 <table width='100%'>
1982 <td class='base'> $Lang ::tr{'urlfilter enabled'}<input type='checkbox' name='ENABLERULE' $checked{'ENABLERULE'}{'on'} /></td>
1990 <td><input type='hidden' name='ACTION' value=' $Lang ::tr{'add'}' /></td>
1991 <td><input type='hidden' name='MODE' value='TIMECONSTRAINT' /></td>
1992 <td><input type='submit' name='SUBMIT' value=' $buttontext ' /></td>
1993 <td><input type='reset' name='ACTION' value=' $Lang ::tr{'urlfilter reset'}' /></td>
1995 <td><input type='button' name='return2main' value=' $Lang ::tr{'urlfilter back to main page'}' onClick='self.location.href=" $ENV {'SCRIPT_NAME'}"'></td>
1999 <table width='100%'>
2001 <td width='1%' align='right'> <img src='/blob.gif' align='top' alt='*' /> </td>
2002 <td><font class='base'> $Lang ::tr{'this field may be blank'}</font></td>
2005 <td width='1%' align='right'><img src='/blob.gif' align='top' alt='*' /><img src='/blob.gif' align='top' alt='*' /> </td>
2006 <td><font class='base'> $Lang ::tr{'urlfilter select multi'}</font></td>
2012 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) {
2013 print "<input type='hidden' name='EDITING' value=' $tcsettings {'ID'}' /> \n " ;
2015 print "<input type='hidden' name='EDITING' value='no' /> \n " ;
2018 & Header
:: closebox
();
2021 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'current rules' });
2023 <table width='100%'>
2025 <td width='5%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter constraint definition'}</b></td>
2026 <td width='10%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter time space'}</b></td>
2027 <td width='15%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter src'}</b></td>
2028 <td width='5%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter dst'}</b></td>
2029 <td width='10%' class='boldbase' colspan='5' align='center'> </td>
2034 if ( $tcsettings { 'ACTION' } ne '' or $changed ne 'no' )
2036 open ( FILE
, $tcfile );
2042 foreach $line ( @tclist )
2046 @temp = split ( /\,/ , $line );
2047 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' } && $tcsettings { 'ID' } eq $id ) {
2048 print "<tr bgcolor=' $Header ::colouryellow'> \n " ; }
2050 print "<tr bgcolor=' $Header ::table1colour'> \n " ; }
2052 print "<tr bgcolor=' $Header ::table2colour'> \n " ; }
2053 if ( $temp [ 0 ] eq 'within' ) { $temp [ 0 ]= $Lang :: tr
{ 'urlfilter constraint within' }; } else { $temp [ 0 ]= $Lang :: tr
{ 'urlfilter constraint outside' }; }
2054 if ( $temp [ 13 ] eq 'any' ) { $temp [ 13 ]= $Lang :: tr
{ 'urlfilter category all' }; }
2055 if ( $temp [ 15 ] eq 'on' ) { $gif = 'on.gif' ; $toggle = 'off' ; $gdesc = $Lang :: tr
{ 'click to disable' };}
2056 else { $gif = 'off.gif' ; $toggle = 'on' ; $gdesc = $Lang :: tr
{ 'click to enable' }; }
2057 if ( $temp [ 14 ] eq 'block' ) { $led = 'led-red.gif' ; $ldesc = $Lang :: tr
{ 'urlfilter block access' };}
2058 else { $led = 'led-green.gif' ; $ldesc = $Lang :: tr
{ 'urlfilter allow access' }; }
2061 if ( $temp [ 1 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter mon' }; } else { $time .= '=' ; }
2062 if ( $temp [ 2 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter tue' }; } else { $time .= '=' ; }
2063 if ( $temp [ 3 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter wed' }; } else { $time .= '=' ; }
2064 if ( $temp [ 4 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter thu' }; } else { $time .= '=' ; }
2065 if ( $temp [ 5 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter fri' }; } else { $time .= '=' ; }
2066 if ( $temp [ 6 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter sat' }; } else { $time .= '=' ; }
2067 if ( $temp [ 7 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter sun' }; } else { $time .= '=' ; }
2068 $time = $time . ' ' . $temp [ 8 ]. ':' . $temp [ 9 ]. ' to ' . $temp [ 10 ]. ':' . $temp [ 11 ];
2071 <td align='center'> $temp [0]</td>
2072 <td align='center' nowrap> $time </td>
2073 <td align='center'> $temp [12]</td>
2074 <td align='center'> $temp [13]</td>
2075 <td align='center'><image src='/images/urlfilter/ $led ' alt=' $ldesc '></td>
2078 <form method='post' name='frma $id ' action=' $ENV {'SCRIPT_NAME'}'>
2079 <input type='image' name=' $Lang ::tr{'toggle enable disable'}' src='/images/ $gif ' title=' $gdesc ' alt=' $gdesc ' />
2080 <input type='hidden' name='MODE' value='TIMECONSTRAINT' />
2081 <input type='hidden' name='ID' value=' $id ' />
2082 <input type='hidden' name='ACTIVE' value=' $toggle ' />
2083 <input type='hidden' name='ACTION' value=' $Lang ::tr{'toggle enable disable'}' />
2088 <form method='post' name='frmb $id ' action=' $ENV {'SCRIPT_NAME'}'>
2089 <input type='image' name=' $Lang ::tr{'edit'}' src='/images/edit.gif' title=' $Lang ::tr{'edit'}' alt=' $Lang ::tr{'edit'}' />
2090 <input type='hidden' name='MODE' value='TIMECONSTRAINT' />
2091 <input type='hidden' name='ID' value=' $id ' />
2092 <input type='hidden' name='ACTION' value=' $Lang ::tr{'edit'}' />
2097 <form method='post' name='frmc $id ' action=' $ENV {'SCRIPT_NAME'}'>
2098 <input type='image' name=' $Lang ::tr{'urlfilter copy rule'}' src='/images/urlfilter/copy.gif' title=' $Lang ::tr{'urlfilter copy rule'}' alt=' $Lang ::tr{'urlfilter copy rule'}' />
2099 <input type='hidden' name='MODE' value='TIMECONSTRAINT' />
2100 <input type='hidden' name='ID' value=' $id ' />
2101 <input type='hidden' name='ACTION' value=' $Lang ::tr{'urlfilter copy rule'}' />
2106 <form method='post' name='frmd $id ' action=' $ENV {'SCRIPT_NAME'}'>
2107 <input type='image' name=' $Lang ::tr{'remove'}' src='/images/delete.gif' title=' $Lang ::tr{'remove'}' alt=' $Lang ::tr{'remove'}' />
2108 <input type='hidden' name='MODE' value='TIMECONSTRAINT' />
2109 <input type='hidden' name='ID' value=' $id ' />
2110 <input type='hidden' name='ACTION' value=' $Lang ::tr{'remove'}' />
2117 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' } && $tcsettings { 'ID' } eq $id ) {
2118 print "<tr bgcolor=' $Header ::colouryellow'> \n " ; }
2120 print "<tr bgcolor=' $Header ::table1colour'> \n " ; }
2122 print "<tr bgcolor=' $Header ::table2colour'> \n " ; }
2124 <td align='center' colspan='4'> $temp [16]
2126 <td align='center' colspan='5'>
2135 # If the time constraint file contains entries, print entries and action icons
2136 if (! - z
" $tcfile " ) {
2141 <td class='boldbase'> <b> $Lang ::tr{'legend'}:</b></td>
2142 <td> <img src='/images/urlfilter/led-green.gif' alt=' $Lang ::tr{'urlfilter allow access'}' /></td>
2143 <td class='base'> $Lang ::tr{'urlfilter allow'}</td>
2144 <td> <img src='/images/urlfilter/led-red.gif' alt=' $Lang ::tr{'urlfilter block access'}' /></td>
2145 <td class='base'> $Lang ::tr{'urlfilter block'}</td>
2146 <td> <img src='/images/on.gif' alt=' $Lang ::tr{'click to disable'}' /></td>
2147 <td class='base'> $Lang ::tr{'click to disable'}</td>
2148 <td> <img src='/images/off.gif' alt=' $Lang ::tr{'click to enable'}' /></td>
2149 <td class='base'> $Lang ::tr{'click to enable'}</td>
2150 <td> <img src='/images/edit.gif' alt=' $Lang ::tr{'edit'}' /></td>
2151 <td class='base'> $Lang ::tr{'edit'}</td>
2152 <td> <img src='/images/urlfilter/copy.gif' alt=' $Lang ::tr{'urlfilter copy rule'}' /></td>
2153 <td class='base'> $Lang ::tr{'urlfilter copy rule'}</td>
2154 <td> <img src='/images/delete.gif' alt=' $Lang ::tr{'remove'}' /></td>
2155 <td class='base'> $Lang ::tr{'remove'}</td>
2162 & Header
:: closebox
();
2164 } elsif ( $uqsettings { 'UQMODE' }) {
2166 #==========================================================
2168 # Section: Set User Quota
2170 #==========================================================
2172 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}'> \n " ;
2174 $buttontext = $Lang :: tr
{ 'urlfilter add rule' };
2175 if ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) {
2176 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter edit user quota rule' }. ':' );
2177 $buttontext = $Lang :: tr
{ 'urlfilter update rule' };
2179 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter add new user quota rule' }. ':' );
2183 <table width='100%'>
2185 <td width='25%'></td> <td width='20%'> </td><td width='25%'> </td><td width='30%'></td>
2188 <td class='base'> $Lang ::tr{'urlfilter user time quota'}:</td>
2189 <td><input type='text' name='TIME_QUOTA' value=' $uqsettings {'TIME_QUOTA'}' size='5' /></td>
2190 <td colspan='2' rowspan= '5' valign='top' class='base'>
2191 <table cellpadding='0' cellspacing='0'>
2193 <!-- intentionally left empty -->
2196 <td> $Lang ::tr{'urlfilter assigned quota users'}:</td>
2199 <!-- intentionally left empty -->
2202 <!-- intentionally left empty -->
2205 <td><textarea name='QUOTA_USERS' cols='32' rows='6' wrap='off'>
2209 $uqsettings { 'QUOTA_USERS' } =~ s/\|/\n/g ;
2210 print $uqsettings { 'QUOTA_USERS' };
2219 <td class='base'> $Lang ::tr{'urlfilter activity detection'}:</td>
2220 <td class='base'><select name='SPORADIC'>
2221 <option value='0' $selected {'SPORADIC'}{'0'}> $Lang ::tr{'urlfilter disabled'}</option>
2222 <option value='300' $selected {'SPORADIC'}{'300'}>5 $Lang ::tr{'urlfilter minutes'}</option>
2223 <option value='900' $selected {'SPORADIC'}{'900'}>15 $Lang ::tr{'urlfilter minutes'}</option>
2227 <td class='base'> $Lang ::tr{'urlfilter renewal period'}:</td>
2228 <td class='base'><select name='RENEWAL'>
2229 <option value='hourly' $selected {'RENEWAL'}{'hourly'}> $Lang ::tr{'urlfilter hourly'}</option>
2230 <option value='daily' $selected {'RENEWAL'}{'daily'}> $Lang ::tr{'urlfilter daily'}</option>
2231 <option value='weekly' $selected {'RENEWAL'}{'weekly'}> $Lang ::tr{'urlfilter weekly'}</option>
2235 <td colspan='2'> </td>
2238 <td class='base'> $Lang ::tr{'urlfilter enabled'}</td>
2239 <td class='base'><input type='checkbox' name='ENABLEQUOTA' $checked {'ENABLEQUOTA'}{'on'} /></td>
2247 <td><input type='hidden' name='ACTION' value=' $Lang ::tr{'add'}' /></td>
2248 <td><input type='hidden' name='MODE' value='USERQUOTA' /></td>
2249 <td><input type='submit' name='SUBMIT' value=' $buttontext ' /></td>
2250 <td><input type='reset' name='ACTION' value=' $Lang ::tr{'urlfilter reset'}' /></td>
2252 <td><input type='button' name='return2main' value=' $Lang ::tr{'urlfilter back to main page'}' onClick='self.location.href=" $ENV {'SCRIPT_NAME'}"'></td>
2260 if ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) {
2261 print "<input type='hidden' name='EDITING' value=' $uqsettings {'ID'}' /> \n " ;
2263 print "<input type='hidden' name='EDITING' value='no' /> \n " ;
2266 & Header
:: closebox
();
2269 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'current rules' });
2271 <table width='100%'>
2273 <td width='15%' class='boldbase' align='center'><b><nobr> $Lang ::tr{'urlfilter time quota'}</nobr></b></td>
2274 <td width='15%' class='boldbase' align='center'><b><nobr> $Lang ::tr{'urlfilter activity detection'}</nobr></b></td>
2275 <td width='10%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter renewal'}</b></td>
2276 <td class='boldbase' align='center'><b> $Lang ::tr{'urlfilter assigned users'}</b></td>
2277 <td width='20%' class='boldbase' colspan='4' align='center'> </td>
2282 if ( $uqsettings { 'ACTION' } ne '' or $changed ne 'no' )
2284 open ( FILE
, $uqfile );
2290 foreach $line ( @uqlist )
2294 @temp = split ( /\,/ , $line );
2295 if ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' } && $uqsettings { 'ID' } eq $id ) {
2296 print "<tr bgcolor=' $Header ::colouryellow'> \n " ; }
2298 print "<tr bgcolor=' $Header ::table1colour'> \n " ; }
2300 print "<tr bgcolor=' $Header ::table2colour'> \n " ; }
2301 if ( $temp [ 4 ] eq 'on' ) { $gif = 'on.gif' ; $toggle = 'off' ; $gdesc = $Lang :: tr
{ 'click to disable' };}
2302 else { $gif = 'off.gif' ; $toggle = 'on' ; $gdesc = $Lang :: tr
{ 'click to enable' }; }
2304 $temp [ 5 ] = $temp [ 1 ];
2305 if ( $temp [ 1 ] eq '0' ) { $temp [ 5 ] = $Lang :: tr
{ 'urlfilter disabled' } } else { $temp [ 5 ] = ( $temp [ 5 ]/ 60 ). ' ' . $Lang :: tr
{ 'urlfilter minutes' } }
2306 $_ = $temp [ 3 ]; s/\|/, /g ; $temp [ 6 ] = $_ ;
2309 <td align='center'> $temp [0] $Lang ::tr{'urlfilter minutes'}</td>
2310 <td align='center'> $temp [5]</td>
2311 <td align='center'> $Lang ::tr{'urlfilter '. $temp [2]}</td>
2312 <td align='center'> $temp [6]</td>
2315 <form method='post' name='frma $id ' action=' $ENV {'SCRIPT_NAME'}'>
2316 <input type='image' name=' $Lang ::tr{'toggle enable disable'}' src='/images/ $gif ' title=' $gdesc ' alt=' $gdesc ' />
2317 <input type='hidden' name='MODE' value='USERQUOTA' />
2318 <input type='hidden' name='ID' value=' $id ' />
2319 <input type='hidden' name='ACTIVE' value=' $toggle ' />
2320 <input type='hidden' name='ACTION' value=' $Lang ::tr{'toggle enable disable'}' />
2325 <form method='post' name='frmb $id ' action=' $ENV {'SCRIPT_NAME'}'>
2326 <input type='image' name=' $Lang ::tr{'edit'}' src='/images/edit.gif' title=' $Lang ::tr{'edit'}' alt=' $Lang ::tr{'edit'}' />
2327 <input type='hidden' name='MODE' value='USERQUOTA' />
2328 <input type='hidden' name='ID' value=' $id ' />
2329 <input type='hidden' name='ACTION' value=' $Lang ::tr{'edit'}' />
2334 <form method='post' name='frmc $id ' action=' $ENV {'SCRIPT_NAME'}'>
2335 <input type='image' name=' $Lang ::tr{'remove'}' src='/images/delete.gif' title=' $Lang ::tr{'remove'}' alt=' $Lang ::tr{'remove'}' />
2336 <input type='hidden' name='MODE' value='USERQUOTA' />
2337 <input type='hidden' name='ID' value=' $id ' />
2338 <input type='hidden' name='ACTION' value=' $Lang ::tr{'remove'}' />
2349 # If the user quota file contains entries, print entries and action icons
2350 if (! - z
" $uqfile " ) {
2355 <td class='boldbase'> <b> $Lang ::tr{'legend'}:</b></td>
2356 <td> <img src='/images/on.gif' alt=' $Lang ::tr{'click to disable'}' /></td>
2357 <td class='base'> $Lang ::tr{'click to disable'}</td>
2358 <td> <img src='/images/off.gif' alt=' $Lang ::tr{'click to enable'}' /></td>
2359 <td class='base'> $Lang ::tr{'click to enable'}</td>
2360 <td> <img src='/images/edit.gif' alt=' $Lang ::tr{'edit'}' /></td>
2361 <td class='base'> $Lang ::tr{'edit'}</td>
2362 <td> <img src='/images/delete.gif' alt=' $Lang ::tr{'remove'}' /></td>
2363 <td class='base'> $Lang ::tr{'remove'}</td>
2370 & Header
:: closebox
();
2374 #==========================================================
2376 # Section: Blacklist editor
2378 #==========================================================
2380 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}' enctype='multipart/form-data'> \n " ;
2382 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter urlfilter blacklist editor' }. ':' );
2386 <table width='100%'>
2388 <td width='25%'></td> <td width='20%'> </td><td width='25%'> </td><td width='30%'></td>
2391 <td class='base'><b> $Lang ::tr{'urlfilter blacklist name'}</b></td>
2394 <td class='base'> $Lang ::tr{'urlfilter blacklist category name'}:</td>
2395 <td><input type='text' name='BE_NAME' value=' $besettings {'BE_NAME'}' size='12' /></td>
2399 <table width='100%'>
2401 <td width='25%'></td> <td width='20%'> </td><td width='25%'> </td><td width='20%'></td>
2404 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter edit domains urls expressions'}</b></td>
2407 <td colspan='2'> $Lang ::tr{'urlfilter domains'}</td>
2408 <td colspan='2'> $Lang ::tr{'urlfilter urls'}</td>
2411 <td colspan='2'><textarea name='BE_DOMAINS' cols='38' rows='10' wrap='off'>
2415 print $besettings { 'BE_DOMAINS' };
2419 <td colspan='2'><textarea name='BE_URLS' cols='38' rows='10' wrap='off'>
2423 print $besettings { 'BE_URLS' };
2429 <td colspan='4'> $Lang ::tr{'urlfilter expressions'}</td>
2432 <td colspan='4'><textarea name='BE_EXPRESSIONS' cols='80' rows='3' wrap='off'>
2436 print $besettings { 'BE_EXPRESSIONS' };
2443 <table width='100%'>
2445 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter load blacklist'}</b></td>
2448 <td width='25%' class='base'> $Lang ::tr{'urlfilter select blacklist'}:</td>
2449 <td width='20%' class='base'>
2450 <select name='BE_BLACKLIST'>
2454 & readblockcategories
;
2455 foreach ( @categories )
2457 print "<option value=' $_ ' $selected {'BE_BLACKLIST'}{ $_ }> $_ </option> \n " ;
2466 <td colpsan='4'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter load blacklist'}' /></td>
2471 <table width='100%'>
2473 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter import blacklist'}</b></td>
2476 <td colspan='4'> $Lang ::tr{'urlfilter import text'}:</td>
2479 <td nowrap><input type='file' name='IMPORTFILE' size='40' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter import blacklist'}' /></td>
2480 <td><input type='hidden' name='MODE' value='BLACKLIST_EDITOR' /></td>
2484 <table width='100%'>
2486 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter export blacklist'}</b></td>
2489 <td><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter export blacklist'}' /></td>
2493 <table width='100%'>
2495 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter install blacklist'}</b></td>
2498 <td width='25%' class='base'> $Lang ::tr{'urlfilter dont restart urlfilter'}:</td>
2499 <td width='20%' class='base'><input type='checkbox' name='NORESTART' $checked {'NORESTART'}{'on'} /></td>
2504 <td><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter install blacklist'}' /></td>
2507 <td class='base' colspan='4'><br> $Lang ::tr{'urlfilter install information'}</td>
2513 <td><input type='reset' name='ACTION' value=' $Lang ::tr{'urlfilter reset'}' /></td>
2515 <td><input type='button' name='return2main' value=' $Lang ::tr{'urlfilter back to main page'}' onClick='self.location.href=" $ENV {'SCRIPT_NAME'}"'></td>
2522 & Header
:: closebox
();
2527 & Header
:: closebigbox
();
2529 & Header
:: closepage
();
2531 # -------------------------------------------------------------------
2535 # transform to pre1.8 client definitions
2536 @clients = split ( /\n/ , $filtersettings { 'UNFILTERED_CLIENTS' });
2537 undef $filtersettings { 'UNFILTERED_CLIENTS' };
2540 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
2541 $filtersettings { 'UNFILTERED_CLIENTS' } .= " $_ " ;
2543 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/\s+$// ;
2545 # transform to pre1.8 client definitions
2546 @clients = split ( /\n/ , $filtersettings { 'BANNED_CLIENTS' });
2547 undef $filtersettings { 'BANNED_CLIENTS' };
2550 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
2551 $filtersettings { 'BANNED_CLIENTS' } .= " $_ " ;
2553 $filtersettings { 'BANNED_CLIENTS' } =~ s/\s+$// ;
2557 delete $filtersettings { 'CUSTOM_BLACK_DOMAINS' };
2558 delete $filtersettings { 'CUSTOM_BLACK_URLS' };
2559 delete $filtersettings { 'CUSTOM_WHITE_DOMAINS' };
2560 delete $filtersettings { 'CUSTOM_WHITE_URLS' };
2561 delete $filtersettings { 'CUSTOM_EXPRESSIONS' };
2562 delete $filtersettings { 'BACKGROUND' };
2563 delete $filtersettings { 'UPDATEFILE' };
2565 & General
:: writehash
( "${General::swroot}/urlfilter/settings" , \
%filtersettings );
2568 # -------------------------------------------------------------------
2570 sub readblockcategories
2574 & getblockcategory
( $dbdir );
2576 foreach ( @categories ) { $_ = substr ( $_ , length ( $dbdir )+ 1 ); }
2578 @filtergroups = @categories ;
2580 foreach ( @filtergroups ) {
2587 # -------------------------------------------------------------------
2589 sub getblockcategory
2591 foreach $category (< $_ [ 0 ]/*>)
2595 if ((- e
" $category /domains" ) || (- e
" $category /urls" ))
2597 unless ( $category =~ /\bcustom\b/ ) { push ( @categories , $category ); }
2599 & getblockcategory
( $category );
2604 # -------------------------------------------------------------------
2608 if (- e
" $dbdir /custom/blocked/domains" ) {
2609 open ( FILE
, " $dbdir /custom/blocked/domains" );
2610 delete $filtersettings { 'CUSTOM_BLACK_DOMAINS' };
2611 while (< FILE
>) { $filtersettings { 'CUSTOM_BLACK_DOMAINS' } .= $_ };
2615 if (- e
" $dbdir /custom/blocked/urls" ) {
2616 open ( FILE
, " $dbdir /custom/blocked/urls" );
2617 delete $filtersettings { 'CUSTOM_BLACK_URLS' };
2618 while (< FILE
>) { $filtersettings { 'CUSTOM_BLACK_URLS' } .= $_ };
2622 if (- e
" $dbdir /custom/blocked/expressions" ) {
2623 open ( FILE
, " $dbdir /custom/blocked/expressions" );
2624 delete $filtersettings { 'CUSTOM_EXPRESSIONS' };
2625 while (< FILE
>) { $filtersettings { 'CUSTOM_EXPRESSIONS' } .= $_ };
2629 if (- e
" $dbdir /custom/allowed/domains" ) {
2630 open ( FILE
, " $dbdir /custom/allowed/domains" );
2631 delete $filtersettings { 'CUSTOM_WHITE_DOMAINS' };
2632 while (< FILE
>) { $filtersettings { 'CUSTOM_WHITE_DOMAINS' } .= $_ };
2635 if (- e
" $dbdir /custom/allowed/urls" ) {
2636 open ( FILE
, " $dbdir /custom/allowed/urls" );
2637 delete $filtersettings { 'CUSTOM_WHITE_URLS' };
2638 while (< FILE
>) { $filtersettings { 'CUSTOM_WHITE_URLS' } .= $_ };
2643 # -------------------------------------------------------------------
2645 sub aggregatedconstraints
2665 @tmp1 = split ( /\,/ , $x );
2669 @tmp2 = split ( /\,/ );
2670 if (( $tmp1 [ 15 ] eq 'on' ) && ( $tmp2 [ 15 ] eq 'on' ))
2672 if (( $tmp1 [ 0 ] eq $tmp2 [ 0 ]) && ( $tmp1 [ 12 ] eq $tmp2 [ 12 ]) && ( $tmp1 [ 13 ] eq $tmp2 [ 13 ]) && ( $tmp1 [ 14 ] eq $tmp2 [ 14 ]))
2675 $tmp2 [ 16 ] .= " weekly " ;
2676 if ( $tmp1 [ 1 ] eq 'on' ) { $tmp2 [ 16 ] .= "m" ; }
2677 if ( $tmp1 [ 2 ] eq 'on' ) { $tmp2 [ 16 ] .= "t" ; }
2678 if ( $tmp1 [ 3 ] eq 'on' ) { $tmp2 [ 16 ] .= "w" ; }
2679 if ( $tmp1 [ 4 ] eq 'on' ) { $tmp2 [ 16 ] .= "h" ; }
2680 if ( $tmp1 [ 5 ] eq 'on' ) { $tmp2 [ 16 ] .= "f" ; }
2681 if ( $tmp1 [ 6 ] eq 'on' ) { $tmp2 [ 16 ] .= "a" ; }
2682 if ( $tmp1 [ 7 ] eq 'on' ) { $tmp2 [ 16 ] .= "s" ; }
2683 $tmp2 [ 16 ] .= " $tmp1 [8]: $tmp1 [9]- $tmp1 [10]: $tmp1 [11] \n " ;
2684 $_ = join ( "," , @tmp2 );
2691 $tmp1 [ 16 ] .= " weekly " ;
2692 if ( $tmp1 [ 1 ] eq 'on' ) { $tmp1 [ 16 ] .= "m" ; }
2693 if ( $tmp1 [ 2 ] eq 'on' ) { $tmp1 [ 16 ] .= "t" ; }
2694 if ( $tmp1 [ 3 ] eq 'on' ) { $tmp1 [ 16 ] .= "w" ; }
2695 if ( $tmp1 [ 4 ] eq 'on' ) { $tmp1 [ 16 ] .= "h" ; }
2696 if ( $tmp1 [ 5 ] eq 'on' ) { $tmp1 [ 16 ] .= "f" ; }
2697 if ( $tmp1 [ 6 ] eq 'on' ) { $tmp1 [ 16 ] .= "a" ; }
2698 if ( $tmp1 [ 7 ] eq 'on' ) { $tmp1 [ 16 ] .= "s" ; }
2699 $tmp1 [ 16 ] .= " $tmp1 [8]: $tmp1 [9]- $tmp1 [10]: $tmp1 [11] \n " ;
2700 $x = join ( "," , @tmp1 );
2710 # -------------------------------------------------------------------
2716 foreach $category (< $bldir /*>)
2719 system ( "chmod 755 $category &> /dev/null" );
2720 foreach $blacklist (< $category /*>)
2722 if (- f
$blacklist ) { system ( "chmod 644 $blacklist &> /dev/null" ); }
2723 if (- d
$blacklist ) { system ( "chmod 755 $blacklist &> /dev/null" ); }
2725 system ( "chmod 666 $category /*.db &> /dev/null" );
2726 & setpermissions
( $category );
2731 # -------------------------------------------------------------------
2735 my $executables = " \\ .\(ade|adp|asx|bas|bat|chm|com|cmd|cpl|crt|dll|eml|exe|hiv|hlp|hta|inc|inf|ins|isp|jse|jtd|lnk|msc|msh|msi|msp|mst|nws|ocx|oft|ops|pcd|pif|plx|reg|scr|sct|sha|shb|shm|shs|sys|tlb|tsp|url|vbe|vbs|vxd|wsc|wsf|wsh\)\$" ;
2736 my $audiovideo = " \\ .\(aiff|asf|avi|dif|divx|mov|movie|mp3|mpe?g?|mpv2|ogg|ra?m|snd|qt|wav|wma|wmf|wmv\)\$" ;
2737 my $archives = " \\ .\(bin|bz2|cab|cdr|dmg|gz|hqx|rar|smi|sit|sea|tar|tgz|zip\)\$" ;
2739 my $ident = " anonymous" ;
2752 if (!(- d
" $dbdir /custom" )) { mkdir ( " $dbdir /custom" ) }
2753 if (!(- d
" $dbdir /custom/blocked" )) { mkdir ( " $dbdir /custom/blocked" ) }
2754 if (!(- d
" $dbdir /custom/allowed" )) { mkdir ( " $dbdir /custom/allowed" ) }
2756 open ( FILE
, ">/ $dbdir /custom/blocked/domains" );
2757 print FILE
$filtersettings { 'CUSTOM_BLACK_DOMAINS' };
2759 open ( FILE
, ">/ $dbdir /custom/blocked/urls" );
2760 print FILE
$filtersettings { 'CUSTOM_BLACK_URLS' };
2762 open ( FILE
, ">/ $dbdir /custom/blocked/expressions" );
2763 print FILE
$filtersettings { 'CUSTOM_EXPRESSIONS' };
2765 open ( FILE
, ">/ $dbdir /custom/blocked/files" );
2766 if ( $filtersettings { 'BLOCK_EXECUTABLES' } eq 'on' ) { print FILE
" $executables \n " ; }
2767 if ( $filtersettings { 'BLOCK_AUDIO-VIDEO' } eq 'on' ) { print FILE
" $audiovideo \n " ; }
2768 if ( $filtersettings { 'BLOCK_ARCHIVES' } eq 'on' ) { print FILE
" $archives \n " ; }
2770 open ( FILE
, ">/ $dbdir /custom/allowed/domains" );
2771 print FILE
$filtersettings { 'CUSTOM_WHITE_DOMAINS' };
2773 open ( FILE
, ">/ $dbdir /custom/allowed/urls" );
2774 print FILE
$filtersettings { 'CUSTOM_WHITE_URLS' };
2777 if ( $filtersettings { 'ENABLE_USERNAME_LOG' } eq 'on' ) { $ident = "" ; }
2779 if ( $filtersettings { 'REDIRECT_PAGE' } eq '' )
2781 if (( $filtersettings { 'SHOW_CATEGORY' } eq 'on' ) || ( $filtersettings { 'SHOW_URL' } eq 'on' ) || ( $filtersettings { 'SHOW_IP' } eq 'on' )) {
2782 if ( $filtersettings { 'SHOW_CATEGORY' } eq 'on' ) { $redirect .= "&category= %t " ; }
2783 if ( $filtersettings { 'SHOW_URL' } eq 'on' ) { $redirect .= "&url= %u " ; }
2784 if ( $filtersettings { 'SHOW_IP' } eq 'on' ) { $redirect .= "&ip= %a " ; }
2785 $redirect =~ s/^&/?/ ;
2786 $redirect = "http:\/\/ $netsettings {'GREEN_ADDRESS'}: $http_port \/redirect.cgi" . $redirect ;
2788 $redirect = "http:\/\/ $netsettings {'GREEN_ADDRESS'}: $http_port \/redirect.cgi" ;
2790 } else { $redirect = $filtersettings { 'REDIRECT_PAGE' }; }
2792 if ( $filtersettings { 'ENABLE_DNSERROR' } eq 'on' ) { $redirect = "302:http://0.0.0.0" ; }
2796 if ( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' )
2798 $defaultrule .= "custom-allowed " ;
2800 if ( $filtersettings { 'BLOCK_ALL' } eq 'on' )
2802 $defaultrule .= "none" ;
2806 if ( $filtersettings { 'BLOCK_IP_ADDR' } eq 'on' )
2808 $defaultrule .= "!in-addr " ;
2810 for ( $i = 0 ; $i <= @filtergroups ; $i ++) {
2811 if ( $filtersettings { @filtergroups [ $i ]} eq 'on' )
2813 $defaultrule .= "! @categories [ $i ] " ;
2816 if ( $filtersettings { 'ENABLE_CUSTOM_BLACKLIST' } eq 'on' )
2818 $defaultrule .= "!custom-blocked " ;
2820 if ( $filtersettings { 'ENABLE_CUSTOM_EXPRESSIONS' } eq 'on' )
2822 $defaultrule .= "!custom-expressions " ;
2824 if (( $filtersettings { 'BLOCK_EXECUTABLES' } eq 'on' ) ||
2825 ( $filtersettings { 'BLOCK_AUDIO-VIDEO' } eq 'on' ) ||
2826 ( $filtersettings { 'BLOCK_ARCHIVES' } eq 'on' ))
2828 $defaultrule .= "!files " ;
2830 $defaultrule .= "any" ;
2833 $defaultrule =~ s/\// _
/ g
;
2835 open ( FILE
, ">${General::swroot}/urlfilter/squidGuard.conf" ) or die "Unable to write squidGuard.conf file" ;
2838 print FILE
"logdir /var/log/squidGuard \n " ;
2839 print FILE
"dbhome $dbdir \n\n " ;
2841 undef @repositoryfiles ;
2842 if ( $filtersettings { 'ENABLE_REWRITE' } eq 'on' )
2844 @repositorylist = < $repository /*>;
2845 foreach ( @repositorylist )
2847 if (!- d
) { push ( @repositoryfiles , substr ( $_ , rindex ( $_ , "/" )+ 1 )); }
2851 if ((( $filtersettings { 'ENABLE_REWRITE' } eq 'on' ) && ( @repositoryfiles )) || ( $filtersettings { 'ENABLE_SAFESEARCH' } eq 'on' ))
2853 print FILE
"rewrite rew-rule-1 { \n " ;
2855 if (( $filtersettings { 'ENABLE_REWRITE' } eq 'on' ) && ( @repositoryfiles ))
2857 print FILE
" # rewrite localfiles \n " ;
2858 foreach ( @repositoryfiles )
2860 print FILE
" s@.*/ $_ \$\ @http :// $netsettings {'GREEN_ADDRESS'}: $http_port /repository/ $_ \ @i \n " ;
2864 if ( $filtersettings { 'ENABLE_SAFESEARCH' } eq 'on' )
2866 print FILE
" # rewrite safesearch \n " ;
2867 print FILE
" s@(.* \\ Wgoogle \\ . \\ w+/(webhp|search|imghp|images|grphp|groups|frghp|froogle) \\ ?)(.*)( \\ bsafe= \\ w+)(.*)\@ \\ 1 \\ 3safe=strict \\ 5\ @i \n " ;
2868 print FILE
" s@(.* \\ Wgoogle \\ . \\ w+/(webhp|search|imghp|images|grphp|groups|frghp|froogle) \\ ?)(.*)\@ \\ 1safe=strict \\ \& \\ 3\ @i \n " ;
2869 print FILE
" s@(.* \\ Wsearch \\ .yahoo \\ . \\ w+/search \\ W)(.*)( \\ bvm= \\ w+)(.*)\@ \\ 1 \\ 2vm=r \\ 4\ @i \n " ;
2870 print FILE
" s@(.* \\ Wsearch \\ .yahoo \\ . \\ w+/search \\ W.*)\@ \\ 1 \\ \&vm=r\ @i \n " ;
2871 print FILE
" s@(.* \\ Walltheweb \\ .com/customize \\ ?)(.*)( \\ bcopt_offensive= \\ w+)(.*)\@ \\ 1 \\ 2copt_offensive=on \\ 4\ @i \n " ;
2876 if ((!( $filtersettings { 'UNFILTERED_CLIENTS' } eq '' )) && ( $filtersettings { 'ENABLE_SAFESEARCH' } eq 'on' )) {
2877 print FILE
"rewrite rew-rule-2 { \n " ;
2878 if (( $filtersettings { 'ENABLE_REWRITE' } eq 'on' ) && ( @repositoryfiles ))
2880 print FILE
" # rewrite localfiles \n " ;
2881 foreach ( @repositoryfiles )
2883 print FILE
" s@.*/ $_ \$\ @http :// $netsettings {'GREEN_ADDRESS'}: $http_port /repository/ $_ \ @i \n " ;
2886 print FILE
" # rewrite nothing \n " ;
2892 if (!( $filtersettings { 'UNFILTERED_CLIENTS' } eq '' )) {
2893 print FILE
"src unfiltered { \n " ;
2894 print FILE
" ip $filtersettings {'UNFILTERED_CLIENTS'} \n " ;
2897 if (!( $filtersettings { 'BANNED_CLIENTS' } eq '' )) {
2898 print FILE
"src banned { \n " ;
2899 print FILE
" ip $filtersettings {'BANNED_CLIENTS'} \n " ;
2900 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
2902 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
2904 print FILE
" logfile " . $ident . " banned.log \n " ;
2906 print FILE
" logfile " . $ident . " urlfilter.log \n " ;
2928 $uq [ 0 ] = $uq [ 0 ] * 60 ;
2929 if ( $uq [ 1 ] eq '0' ) {
2930 if ( $uq [ 2 ] eq 'hourly' ) { $uq [ 1 ] = 3600 }
2931 if ( $uq [ 2 ] eq 'daily' ) { $uq [ 1 ] = 86400 }
2932 if ( $uq [ 2 ] eq 'weekly' ) { $uq [ 1 ] = 604800 }
2935 print FILE
"src quota- $idx { \n " ;
2936 print FILE
" user $uq [3] \n " ;
2937 print FILE
" userquota $uq [0] $uq [1] $uq [2] \n " ;
2945 @tclist = & aggregatedconstraints
;
2954 if ( $tc [ 15 ] eq 'on' )
2957 print FILE
"src network- $idx { \n " ;
2958 @clients = split ( / / , $tc [ 12 ]);
2959 @temp = split ( /-/ , $clients [ 0 ]);
2960 if ( (& General
:: validipormask
( $temp [ 0 ])) || (& General
:: validipandmask
( $temp [ 0 ])))
2962 print FILE
" ip $tc [12] \n " ;
2965 @clients = split ( / / , $tc [ 12 ]);
2966 foreach $line ( @clients )
2968 $line =~ s/(^\w+)\\(\w+$)/$1%5c$2/ ;
2969 print FILE
" $line " ;
2973 if (( $filtersettings { 'ENABLE_LOG' } eq 'on' ) && ( $tc [ 14 ] eq 'block' ) && ( $tc [ 13 ] eq 'any' ))
2975 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
2977 print FILE
" logfile " . $ident . " timeconst.log \n " ;
2979 print FILE
" logfile " . $ident . " urlfilter.log \n " ;
2991 if ( $tc [ 15 ] eq 'on' )
2994 print FILE
"time constraint- $idx { \n " ;
2995 print FILE
" $tc [16] \n " ;
3001 foreach $category ( @categories ) {
3002 $blacklist = $category ;
3003 $category =~ s/\// _
/ g
;
3004 print FILE
"dest $category { \n " ;
3005 if (- e
" $dbdir / $blacklist /domains" ) {
3006 print FILE
" domainlist $blacklist \/domains \n " ;
3008 if (- e
" $dbdir / $blacklist /urls" ) {
3009 print FILE
" urllist $blacklist \/urls \n " ;
3011 if ((- e
" $dbdir / $blacklist /expressions" ) && ( $filtersettings { 'ENABLE_EXPR_LISTS' } eq 'on' )) {
3012 print FILE
" expressionlist $blacklist \/expressions \n " ;
3014 if ((( $category eq 'ads' ) || ( $category eq 'adv' )) && ( $filtersettings { 'ENABLE_EMPTY_ADS' } eq 'on' ))
3016 print FILE
" redirect http:\/\/ $netsettings {'GREEN_ADDRESS'}: $http_port \/images/urlfilter/1x1.gif \n " ;
3018 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
3020 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3022 print FILE
" logfile $ident $category .log \n " ;
3024 print FILE
" logfile $ident urlfilter.log \n " ;
3028 $category = $blacklist ;
3031 print FILE
"dest files { \n " ;
3032 print FILE
" expressionlist custom\/blocked\/files \n " ;
3033 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
3035 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3037 print FILE
" logfile $ident files.log \n " ;
3039 print FILE
" logfile $ident urlfilter.log \n " ;
3044 print FILE
"dest custom-allowed { \n " ;
3045 print FILE
" domainlist custom\/allowed\/domains \n " ;
3046 print FILE
" urllist custom\/allowed\/urls \n " ;
3049 print FILE
"dest custom-blocked { \n " ;
3050 print FILE
" domainlist custom\/blocked\/domains \n " ;
3051 print FILE
" urllist custom\/blocked\/urls \n " ;
3052 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
3054 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3056 print FILE
" logfile $ident custom.log \n " ;
3058 print FILE
" logfile $ident urlfilter.log \n " ;
3063 print FILE
"dest custom-expressions { \n " ;
3064 print FILE
" expressionlist custom\/blocked\/expressions \n " ;
3065 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
3067 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3069 print FILE
" logfile $ident custom.log \n " ;
3071 print FILE
" logfile $ident urlfilter.log \n " ;
3076 print FILE
"acl { \n " ;
3077 if (!( $filtersettings { 'UNFILTERED_CLIENTS' } eq '' )) {
3078 print FILE
" unfiltered { \n " ;
3079 print FILE
" pass all \n " ;
3080 if ( $filtersettings { 'ENABLE_SAFESEARCH' } eq 'on' )
3082 print FILE
" rewrite rew-rule-2 \n " ;
3084 print FILE
" } \n\n " ;
3086 if (!( $filtersettings { 'BANNED_CLIENTS' } eq '' )) {
3087 print FILE
" banned { \n " ;
3088 print FILE
" pass " ;
3089 if (( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' ) && ( $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } eq 'on' ))
3091 print FILE
"custom-allowed " ;
3093 print FILE
"none \n " ;
3094 print FILE
" } \n\n " ;
3111 $qredirect = $redirect ;
3112 $qredirect =~ s/\%t/\%q\%20-\%20\%i/ ;
3113 print FILE
" quota- $idx { \n " ;
3114 print FILE
" pass " ;
3115 if (( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' ) && ( $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } eq 'on' ))
3117 print FILE
"custom-allowed " ;
3119 print FILE
"none \n " ;
3120 unless ( $redirect eq $qredirect ) { print FILE
" redirect $qredirect \n " ; }
3121 print FILE
" } \n\n " ;
3133 @ec = split ( /\|/ , $tc [ 13 ]);
3134 foreach ( @ec ) { s/\// _
/ g
; }
3135 if ( $tc [ 15 ] eq 'on' )
3138 print FILE
" network- $idx $tc [0] constraint- $idx { \n " ;
3139 print FILE
" pass " ;
3141 if ( $filtersettings { 'BLOCK_ALL' } eq 'on' )
3143 if ( $tc [ 14 ] eq 'block' )
3145 if (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' )) {
3146 if (( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' ) && ( $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } eq 'on' ))
3148 print FILE
"custom-allowed " ;
3152 print FILE
$defaultrule ;
3159 print FILE
$defaultrule unless (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' ));
3162 if ( $tc [ 14 ] eq 'block' )
3164 $tcrule = $defaultrule ;
3165 if ( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' ) {
3166 $tcrule =~ s/custom-allowed // ;
3167 print FILE
"custom-allowed " unless (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' ) && ( $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } eq 'off' ));
3169 if (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' )) {
3174 print FILE
"! $_ " unless ( index ( $defaultrule , "!" . $_ . " " ) ge 0 );
3177 print FILE
$tcrule unless (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' ));
3179 $tcrule = $defaultrule ;
3180 if (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' ))
3186 $tcrule = " $_ " . $tcrule unless ( index ( $defaultrule , "!" . $_ . " " ) ge 0 );
3187 $tcrule =~ s/!$_ // ;
3196 print FILE
" } \n\n " ;
3201 print FILE
" default { \n " ;
3202 print FILE
" pass $defaultrule \n " ;
3203 if (( $filtersettings { 'ENABLE_LOG' } eq 'on' ) && ( $filtersettings { 'BLOCK_ALL' } eq 'on' ))
3205 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3207 print FILE
" logfile" . $ident . " default.log \n " ;
3209 print FILE
" logfile" . $ident . " urlfilter.log \n " ;
3212 if ((( $filtersettings { 'ENABLE_REWRITE' } eq 'on' ) && ( @repositoryfiles )) || ( $filtersettings { 'ENABLE_SAFESEARCH' } eq 'on' ))
3214 print FILE
" rewrite rew-rule-1 \n " ;
3216 print FILE
" redirect $redirect \n " ;
3223 # -------------------------------------------------------------------