mirror of
https://github.com/webmin/webmin.git
synced 2025-07-21 23:40:34 +00:00
52 lines
1.4 KiB
Perl
Executable File
52 lines
1.4 KiB
Perl
Executable File
#!/usr/local/bin/perl
|
|
# http_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{'sahttp_ftspr'});
|
|
|
|
my @https = &find_config("http_access", $conf);
|
|
my ($http, %used);
|
|
if (defined($in{'index'})) {
|
|
$http = $conf->[$in{'index'}];
|
|
}
|
|
if ($in{'delete'}) {
|
|
# delete this restriction
|
|
splice(@https, &indexof($http, @https), 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 $newhttp = { 'name' => 'http_access', 'values' => \@vals };
|
|
if ($http) { splice(@https, &indexof($http, @https), 1, $newhttp); }
|
|
else { push(@https, $newhttp); }
|
|
}
|
|
|
|
# Find the last referenced ACL
|
|
my @acls = grep { $used{$_->{'values'}->[0]} } &find_config("acl", $conf);
|
|
my $lastacl = @acls ? $acls[$#acls] : undef;
|
|
|
|
&save_directive($conf, "http_access", \@https, $lastacl);
|
|
&flush_file_lines();
|
|
&unlock_file($config{'squid_conf'});
|
|
&webmin_log($in{'delete'} ? 'delete' : $http ? 'modify' : 'create', "http");
|
|
&redirect("edit_acl.cgi?mode=http");
|
|
|