mirror of
https://github.com/webmin/webmin.git
synced 2026-05-06 15:20:29 +01:00
Fix nftables direct-mode operations so create, edit, delete, and move actions apply only the selected table instead of rewriting or applying the full ruleset. This avoids copying firewalld-owned rules, or any other externally managed rules, into Webmin’s save file and prevents operations from failing against externally managed tables. Also remove previously added unsafe full-ruleset flush action and keep Apply Configuration out of direct mode (will be further reworked).
54 lines
1.5 KiB
Perl
Executable File
54 lines
1.5 KiB
Perl
Executable File
#!/usr/bin/perl
|
|
# delete_sets.cgi
|
|
# Delete selected nftables sets
|
|
|
|
require './nftables-lib.pl'; ## no critic
|
|
use strict;
|
|
use warnings;
|
|
our (%in, %text);
|
|
ReadParse();
|
|
error_setup($text{'delete_sets_err'});
|
|
|
|
my @tables = get_nftables_save();
|
|
my $table_idx = $in{'table'};
|
|
my $table;
|
|
if (defined($in{'table_family'}) && defined($in{'table_name'})) {
|
|
for (my $i = 0; $i <= $#tables; $i++) {
|
|
if ($tables[$i]->{'family'} eq $in{'table_family'} &&
|
|
$tables[$i]->{'name'} eq $in{'table_name'}) {
|
|
$table_idx = $i;
|
|
$table = $tables[$i];
|
|
last;
|
|
}
|
|
}
|
|
}
|
|
$table ||= $tables[$table_idx];
|
|
$table || error($text{'set_notable'});
|
|
|
|
my @sets = split(/\0/, $in{'s'} || "");
|
|
my %seen;
|
|
@sets = grep { defined($_) && $_ ne '' && !$seen{$_}++ } @sets;
|
|
@sets || error($text{'delete_sets_enone'});
|
|
|
|
foreach my $s (@sets) {
|
|
$table->{'sets'}->{$s} || error(text('delete_sets_noset', $s));
|
|
}
|
|
|
|
my $refs = 0;
|
|
foreach my $s (@sets) {
|
|
$refs += count_set_references($table, $s);
|
|
}
|
|
$refs && error(text('delete_sets_inuse', $refs));
|
|
|
|
foreach my $s (@sets) {
|
|
delete($table->{'sets'}->{$s});
|
|
}
|
|
|
|
my $err = save_table_configuration($table, @tables);
|
|
error(text('delete_sets_failed', $err)) if ($err);
|
|
webmin_log("delete", "sets", scalar(@sets),
|
|
{ 'table' => $table->{'name'},
|
|
'family' => $table->{'family'} });
|
|
redirect("index.cgi?table_family=".urlize($table->{'family'}).
|
|
"&table_name=".urlize($table->{'name'})."&view=sets");
|