# debians-linux-lib.pl # Deal with debian's iptables save file and startup script &foreign_require("init"); if ($gconfig{'os_version'} >= 3.1 && !-r "/etc/init.d/ip${ipvx}tables" && !-r "/etc/init.d/webmin-ip${ipvx}tables" && !$config{'force_init'} && !-d "/etc/netplan" && !-d "/etc/iptables") { # In newer Debians, IPtable is started by the network init script, # unless netplan is in use $has_new_debian_iptables = 1; $ip6tables_save_file = "/etc/ip6tables.up.rules"; $iptables_save_file = "/etc/iptables.up.rules"; $debian_init_script = "ip${ipvx}tables"; } elsif (-d "/etc/iptables") { # Ubuntu 20 uses files in /etc/iptables if iptables-persistent is # installed. However, on Debian 10 there is no init script! $ip6tables_save_file = "/etc/iptables/rules.v6"; $iptables_save_file = "/etc/iptables/rules.v4"; $debian_init_script = $ipvx == 4 ? "iptables" : "ip6tables"; } else { # Older Debians use an init script $has_debian_iptables = -r "/etc/init.d/iptables"; $debian_ip6tables_dir = "/var/lib/ip6tables"; $debian_iptables_dir = "/var/lib/iptables"; if ($has_debian_iptables) { $debian_init_script = "iptables"; mkdir($debian_ip6tables_dir, 0755) if (!-d $debian_ip6tables_dir); mkdir($debian_iptables_dir, 0755) if (!-d $debian_iptables_dir); $iptables_save_file = "$debian_iptables_dir/active"; $ip6tables_save_file = "$debian_ip6tables_dir/active"; } } if (!&init::action_status($debian_init_script)) { # Expected script doesn't exist! $debian_init_script = undef; } # apply_iptables() # Applies the current iptables configuration from the save file sub apply_iptables { if ($debian_init_script) { my ($ok, $err) = &init::restart_action($debian_init_script); return $ok ? undef : &html_escape($err); } else { return &iptables_restore(); } } # unapply_iptables() # Writes the current iptables configuration to the save file sub unapply_iptables { if ($has_debian_iptables) { # On some debian versions the init script can do this $out = &backquote_logged("cd / ; /etc/init.d/ip${ipvx}tables save active 2>&1 </dev/null"); return $? ? "<pre>$out</pre>" : undef; } else { return &iptables_save(); } } # started_at_boot() sub started_at_boot { if ($debian_init_script) { # Check Debian init script return &init::action_status($debian_init_script) == 2; } elsif ($has_new_debian_iptables) { # Check network interface config local $pri = &get_primary_network_interface(); local ($debpri) = grep { $_->[0] eq $pri->{'fullname'} } &net::get_interface_defs(); foreach my $o (@{$debpri->[3]}) { if (($o->[0] eq "pre-up" || $o->[0] eq "post-up") && $o->[1] =~ /\S*ip${ipvx}tables-restore\s+<\s+(\S+)/ && $1 eq $ipvx_save) { return 1; } } } else { # Check Webmin init script return &init::action_status("webmin-ip${ipvx}tables") == 2; } } sub enable_at_boot { if ($debian_init_script) { # Enable the init script (assumes it exists) &init::action_status($debian_init_script) > 0 || &error("Bootup action $debian_init_script does not exist"); &init::enable_at_boot($debian_init_script); } elsif ($has_new_debian_iptables) { # Add to network interface config local $pri = &get_primary_network_interface(); local ($debpri) = grep { $_->[0] eq $pri->{'fullname'} } &net::get_interface_defs(); if ($debpri && !&started_at_boot()) { my ($name, $addrfam, $method, $options, $file,$line) = @$debpri; push(@$options, [ "post-up", "ip${ipvx}tables-restore < $ipvx_save" ]); &net::modify_interface_def($name, $addrfam, $method, $options, 0, $file); } } else { &create_webmin_init(); } } sub disable_at_boot { if ($debian_init_script) { # Turn off the init script &init::disable_at_boot($debian_init_script); } elsif ($has_new_debian_iptables) { # Remove from network interface config local $pri = &get_primary_network_interface(); local ($debpri) = grep { $_->[0] eq $pri->{'fullname'} } &net::get_interface_defs(); @{$debpri->[3]} = grep { ($_->[0] ne "pre-up" && $_->[0] ne "post-up") || $_->[1] !~ /^\S*ip${ipvx}tables/ } @{$debpri->[3]}; &net::modify_interface_def(@$debpri); } else { &init::disable_at_boot("webmin-ip${ipvx}tables"); } } sub get_primary_network_interface { &foreign_require("net"); local @boot = sort { $a->{'fullname'} cmp $b->{'fullname'} } &net::boot_interfaces(); local $pri; if ($config{'iface'}) { ($pri) = grep { $_->{'fullname'} eq $config{'iface'} } @boot; } local ($eth) = grep { $_->{'fullname'} =~ /^eth\d+$/ } @boot; local ($ppp) = grep { $_->{'fullname'} =~ /^ppp\d+$/ } @boot; local ($venetn) = grep { $_->{'fullname'} =~ /^venet\d+:\d+$/ } @boot; local ($venet) = grep { $_->{'fullname'} =~ /^venet\d+$/ } @boot; return $pri || $eth || $ppp || $venetn || $venet || $boot[0]; } 1;
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
help | Folder | 0755 |
|
|
images | Folder | 0755 |
|
|
lang | Folder | 0755 |
|
|
acl_security.pl | File | 1.02 KB | 0755 |
|
apply.cgi | File | 512 B | 0755 |
|
backup_config.pl | File | 649 B | 0755 |
|
bootup.cgi | File | 600 B | 0755 |
|
cgi_args.pl | File | 430 B | 0755 |
|
cluster.cgi | File | 2.08 KB | 0755 |
|
cluster_add.cgi | File | 2.19 KB | 0755 |
|
cluster_delete.cgi | File | 651 B | 0755 |
|
coherent-linux-lib.pl | File | 1.54 KB | 0755 |
|
config | File | 83 B | 0644 |
|
config.info | File | 1.23 KB | 0644 |
|
config.info.ca | File | 1.5 KB | 0644 |
|
config.info.cs | File | 982 B | 0644 |
|
config.info.de | File | 1.42 KB | 0644 |
|
config.info.fr | File | 1.63 KB | 0644 |
|
config.info.ja | File | 421 B | 0644 |
|
config.info.nl | File | 976 B | 0644 |
|
config.info.no | File | 968 B | 0644 |
|
config.info.pl | File | 1012 B | 0644 |
|
config.info.pt_BR | File | 983 B | 0644 |
|
config.info.ru | File | 1.31 KB | 0644 |
|
config.info.sk | File | 989 B | 0644 |
|
config.info.tr | File | 827 B | 0644 |
|
convert.cgi | File | 756 B | 0755 |
|
debian-linux-lib.pl | File | 4.69 KB | 0755 |
|
defaultacl | File | 100 B | 0644 |
|
edit_rule.cgi | File | 14.88 KB | 0755 |
|
firewall-lib.pl | File | 17.32 KB | 0755 |
|
firewall4-lib.pl | File | 1.82 KB | 0755 |
|
firewall6-lib.pl | File | 1.76 KB | 0755 |
|
gentoo-linux-lib.pl | File | 722 B | 0755 |
|
index.cgi | File | 16.42 KB | 0755 |
|
install_check.pl | File | 841 B | 0755 |
|
log_parser.pl | File | 835 B | 0755 |
|
mandrake-linux-lib.pl | File | 1.69 KB | 0755 |
|
module.info | File | 238 B | 0644 |
|
module.info.af | File | 0 B | 0644 |
|
module.info.af.auto | File | 182 B | 0644 |
|
module.info.ar | File | 0 B | 0644 |
|
module.info.ar.auto | File | 254 B | 0644 |
|
module.info.be | File | 0 B | 0644 |
|
module.info.be.auto | File | 278 B | 0644 |
|
module.info.bg | File | 0 B | 0644 |
|
module.info.bg.auto | File | 299 B | 0644 |
|
module.info.ca | File | 155 B | 0644 |
|
module.info.ca.auto | File | 18 B | 0644 |
|
module.info.cs | File | 0 B | 0644 |
|
module.info.cs.auto | File | 194 B | 0644 |
|
module.info.da | File | 0 B | 0644 |
|
module.info.da.auto | File | 183 B | 0644 |
|
module.info.de | File | 161 B | 0644 |
|
module.info.de.auto | File | 18 B | 0644 |
|
module.info.el | File | 0 B | 0644 |
|
module.info.el.auto | File | 346 B | 0644 |
|
module.info.es | File | 0 B | 0644 |
|
module.info.es.auto | File | 185 B | 0644 |
|
module.info.eu | File | 0 B | 0644 |
|
module.info.eu.auto | File | 167 B | 0644 |
|
module.info.fa | File | 0 B | 0644 |
|
module.info.fa.auto | File | 268 B | 0644 |
|
module.info.fi | File | 0 B | 0644 |
|
module.info.fi.auto | File | 186 B | 0644 |
|
module.info.fr | File | 0 B | 0644 |
|
module.info.fr.auto | File | 180 B | 0644 |
|
module.info.he | File | 0 B | 0644 |
|
module.info.he.auto | File | 251 B | 0644 |
|
module.info.hr | File | 0 B | 0644 |
|
module.info.hr.auto | File | 173 B | 0644 |
|
module.info.hu | File | 0 B | 0644 |
|
module.info.hu.auto | File | 201 B | 0644 |
|
module.info.it | File | 0 B | 0644 |
|
module.info.it.auto | File | 174 B | 0644 |
|
module.info.ja | File | 0 B | 0644 |
|
module.info.ja.auto | File | 263 B | 0644 |
|
module.info.ko | File | 0 B | 0644 |
|
module.info.ko.auto | File | 206 B | 0644 |
|
module.info.lt | File | 0 B | 0644 |
|
module.info.lt.auto | File | 209 B | 0644 |
|
module.info.lv | File | 0 B | 0644 |
|
module.info.lv.auto | File | 180 B | 0644 |
|
module.info.ms | File | 0 B | 0644 |
|
module.info.ms.auto | File | 176 B | 0644 |
|
module.info.mt | File | 0 B | 0644 |
|
module.info.mt.auto | File | 192 B | 0644 |
|
module.info.nl | File | 0 B | 0644 |
|
module.info.nl.auto | File | 186 B | 0644 |
|
module.info.no | File | 0 B | 0644 |
|
module.info.no.auto | File | 176 B | 0644 |
|
module.info.pl | File | 0 B | 0644 |
|
module.info.pl.auto | File | 197 B | 0644 |
|
module.info.pt | File | 0 B | 0644 |
|
module.info.pt.auto | File | 172 B | 0644 |
|
module.info.pt_BR | File | 0 B | 0644 |
|
module.info.pt_BR.auto | File | 181 B | 0644 |
|
module.info.ro | File | 0 B | 0644 |
|
module.info.ro.auto | File | 186 B | 0644 |
|
module.info.ru | File | 0 B | 0644 |
|
module.info.ru.auto | File | 250 B | 0644 |
|
module.info.sk | File | 0 B | 0644 |
|
module.info.sk.auto | File | 203 B | 0644 |
|
module.info.sl | File | 0 B | 0644 |
|
module.info.sl.auto | File | 182 B | 0644 |
|
module.info.sv | File | 0 B | 0644 |
|
module.info.sv.auto | File | 177 B | 0644 |
|
module.info.th | File | 0 B | 0644 |
|
module.info.th.auto | File | 275 B | 0644 |
|
module.info.tr | File | 0 B | 0644 |
|
module.info.tr.auto | File | 222 B | 0644 |
|
module.info.uk | File | 0 B | 0644 |
|
module.info.uk.auto | File | 291 B | 0644 |
|
module.info.ur | File | 0 B | 0644 |
|
module.info.ur.auto | File | 306 B | 0644 |
|
module.info.vi | File | 0 B | 0644 |
|
module.info.vi.auto | File | 205 B | 0644 |
|
module.info.zh | File | 0 B | 0644 |
|
module.info.zh.auto | File | 146 B | 0644 |
|
module.info.zh_TW | File | 0 B | 0644 |
|
module.info.zh_TW.auto | File | 155 B | 0644 |
|
move.cgi | File | 1.29 KB | 0755 |
|
newchain.cgi | File | 898 B | 0755 |
|
open-ports.pl | File | 3.4 KB | 0755 |
|
prefs.info | File | 55 B | 0644 |
|
redhat-linux-lib.pl | File | 2.14 KB | 0755 |
|
save_policy.cgi | File | 7.15 KB | 0755 |
|
save_rule.cgi | File | 12.4 KB | 0755 |
|
save_rule6.cgi | File | 12.05 KB | 0755 |
|
setup.cgi | File | 9.37 KB | 0755 |
|
setup6.cgi | File | 8.12 KB | 0755 |
|
trustix-linux-lib.pl | File | 2.14 KB | 0755 |
|
unapply.cgi | File | 609 B | 0755 |
|