%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
| Server IP : 49.231.201.246 / Your IP : 216.73.216.146 Web Server : Apache/2.4.18 (Ubuntu) System : Linux 246 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : root ( 0) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : exec,passthru,shell_exec,system,proc_open,popen,pcntl_exec MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /proc/thread-self/root/proc/self/root/usr/share/webmin/squid/ |
Upload File : |
#!/usr/bin/perl
# icp_access_save.cgi
# Save or delete a proxy restriction
use strict;
use warnings;
no warnings 'redefine';
no warnings 'uninitialized';
our (%text, %in, %access, $squid_version, %config);
require './squid-lib.pl';
$access{'actrl'} || &error($text{'eacl_ecannot'});
&ReadParse();
&lock_file($config{'squid_conf'});
my $conf = &get_config();
&error_setup($text{'saicp_ftsir'});
my @icps = &find_config("icp_access", $conf);
my ($icp, %used);
if (defined($in{'index'})) {
$icp = $conf->[$in{'index'}];
}
if ($in{'delete'}) {
# delete this restriction
splice(@icps, &indexof($icp, @icps), 1);
}
else {
# update or create
my @vals = ( $in{'action'} );
foreach my $y (split(/\0/, $in{'yes'})) {
push(@vals, $y);
$used{$y}++;
}
foreach my $n (split(/\0/, $in{'no'})) {
push(@vals, "!$n");
$used{$n}++;
}
my $newicp = { 'name' => 'icp_access', 'values' => \@vals };
if ($icp) { splice(@icps, &indexof($icp, @icps), 1, $newicp); }
else { push(@icps, $newicp); }
}
# Find the last referenced ACL
my @acls = grep { $used{$_->{'values'}->[0]} } &find_config("acl", $conf);
my $lastacl = @acls ? $acls[$#acls] : undef;
&save_directive($conf, "icp_access", \@icps, $lastacl);
&flush_file_lines();
&unlock_file($config{'squid_conf'});
&webmin_log($in{'delete'} ? 'delete' : $icp ? 'modify' : 'create', "icp");
&redirect("edit_acl.cgi?mode=icp");