]>
git.ipfire.org Git - ipfire-2.x.git/blob - html/cgi-bin/urlfilter.cgi
3a28721a92248cdd42d9b2ce78b1ec12dca7fde6
2 ###############################################################################
4 # IPFire.org - A linux based firewall #
5 # Copyright (C) 2005-2010 IPFire Team #
7 # This program is free software: you can redistribute it and/or modify #
8 # it under the terms of the GNU General Public License as published by #
9 # the Free Software Foundation, either version 3 of the License, or #
10 # (at your option) any later version. #
12 # This program is distributed in the hope that it will be useful, #
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
15 # GNU General Public License for more details. #
17 # You should have received a copy of the GNU General Public License #
18 # along with this program. If not, see <http://www.gnu.org/licenses/>. #
20 ###############################################################################
24 # enable only the following on debugging purpose
26 #use CGI::Carp 'fatalsToBrowser';
31 require '/var/ipfire/general-functions.pl' ;
32 require "${General::swroot}/lang.pl" ;
33 require "${General::swroot}/header.pl" ;
39 my %filtersettings =();
43 my %updatesettings =();
58 my $tcfile = "${General::swroot}/urlfilter/timeconst" ;
59 my $uqfile = "${General::swroot}/urlfilter/userquota" ;
60 my $dbdir = "${General::swroot}/urlfilter/blacklists" ;
61 my $editdir = "${General::swroot}/urlfilter/editor" ;
62 my $templatedir = "/srv/web/ipfire/html/redirect-templates" ;
63 my $repository = "/var/urlrepo" ;
64 my $hintcolour = '#FFFFCC' ;
66 my $sourceurlfile = "${General::swroot}/urlfilter/autoupdate/autoupdate.urls" ;
67 my $updconffile = "${General::swroot}/urlfilter/autoupdate/autoupdate.conf" ;
68 my $updflagfile = "${General::swroot}/urlfilter/blacklists/.autoupdate.last" ;
72 my $restoremessage = '' ;
78 my @repositorylist =();
79 my @repositoryfiles =();
81 my @selectedcategories =();
85 my @source_urllist =();
97 if (! - d
$dbdir ) { mkdir ( " $dbdir " ); }
98 if (! - e
$tcfile ) { & General
:: system ( "touch" , " $tcfile " ); }
99 if (! - e
$uqfile ) { & General
:: system ( "touch" , " $uqfile " ); }
100 if (! - e
$sourceurlfile ) { & General
:: system ( "touch" , " $sourceurlfile " ); }
102 & General
:: readhash
( "${General::swroot}/ethernet/settings" , \
%netsettings );
103 & General
:: readhash
( "${General::swroot}/main/settings" , \
%mainsettings );
104 & General
:: readhash
( "${General::swroot}/proxy/settings" , \
%proxysettings );
106 & readblockcategories
;
114 open ( FILE
, $sourceurlfile );
115 @source_urllist = < FILE
>;
118 $filtersettings { 'ENABLE_CUSTOM_BLACKLIST' } = 'off' ;
119 $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } = 'off' ;
120 $filtersettings { 'ENABLE_CUSTOM_EXPRESSIONS' } = 'off' ;
121 $filtersettings { 'BLOCK_EXECUTABLES' } = 'off' ;
122 $filtersettings { 'BLOCK_AUDIO-VIDEO' } = 'off' ;
123 $filtersettings { 'BLOCK_ARCHIVES' } = 'off' ;
124 $filtersettings { 'ENABLE_REWRITE' } = 'off' ;
125 $filtersettings { 'UNFILTERED_CLIENTS' } = '' ;
126 $filtersettings { 'BANNED_CLIENTS' } = '' ;
127 $filtersettings { 'SHOW_CATEGORY' } = 'off' ;
128 $filtersettings { 'SHOW_URL' } = 'off' ;
129 $filtersettings { 'SHOW_IP' } = 'off' ;
130 $filtersettings { 'ENABLE_DNSERROR' } = 'off' ;
131 $filtersettings { 'ENABLE_JPEG' } = 'off' ;
132 $filtersettings { 'REDIRECT_PAGE' } = '' ;
133 $filtersettings { 'MSG_TEXT_1' } = '' ;
134 $filtersettings { 'MSG_TEXT_2' } = '' ;
135 $filtersettings { 'MSG_TEXT_3' } = '' ;
136 $filtersettings { 'ENABLE_EXPR_LISTS' } = 'off' ;
137 $filtersettings { 'BLOCK_IP_ADDR' } = 'off' ;
138 $filtersettings { 'BLOCK_ALL' } = 'off' ;
139 $filtersettings { 'ENABLE_EMPTY_ADS' } = 'off' ;
140 $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } = 'off' ;
141 $filtersettings { 'ENABLE_LOG' } = 'off' ;
142 $filtersettings { 'ENABLE_USERNAME_LOG' } = 'off' ;
143 $filtersettings { 'ENABLE_CATEGORY_LOG' } = 'off' ;
144 $filtersettings { 'ENABLE_AUTOUPDATE' } = 'off' ;
145 $filtersettings { 'REDIRECT_TEMPLATE' } = 'legacy' ;
147 $filtersettings { 'ACTION' } = '' ;
148 $filtersettings { 'VALID' } = '' ;
150 & Header
:: getcgihash
( \
%filtersettings );
151 & Header
:: getcgihash
( \
%tcsettings );
152 & Header
:: getcgihash
( \
%uqsettings );
153 & Header
:: getcgihash
( \
%besettings );
155 if (( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'save' }) ||
156 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter save and restart' }) ||
157 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload file' }) ||
158 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter remove file' }) ||
159 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload blacklist' }) ||
160 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter backup' }) ||
161 ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter restore' }))
164 @clients = split ( /\n/ , $filtersettings { 'UNFILTERED_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 @clients = split ( /\n/ , $filtersettings { 'BANNED_CLIENTS' });
175 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
176 if ( /.*-.*-.*/ ) { $errormessage = $Lang :: tr
{ 'urlfilter invalid ip or mask error' }; }
178 foreach ( @temp ) { unless ((& General
:: validipormask
( $_ )) || (& General
:: validipandmask
( $_ ))) { $errormessage = $Lang :: tr
{ 'urlfilter invalid ip or mask error' }; } }
180 if ( $errormessage ) { goto ERROR
; }
182 if ((!( $filtersettings { 'REDIRECT_PAGE' } eq '' )) && (!( $filtersettings { 'REDIRECT_PAGE' } =~ /^https?:\/ \
// )))
184 $filtersettings { 'REDIRECT_PAGE' } = "http://" . $filtersettings { 'REDIRECT_PAGE' };
187 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter remove file' })
189 if (- e
" $repository / $filtersettings {'ID'}" ) { unlink ( " $repository / $filtersettings {'ID'}" ); }
190 $filtersettings { 'ACTION' } = $Lang :: tr
{ 'urlfilter manage repository' };
193 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload file' })
195 & Header
:: getcgihash
( \
%filtersettings , { 'wantfile' => 1 , 'filevar' => 'UPLOADFILE' });
197 $filtersettings { 'ACTION' } = $Lang :: tr
{ 'urlfilter manage repository' };
198 $_ = $filtersettings { 'UPLOADFILE' };
200 $_ = substr ( $_ , rindex ( $_ , "/" )+ 1 );
202 if ( copy
( $filtersettings { 'UPLOADFILE' }, " $repository / $_ " ) != 1 )
211 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter upload blacklist' })
213 & Header
:: getcgihash
( \
%filtersettings , { 'wantfile' => 1 , 'filevar' => 'UPDATEFILE' });
215 if (!( $filtersettings { 'UPDATEFILE' } =~ /.tar.gz$/ ))
217 $errormessage = $Lang :: tr
{ 'urlfilter wrong filetype' };
221 if ( copy
( $filtersettings { 'UPDATEFILE' }, "${General::swroot}/urlfilter/blacklists.tar.gz" ) != 1 )
227 if (!(- d
"${General::swroot}/urlfilter/update" )) { mkdir ( "${General::swroot}/urlfilter/update" ); }
229 my $exitcode = & General
:: system ( "/bin/tar" , "--no-same-owner" , "-xzf" , "${General::swroot}/urlfilter/blacklists.tar.gz" , "-C" , "${General::swroot}/urlfilter/update" );
233 $errormessage = $Lang :: tr
{ 'urlfilter tar error' };
236 if (- d
"${General::swroot}/urlfilter/update/BL" )
238 & General
:: system ( "mv" , "${General::swroot}/urlfilter/update/BL" , "${General::swroot}/urlfilter/update/blacklists" );
241 if (- d
"${General::swroot}/urlfilter/update/category" )
243 & General
:: system ( "mv" , "${General::swroot}/urlfilter/update/category" , "${General::swroot}/urlfilter/update/blacklists" );
246 if (!(- d
"${General::swroot}/urlfilter/update/blacklists" ))
248 $errormessage = $Lang :: tr
{ 'urlfilter invalid content' };
251 system ( "cp -r ${General::swroot}/urlfilter/update/blacklists/* $dbdir " );
253 & readblockcategories
;
258 $updatemessage = $Lang :: tr
{ 'urlfilter upload success' };
259 & General
:: system_background
( "${General::swroot}/urlfilter/bin/prebuild.pl" );
260 & General
:: system ( "logger" , "-t" , "installpackage[urlfilter]" , "URL filter blacklist - Blacklist update from local source completed" );
263 if (- d
"${General::swroot}/urlfilter/update" ) { & General
:: system ( "rm" , "-rf" , "${General::swroot}/urlfilter/update" ); }
264 if (- e
"${General::swroot}/urlfilter/blacklists.tar.gz" ) { unlink ( "${General::swroot}/urlfilter/blacklists.tar.gz" ); }
265 if ( $errormessage ) { goto ERROR
; }
268 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter backup' })
270 $blistbackup = ( $filtersettings { 'ENABLE_FULLBACKUP' } eq 'on' ) ?
"blacklists" : "blacklists/custom" ;
271 if (& General
:: system ( "/bin/tar" , "-C" , "${General::swroot}/urlfilter" , "-czf" , "${General::swroot}/urlfilter/backup.tar.gz" , "settings" , "timeconst" , "userquota" , "autoupdate" , " $blistbackup " ))
273 $errormessage = $Lang :: tr
{ 'urlfilter backup error' };
278 print "Content-type: application/gzip \n " ;
279 print "Content-length: " ;
280 print (- s
"${General::swroot}/urlfilter/backup.tar.gz" );
282 print "Content-disposition: attachment; filename=urlfilter-backup.tar.gz \n\n " ;
284 open ( FILE
, "${General::swroot}/urlfilter/backup.tar.gz" );
285 while (< FILE
>) { print ; }
288 if (- e
"${General::swroot}/urlfilter/backup.tar.gz" ) { unlink ( "${General::swroot}/urlfilter/backup.tar.gz" ); }
293 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter restore' })
295 & Header
:: getcgihash
( \
%filtersettings , { 'wantfile' => 1 , 'filevar' => 'UPDATEFILE' });
297 if (!( $filtersettings { 'UPDATEFILE' } =~ /.tar.gz$/ ))
299 $errormessage = $Lang :: tr
{ 'urlfilter wrong filetype' };
303 if (!(- d
"${General::swroot}/urlfilter/restore" )) { mkdir ( "${General::swroot}/urlfilter/restore" ); }
305 if ( copy
( $filtersettings { 'UPDATEFILE' }, "${General::swroot}/urlfilter/backup.tar.gz" ) != 1 )
310 my $exitcode = & General
:: system ( "/bin/tar" , "--no-same-owner" , "--preserve-permissions" , "-xzf" , "${General::swroot}/urlfilter/backup.tar.gz" , "-C" , "${General::swroot}/urlfilter/restore" );
313 $errormessage = $Lang :: tr
{ 'urlfilter tar error' };
315 if (!(- e
"${General::swroot}/urlfilter/restore/settings" ))
317 $errormessage = $Lang :: tr
{ 'urlfilter invalid restore file' };
320 system ( "cp -rp ${General::swroot}/urlfilter/restore/* ${General::swroot}/urlfilter/" );
321 & readblockcategories
;
325 $restoremessage = $Lang :: tr
{ 'urlfilter restore success' };
329 if (- e
"${General::swroot}/urlfilter/backup.tar.gz" ) { unlink ( "${General::swroot}/urlfilter/backup.tar.gz" ); }
330 if (- d
"${General::swroot}/urlfilter/restore" ) { & General
:: system ( "rm" , "-rf" , "${General::swroot}/urlfilter/restore" ); }
331 if ( $errormessage ) { goto ERROR
; }
334 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'save' })
336 $filtersettings { 'VALID' } = 'yes' ;
340 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter save and restart' })
342 if ((!(- e
"${General::swroot}/proxy/enable" )) && (!(- e
"${General::swroot}/proxy/enable_blue" )))
344 $errormessage = $Lang :: tr
{ 'urlfilter web proxy service required' };
347 if (!( $proxysettings { 'ENABLE_FILTER' } eq 'on' ))
349 $errormessage = $Lang :: tr
{ 'urlfilter not enabled' };
353 $filtersettings { 'VALID' } = 'yes' ;
356 & General
:: system ( '/usr/local/bin/squidctrl' , 'restart' );
360 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter set time constraints' }) { $tcsettings { 'TCMODE' } = 'on' }
362 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'add' }))
364 $tcsettings { 'TCMODE' }= 'on' ;
366 if (! $tcsettings { 'DST' })
368 $errormessage = $Lang :: tr
{ 'urlfilter dst error' };
371 if (! $tcsettings { 'SRC' })
373 $errormessage = $Lang :: tr
{ 'urlfilter src error' };
376 if (!( $tcsettings { 'TO_HOUR' }. $tcsettings { 'TO_MINUTE' } gt $tcsettings { 'FROM_HOUR' }. $tcsettings { 'FROM_MINUTE' }))
378 $errormessage = $Lang :: tr
{ 'urlfilter timespace error' };
381 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' )))
383 $errormessage = $Lang :: tr
{ 'urlfilter weekday error' };
388 # transform to pre1.8 client definitions
389 @clients = split ( /\n/ , $tcsettings { 'SRC' });
390 undef $tcsettings { 'SRC' };
393 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
394 $tcsettings { 'SRC' } .= " $_ " ;
396 $tcsettings { 'SRC' } =~ s/\s+$// ;
398 if ( $tcsettings { 'DST' } =~ /^any/ ) { $tcsettings { 'DST' } = 'any' ; }
399 if ( $tcsettings { 'ENABLERULE' } eq 'on' ) { $tcsettings { 'ACTIVE' } = $tcsettings { 'ENABLERULE' }; } else { $tcsettings { 'ACTIVE' } = 'off' }
401 $tcsettings { 'ENABLERULE' } = 'on' ;
402 if ( $tcsettings { 'EDITING' } eq 'no' ) {
403 open ( FILE
, ">> $tcfile " );
405 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 " ;
407 open ( FILE
, "> $tcfile " );
410 foreach $line ( @tclist )
413 if ( $tcsettings { 'EDITING' } eq $id ) {
414 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 " ;
415 } else { print FILE
" $line " ; }
420 $tcsettings { 'CHANGED' }= 'yes' ;
421 $tcsettings { 'TCMODE' }= 'on' ;
424 if ( $tcsettings { 'EDITING' } ne 'no' )
426 $tcsettings { 'ACTION' } = $Lang :: tr
{ 'edit' };
427 $tcsettings { 'ID' } = $tcsettings { 'EDITING' };
432 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter copy rule' }) && (! $errormessage ))
435 foreach $line ( @tclist )
438 if ( $tcsettings { 'ID' } eq $id )
441 @temp = split ( /\,/ , $line );
442 $tcsettings { 'DEFINITION' } = $temp [ 0 ];
443 $tcsettings { 'MON' } = $temp [ 1 ];
444 $tcsettings { 'TUE' } = $temp [ 2 ];
445 $tcsettings { 'WED' } = $temp [ 3 ];
446 $tcsettings { 'THU' } = $temp [ 4 ];
447 $tcsettings { 'FRI' } = $temp [ 5 ];
448 $tcsettings { 'SAT' } = $temp [ 6 ];
449 $tcsettings { 'SUN' } = $temp [ 7 ];
450 $tcsettings { 'FROM_HOUR' } = $temp [ 8 ];
451 $tcsettings { 'FROM_MINUTE' } = $temp [ 9 ];
452 $tcsettings { 'TO_HOUR' } = $temp [ 10 ];
453 $tcsettings { 'TO_MINUTE' } = $temp [ 11 ];
454 $tcsettings { 'SRC' } = $temp [ 12 ];
455 $tcsettings { 'DST' } = $temp [ 13 ];
456 $tcsettings { 'ACCESS' } = $temp [ 14 ];
457 $tcsettings { 'ENABLERULE' } = $temp [ 15 ];
458 $tcsettings { 'COMMENT' } = $temp [ 16 ];
461 $tcsettings { 'TCMODE' }= 'on' ;
464 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'remove' }))
467 open ( FILE
, "> $tcfile " );
469 foreach $line ( @tclist )
472 unless ( $tcsettings { 'ID' } eq $id ) { print FILE
" $line " ; }
475 $tcsettings { 'CHANGED' }= 'yes' ;
476 $tcsettings { 'TCMODE' }= 'on' ;
479 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter restart' }))
481 if (!( $proxysettings { 'ENABLE_FILTER' } eq 'on' ))
483 $errormessage = $Lang :: tr
{ 'urlfilter not enabled' };
485 if ((!(- e
"${General::swroot}/proxy/enable" )) && (!(- e
"${General::swroot}/proxy/enable_blue" )))
487 $errormessage = $Lang :: tr
{ 'urlfilter web proxy service required' };
490 if (! $errormessage ) { & General
:: system ( '/usr/local/bin/squidctrl' , 'restart' ); }
491 $tcsettings { 'TCMODE' }= 'on' ;
494 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'toggle enable disable' }))
496 open ( FILE
, "> $tcfile " );
499 foreach $line ( @tclist )
502 unless ( $tcsettings { 'ID' } eq $id ) { print FILE
" $line " ; }
506 @temp = split ( /\,/ , $line );
507 if ( $temp [ 15 ] eq 'on' ) { $temp [ 15 ] = 'off' ; } else { $temp [ 15 ] = 'on' }
508 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 " ;
512 $tcsettings { 'CHANGED' }= 'yes' ;
513 $tcsettings { 'TCMODE' }= 'on' ;
516 if (( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) && ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) && (! $errormessage ))
519 foreach $line ( @tclist )
522 if ( $tcsettings { 'ID' } eq $id )
525 @temp = split ( /\,/ , $line );
526 $tcsettings { 'DEFINITION' } = $temp [ 0 ];
527 $tcsettings { 'MON' } = $temp [ 1 ];
528 $tcsettings { 'TUE' } = $temp [ 2 ];
529 $tcsettings { 'WED' } = $temp [ 3 ];
530 $tcsettings { 'THU' } = $temp [ 4 ];
531 $tcsettings { 'FRI' } = $temp [ 5 ];
532 $tcsettings { 'SAT' } = $temp [ 6 ];
533 $tcsettings { 'SUN' } = $temp [ 7 ];
534 $tcsettings { 'FROM_HOUR' } = $temp [ 8 ];
535 $tcsettings { 'FROM_MINUTE' } = $temp [ 9 ];
536 $tcsettings { 'TO_HOUR' } = $temp [ 10 ];
537 $tcsettings { 'TO_MINUTE' } = $temp [ 11 ];
538 $tcsettings { 'SRC' } = $temp [ 12 ];
539 $tcsettings { 'DST' } = $temp [ 13 ];
540 $tcsettings { 'ACCESS' } = $temp [ 14 ];
541 $tcsettings { 'ENABLERULE' } = $temp [ 15 ];
542 $tcsettings { 'COMMENT' } = $temp [ 16 ];
545 $tcsettings { 'TCMODE' }= 'on' ;
548 if ((! $errormessage ) && (!( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter copy rule' })) && (!( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }))) {
549 $tcsettings { 'ENABLERULE' }= 'on' ;
550 $tcsettings { 'TO_HOUR' }= '24' ;
553 if ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter set user quota' }) { $uqsettings { 'UQMODE' } = 'on' }
555 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'add' }))
557 $uqsettings { 'UQMODE' }= 'on' ;
559 if ((!( $uqsettings { 'TIME_QUOTA' } =~ /^\d+/ )) || ( $uqsettings { 'TIME_QUOTA' } < '1' ))
561 $errormessage = $Lang :: tr
{ 'urlfilter quota time error' };
564 @temp = split ( /\n/ , $uqsettings { 'QUOTA_USERS' });
565 undef $uqsettings { 'QUOTA_USERS' };
568 s/^\s+//g ; s/\s+$//g ;
569 if ( $_ ) { $uqsettings { 'QUOTA_USERS' } .= $_ . " \n " ; }
572 if ( $uqsettings { 'QUOTA_USERS' } eq '' )
574 $errormessage = $Lang :: tr
{ 'urlfilter quota user error' };
577 $_ = $uqsettings { 'QUOTA_USERS' };
579 my $quota_users = $_ ;
581 if ( $uqsettings { 'QUOTA_USERS' } =~ /\\/ )
583 $errormessage = $Lang :: tr
{ 'urlfilter invalid user error' };
586 if (! $errormessage ) {
587 if ( $uqsettings { 'ENABLEQUOTA' } eq 'on' ) { $uqsettings { 'ACTIVE' } = $uqsettings { 'ENABLEQUOTA' }; } else { $uqsettings { 'ACTIVE' } = 'off' }
589 $uqsettings { 'ENABLERULE' } = 'on' ;
590 if ( $uqsettings { 'EDITING' } eq 'no' ) {
591 open ( FILE
, ">> $uqfile " );
593 print FILE
" $uqsettings {'TIME_QUOTA'}, $uqsettings {'SPORADIC'}, $uqsettings {'RENEWAL'}, $quota_users , $uqsettings {'ACTIVE'} \n " ;
595 open ( FILE
, "> $uqfile " );
598 foreach $line ( @uqlist )
601 if ( $uqsettings { 'EDITING' } eq $id ) {
602 print FILE
" $uqsettings {'TIME_QUOTA'}, $uqsettings {'SPORADIC'}, $uqsettings {'RENEWAL'}, $quota_users , $uqsettings {'ACTIVE'} \n " ;
603 } else { print FILE
" $line " ; }
608 $uqsettings { 'CHANGED' }= 'yes' ;
609 $uqsettings { 'MODE' }= 'USERQUOTA' ;
610 $uqsettings { 'UQMODE' }= 'on' ;
613 if ( $uqsettings { 'EDITING' } ne 'no' )
615 $uqsettings { 'ACTION' } = $Lang :: tr
{ 'edit' };
616 $uqsettings { 'ID' } = $uqsettings { 'EDITING' };
621 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'remove' }))
624 open ( FILE
, "> $uqfile " );
626 foreach $line ( @uqlist )
629 unless ( $uqsettings { 'ID' } eq $id ) { print FILE
" $line " ; }
632 $uqsettings { 'CHANGED' }= 'yes' ;
633 $uqsettings { 'UQMODE' }= 'on' ;
636 if (! $errormessage ) {
637 $uqsettings { 'ENABLEQUOTA' }= 'on' ;
640 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) && (! $errormessage ))
643 foreach $line ( @uqlist )
646 if ( $uqsettings { 'ID' } eq $id )
649 @temp = split ( /\,/ , $line );
650 $uqsettings { 'TIME_QUOTA' } = $temp [ 0 ];
651 $uqsettings { 'SPORADIC' } = $temp [ 1 ];
652 $uqsettings { 'RENEWAL' } = $temp [ 2 ];
653 $uqsettings { 'QUOTA_USERS' } = $temp [ 3 ];
654 $uqsettings { 'ENABLEQUOTA' } = $temp [ 4 ];
657 $uqsettings { 'UQMODE' }= 'on' ;
660 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'toggle enable disable' }))
662 open ( FILE
, "> $uqfile " );
665 foreach $line ( @uqlist )
668 unless ( $uqsettings { 'ID' } eq $id ) { print FILE
" $line " ; }
672 @temp = split ( /\,/ , $line );
673 if ( $temp [ 4 ] eq 'on' ) { $temp [ 4 ] = 'off' ; } else { $temp [ 4 ] = 'on' }
674 print FILE
" $temp [0], $temp [1], $temp [2], $temp [3], $temp [4] \n " ;
678 $uqsettings { 'CHANGED' }= 'yes' ;
679 $uqsettings { 'UQMODE' }= 'on' ;
682 if (( $uqsettings { 'MODE' } eq 'USERQUOTA' ) && ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter restart' }))
684 if (!( $proxysettings { 'ENABLE_FILTER' } eq 'on' ))
686 $errormessage = $Lang :: tr
{ 'urlfilter not enabled' };
688 if ((!(- e
"${General::swroot}/proxy/enable" )) && (!(- e
"${General::swroot}/proxy/enable_blue" )))
690 $errormessage = $Lang :: tr
{ 'urlfilter web proxy service required' };
693 if (! $errormessage ) { & General
:: system ( '/usr/local/bin/squidctrl' , 'restart' ); }
694 $uqsettings { 'UQMODE' }= 'on' ;
697 if ( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter blacklist editor' }) { $besettings { 'BEMODE' } = 'on' ; }
699 if ( $besettings { 'MODE' } eq 'BLACKLIST_EDITOR' )
701 @temp = split ( /\n/ , $besettings { 'BE_DOMAINS' });
702 undef $besettings { 'BE_DOMAINS' };
705 s/^\s+//g ; s/\s+$//g ;
706 if ( $_ ) { $besettings { 'BE_DOMAINS' } .= $_ . " \n " ; }
708 chomp ( $besettings { 'BE_DOMAINS' });
709 @temp = split ( /\n/ , $besettings { 'BE_URLS' });
710 undef $besettings { 'BE_URLS' };
713 s/^\s+//g ; s/\s+$//g ;
714 if ( $_ ) { $besettings { 'BE_URLS' } .= $_ . " \n " ; }
716 chomp ( $besettings { 'BE_URLS' });
717 @temp = split ( /\n/ , $besettings { 'BE_EXPRESSIONS' });
718 undef $besettings { 'BE_EXPRESSIONS' };
721 s/^\s+//g ; s/\s+$//g ;
722 if ( $_ ) { $besettings { 'BE_EXPRESSIONS' } .= $_ . " \n " ; }
724 chomp ( $besettings { 'BE_EXPRESSIONS' });
727 if (( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter load blacklist' }) && ( $besettings { 'MODE' } = 'BLACKLIST_EDITOR' ))
729 $besettings { 'BEMODE' } = 'on' ;
731 $besettings { 'BE_NAME' } = $besettings { 'BE_BLACKLIST' };
733 delete $besettings { 'BE_DOMAINS' };
734 delete $besettings { 'BE_URLS' };
735 delete $besettings { 'BE_EXPRESSIONS' };
737 if (- e
" $dbdir / $besettings {'BE_NAME'}/domains" )
739 open ( FILE
, " $dbdir / $besettings {'BE_NAME'}/domains" );
740 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_DOMAINS' } .= $_ } };
742 chomp ( $besettings { 'BE_DOMAINS' });
744 if (- e
" $dbdir / $besettings {'BE_NAME'}/urls" )
746 open ( FILE
, " $dbdir / $besettings {'BE_NAME'}/urls" );
747 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_URLS' } .= $_ } };
749 chomp ( $besettings { 'BE_URLS' });
751 if (- e
" $dbdir / $besettings {'BE_NAME'}/expressions" )
753 open ( FILE
, " $dbdir / $besettings {'BE_NAME'}/expressions" );
754 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_EXPRESSIONS' } .= $_ } };
756 chomp ( $besettings { 'BE_EXPRESSIONS' });
760 if (( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter import blacklist' }) && ( $besettings { 'MODE' } = 'BLACKLIST_EDITOR' ))
762 $besettings { 'BEMODE' } = 'on' ;
764 & Header
:: getcgihash
( \
%besettings , { 'wantfile' => 1 , 'filevar' => 'IMPORTFILE' });
766 if (!( $besettings { 'IMPORTFILE' } =~ /.tar.gz$/ ))
768 $errormessage = $Lang :: tr
{ 'urlfilter wrong filetype' };
770 if (!- d
" $editdir " ) { mkdir ( " $editdir " ); }
772 if ( copy
( $besettings { 'IMPORTFILE' }, " $editdir /blacklist.tar.gz" ) != 1 )
777 my $exitcode = & General
:: system ( "/bin/tar" , "--no-same-owner" , "--preserve-permissions" , "-xzf" , " $editdir /blacklist.tar.gz" , "-C" , " $editdir " );
780 $errormessage = $Lang :: tr
{ 'urlfilter tar error' };
783 foreach (< $editdir /blacklists/ *>)
788 $besettings { 'BE_NAME' } = substr ( $_ , rindex ( $_ , "/" )+ 1 );
794 $errormessage = $Lang :: tr
{ 'urlfilter invalid import file' };
796 delete $besettings { 'BE_DOMAINS' };
797 delete $besettings { 'BE_URLS' };
798 delete $besettings { 'BE_EXPRESSIONS' };
800 if (- e
" $editdir /blacklists/ $besettings {'BE_NAME'}/domains" )
802 open ( FILE
, " $editdir /blacklists/ $besettings {'BE_NAME'}/domains" );
803 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_DOMAINS' } .= $_ } };
805 chomp ( $besettings { 'BE_DOMAINS' });
807 if (- e
" $editdir /blacklists/ $besettings {'BE_NAME'}/urls" )
809 open ( FILE
, " $editdir /blacklists/ $besettings {'BE_NAME'}/urls" );
810 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_URLS' } .= $_ } };
812 chomp ( $besettings { 'BE_URLS' });
814 if (- e
" $editdir /blacklists/ $besettings {'BE_NAME'}/expressions" )
816 open ( FILE
, " $editdir /blacklists/ $besettings {'BE_NAME'}/expressions" );
817 while (< FILE
>) { unless ( $_ eq ' \n ' ) { $besettings { 'BE_EXPRESSIONS' } .= $_ } };
819 chomp ( $besettings { 'BE_EXPRESSIONS' });
824 if (- d
$editdir ) { & General
:: system ( "rm" , "-rf" , " $editdir " ); }
830 if (( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter export blacklist' }) && ( $besettings { 'MODE' } = 'BLACKLIST_EDITOR' ))
832 $besettings { 'BEMODE' } = 'on' ;
834 if ( $besettings { 'BE_NAME' } eq '' )
836 $errormessage = $Lang :: tr
{ 'urlfilter category name error' };
837 } elsif ( $besettings { 'BE_DOMAINS' } || $besettings { 'BE_URLS' } || $besettings { 'BE_EXPRESSIONS' }) {
839 $_ = $besettings { 'BE_NAME' }; tr/A-Z/a-z/ ; $besettings { 'BE_NAME' } = $_ ;
841 if (!(- d
" $editdir " )) { mkdir ( " $editdir " ); }
842 if (!(- d
" $editdir /blacklists" )) { mkdir ( " $editdir /blacklists" ); }
843 if (!(- d
" $editdir /blacklists/ $besettings {'BE_NAME'}" )) { mkdir ( " $editdir /blacklists/ $besettings {'BE_NAME'}" ); }
845 open ( FILE
, "> $editdir /blacklists/ $besettings {'BE_NAME'}/domains" );
847 print FILE
" $besettings {'BE_DOMAINS'} \n " ;
849 open ( FILE
, "> $editdir /blacklists/ $besettings {'BE_NAME'}/urls" );
851 print FILE
" $besettings {'BE_URLS'} \n " ;
853 open ( FILE
, "> $editdir /blacklists/ $besettings {'BE_NAME'}/expressions" );
855 print FILE
" $besettings {'BE_EXPRESSIONS'} \n " ;
858 if (& General
:: system ( "/bin/tar" , "-C" , " $editdir " , "-czf" , " $editdir / $besettings {'BE_NAME'}.tar.gz" , "blacklists" ))
860 $errormessage = $Lang :: tr
{ 'urlfilter export error' };
864 print "Content-type: application/gzip \n " ;
865 print "Content-length: " ;
866 print (- s
" $editdir / $besettings {'BE_NAME'}.tar.gz" );
868 print "Content-disposition: attachment; filename= $besettings {'BE_NAME'}.tar.gz \n\n " ;
870 open ( FILE
, " $editdir / $besettings {'BE_NAME'}.tar.gz" );
871 while (< FILE
>) { print ; }
874 if (- d
$editdir ) { & General
:: system ( "rm" , "-rf" , " $editdir " ); }
878 $errormessage = $Lang :: tr
{ 'urlfilter category data error' };
882 if (( $besettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter install blacklist' }) && ( $besettings { 'MODE' } = 'BLACKLIST_EDITOR' ))
884 $besettings { 'BEMODE' } = 'on' ;
886 if ( $besettings { 'BE_NAME' } eq '' )
888 $errormessage = $Lang :: tr
{ 'urlfilter category name error' };
889 } elsif ( $besettings { 'BE_DOMAINS' } || $besettings { 'BE_URLS' } || $besettings { 'BE_EXPRESSIONS' }) {
891 $_ = $besettings { 'BE_NAME' }; tr/A-Z/a-z/ ; $besettings { 'BE_NAME' } = $_ ;
893 if (!- d
" $editdir " ) { mkdir ( " $editdir " ); }
895 if (!- d
" $dbdir / $besettings {'BE_NAME'}" ) { mkdir ( " $dbdir / $besettings {'BE_NAME'}" ); }
897 if (- e
" $dbdir / $besettings {'BE_NAME'}/domains" ) { unlink ( " $dbdir / $besettings {'BE_NAME'}/domains" ); }
898 if ( $besettings { 'BE_DOMAINS' })
900 open ( FILE
, "> $dbdir / $besettings {'BE_NAME'}/domains" );
902 print FILE
" $besettings {'BE_DOMAINS'} \n " ;
905 if (- e
" $dbdir / $besettings {'BE_NAME'}/urls" ) { unlink ( " $dbdir / $besettings {'BE_NAME'}/urls" ); }
906 if ( $besettings { 'BE_URLS' })
908 open ( FILE
, "> $dbdir / $besettings {'BE_NAME'}/urls" );
910 print FILE
" $besettings {'BE_URLS'} \n " ;
913 if (- e
" $dbdir / $besettings {'BE_NAME'}/expressions" ) { unlink ( " $dbdir / $besettings {'BE_NAME'}/expressions" ); }
914 if ( $besettings { 'BE_EXPRESSIONS' })
916 open ( FILE
, "> $dbdir / $besettings {'BE_NAME'}/expressions" );
918 print FILE
" $besettings {'BE_EXPRESSIONS'} \n " ;
922 open ( FILE
, "> $editdir /install.conf" );
924 print FILE
"logdir /var/log/squidGuard \n " ;
925 print FILE
"dbhome $dbdir / $besettings {'BE_NAME'} \n\n " ;
926 print FILE
"dest $besettings {'BE_NAME'} { \n " ;
927 if ( $besettings { 'BE_DOMAINS' }) { print FILE
" domainlist domains \n " ; }
928 if ( $besettings { 'BE_URLS' }) { print FILE
" urllist urls \n " ; }
929 if ( $besettings { 'BE_EXPRESSIONS' }) { print FILE
" expressions expressions \n " ; }
931 print FILE
"acl { \n " ;
932 print FILE
" default { \n " ;
933 print FILE
" pass none \n " ;
939 system ( "rm -f $dbdir / $besettings {'BE_NAME'}/*.db" );
940 & General
:: system ( "/usr/bin/squidGuard" , "-c" , " $editdir /install.conf" , "-C" , "all" );
942 system ( "chmod a+w $dbdir / $besettings {'BE_NAME'}/*.db" );
944 & readblockcategories
;
949 & General
:: system ( '/usr/local/bin/squidctrl' , 'restart' ) unless ( $besettings { 'NORESTART' } eq 'on' );
951 if (- d
$editdir ) { & General
:: system ( "rm" , "-rf" , " $editdir " ); }
953 $errormessage = $Lang :: tr
{ 'urlfilter category data error' };
957 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter save schedule' })
959 if (( $filtersettings { 'UPDATE_SOURCE' } eq 'custom' ) && ( $filtersettings { 'CUSTOM_UPDATE_URL' } eq '' ))
961 $errormessage = $Lang :: tr
{ 'urlfilter custom url required' };
963 open ( FILE
, "> $updconffile " );
964 print FILE
"ENABLE_AUTOUPDATE= $filtersettings {'ENABLE_AUTOUPDATE'} \n " ;
965 print FILE
"UPDATE_SCHEDULE= $filtersettings {'UPDATE_SCHEDULE'} \n " ;
966 print FILE
"UPDATE_SOURCE= $filtersettings {'UPDATE_SOURCE'} \n " ;
967 print FILE
"CUSTOM_UPDATE_URL= $filtersettings {'CUSTOM_UPDATE_URL'} \n " ;
971 if (( $filtersettings { 'ENABLE_AUTOUPDATE' } eq 'on' ) && ( $filtersettings { 'UPDATE_SCHEDULE' } eq 'daily' ))
973 & General
:: system ( '/usr/local/bin/urlfilterctrl' , 'cron' , 'daily' );
976 if (( $filtersettings { 'ENABLE_AUTOUPDATE' } eq 'on' ) && ( $filtersettings { 'UPDATE_SCHEDULE' } eq 'weekly' ))
978 & General
:: system ( '/usr/local/bin/urlfilterctrl' , 'cron' , 'weekly' );
981 if (( $filtersettings { 'ENABLE_AUTOUPDATE' } eq 'on' ) && ( $filtersettings { 'UPDATE_SCHEDULE' } eq 'monthly' ))
983 & General
:: system ( '/usr/local/bin/urlfilterctrl' , 'cron' , 'monthly' );
988 if ( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter update now' })
990 if ( $filtersettings { 'UPDATE_SOURCE' } eq 'custom' )
992 if ( $filtersettings { 'CUSTOM_UPDATE_URL' } eq '' )
994 $errormessage = $Lang :: tr
{ 'urlfilter custom url required' };
996 & General
:: system_background
( "${General::swroot}/urlfilter/bin/autoupdate.pl" , " $filtersettings {'CUSTOM_UPDATE_URL'}" );
999 & General
:: system_background
( "${General::swroot}/urlfilter/bin/autoupdate.pl" , " $filtersettings {'UPDATE_SOURCE'}" );
1004 if (- e
"${General::swroot}/urlfilter/settings" ) { & General
:: readhash
( "${General::swroot}/urlfilter/settings" , \
%filtersettings ); }
1010 if ( $errormessage ) { $filtersettings { 'VALID' } = 'no' ; }
1012 $checked { 'ENABLE_CUSTOM_BLACKLIST' }{ 'off' } = '' ;
1013 $checked { 'ENABLE_CUSTOM_BLACKLIST' }{ 'on' } = '' ;
1014 $checked { 'ENABLE_CUSTOM_BLACKLIST' }{ $filtersettings { 'ENABLE_CUSTOM_BLACKLIST' }} = "checked='checked'" ;
1015 $checked { 'ENABLE_CUSTOM_WHITELIST' }{ 'off' } = '' ;
1016 $checked { 'ENABLE_CUSTOM_WHITELIST' }{ 'on' } = '' ;
1017 $checked { 'ENABLE_CUSTOM_WHITELIST' }{ $filtersettings { 'ENABLE_CUSTOM_WHITELIST' }} = "checked='checked'" ;
1018 $checked { 'ENABLE_CUSTOM_EXPRESSIONS' }{ 'off' } = '' ;
1019 $checked { 'ENABLE_CUSTOM_EXPRESSIONS' }{ 'on' } = '' ;
1020 $checked { 'ENABLE_CUSTOM_EXPRESSIONS' }{ $filtersettings { 'ENABLE_CUSTOM_EXPRESSIONS' }} = "checked='checked'" ;
1021 $checked { 'BLOCK_EXECUTABLES' }{ 'off' } = '' ;
1022 $checked { 'BLOCK_EXECUTABLES' }{ 'on' } = '' ;
1023 $checked { 'BLOCK_EXECUTABLES' }{ $filtersettings { 'BLOCK_EXECUTABLES' }} = "checked='checked'" ;
1024 $checked { 'BLOCK_AUDIO-VIDEO' }{ 'off' } = '' ;
1025 $checked { 'BLOCK_AUDIO-VIDEO' }{ 'on' } = '' ;
1026 $checked { 'BLOCK_AUDIO-VIDEO' }{ $filtersettings { 'BLOCK_AUDIO-VIDEO' }} = "checked='checked'" ;
1027 $checked { 'BLOCK_ARCHIVES' }{ 'off' } = '' ;
1028 $checked { 'BLOCK_ARCHIVES' }{ 'on' } = '' ;
1029 $checked { 'BLOCK_ARCHIVES' }{ $filtersettings { 'BLOCK_ARCHIVES' }} = "checked='checked'" ;
1030 $checked { 'ENABLE_REWRITE' }{ 'off' } = '' ;
1031 $checked { 'ENABLE_REWRITE' }{ 'on' } = '' ;
1032 $checked { 'ENABLE_REWRITE' }{ $filtersettings { 'ENABLE_REWRITE' }} = "checked='checked'" ;
1033 $checked { 'SHOW_CATEGORY' }{ 'off' } = '' ;
1034 $checked { 'SHOW_CATEGORY' }{ 'on' } = '' ;
1035 $checked { 'SHOW_CATEGORY' }{ $filtersettings { 'SHOW_CATEGORY' }} = "checked='checked'" ;
1036 $checked { 'SHOW_URL' }{ 'off' } = '' ;
1037 $checked { 'SHOW_URL' }{ 'on' } = '' ;
1038 $checked { 'SHOW_URL' }{ $filtersettings { 'SHOW_URL' }} = "checked='checked'" ;
1039 $checked { 'SHOW_IP' }{ 'off' } = '' ;
1040 $checked { 'SHOW_IP' }{ 'on' } = '' ;
1041 $checked { 'SHOW_IP' }{ $filtersettings { 'SHOW_IP' }} = "checked='checked'" ;
1042 $checked { 'ENABLE_DNSERROR' }{ 'off' } = '' ;
1043 $checked { 'ENABLE_DNSERROR' }{ 'on' } = '' ;
1044 $checked { 'ENABLE_DNSERROR' }{ $filtersettings { 'ENABLE_DNSERROR' }} = "checked='checked'" ;
1045 $checked { 'ENABLE_JPEG' }{ 'off' } = '' ;
1046 $checked { 'ENABLE_JPEG' }{ 'on' } = '' ;
1047 $checked { 'ENABLE_JPEG' }{ $filtersettings { 'ENABLE_JPEG' }} = "checked='checked'" ;
1048 $checked { 'ENABLE_EXPR_LISTS' }{ 'off' } = '' ;
1049 $checked { 'ENABLE_EXPR_LISTS' }{ 'on' } = '' ;
1050 $checked { 'ENABLE_EXPR_LISTS' }{ $filtersettings { 'ENABLE_EXPR_LISTS' }} = "checked='checked'" ;
1051 $checked { 'BLOCK_IP_ADDR' }{ 'off' } = '' ;
1052 $checked { 'BLOCK_IP_ADDR' }{ 'on' } = '' ;
1053 $checked { 'BLOCK_IP_ADDR' }{ $filtersettings { 'BLOCK_IP_ADDR' }} = "checked='checked'" ;
1054 $checked { 'BLOCK_ALL' }{ 'off' } = '' ;
1055 $checked { 'BLOCK_ALL' }{ 'on' } = '' ;
1056 $checked { 'BLOCK_ALL' }{ $filtersettings { 'BLOCK_ALL' }} = "checked='checked'" ;
1057 $checked { 'ENABLE_EMPTY_ADS' }{ 'off' } = '' ;
1058 $checked { 'ENABLE_EMPTY_ADS' }{ 'on' } = '' ;
1059 $checked { 'ENABLE_EMPTY_ADS' }{ $filtersettings { 'ENABLE_EMPTY_ADS' }} = "checked='checked'" ;
1060 $checked { 'ENABLE_GLOBAL_WHITELIST' }{ 'off' } = '' ;
1061 $checked { 'ENABLE_GLOBAL_WHITELIST' }{ 'on' } = '' ;
1062 $checked { 'ENABLE_GLOBAL_WHITELIST' }{ $filtersettings { 'ENABLE_GLOBAL_WHITELIST' }} = "checked='checked'" ;
1063 $checked { 'ENABLE_LOG' }{ 'off' } = '' ;
1064 $checked { 'ENABLE_LOG' }{ 'on' } = '' ;
1065 $checked { 'ENABLE_LOG' }{ $filtersettings { 'ENABLE_LOG' }} = "checked='checked'" ;
1066 $checked { 'ENABLE_USERNAME_LOG' }{ 'off' } = '' ;
1067 $checked { 'ENABLE_USERNAME_LOG' }{ 'on' } = '' ;
1068 $checked { 'ENABLE_USERNAME_LOG' }{ $filtersettings { 'ENABLE_USERNAME_LOG' }} = "checked='checked'" ;
1069 $checked { 'ENABLE_CATEGORY_LOG' }{ 'off' } = '' ;
1070 $checked { 'ENABLE_CATEGORY_LOG' }{ 'on' } = '' ;
1071 $checked { 'ENABLE_CATEGORY_LOG' }{ $filtersettings { 'ENABLE_CATEGORY_LOG' }} = "checked='checked'" ;
1073 foreach $category ( @filtergroups ) {
1074 $checked { $category }{ 'off' } = '' ;
1075 $checked { $category }{ 'on' } = '' ;
1076 $checked { $category }{ $filtersettings { $category }} = "checked='checked'" ;
1079 $selected { 'REDIRECT_TEMPLATE' }{ $filtersettings { 'REDIRECT_TEMPLATE' }} = "selected='selected'" ;
1081 $selected { 'DEFINITION' }{ $tcsettings { 'DEFINITION' }} = "selected='selected'" ;
1082 $selected { 'FROM_HOUR' }{ $tcsettings { 'FROM_HOUR' }} = "selected='selected'" ;
1083 $selected { 'FROM_MINUTE' }{ $tcsettings { 'FROM_MINUTE' }} = "selected='selected'" ;
1084 $selected { 'TO_HOUR' }{ $tcsettings { 'TO_HOUR' }} = "selected='selected'" ;
1085 $selected { 'TO_MINUTE' }{ $tcsettings { 'TO_MINUTE' }} = "selected='selected'" ;
1087 @selectedcategories = split ( /\|/ , $tcsettings { 'DST' });
1088 foreach ( @selectedcategories )
1090 $selected { 'DST' }{ $_ } = "selected='selected'" ;
1093 $selected { 'ACCESS' }{ $tcsettings { 'ACCESS' }} = "selected='selected'" ;
1095 $checked { 'ENABLERULE' }{ 'off' } = '' ;
1096 $checked { 'ENABLERULE' }{ 'on' } = '' ;
1097 $checked { 'ENABLERULE' }{ $tcsettings { 'ENABLERULE' }} = "checked='checked'" ;
1098 $checked { 'MON' }{ 'off' } = '' ;
1099 $checked { 'MON' }{ 'on' } = '' ;
1100 $checked { 'MON' }{ $tcsettings { 'MON' }} = "checked='checked'" ;
1101 $checked { 'TUE' }{ 'off' } = '' ;
1102 $checked { 'TUE' }{ 'on' } = '' ;
1103 $checked { 'TUE' }{ $tcsettings { 'TUE' }} = "checked='checked'" ;
1104 $checked { 'WED' }{ 'off' } = '' ;
1105 $checked { 'WED' }{ 'on' } = '' ;
1106 $checked { 'WED' }{ $tcsettings { 'WED' }} = "checked='checked'" ;
1107 $checked { 'THU' }{ 'off' } = '' ;
1108 $checked { 'THU' }{ 'on' } = '' ;
1109 $checked { 'THU' }{ $tcsettings { 'THU' }} = "checked='checked'" ;
1110 $checked { 'FRI' }{ 'off' } = '' ;
1111 $checked { 'FRI' }{ 'on' } = '' ;
1112 $checked { 'FRI' }{ $tcsettings { 'FRI' }} = "checked='checked'" ;
1113 $checked { 'SAT' }{ 'off' } = '' ;
1114 $checked { 'SAT' }{ 'on' } = '' ;
1115 $checked { 'SAT' }{ $tcsettings { 'SAT' }} = "checked='checked'" ;
1116 $checked { 'SUN' }{ 'off' } = '' ;
1117 $checked { 'SUN' }{ 'on' } = '' ;
1118 $checked { 'SUN' }{ $tcsettings { 'SUN' }} = "checked='checked'" ;
1120 $selected { 'SPORADIC' }{ $uqsettings { 'SPORADIC' }} = "selected='selected'" ;
1121 $selected { 'RENEWAL' } { $uqsettings { 'RENEWAL' }} = "selected='selected'" ;
1123 $checked { 'ENABLEQUOTA' }{ 'off' } = '' ;
1124 $checked { 'ENABLEQUOTA' }{ 'on' } = '' ;
1125 $checked { 'ENABLEQUOTA' }{ $uqsettings { 'ENABLEQUOTA' }} = "checked='checked'" ;
1127 $selected { 'BE_BLACKLIST' }{ $besettings { 'BE_BLACKLIST' }} = "selected='selected'" ;
1130 & Header
:: showhttpheaders
();
1132 & Header
:: openpage
( $Lang :: tr
{ 'urlfilter configuration' }, 1 , '' );
1134 & Header
:: openbigbox
( '100%' , 'left' , '' , $errormessage );
1136 if ( $errormessage ) {
1137 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'error messages' });
1138 print "<font class='base'> $errormessage </font> \n " ;
1139 & Header
:: closebox
();
1140 } elsif (( $tcsettings { 'CHANGED' } eq 'yes' ) || ( $uqsettings { 'CHANGED' } eq 'yes' ) ) {
1142 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}'> \n " ;
1143 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter restart notification'}:" );
1144 print "<class name='base'> $Lang ::tr{'urlfilter restart message'} \n " ;
1145 if ( $uqsettings { 'MODE' } eq 'USERQUOTA' ) { print "<p><class name='base'> $Lang ::tr{'urlfilter quota restart message'} \n " ; }
1147 print "<p><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter restart'}' />" ;
1148 if ( $tcsettings { 'MODE' } eq 'TIMECONSTRAINT' ) { print "<input type='hidden' name='MODE' value='TIMECONSTRAINT' />" ; }
1149 if ( $uqsettings { 'MODE' } eq 'USERQUOTA' ) { print "<input type='hidden' name='MODE' value='USERQUOTA' />" ; }
1150 & Header
:: closebox
();
1154 if ( $restoremessage ) {
1155 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter restore results'}:" );
1156 print "<class name='base'> $restoremessage \n " ;
1157 print " </class> \n " ;
1158 & Header
:: closebox
();
1161 if ((! $tcsettings { 'TCMODE' }) && (! $uqsettings { 'UQMODE' }) && (! $besettings { 'BEMODE' })) {
1163 if (!( $filtersettings { 'ACTION' } eq $Lang :: tr
{ 'urlfilter manage repository' })) {
1165 #==========================================================
1167 # Section: Main Configuration
1169 #==========================================================
1171 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}' enctype='multipart/form-data'> \n " ;
1173 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter filter settings'}" );
1175 <table width='100%'>
1177 <td colspan='4'><b> $Lang ::tr{'urlfilter block categories'}</b></td>
1182 if ( @categories == 0 ) {
1185 <td><i> $Lang ::tr{'urlfilter no categories'}</i></td>
1195 for ( $n = 0 ; $n <= @categories ; $n = $n + $i ) {
1196 for ( $i = 0 ; $i <= 3 ; $i ++) {
1197 if ( $i eq 0 ) { print "<tr> \n " ; }
1198 if (( $n + $i ) < @categories ) {
1199 print "<td width='15%'> @categories [ $n + $i ]:<\/td> \n " ;
1200 print "<td width='10%'><input type='checkbox' name= @filtergroups [ $n + $i ] $checked { @filtergroups [ $n + $i ]}{'on'} /></td> \n " ;
1202 if ( $i eq 3 ) { print "<\/tr> \n " ; }
1209 <table width='100%'>
1211 <td><b> $Lang ::tr{'urlfilter custom blacklist'}</b></td>
1217 <td colspan='2'> $Lang ::tr{'urlfilter blocked domains'}</td>
1218 <td colspan='2'> $Lang ::tr{'urlfilter blocked urls'}</td>
1221 <td colspan='2'> $Lang ::tr{'urlfilter example'}</td>
1222 <td colspan='2'> $Lang ::tr{'urlfilter example ads'}</td>
1225 <td colspan='2' width='50%'><textarea name='CUSTOM_BLACK_DOMAINS' cols='32' rows='6' wrap='off'>
1229 print $filtersettings { 'CUSTOM_BLACK_DOMAINS' };
1233 <td colspan='2' width='50%'><textarea name='CUSTOM_BLACK_URLS' cols='32' rows='6' wrap='off'>
1237 print $filtersettings { 'CUSTOM_BLACK_URLS' };
1243 <table width='100%'>
1245 <td class='base' width='25%'> $Lang ::tr{'urlfilter enable custom blacklist'}:</td>
1246 <td><input type='checkbox' name='ENABLE_CUSTOM_BLACKLIST' $checked {'ENABLE_CUSTOM_BLACKLIST'}{'on'} /></td>
1252 <table width='100%'>
1254 <td><b> $Lang ::tr{'urlfilter custom whitelist'}</b></td>
1260 <td colspan='2'> $Lang ::tr{'urlfilter allowed domains'}</td>
1261 <td colspan='2'> $Lang ::tr{'urlfilter allowed urls'}</td>
1264 <td colspan='2'> $Lang ::tr{'urlfilter example'}</td>
1265 <td colspan='2'> $Lang ::tr{'urlfilter example ads'}</td>
1268 <td colspan='2' width='50%'><textarea name='CUSTOM_WHITE_DOMAINS' cols='32' rows='6' wrap='off'>
1272 print $filtersettings { 'CUSTOM_WHITE_DOMAINS' };
1276 <td colspan='2' width='50%'><textarea name='CUSTOM_WHITE_URLS' cols='32' rows='6' wrap='off'>
1280 print $filtersettings { 'CUSTOM_WHITE_URLS' };
1286 <table width='100%'>
1288 <td class='base' width='25%'> $Lang ::tr{'urlfilter enable custom whitelist'}:</td>
1289 <td><input type='checkbox' name='ENABLE_CUSTOM_WHITELIST' $checked {'ENABLE_CUSTOM_WHITELIST'}{'on'} /></td>
1295 <table width='100%'>
1297 <td colspan='4'><b> $Lang ::tr{'urlfilter custom expression list'}</b></td>
1300 <td colspan='4'> $Lang ::tr{'urlfilter blocked expressions'}</td>
1303 <td colspan='4'><textarea name='CUSTOM_EXPRESSIONS' cols='70' rows='3' wrap='off'>
1307 print $filtersettings { 'CUSTOM_EXPRESSIONS' };
1313 <td class='base' width='25%'> $Lang ::tr{'urlfilter enable custom expression list'}:</td>
1314 <td><input type='checkbox' name='ENABLE_CUSTOM_EXPRESSIONS' $checked {'ENABLE_CUSTOM_EXPRESSIONS'}{'on'} /></td>
1320 <table width='100%'>
1322 <td colspan='4'><b> $Lang ::tr{'urlfilter file ext block'}</b></td>
1325 <td width='25%' class='base'> $Lang ::tr{'urlfilter block executables'}:</td>
1326 <td width='12%'><input type='checkbox' name='BLOCK_EXECUTABLES' $checked {'BLOCK_EXECUTABLES'}{'on'} /></td>
1327 <td width='25%' class='base'> $Lang ::tr{'urlfilter block audio-video'}:</td>
1328 <td><input type='checkbox' name='BLOCK_AUDIO-VIDEO' $checked {'BLOCK_AUDIO-VIDEO'}{'on'} /></td>
1331 <td class='base'> $Lang ::tr{'urlfilter block archives'}:</td>
1332 <td><input type='checkbox' name='BLOCK_ARCHIVES' $checked {'BLOCK_ARCHIVES'}{'on'} /></td>
1338 <table width='100%'>
1340 <td colspan='4'><b> $Lang ::tr{'urlfilter local file redirection'}</b></td>
1343 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable rewrite rules'}:</td>
1344 <td width='12%'><input type='checkbox' name='ENABLE_REWRITE' $checked {'ENABLE_REWRITE'}{'on'} /></td>
1349 <td><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter manage repository'}'></td>
1356 <table width='100%'>
1358 <td colspan='2'><b> $Lang ::tr{'urlfilter network access control'}</b></td>
1363 <td colspan='2'> $Lang ::tr{'urlfilter unfiltered clients'}</td>
1364 <td colspan='2'> $Lang ::tr{'urlfilter banned clients'}</td>
1367 <td colspan='2' width='50%'><textarea name='UNFILTERED_CLIENTS' cols='32' rows='6' wrap='off'>
1371 # transform from pre1.8 client definitions
1372 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/^\s+//g ;
1373 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/\s+$//g ;
1374 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/\s+-\s+/-/g ;
1375 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/\s+/ /g ;
1377 @clients = split ( / / , $filtersettings { 'UNFILTERED_CLIENTS' });
1378 undef $filtersettings { 'UNFILTERED_CLIENTS' };
1379 foreach ( @clients ) { $filtersettings { 'UNFILTERED_CLIENTS' } .= " $_ \n " ; }
1381 print $filtersettings { 'UNFILTERED_CLIENTS' };
1385 <td colspan='2' width='50%'><textarea name='BANNED_CLIENTS' cols='32' rows='6' wrap='off'>
1389 # transform from pre1.8 client definitions
1390 $filtersettings { 'BANNED_CLIENTS' } =~ s/^\s+//g ;
1391 $filtersettings { 'BANNED_CLIENTS' } =~ s/\s+$//g ;
1392 $filtersettings { 'BANNED_CLIENTS' } =~ s/\s+-\s+/-/g ;
1393 $filtersettings { 'BANNED_CLIENTS' } =~ s/\s+/ /g ;
1395 @clients = split ( / / , $filtersettings { 'BANNED_CLIENTS' });
1396 undef $filtersettings { 'BANNED_CLIENTS' };
1397 foreach ( @clients ) { $filtersettings { 'BANNED_CLIENTS' } .= " $_ \n " ; }
1399 print $filtersettings { 'BANNED_CLIENTS' };
1406 <table width='100%'>
1408 <td colspan='4'><b> $Lang ::tr{'urlfilter timebased access control'}</b></td>
1411 <td width='25%'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter set time constraints'}'></td>
1412 <td width='25%'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter set user quota'}'></td>
1418 <table width='100%'>
1420 <td colspan='4'><b> $Lang ::tr{'urlfilter block settings'}</b></td>
1423 <td width='25%' class='base'> $Lang ::tr{'urlfilter redirect template'}</td>
1424 <td width='75%' colspan='2'>
1425 <select name='REDIRECT_TEMPLATE'>
1429 foreach (< $templatedir /*>) {
1430 if ((- d
" $_ " ) && (- e
" $_ /template.html" )) {
1431 my $template = substr ( $_ , rindex ( $_ , "/" )+ 1 );
1432 print "<option value=' $template ' $selected {'REDIRECT_TEMPLATE'}{ $template }> $template </option> \n " ;
1441 <td width='25%' class='base'> $Lang ::tr{'urlfilter show category'}:</td>
1442 <td width='12%'><input type='checkbox' name='SHOW_CATEGORY' $checked {'SHOW_CATEGORY'}{'on'} /></td>
1443 <td width='25%' class='base'> $Lang ::tr{'urlfilter redirectpage'}:</td>
1444 <td><input type='text' name='REDIRECT_PAGE' value=' $filtersettings {'REDIRECT_PAGE'}' size='40' /></td>
1447 <td class='base'> $Lang ::tr{'urlfilter show url'}:</td>
1448 <td><input type='checkbox' name='SHOW_URL' $checked {'SHOW_URL'}{'on'} /></td>
1449 <td class='base'> $Lang ::tr{'urlfilter msg text 1'}:</td>
1450 <td><input type='text' name='MSG_TEXT_1' value=' $filtersettings {'MSG_TEXT_1'}' size='40' /></td>
1453 <td class='base'> $Lang ::tr{'urlfilter show ip'}:</td>
1454 <td><input type='checkbox' name='SHOW_IP' $checked {'SHOW_IP'}{'on'} /></td>
1455 <td class='base'> $Lang ::tr{'urlfilter msg text 2'}:</td>
1456 <td><input type='text' name='MSG_TEXT_2' value=' $filtersettings {'MSG_TEXT_2'}' size='40' /></td>
1459 <td class='base'> $Lang ::tr{'urlfilter show dnserror'}:</td>
1460 <td><input type='checkbox' name='ENABLE_DNSERROR' $checked {'ENABLE_DNSERROR'}{'on'} /></td>
1461 <td class='base'> $Lang ::tr{'urlfilter msg text 3'}:</td>
1462 <td><input type='text' name='MSG_TEXT_3' value=' $filtersettings {'MSG_TEXT_3'}' size='40' /></td>
1466 <table width='100%'>
1468 <td colspan='4'><b> $Lang ::tr{'urlfilter advanced settings'}</b></td>
1471 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable expression lists'}:</td>
1472 <td width='12%'><input type='checkbox' name='ENABLE_EXPR_LISTS' $checked {'ENABLE_EXPR_LISTS'}{'on'} /></td>
1473 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable log'}:</td>
1474 <td><input type='checkbox' name='ENABLE_LOG' $checked {'ENABLE_LOG'}{'on'} /></td>
1477 <td class='base'> $Lang ::tr{'urlfilter empty ads'}:</td>
1478 <td><input type='checkbox' name='ENABLE_EMPTY_ADS' $checked {'ENABLE_EMPTY_ADS'}{'on'} /></td>
1479 <td class='base'> $Lang ::tr{'urlfilter username log'}:</td>
1480 <td><input type='checkbox' name='ENABLE_USERNAME_LOG' $checked {'ENABLE_USERNAME_LOG'}{'on'} /></td>
1483 <td class='base'> $Lang ::tr{'urlfilter block ip'}:</td>
1484 <td><input type='checkbox' name='BLOCK_IP_ADDR' $checked {'BLOCK_IP_ADDR'}{'on'} /></td>
1485 <td class='base'> $Lang ::tr{'urlfilter category log'}:</td>
1486 <td><input type='checkbox' name='ENABLE_CATEGORY_LOG' $checked {'ENABLE_CATEGORY_LOG'}{'on'} /></td>
1489 <td class='base'> $Lang ::tr{'urlfilter block all'}:</td>
1490 <td><input type='checkbox' name='BLOCK_ALL' $checked {'BLOCK_ALL'}{'on'} /></td>
1491 <td class='base'> $Lang ::tr{'urlfilter whitelist always allowed'}:</td>
1492 <td><input type='checkbox' name='ENABLE_GLOBAL_WHITELIST' $checked {'ENABLE_GLOBAL_WHITELIST'}{'on'} /></td>
1496 <table width='100%'>
1498 <td><img src='/blob.gif' align='top' alt='*' /> <font class='base'> $Lang ::tr{'required field'}</font></td>
1499 <td align='right'> </td>
1502 <table width='100%'>
1505 <td align='center'><input type='submit' name='ACTION' value=' $Lang ::tr{'save'}' /></td>
1506 <td align='center'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter save and restart'}' /></td>
1513 & Header
:: closebox
();
1517 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}' enctype='multipart/form-data'> \n " ;
1519 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter maintenance'}" );
1522 <table width='100%'>
1524 <td class='base'><b> $Lang ::tr{'urlfilter blacklist update'}</b></td>
1527 <td> $Lang ::tr{'urlfilter upload information'}<p> $Lang ::tr{'urlfilter upload text'}:</td>
1530 <td><input type='file' name='UPDATEFILE' size='40' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter upload blacklist'}' /></td>
1536 <table width='100%'>
1538 <td colspan='2' class='base'><b> $Lang ::tr{'urlfilter automatic blacklist update'}</b>
1541 if (- e
" $updflagfile " )
1543 $blacklistage = int (- M
" $updflagfile " );
1544 print " <b>[</b> <small><i> $Lang ::tr{'urlfilter blacklist age 1'} <b> $blacklistage </b> $Lang ::tr{'urlfilter blacklist age 2'}</i></small> <b>]</b>" ;
1547 $updatesettings { 'UPDATE_SCHEDULE' } = 'monthly' ;
1548 $updatesettings { 'CUSTOM_UPDATE_URL' } = '' ;
1550 if (- e
" $updconffile " ) { & General
:: readhash
( " $updconffile " , \
%updatesettings ); }
1552 $checked { 'ENABLE_AUTOUPDATE' }{ 'off' } = '' ;
1553 $checked { 'ENABLE_AUTOUPDATE' }{ 'on' } = '' ;
1554 $checked { 'ENABLE_AUTOUPDATE' }{ $updatesettings { 'ENABLE_AUTOUPDATE' }} = "checked='checked'" ;
1556 $selected { 'UPDATE_SCHEDULE' }{ $updatesettings { 'UPDATE_SCHEDULE' }} = "selected='selected'" ;
1558 $selected { 'UPDATE_SOURCE' }{ $updatesettings { 'UPDATE_SOURCE' }} = "selected='selected'" ;
1564 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable automatic blacklist update'}:</td>
1565 <td width='75%' class='base'><input type='checkbox' name='ENABLE_AUTOUPDATE' $checked {'ENABLE_AUTOUPDATE'}{'on'} /></td>
1568 <td class='base'> $Lang ::tr{'urlfilter automatic update schedule'}:</td>
1570 <select name='UPDATE_SCHEDULE'>
1571 <option value='daily' $selected {'UPDATE_SCHEDULE'}{'daily'}> $Lang ::tr{'urlfilter daily'}</option>
1572 <option value='weekly' $selected {'UPDATE_SCHEDULE'}{'weekly'}> $Lang ::tr{'urlfilter weekly'}</option>
1573 <option value='monthly' $selected {'UPDATE_SCHEDULE'}{'monthly'}> $Lang ::tr{'urlfilter monthly'}</option>
1578 <td class='base'> $Lang ::tr{'urlfilter select source'}:</td>
1579 <td class='base' colspan='2'>
1580 <select name='UPDATE_SOURCE'>
1584 foreach ( @source_urllist ) {
1586 $source_name = substr ( $_ , 0 , rindex ( $_ , "," ));
1587 $source_url = substr ( $_ , index ( $_ , "," )+ 1 );
1588 print " \t <option value=' $source_url ' $selected {'UPDATE_SOURCE'}{ $source_url }> $source_name </option> \n " ;
1592 <option value='custom' $selected {'UPDATE_SOURCE'}{'custom'}> $Lang ::tr{'urlfilter custom url'}</option>
1597 <td> $Lang ::tr{'urlfilter custom url'}:</td>
1598 <td><input type='text' name='CUSTOM_UPDATE_URL' value=' $updatesettings {'CUSTOM_UPDATE_URL'}' size='72' /></td>
1601 <table width='100%'>
1603 <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>
1609 <table width='100%'>
1611 <td class='base'><b> $Lang ::tr{'urlfilter blacklist editor'}</b></td>
1614 <td> $Lang ::tr{'urlfilter blacklist editor info'}</td>
1617 <td><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter blacklist editor'}' /></td>
1623 <table width='100%'>
1625 <td colspan='4' class='base'><b> $Lang ::tr{'urlfilter backup settings'}</b></td>
1628 <td width='25%' class='base'> $Lang ::tr{'urlfilter enable full backup'}:</td>
1629 <td width='12%' class='base'><input type='checkbox' name='ENABLE_FULLBACKUP' $checked {'ENABLE_FULLBACKUP'}{'on'} /></td>
1634 <td colspan='4' class='base'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter backup'}' /></td>
1640 <table width='100%'>
1642 <td class='base'><b> $Lang ::tr{'urlfilter restore settings'}</b></td>
1645 <td> $Lang ::tr{'urlfilter restore text'}:</td>
1648 <td><input type='file' name='UPDATEFILE' size='40' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter restore'}' /></td>
1655 & Header
:: closebox
();
1659 #==========================================================
1661 # Section: Manage Repository
1663 #==========================================================
1665 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}' enctype='multipart/form-data'> \n " ;
1667 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter manage local file repository'}:" );
1669 <table width='100%'>
1671 <td> $Lang ::tr{'urlfilter repository information'}<br><br></td>
1674 <td> $Lang ::tr{'urlfilter upload file text'}:</td>
1677 <td><input type='file' name='UPLOADFILE' size='50' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter upload file'}' /></td>
1680 <td><br><b> $Lang ::tr{'urlfilter upload file information 1'}:</b> $Lang ::tr{'urlfilter upload file information 2'}</td>
1684 <table width='100%'>
1686 <td><input type='button' name='return2main' value=' $Lang ::tr{'urlfilter back to main page'}' onClick='self.location.href=" $ENV {'SCRIPT_NAME'}"'></td>
1693 & Header
:: closebox
();
1695 & Header
:: openbox
( '100%' , 'left' , " $Lang ::tr{'urlfilter current files'}: </b>[ $repository ]" );
1697 @repositorylist = < $repository /*>;
1699 undef @repositoryfiles ;
1700 foreach ( @repositorylist )
1702 if (!- d
) { push ( @repositoryfiles , substr ( $_ , rindex ( $_ , "/" )+ 1 )); }
1705 if ( @repositoryfiles )
1708 <table width='100%'>
1710 <td align='center'><b> $Lang ::tr{'urlfilter filename'}</b></td>
1711 <td width='15%' align='center'><b> $Lang ::tr{'urlfilter filesize'}</b></td>
1712 <td width='10%'></td>
1717 foreach $line ( @repositoryfiles )
1721 print "<tr bgcolor=' $Header ::table1colour'> \n " ; }
1723 print "<tr bgcolor=' $Header ::table2colour'> \n " ; }
1724 $filesize = (- s
" $repository / $line " );
1725 1 while $filesize =~ s/^(-?\d+)(\d{3})/$1.$2/ ;
1728 <td> $line </td>
1729 <td align='right'> $filesize </td>
1732 <form method='post' name='frma $id ' action=' $ENV {'SCRIPT_NAME'}'>
1733 <input type='image' name=' $Lang ::tr{'remove'}' src='/images/delete.gif' title=' $Lang ::tr{'remove'}' alt=' $Lang ::tr{'remove'}' />
1734 <input type='hidden' name='ID' value=' $line ' />
1735 <input type='hidden' name='ACTION' value=' $Lang ::tr{'urlfilter remove file'}' />
1752 <td class='boldbase'> <b> $Lang ::tr{'legend'}:</b></td>
1753 <td> <img src='/images/delete.gif' alt=' $Lang ::tr{'remove'}' /></td>
1754 <td class='base'> $Lang ::tr{'remove'}</td>
1761 print "<i> $Lang ::tr{'urlfilter empty repository'}</i> \n " ;
1764 & Header
:: closebox
();
1768 } elsif ( $tcsettings { 'TCMODE' }) {
1770 #==========================================================
1772 # Section: Set Time Constraints
1774 #==========================================================
1776 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}'> \n " ;
1778 $buttontext = $Lang :: tr
{ 'urlfilter add rule' };
1779 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) {
1780 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter edit time constraint rule' }. ':' );
1781 $buttontext = $Lang :: tr
{ 'urlfilter update rule' };
1783 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter add new time constraint rule' }. ':' );
1787 <table width='100%'>
1789 <td width='2%'> $Lang ::tr{'urlfilter constraint definition'}</td>
1790 <td width='1%'> </td>
1791 <td width='2%' align='center'> $Lang ::tr{'urlfilter monday'}</td>
1792 <td width='2%' align='center'> $Lang ::tr{'urlfilter tuesday'}</td>
1793 <td width='2%' align='center'> $Lang ::tr{'urlfilter wednesday'}</td>
1794 <td width='2%' align='center'> $Lang ::tr{'urlfilter thursday'}</td>
1795 <td width='2%' align='center'> $Lang ::tr{'urlfilter friday'}</td>
1796 <td width='2%' align='center'> $Lang ::tr{'urlfilter saturday'}</td>
1797 <td width='2%' align='center'> $Lang ::tr{'urlfilter sunday'}</td>
1798 <td width='1%'> </td>
1799 <td width='7%' colspan=3> $Lang ::tr{'urlfilter from'}</td>
1800 <td width='1%'> </td>
1801 <td width='7%' colspan=3> $Lang ::tr{'urlfilter to'}</td>
1806 <select name='DEFINITION'>
1807 <option value='within' $selected {'DEFINITION'}{'within'}> $Lang ::tr{'urlfilter constraint within'}</option>
1808 <option value='outside' $selected {'DEFINITION'}{'outside'}> $Lang ::tr{'urlfilter constraint outside'}</option>
1812 <td class='base'><input type='checkbox' name='MON' $checked {'MON'}{'on'} /></td>
1813 <td class='base'><input type='checkbox' name='TUE' $checked {'TUE'}{'on'} /></td>
1814 <td class='base'><input type='checkbox' name='WED' $checked {'WED'}{'on'} /></td>
1815 <td class='base'><input type='checkbox' name='THU' $checked {'THU'}{'on'} /></td>
1816 <td class='base'><input type='checkbox' name='FRI' $checked {'FRI'}{'on'} /></td>
1817 <td class='base'><input type='checkbox' name='SAT' $checked {'SAT'}{'on'} /></td>
1818 <td class='base'><input type='checkbox' name='SUN' $checked {'SUN'}{'on'} /></td>
1821 <select name='FROM_HOUR'>
1824 for ( $i = 0 ; $i <= 24 ; $i ++) {
1825 $_ = sprintf ( " %02s " , $i );
1826 print "<option $selected {'FROM_HOUR'}{ $_ }> $_ </option> \n " ;
1833 <select name='FROM_MINUTE'>
1836 for ( $i = 0 ; $i <= 45 ; $i += 15 ) {
1837 $_ = sprintf ( " %02s " , $i );
1838 print "<option $selected {'FROM_MINUTE'}{ $_ }> $_ </option> \n " ;
1845 <select name='TO_HOUR'>
1848 for ( $i = 0 ; $i <= 24 ; $i ++) {
1849 $_ = sprintf ( " %02s " , $i );
1850 print "<option $selected {'TO_HOUR'}{ $_ }> $_ </option> \n " ;
1857 <select name='TO_MINUTE'>
1860 for ( $i = 0 ; $i <= 45 ; $i += 15 ) {
1861 $_ = sprintf ( " %02s " , $i );
1862 print "<option $selected {'TO_MINUTE'}{ $_ }> $_ </option> \n " ;
1873 <table width='100%'>
1875 <td width='5%'> $Lang ::tr{'urlfilter source'} <img src='/blob.gif' alt='*' /></td>
1876 <td width='1%'> </td>
1877 <td width='5%'> $Lang ::tr{'urlfilter dst'} <img src='/blob.gif' alt='*' /></td>
1878 <td width='1%'> </td>
1879 <td width='5%'> $Lang ::tr{'urlfilter access'}</td>
1883 <td rowspan='2'><textarea name='SRC' cols='28' rows='5' wrap='off'>
1887 # transform from pre1.8 client definitions
1888 $tcsettings { 'SRC' } =~ s/^\s+//g ;
1889 $tcsettings { 'SRC' } =~ s/\s+$//g ;
1890 $tcsettings { 'SRC' } =~ s/\s+-\s+/-/g ;
1891 $tcsettings { 'SRC' } =~ s/\s+/ /g ;
1893 @clients = split ( / / , $tcsettings { 'SRC' });
1894 undef $tcsettings { 'SRC' };
1895 foreach ( @clients ) { $tcsettings { 'SRC' } .= " $_ \n " ; }
1897 print $tcsettings { 'SRC' };
1903 <td class='base' rowspan='2' valign='top'>
1904 <select name='DST' size='6' multiple>
1905 <option value='any' $selected {'DST'}{'any'} = "selected='selected'"> $Lang ::tr{'urlfilter category all'}</option>
1906 <option value='in-addr' $selected {'DST'}{'in-addr'} = "selected='selected'">in-addr</option>
1910 & readblockcategories
;
1911 foreach ( @categories )
1913 print "<option value=' $_ ' $selected {'DST'}{ $_ }> $_ </option> \n " ;
1917 <option value='files' $selected {'DST'}{'files'} = "selected='selected'">files</option>
1918 <option value='custom-blocked' $selected {'DST'}{'custom-blocked'} = "selected='selected'">custom-blocked</option>
1919 <option value='custom-expressions' $selected {'DST'}{'custom-expressions'} = "selected='selected'">custom-expressions</option>
1923 <td class='base' valign='top'>
1924 <select name='ACCESS'>
1925 <option value='block' $selected {'ACCESS'}{'block'}> $Lang ::tr{'urlfilter mode block'}</option>
1926 <option value='allow' $selected {'ACCESS'}{'allow'}> $Lang ::tr{'urlfilter mode allow'}</option>
1938 <td> $Lang ::tr{'remark'}</td>
1946 <td><input type='text' name='COMMENT' value=' $tcsettings {'COMMENT'}' size='32' /></td>
1955 <table width='100%'>
1957 <td class='base'> $Lang ::tr{'urlfilter enabled'}<input type='checkbox' name='ENABLERULE' $checked{'ENABLERULE'}{'on'} /></td>
1965 <td><input type='hidden' name='ACTION' value=' $Lang ::tr{'add'}' /></td>
1966 <td><input type='hidden' name='MODE' value='TIMECONSTRAINT' /></td>
1967 <td><input type='submit' name='SUBMIT' value=' $buttontext ' /></td>
1968 <td><input type='reset' name='ACTION' value=' $Lang ::tr{'urlfilter reset'}' /></td>
1970 <td><input type='button' name='return2main' value=' $Lang ::tr{'urlfilter back to main page'}' onClick='self.location.href=" $ENV {'SCRIPT_NAME'}"'></td>
1974 <table width='100%'>
1976 <td width='1%' align='right'> <img src='/blob.gif' align='top' alt='*' /> </td>
1977 <td><font class='base'> $Lang ::tr{'required field'}</font></td>
1980 <td width='1%' align='right'> </td>
1981 <td><font class='base'> $Lang ::tr{'urlfilter select multi'}</font></td>
1987 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) {
1988 print "<input type='hidden' name='EDITING' value=' $tcsettings {'ID'}' /> \n " ;
1990 print "<input type='hidden' name='EDITING' value='no' /> \n " ;
1993 & Header
:: closebox
();
1996 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'current rules' });
1998 <table width='100%'>
2000 <td width='5%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter constraint definition'}</b></td>
2001 <td width='10%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter time space'}</b></td>
2002 <td width='15%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter src'}</b></td>
2003 <td width='5%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter dst'}</b></td>
2004 <td width='10%' class='boldbase' colspan='5' align='center'> </td>
2009 if ( $tcsettings { 'ACTION' } ne '' or $changed ne 'no' )
2011 open ( FILE
, $tcfile );
2017 foreach $line ( @tclist )
2021 @temp = split ( /\,/ , $line );
2022 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' } && $tcsettings { 'ID' } eq $id ) {
2023 print "<tr bgcolor=' $Header ::colouryellow'> \n " ; }
2025 print "<tr bgcolor=' $Header ::table1colour'> \n " ; }
2027 print "<tr bgcolor=' $Header ::table2colour'> \n " ; }
2028 if ( $temp [ 0 ] eq 'within' ) { $temp [ 0 ]= $Lang :: tr
{ 'urlfilter constraint within' }; } else { $temp [ 0 ]= $Lang :: tr
{ 'urlfilter constraint outside' }; }
2029 if ( $temp [ 13 ] eq 'any' ) { $temp [ 13 ]= $Lang :: tr
{ 'urlfilter category all' }; }
2030 if ( $temp [ 15 ] eq 'on' ) { $gif = 'on.gif' ; $toggle = 'off' ; $gdesc = $Lang :: tr
{ 'click to disable' };}
2031 else { $gif = 'off.gif' ; $toggle = 'on' ; $gdesc = $Lang :: tr
{ 'click to enable' }; }
2032 if ( $temp [ 14 ] eq 'block' ) { $led = 'led-red.gif' ; $ldesc = $Lang :: tr
{ 'urlfilter block access' };}
2033 else { $led = 'led-green.gif' ; $ldesc = $Lang :: tr
{ 'urlfilter allow access' }; }
2036 if ( $temp [ 1 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter mon' }; } else { $time .= '=' ; }
2037 if ( $temp [ 2 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter tue' }; } else { $time .= '=' ; }
2038 if ( $temp [ 3 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter wed' }; } else { $time .= '=' ; }
2039 if ( $temp [ 4 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter thu' }; } else { $time .= '=' ; }
2040 if ( $temp [ 5 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter fri' }; } else { $time .= '=' ; }
2041 if ( $temp [ 6 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter sat' }; } else { $time .= '=' ; }
2042 if ( $temp [ 7 ] eq 'on' ) { $time .= $Lang :: tr
{ 'urlfilter sun' }; } else { $time .= '=' ; }
2043 $time = $time . ' ' . $temp [ 8 ]. ':' . $temp [ 9 ]. ' to ' . $temp [ 10 ]. ':' . $temp [ 11 ];
2046 <td align='center'> $temp [0]</td>
2047 <td align='center' nowrap> $time </td>
2048 <td align='center'> $temp [12]</td>
2049 <td align='center'> $temp [13]</td>
2050 <td align='center'><image src='/images/urlfilter/ $led ' alt=' $ldesc '></td>
2053 <form method='post' name='frma $id ' action=' $ENV {'SCRIPT_NAME'}'>
2054 <input type='image' name=' $Lang ::tr{'toggle enable disable'}' src='/images/ $gif ' title=' $gdesc ' alt=' $gdesc ' />
2055 <input type='hidden' name='MODE' value='TIMECONSTRAINT' />
2056 <input type='hidden' name='ID' value=' $id ' />
2057 <input type='hidden' name='ACTIVE' value=' $toggle ' />
2058 <input type='hidden' name='ACTION' value=' $Lang ::tr{'toggle enable disable'}' />
2063 <form method='post' name='frmb $id ' action=' $ENV {'SCRIPT_NAME'}'>
2064 <input type='image' name=' $Lang ::tr{'edit'}' src='/images/edit.gif' title=' $Lang ::tr{'edit'}' alt=' $Lang ::tr{'edit'}' />
2065 <input type='hidden' name='MODE' value='TIMECONSTRAINT' />
2066 <input type='hidden' name='ID' value=' $id ' />
2067 <input type='hidden' name='ACTION' value=' $Lang ::tr{'edit'}' />
2072 <form method='post' name='frmc $id ' action=' $ENV {'SCRIPT_NAME'}'>
2073 <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'}' />
2074 <input type='hidden' name='MODE' value='TIMECONSTRAINT' />
2075 <input type='hidden' name='ID' value=' $id ' />
2076 <input type='hidden' name='ACTION' value=' $Lang ::tr{'urlfilter copy rule'}' />
2081 <form method='post' name='frmd $id ' action=' $ENV {'SCRIPT_NAME'}'>
2082 <input type='image' name=' $Lang ::tr{'remove'}' src='/images/delete.gif' title=' $Lang ::tr{'remove'}' alt=' $Lang ::tr{'remove'}' />
2083 <input type='hidden' name='MODE' value='TIMECONSTRAINT' />
2084 <input type='hidden' name='ID' value=' $id ' />
2085 <input type='hidden' name='ACTION' value=' $Lang ::tr{'remove'}' />
2092 if ( $tcsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' } && $tcsettings { 'ID' } eq $id ) {
2093 print "<tr bgcolor=' $Header ::colouryellow'> \n " ; }
2095 print "<tr bgcolor=' $Header ::table1colour'> \n " ; }
2097 print "<tr bgcolor=' $Header ::table2colour'> \n " ; }
2099 <td align='center' colspan='4'> $temp [16]
2101 <td align='center' colspan='5'>
2110 # If the time constraint file contains entries, print entries and action icons
2111 if (! - z
" $tcfile " ) {
2116 <td class='boldbase'> <b> $Lang ::tr{'legend'}:</b></td>
2117 <td> <img src='/images/urlfilter/led-green.gif' alt=' $Lang ::tr{'urlfilter allow access'}' /></td>
2118 <td class='base'> $Lang ::tr{'urlfilter allow'}</td>
2119 <td> <img src='/images/urlfilter/led-red.gif' alt=' $Lang ::tr{'urlfilter block access'}' /></td>
2120 <td class='base'> $Lang ::tr{'urlfilter block'}</td>
2121 <td> <img src='/images/on.gif' alt=' $Lang ::tr{'click to disable'}' /></td>
2122 <td class='base'> $Lang ::tr{'click to disable'}</td>
2123 <td> <img src='/images/off.gif' alt=' $Lang ::tr{'click to enable'}' /></td>
2124 <td class='base'> $Lang ::tr{'click to enable'}</td>
2125 <td> <img src='/images/edit.gif' alt=' $Lang ::tr{'edit'}' /></td>
2126 <td class='base'> $Lang ::tr{'edit'}</td>
2127 <td> <img src='/images/urlfilter/copy.gif' alt=' $Lang ::tr{'urlfilter copy rule'}' /></td>
2128 <td class='base'> $Lang ::tr{'urlfilter copy rule'}</td>
2129 <td> <img src='/images/delete.gif' alt=' $Lang ::tr{'remove'}' /></td>
2130 <td class='base'> $Lang ::tr{'remove'}</td>
2137 & Header
:: closebox
();
2139 } elsif ( $uqsettings { 'UQMODE' }) {
2141 #==========================================================
2143 # Section: Set User Quota
2145 #==========================================================
2147 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}'> \n " ;
2149 $buttontext = $Lang :: tr
{ 'urlfilter add rule' };
2150 if ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) {
2151 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter edit user quota rule' }. ':' );
2152 $buttontext = $Lang :: tr
{ 'urlfilter update rule' };
2154 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter add new user quota rule' }. ':' );
2158 <table width='100%'>
2160 <td width='25%'></td> <td width='20%'> </td><td width='25%'> </td><td width='30%'></td>
2163 <td class='base'> $Lang ::tr{'urlfilter user time quota'}: <img src='/blob.gif' alt='*' /></td>
2164 <td><input type='text' name='TIME_QUOTA' value=' $uqsettings {'TIME_QUOTA'}' size='5' /></td>
2165 <td colspan='2' rowspan= '5' valign='top' class='base'>
2166 <table cellpadding='0' cellspacing='0'>
2168 <!-- intentionally left empty -->
2171 <td> $Lang ::tr{'urlfilter assigned quota users'}: <img src='/blob.gif' alt='*' /></td>
2174 <!-- intentionally left empty -->
2177 <!-- intentionally left empty -->
2180 <td><textarea name='QUOTA_USERS' cols='32' rows='6' wrap='off'>
2184 $uqsettings { 'QUOTA_USERS' } =~ s/\|/\n/g ;
2185 print $uqsettings { 'QUOTA_USERS' };
2194 <td class='base'> $Lang ::tr{'urlfilter activity detection'}:</td>
2195 <td class='base'><select name='SPORADIC'>
2196 <option value='0' $selected {'SPORADIC'}{'0'}> $Lang ::tr{'urlfilter disabled'}</option>
2197 <option value='300' $selected {'SPORADIC'}{'300'}>5 $Lang ::tr{'urlfilter minutes'}</option>
2198 <option value='900' $selected {'SPORADIC'}{'900'}>15 $Lang ::tr{'urlfilter minutes'}</option>
2202 <td class='base'> $Lang ::tr{'urlfilter renewal period'}:</td>
2203 <td class='base'><select name='RENEWAL'>
2204 <option value='hourly' $selected {'RENEWAL'}{'hourly'}> $Lang ::tr{'urlfilter hourly'}</option>
2205 <option value='daily' $selected {'RENEWAL'}{'daily'}> $Lang ::tr{'urlfilter daily'}</option>
2206 <option value='weekly' $selected {'RENEWAL'}{'weekly'}> $Lang ::tr{'urlfilter weekly'}</option>
2210 <td colspan='2'> </td>
2213 <td class='base'> $Lang ::tr{'urlfilter enabled'}</td>
2214 <td class='base'><input type='checkbox' name='ENABLEQUOTA' $checked {'ENABLEQUOTA'}{'on'} /></td>
2222 <td><input type='hidden' name='ACTION' value=' $Lang ::tr{'add'}' /></td>
2223 <td><input type='hidden' name='MODE' value='USERQUOTA' /></td>
2224 <td><input type='submit' name='SUBMIT' value=' $buttontext ' /></td>
2225 <td><input type='reset' name='ACTION' value=' $Lang ::tr{'urlfilter reset'}' /></td>
2227 <td><input type='button' name='return2main' value=' $Lang ::tr{'urlfilter back to main page'}' onClick='self.location.href=" $ENV {'SCRIPT_NAME'}"'></td>
2235 if ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' }) {
2236 print "<input type='hidden' name='EDITING' value=' $uqsettings {'ID'}' /> \n " ;
2238 print "<input type='hidden' name='EDITING' value='no' /> \n " ;
2241 & Header
:: closebox
();
2244 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'current rules' });
2246 <table width='100%'>
2248 <td width='15%' class='boldbase' align='center'><b><nobr> $Lang ::tr{'urlfilter time quota'}</nobr></b></td>
2249 <td width='15%' class='boldbase' align='center'><b><nobr> $Lang ::tr{'urlfilter activity detection'}</nobr></b></td>
2250 <td width='10%' class='boldbase' align='center'><b> $Lang ::tr{'urlfilter renewal'}</b></td>
2251 <td class='boldbase' align='center'><b> $Lang ::tr{'urlfilter assigned users'}</b></td>
2252 <td width='20%' class='boldbase' colspan='4' align='center'> </td>
2257 if ( $uqsettings { 'ACTION' } ne '' or $changed ne 'no' )
2259 open ( FILE
, $uqfile );
2265 foreach $line ( @uqlist )
2269 @temp = split ( /\,/ , $line );
2270 if ( $uqsettings { 'ACTION' } eq $Lang :: tr
{ 'edit' } && $uqsettings { 'ID' } eq $id ) {
2271 print "<tr bgcolor=' $Header ::colouryellow'> \n " ; }
2273 print "<tr bgcolor=' $Header ::table1colour'> \n " ; }
2275 print "<tr bgcolor=' $Header ::table2colour'> \n " ; }
2276 if ( $temp [ 4 ] eq 'on' ) { $gif = 'on.gif' ; $toggle = 'off' ; $gdesc = $Lang :: tr
{ 'click to disable' };}
2277 else { $gif = 'off.gif' ; $toggle = 'on' ; $gdesc = $Lang :: tr
{ 'click to enable' }; }
2279 $temp [ 5 ] = $temp [ 1 ];
2280 if ( $temp [ 1 ] eq '0' ) { $temp [ 5 ] = $Lang :: tr
{ 'urlfilter disabled' } } else { $temp [ 5 ] = ( $temp [ 5 ]/ 60 ). ' ' . $Lang :: tr
{ 'urlfilter minutes' } }
2281 $_ = $temp [ 3 ]; s/\|/, /g ; $temp [ 6 ] = $_ ;
2284 <td align='center'> $temp [0] $Lang ::tr{'urlfilter minutes'}</td>
2285 <td align='center'> $temp [5]</td>
2286 <td align='center'> $Lang ::tr{'urlfilter '. $temp [2]}</td>
2287 <td align='center'> $temp [6]</td>
2290 <form method='post' name='frma $id ' action=' $ENV {'SCRIPT_NAME'}'>
2291 <input type='image' name=' $Lang ::tr{'toggle enable disable'}' src='/images/ $gif ' title=' $gdesc ' alt=' $gdesc ' />
2292 <input type='hidden' name='MODE' value='USERQUOTA' />
2293 <input type='hidden' name='ID' value=' $id ' />
2294 <input type='hidden' name='ACTIVE' value=' $toggle ' />
2295 <input type='hidden' name='ACTION' value=' $Lang ::tr{'toggle enable disable'}' />
2300 <form method='post' name='frmb $id ' action=' $ENV {'SCRIPT_NAME'}'>
2301 <input type='image' name=' $Lang ::tr{'edit'}' src='/images/edit.gif' title=' $Lang ::tr{'edit'}' alt=' $Lang ::tr{'edit'}' />
2302 <input type='hidden' name='MODE' value='USERQUOTA' />
2303 <input type='hidden' name='ID' value=' $id ' />
2304 <input type='hidden' name='ACTION' value=' $Lang ::tr{'edit'}' />
2309 <form method='post' name='frmc $id ' action=' $ENV {'SCRIPT_NAME'}'>
2310 <input type='image' name=' $Lang ::tr{'remove'}' src='/images/delete.gif' title=' $Lang ::tr{'remove'}' alt=' $Lang ::tr{'remove'}' />
2311 <input type='hidden' name='MODE' value='USERQUOTA' />
2312 <input type='hidden' name='ID' value=' $id ' />
2313 <input type='hidden' name='ACTION' value=' $Lang ::tr{'remove'}' />
2324 # If the user quota file contains entries, print entries and action icons
2325 if (! - z
" $uqfile " ) {
2330 <td class='boldbase'> <b> $Lang ::tr{'legend'}:</b></td>
2331 <td> <img src='/images/on.gif' alt=' $Lang ::tr{'click to disable'}' /></td>
2332 <td class='base'> $Lang ::tr{'click to disable'}</td>
2333 <td> <img src='/images/off.gif' alt=' $Lang ::tr{'click to enable'}' /></td>
2334 <td class='base'> $Lang ::tr{'click to enable'}</td>
2335 <td> <img src='/images/edit.gif' alt=' $Lang ::tr{'edit'}' /></td>
2336 <td class='base'> $Lang ::tr{'edit'}</td>
2337 <td> <img src='/images/delete.gif' alt=' $Lang ::tr{'remove'}' /></td>
2338 <td class='base'> $Lang ::tr{'remove'}</td>
2345 & Header
:: closebox
();
2349 #==========================================================
2351 # Section: Blacklist editor
2353 #==========================================================
2355 print "<form method='post' action=' $ENV {'SCRIPT_NAME'}' enctype='multipart/form-data'> \n " ;
2357 & Header
:: openbox
( '100%' , 'left' , $Lang :: tr
{ 'urlfilter urlfilter blacklist editor' }. ':' );
2361 <table width='100%'>
2363 <td width='25%'></td> <td width='20%'> </td><td width='25%'> </td><td width='30%'></td>
2366 <td class='base'><b> $Lang ::tr{'urlfilter blacklist name'}</b></td>
2369 <td class='base'> $Lang ::tr{'urlfilter blacklist category name'}: <img src='/blob.gif' alt='*' /></td>
2370 <td><input type='text' name='BE_NAME' value=' $besettings {'BE_NAME'}' size='12' /></td>
2374 <table width='100%'>
2376 <td width='25%'></td> <td width='20%'> </td><td width='25%'> </td><td width='20%'></td>
2379 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter edit domains urls expressions'}</b> <img src='/blob.gif' alt='*' /></td>
2382 <td colspan='2'> $Lang ::tr{'urlfilter domains'}</td>
2383 <td colspan='2'> $Lang ::tr{'urlfilter urls'}</td>
2386 <td colspan='2'><textarea name='BE_DOMAINS' cols='38' rows='10' wrap='off'>
2390 print $besettings { 'BE_DOMAINS' };
2394 <td colspan='2'><textarea name='BE_URLS' cols='38' rows='10' wrap='off'>
2398 print $besettings { 'BE_URLS' };
2404 <td colspan='4'> $Lang ::tr{'urlfilter expressions'}</td>
2407 <td colspan='4'><textarea name='BE_EXPRESSIONS' cols='80' rows='3' wrap='off'>
2411 print $besettings { 'BE_EXPRESSIONS' };
2418 <table width='100%'>
2420 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter load blacklist'}</b></td>
2423 <td width='25%' class='base'> $Lang ::tr{'urlfilter select blacklist'}:</td>
2424 <td width='20%' class='base'>
2425 <select name='BE_BLACKLIST'>
2429 & readblockcategories
;
2430 foreach ( @categories )
2432 print "<option value=' $_ ' $selected {'BE_BLACKLIST'}{ $_ }> $_ </option> \n " ;
2441 <td colpsan='4'><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter load blacklist'}' /></td>
2446 <table width='100%'>
2448 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter import blacklist'}</b></td>
2451 <td colspan='4'> $Lang ::tr{'urlfilter import text'}:</td>
2454 <td nowrap><input type='file' name='IMPORTFILE' size='40' /> <input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter import blacklist'}' /></td>
2455 <td><input type='hidden' name='MODE' value='BLACKLIST_EDITOR' /></td>
2459 <table width='100%'>
2461 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter export blacklist'}</b></td>
2464 <td><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter export blacklist'}' /></td>
2468 <table width='100%'>
2470 <td class='base' colspan='4'><b> $Lang ::tr{'urlfilter install blacklist'}</b></td>
2473 <td width='25%' class='base'> $Lang ::tr{'urlfilter dont restart urlfilter'}:</td>
2474 <td width='20%' class='base'><input type='checkbox' name='NORESTART' $checked {'NORESTART'}{'on'} /></td>
2479 <td><input type='submit' name='ACTION' value=' $Lang ::tr{'urlfilter install blacklist'}' /></td>
2482 <td class='base' colspan='4'><br> $Lang ::tr{'urlfilter install information'}</td>
2488 <td><input type='reset' name='ACTION' value=' $Lang ::tr{'urlfilter reset'}' /></td>
2490 <td><input type='button' name='return2main' value=' $Lang ::tr{'urlfilter back to main page'}' onClick='self.location.href=" $ENV {'SCRIPT_NAME'}"'></td>
2497 & Header
:: closebox
();
2502 & Header
:: closebigbox
();
2504 & Header
:: closepage
();
2506 # -------------------------------------------------------------------
2510 # transform to pre1.8 client definitions
2511 @clients = split ( /\n/ , $filtersettings { 'UNFILTERED_CLIENTS' });
2512 undef $filtersettings { 'UNFILTERED_CLIENTS' };
2515 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
2516 $filtersettings { 'UNFILTERED_CLIENTS' } .= " $_ " ;
2518 $filtersettings { 'UNFILTERED_CLIENTS' } =~ s/\s+$// ;
2520 # transform to pre1.8 client definitions
2521 @clients = split ( /\n/ , $filtersettings { 'BANNED_CLIENTS' });
2522 undef $filtersettings { 'BANNED_CLIENTS' };
2525 s/^\s+//g ; s/\s+$//g ; s/\s+-\s+/-/g ; s/\s+/ /g ; s/\n//g ;
2526 $filtersettings { 'BANNED_CLIENTS' } .= " $_ " ;
2528 $filtersettings { 'BANNED_CLIENTS' } =~ s/\s+$// ;
2532 delete $filtersettings { 'CUSTOM_BLACK_DOMAINS' };
2533 delete $filtersettings { 'CUSTOM_BLACK_URLS' };
2534 delete $filtersettings { 'CUSTOM_WHITE_DOMAINS' };
2535 delete $filtersettings { 'CUSTOM_WHITE_URLS' };
2536 delete $filtersettings { 'CUSTOM_EXPRESSIONS' };
2537 delete $filtersettings { 'BACKGROUND' };
2538 delete $filtersettings { 'UPDATEFILE' };
2540 & General
:: system ( "chown" , "-R" , "nobody.nobody" , " $dbdir " );
2541 & General
:: system ( '/usr/bin/squidGuard' , '-C' , 'custom/allowed/domains' );
2542 & General
:: system ( '/usr/bin/squidGuard' , '-C' , 'custom/allowed/urls' );
2543 & General
:: system ( '/usr/bin/squidGuard' , '-C' , 'custom/blocked/domains' );
2544 & General
:: system ( '/usr/bin/squidGuard' , '-C' , 'custom/blocked/urls' );
2545 & setpermissions
( $dbdir );
2547 & General
:: writehash
( "${General::swroot}/urlfilter/settings" , \
%filtersettings );
2550 # -------------------------------------------------------------------
2552 sub readblockcategories
2556 & getblockcategory
( $dbdir );
2558 foreach ( @categories ) { $_ = substr ( $_ , length ( $dbdir )+ 1 ); }
2560 @filtergroups = @categories ;
2562 foreach ( @filtergroups ) {
2569 # -------------------------------------------------------------------
2571 sub getblockcategory
2573 foreach $category (< $_ [ 0 ]/*>)
2577 if ((- e
" $category /domains" ) || (- e
" $category /urls" ))
2579 unless ( $category =~ /\bcustom\b/ ) { push ( @categories , $category ); }
2581 & getblockcategory
( $category );
2586 # -------------------------------------------------------------------
2590 if (- e
" $dbdir /custom/blocked/domains" ) {
2591 open ( FILE
, " $dbdir /custom/blocked/domains" );
2592 delete $filtersettings { 'CUSTOM_BLACK_DOMAINS' };
2593 while (< FILE
>) { $filtersettings { 'CUSTOM_BLACK_DOMAINS' } .= $_ };
2597 if (- e
" $dbdir /custom/blocked/urls" ) {
2598 open ( FILE
, " $dbdir /custom/blocked/urls" );
2599 delete $filtersettings { 'CUSTOM_BLACK_URLS' };
2600 while (< FILE
>) { $filtersettings { 'CUSTOM_BLACK_URLS' } .= $_ };
2604 if (- e
" $dbdir /custom/blocked/expressions" ) {
2605 open ( FILE
, " $dbdir /custom/blocked/expressions" );
2606 delete $filtersettings { 'CUSTOM_EXPRESSIONS' };
2607 while (< FILE
>) { $filtersettings { 'CUSTOM_EXPRESSIONS' } .= $_ };
2611 if (- e
" $dbdir /custom/allowed/domains" ) {
2612 open ( FILE
, " $dbdir /custom/allowed/domains" );
2613 delete $filtersettings { 'CUSTOM_WHITE_DOMAINS' };
2614 while (< FILE
>) { $filtersettings { 'CUSTOM_WHITE_DOMAINS' } .= $_ };
2617 if (- e
" $dbdir /custom/allowed/urls" ) {
2618 open ( FILE
, " $dbdir /custom/allowed/urls" );
2619 delete $filtersettings { 'CUSTOM_WHITE_URLS' };
2620 while (< FILE
>) { $filtersettings { 'CUSTOM_WHITE_URLS' } .= $_ };
2625 # -------------------------------------------------------------------
2627 sub aggregatedconstraints
2647 @tmp1 = split ( /\,/ , $x );
2651 @tmp2 = split ( /\,/ );
2652 if (( $tmp1 [ 15 ] eq 'on' ) && ( $tmp2 [ 15 ] eq 'on' ))
2654 if (( $tmp1 [ 0 ] eq $tmp2 [ 0 ]) && ( $tmp1 [ 12 ] eq $tmp2 [ 12 ]) && ( $tmp1 [ 13 ] eq $tmp2 [ 13 ]) && ( $tmp1 [ 14 ] eq $tmp2 [ 14 ]))
2657 $tmp2 [ 16 ] .= " weekly " ;
2658 if ( $tmp1 [ 1 ] eq 'on' ) { $tmp2 [ 16 ] .= "m" ; }
2659 if ( $tmp1 [ 2 ] eq 'on' ) { $tmp2 [ 16 ] .= "t" ; }
2660 if ( $tmp1 [ 3 ] eq 'on' ) { $tmp2 [ 16 ] .= "w" ; }
2661 if ( $tmp1 [ 4 ] eq 'on' ) { $tmp2 [ 16 ] .= "h" ; }
2662 if ( $tmp1 [ 5 ] eq 'on' ) { $tmp2 [ 16 ] .= "f" ; }
2663 if ( $tmp1 [ 6 ] eq 'on' ) { $tmp2 [ 16 ] .= "a" ; }
2664 if ( $tmp1 [ 7 ] eq 'on' ) { $tmp2 [ 16 ] .= "s" ; }
2665 $tmp2 [ 16 ] .= " $tmp1 [8]: $tmp1 [9]- $tmp1 [10]: $tmp1 [11] \n " ;
2666 $_ = join ( "," , @tmp2 );
2673 $tmp1 [ 16 ] .= " weekly " ;
2674 if ( $tmp1 [ 1 ] eq 'on' ) { $tmp1 [ 16 ] .= "m" ; }
2675 if ( $tmp1 [ 2 ] eq 'on' ) { $tmp1 [ 16 ] .= "t" ; }
2676 if ( $tmp1 [ 3 ] eq 'on' ) { $tmp1 [ 16 ] .= "w" ; }
2677 if ( $tmp1 [ 4 ] eq 'on' ) { $tmp1 [ 16 ] .= "h" ; }
2678 if ( $tmp1 [ 5 ] eq 'on' ) { $tmp1 [ 16 ] .= "f" ; }
2679 if ( $tmp1 [ 6 ] eq 'on' ) { $tmp1 [ 16 ] .= "a" ; }
2680 if ( $tmp1 [ 7 ] eq 'on' ) { $tmp1 [ 16 ] .= "s" ; }
2681 $tmp1 [ 16 ] .= " $tmp1 [8]: $tmp1 [9]- $tmp1 [10]: $tmp1 [11] \n " ;
2682 $x = join ( "," , @tmp1 );
2692 # -------------------------------------------------------------------
2698 foreach $category (< $bldir /*>)
2701 & General
:: system ( "chmod" , "755" , " $category " );
2702 foreach $blacklist (< $category /*>)
2704 if (- f
$blacklist ) { & General
:: system ( "chmod" , "644" , " $blacklist " ); }
2705 if (- d
$blacklist ) { & General
:: system ( "chmod" , "755" , " $blacklist " ); }
2708 system ( "chmod 666 $category /*.db &> /dev/null" );
2709 & setpermissions
( $category );
2714 # -------------------------------------------------------------------
2718 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\)\$" ;
2719 my $audiovideo = "/[^/]* \\ .\(aiff|asf|avi|dif|divx|flv|mkv|mov|movie|mp3|mp4|mpe?g?|mpv2|ogg|ra?m|snd|qt|wav|wma|wmf|wmv\)\$" ;
2720 my $archives = "/[^/]* \\ .\(7z|bin|bz2|cab|cdr|dmg|gz|hqx|rar|smi|sit|sea|tar|tgz|zip\)\$" ;
2722 my $ident = " anonymous" ;
2735 if (!(- d
" $dbdir /custom" )) { mkdir ( " $dbdir /custom" ) }
2736 if (!(- d
" $dbdir /custom/blocked" )) { mkdir ( " $dbdir /custom/blocked" ) }
2737 if (!(- d
" $dbdir /custom/allowed" )) { mkdir ( " $dbdir /custom/allowed" ) }
2739 open ( FILE
, ">/ $dbdir /custom/blocked/domains" );
2740 print FILE
$filtersettings { 'CUSTOM_BLACK_DOMAINS' };
2742 open ( FILE
, ">/ $dbdir /custom/blocked/urls" );
2743 print FILE
$filtersettings { 'CUSTOM_BLACK_URLS' };
2745 open ( FILE
, ">/ $dbdir /custom/blocked/expressions" );
2746 print FILE
$filtersettings { 'CUSTOM_EXPRESSIONS' };
2748 open ( FILE
, ">/ $dbdir /custom/blocked/files" );
2749 if ( $filtersettings { 'BLOCK_EXECUTABLES' } eq 'on' ) { print FILE
" $executables \n " ; }
2750 if ( $filtersettings { 'BLOCK_AUDIO-VIDEO' } eq 'on' ) { print FILE
" $audiovideo \n " ; }
2751 if ( $filtersettings { 'BLOCK_ARCHIVES' } eq 'on' ) { print FILE
" $archives \n " ; }
2753 open ( FILE
, ">/ $dbdir /custom/allowed/domains" );
2754 print FILE
$filtersettings { 'CUSTOM_WHITE_DOMAINS' };
2756 open ( FILE
, ">/ $dbdir /custom/allowed/urls" );
2757 print FILE
$filtersettings { 'CUSTOM_WHITE_URLS' };
2760 if ( $filtersettings { 'ENABLE_USERNAME_LOG' } eq 'on' ) { $ident = "" ; }
2762 if ( $filtersettings { 'REDIRECT_PAGE' } eq '' )
2764 if (( $filtersettings { 'SHOW_CATEGORY' } eq 'on' ) || ( $filtersettings { 'SHOW_URL' } eq 'on' ) || ( $filtersettings { 'SHOW_IP' } eq 'on' )) {
2765 if ( $filtersettings { 'SHOW_CATEGORY' } eq 'on' ) { $redirect .= "&category= %t " ; }
2766 if ( $filtersettings { 'SHOW_URL' } eq 'on' ) { $redirect .= "&url= %u " ; }
2767 if ( $filtersettings { 'SHOW_IP' } eq 'on' ) { $redirect .= "&ip= %a " ; }
2768 $redirect =~ s/^&/?/ ;
2769 $redirect = "http:\/\/ $netsettings {'GREEN_ADDRESS'}: $http_port \/redirect.cgi" . $redirect ;
2771 $redirect = "http:\/\/ $netsettings {'GREEN_ADDRESS'}: $http_port \/redirect.cgi" ;
2773 } else { $redirect = $filtersettings { 'REDIRECT_PAGE' }; }
2775 if ( $filtersettings { 'ENABLE_DNSERROR' } eq 'on' ) { $redirect = "302:http://0.0.0.0" ; }
2779 if ( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' )
2781 $defaultrule .= "custom-allowed " ;
2783 if ( $filtersettings { 'BLOCK_ALL' } eq 'on' )
2785 $defaultrule .= "none" ;
2789 if ( $filtersettings { 'BLOCK_IP_ADDR' } eq 'on' )
2791 $defaultrule .= "!in-addr " ;
2793 for ( $i = 0 ; $i <= @filtergroups ; $i ++) {
2794 if ( $filtersettings { @filtergroups [ $i ]} eq 'on' )
2796 $defaultrule .= "! @categories [ $i ] " ;
2799 if ( $filtersettings { 'ENABLE_CUSTOM_BLACKLIST' } eq 'on' )
2801 $defaultrule .= "!custom-blocked " ;
2803 if ( $filtersettings { 'ENABLE_CUSTOM_EXPRESSIONS' } eq 'on' )
2805 $defaultrule .= "!custom-expressions " ;
2807 if (( $filtersettings { 'BLOCK_EXECUTABLES' } eq 'on' ) ||
2808 ( $filtersettings { 'BLOCK_AUDIO-VIDEO' } eq 'on' ) ||
2809 ( $filtersettings { 'BLOCK_ARCHIVES' } eq 'on' ))
2811 $defaultrule .= "!files " ;
2813 $defaultrule .= "any" ;
2816 $defaultrule =~ s/\// _
/ g
;
2818 open ( FILE
, ">${General::swroot}/urlfilter/squidGuard.conf" ) or die "Unable to write squidGuard.conf file" ;
2821 print FILE
"logdir /var/log/squidGuard \n " ;
2822 print FILE
"dbhome $dbdir \n\n " ;
2824 undef @repositoryfiles ;
2825 if ( $filtersettings { 'ENABLE_REWRITE' } eq 'on' )
2827 @repositorylist = < $repository /*>;
2828 foreach ( @repositorylist )
2830 if (!- d
) { push ( @repositoryfiles , substr ( $_ , rindex ( $_ , "/" )+ 1 )); }
2834 if (( $filtersettings { 'ENABLE_REWRITE' } eq 'on' ) && ( @repositoryfiles )) {
2835 print FILE
"rewrite rew-rule-1 { \n " ;
2837 print FILE
" # rewrite localfiles \n " ;
2838 foreach ( @repositoryfiles )
2840 print FILE
" s@.*/ $_ \$\ @http :// $netsettings {'GREEN_ADDRESS'}: $http_port /repository/ $_ \ @i \n " ;
2845 if (!( $filtersettings { 'UNFILTERED_CLIENTS' } eq '' )) {
2846 print FILE
"src unfiltered { \n " ;
2847 print FILE
" ip $filtersettings {'UNFILTERED_CLIENTS'} \n " ;
2850 if (!( $filtersettings { 'BANNED_CLIENTS' } eq '' )) {
2851 print FILE
"src banned { \n " ;
2852 print FILE
" ip $filtersettings {'BANNED_CLIENTS'} \n " ;
2853 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
2855 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
2857 print FILE
" logfile " . $ident . " banned.log \n " ;
2859 print FILE
" logfile " . $ident . " urlfilter.log \n " ;
2881 $uq [ 0 ] = $uq [ 0 ] * 60 ;
2882 if ( $uq [ 1 ] eq '0' ) {
2883 if ( $uq [ 2 ] eq 'hourly' ) { $uq [ 1 ] = 3600 }
2884 if ( $uq [ 2 ] eq 'daily' ) { $uq [ 1 ] = 86400 }
2885 if ( $uq [ 2 ] eq 'weekly' ) { $uq [ 1 ] = 604800 }
2888 print FILE
"src quota- $idx { \n " ;
2889 print FILE
" user $uq [3] \n " ;
2890 print FILE
" userquota $uq [0] $uq [1] $uq [2] \n " ;
2898 @tclist = & aggregatedconstraints
;
2907 if ( $tc [ 15 ] eq 'on' )
2910 print FILE
"src network- $idx { \n " ;
2911 @clients = split ( / / , $tc [ 12 ]);
2912 @temp = split ( /-/ , $clients [ 0 ]);
2913 if ( (& General
:: validipormask
( $temp [ 0 ])) || (& General
:: validipandmask
( $temp [ 0 ])))
2915 print FILE
" ip $tc [12] \n " ;
2918 @clients = split ( / / , $tc [ 12 ]);
2919 foreach $line ( @clients )
2921 $line =~ s/(^\w+)\\(\w+$)/$1%5c$2/ ;
2922 print FILE
" $line " ;
2926 if (( $filtersettings { 'ENABLE_LOG' } eq 'on' ) && ( $tc [ 14 ] eq 'block' ) && ( $tc [ 13 ] eq 'any' ))
2928 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
2930 print FILE
" logfile " . $ident . " timeconst.log \n " ;
2932 print FILE
" logfile " . $ident . " urlfilter.log \n " ;
2944 if ( $tc [ 15 ] eq 'on' )
2947 print FILE
"time constraint- $idx { \n " ;
2948 print FILE
" $tc [16] \n " ;
2954 foreach $category ( @categories ) {
2955 $blacklist = $category ;
2956 $category =~ s/\// _
/ g
;
2958 if ( $filtersettings { "FILTER_" . uc ( $category )} ne "on" ){
2959 my $constraintrule = "false" ;
2964 $tc [ 13 ] =~ s/\// _
/ g
;
2965 if ( $tc [ 15 ] eq 'on' && $tc [ 13 ] =~ $category ){
2966 $constraintrule = "true" ;
2970 if ( $constraintrule eq "false" ){
2975 print FILE
"dest $category { \n " ;
2976 if (- e
" $dbdir / $blacklist /domains" ) {
2977 print FILE
" domainlist $blacklist \/domains \n " ;
2979 if (- e
" $dbdir / $blacklist /urls" ) {
2980 print FILE
" urllist $blacklist \/urls \n " ;
2982 if ((- e
" $dbdir / $blacklist /expressions" ) && ( $filtersettings { 'ENABLE_EXPR_LISTS' } eq 'on' )) {
2983 print FILE
" expressionlist $blacklist \/expressions \n " ;
2985 if ((( $category eq 'ads' ) || ( $category eq 'adv' )) && ( $filtersettings { 'ENABLE_EMPTY_ADS' } eq 'on' ))
2987 print FILE
" redirect http:\/\/ $netsettings {'GREEN_ADDRESS'}: $http_port \/images/urlfilter/1x1.gif \n " ;
2989 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
2991 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
2993 print FILE
" logfile $ident $category .log \n " ;
2995 print FILE
" logfile $ident urlfilter.log \n " ;
2999 $category = $blacklist ;
3002 print FILE
"dest files { \n " ;
3003 print FILE
" expressionlist custom\/blocked\/files \n " ;
3004 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
3006 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3008 print FILE
" logfile $ident files.log \n " ;
3010 print FILE
" logfile $ident urlfilter.log \n " ;
3015 print FILE
"dest custom-allowed { \n " ;
3016 print FILE
" domainlist custom\/allowed\/domains \n " ;
3017 print FILE
" urllist custom\/allowed\/urls \n " ;
3020 print FILE
"dest custom-blocked { \n " ;
3021 print FILE
" domainlist custom\/blocked\/domains \n " ;
3022 print FILE
" urllist custom\/blocked\/urls \n " ;
3023 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
3025 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3027 print FILE
" logfile $ident custom.log \n " ;
3029 print FILE
" logfile $ident urlfilter.log \n " ;
3034 print FILE
"dest custom-expressions { \n " ;
3035 print FILE
" expressionlist custom\/blocked\/expressions \n " ;
3036 if ( $filtersettings { 'ENABLE_LOG' } eq 'on' )
3038 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3040 print FILE
" logfile $ident custom.log \n " ;
3042 print FILE
" logfile $ident urlfilter.log \n " ;
3047 print FILE
"acl { \n " ;
3048 if (!( $filtersettings { 'UNFILTERED_CLIENTS' } eq '' )) {
3049 print FILE
" unfiltered { \n " ;
3050 print FILE
" pass all \n " ;
3051 print FILE
" } \n\n " ;
3053 if (!( $filtersettings { 'BANNED_CLIENTS' } eq '' )) {
3054 print FILE
" banned { \n " ;
3055 print FILE
" pass " ;
3056 if (( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' ) && ( $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } eq 'on' ))
3058 print FILE
"custom-allowed " ;
3060 print FILE
"none \n " ;
3061 print FILE
" } \n\n " ;
3078 $qredirect = $redirect ;
3079 $qredirect =~ s/\%t/\%q\%20-\%20\%i/ ;
3080 print FILE
" quota- $idx { \n " ;
3081 print FILE
" pass " ;
3082 if (( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' ) && ( $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } eq 'on' ))
3084 print FILE
"custom-allowed " ;
3086 print FILE
"none \n " ;
3087 unless ( $redirect eq $qredirect ) { print FILE
" redirect $qredirect \n " ; }
3088 print FILE
" } \n\n " ;
3100 @ec = split ( /\|/ , $tc [ 13 ]);
3101 foreach ( @ec ) { s/\// _
/ g
; }
3102 if ( $tc [ 15 ] eq 'on' )
3105 print FILE
" network- $idx $tc [0] constraint- $idx { \n " ;
3106 print FILE
" pass " ;
3108 if ( $filtersettings { 'BLOCK_ALL' } eq 'on' )
3110 if ( $tc [ 14 ] eq 'block' )
3112 if (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' )) {
3113 if (( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' ) && ( $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } eq 'on' ))
3115 print FILE
"custom-allowed " ;
3119 print FILE
$defaultrule ;
3126 print FILE
$defaultrule unless (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' ));
3129 if ( $tc [ 14 ] eq 'block' )
3131 $tcrule = $defaultrule ;
3132 if ( $filtersettings { 'ENABLE_CUSTOM_WHITELIST' } eq 'on' ) {
3133 $tcrule =~ s/custom-allowed // ;
3134 print FILE
"custom-allowed " unless (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' ) && ( $filtersettings { 'ENABLE_GLOBAL_WHITELIST' } eq 'off' ));
3136 if (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' )) {
3141 print FILE
"! $_ " unless ( index ( $defaultrule , "!" . $_ . " " ) ge 0 );
3144 print FILE
$tcrule unless (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' ));
3146 $tcrule = $defaultrule ;
3147 if (( @ec == 1 ) && ( $ec [ 0 ] eq 'any' ))
3153 $tcrule = " $_ " . $tcrule unless ( index ( $defaultrule , "!" . $_ . " " ) ge 0 );
3154 $tcrule =~ s/!$_ // ;
3163 print FILE
" } \n\n " ;
3168 print FILE
" default { \n " ;
3169 print FILE
" pass $defaultrule \n " ;
3170 if (( $filtersettings { 'ENABLE_LOG' } eq 'on' ) && ( $filtersettings { 'BLOCK_ALL' } eq 'on' ))
3172 if ( $filtersettings { 'ENABLE_CATEGORY_LOG' } eq 'on' )
3174 print FILE
" logfile" . $ident . " default.log \n " ;
3176 print FILE
" logfile" . $ident . " urlfilter.log \n " ;
3179 if (( $filtersettings { 'ENABLE_REWRITE' } eq 'on' ) && ( @repositoryfiles ))
3181 print FILE
" rewrite rew-rule-1 \n " ;
3183 print FILE
" redirect $redirect \n " ;
3190 # -------------------------------------------------------------------