#!/usr/bin/perl # Show all firewalld rules and zones use strict; use warnings; no warnings 'redefine'; no warnings 'uninitialized'; require './firewalld-lib.pl'; our (%in, %text, %config, %access, $base_remote_user); &ReadParse(); if ($in{'addzone'}) { # Redirect to zone creation form &redirect("zone_form.cgi?zone=".&urlize($in{'zone'})); return; } if ($in{'delzone'}) { # Redirect to zone deletion form &redirect("delete_zone.cgi?zone=".&urlize($in{'zone'})); return; } if ($in{'defzone'}) { # Make a zone the default &redirect("default_zone.cgi?zone=".&urlize($in{'zone'})); return; } &ui_print_header(undef, $text{'index_title'}, "", undef, 1, 1); # Is firewalld working? my $err = &check_firewalld(); if ($err) { &ui_print_endpage(&text('index_cerr', $err)); return; } my @zones; my $zone; # Is FirewallD running if not, show start button my $ok = &is_firewalld_running(); if ($ok) { # Get rules and zones @zones = &list_firewalld_zones(); @zones || &error($text{'index_ezones'}); if ($in{'zone'}) { ($zone) = grep { $_->{'name'} eq $in{'zone'} } @zones; } else { ($zone) = grep { $_->{'default'} } @zones; } $zone ||= $zones[0]; my ($azone); eval { local $main::error_must_die = 1; my @azones = &list_firewalld_zones(1); ($azone) = grep { $_->{'name'} eq $zone->{'name'} } @azones; }; # Show zone selector print &ui_form_start("index.cgi"); print "$text{'index_zone'} ", &ui_select("zone", $zone->{'name'}, [ map { [ $_->{'name'}, $_->{'name'}.($_->{'default'} ? ' (default)' : '') ]} @zones ], 1, 0, 0, 0, "onChange='form.submit()'")," ", &ui_submit($text{'index_zonedef'}, "defzone")," ", &ui_submit($text{'index_zonedel'}, "delzone")," ", &ui_submit($text{'index_zoneadd'}, "addzone")," ", "<p>\n"; print &ui_form_end(); # Show allowed ports and services in this zone my @links = ( &ui_link("edit_port.cgi?new=1&zone=".&urlize($zone->{'name'}), $text{'index_padd'}), &ui_link("edit_serv.cgi?new=1&zone=".&urlize($zone->{'name'}), $text{'index_sadd'}), &ui_link("edit_forward.cgi?new=1&zone=".&urlize($zone->{'name'}), $text{'index_fadd'}), ); if (@{$zone->{'services'}} || @{$zone->{'ports'}}) { my @tds = ( "width=5" ); unshift(@links, &select_all_link("d", 1), &select_invert_link("d", 1)); print &ui_form_start("delete_rules.cgi", "post"); print &ui_hidden("zone", $zone->{'name'}); print &ui_links_row(\@links); print &ui_columns_start([ "", $text{'index_type'}, $text{'index_port'}, $text{'index_proto'} ], 100, 0, \@tds); foreach my $s (@{$zone->{'services'}}) { my $url = "edit_serv.cgi?id=".&urlize($s). "&zone=".&urlize($zone->{'name'}); my $sportsprotos = &list_firewalld_service_desc($s); my $sport = $sportsprotos->{'ports'}; my $sprotocols = $sportsprotos->{'protocols'}; $sport = " ($sport)" if ($sport); print &ui_checked_columns_row([ &ui_link($url, $text{'index_tservice'}), &ui_link($url, "$s$sport"), $sprotocols || "", ], \@tds, "d", "service/".$s); } foreach my $p (@{$zone->{'ports'}}) { my $url = "edit_port.cgi?id=".&urlize($p). "&zone=".&urlize($zone->{'name'}); my ($port, $proto) = split(/\//, $p); print &ui_checked_columns_row([ &ui_link($url, $text{'index_tport'}), &ui_link($url, $port), uc($proto), ], \@tds, "d", "port/".$p); } foreach my $f (@{$zone->{'forward-ports'}}) { my ($port, $proto, $dstport, $dstaddr) = &parse_firewalld_forward($f); my $p = join("/", $port, $proto, $dstport, $dstaddr); my $url = "edit_forward.cgi?id=".&urlize($p). "&zone=".&urlize($zone->{'name'}); print &ui_checked_columns_row([ &ui_link($url, $text{'index_tforward'}), &ui_link($url, $port), &ui_link($url, uc($proto)), ], \@tds, "d", "forward/".$p); } print &ui_columns_end(); print &ui_links_row(\@links); print &ui_form_end([ [ undef, $text{'index_delete'} ] ]); } else { print "$text{'index_none'}<p>\n"; print &ui_links_row(\@links); } if ($azone) { # Show interfaces for this zone print &ui_form_start("save_ifaces.cgi"); print &ui_hidden("zone", $zone->{'name'}); print "<br>$text{'index_ifaces'} \n"; my %zifcs = map { $_, 1 } &unique(@{$azone->{'interfaces'}}, @{$zone->{'interfaces'}}); print &ui_radio("iface_def", %zifcs ? 0 : 1, [ [ 1, $text{'index_ifaces_def'} ], [ 0, $text{'index_ifaces_sel'} ] ]),"\n"; foreach my $i (&list_system_interfaces()) { print &ui_checkbox("iface", $i, $i, $zifcs{$i}),"\n"; } print &ui_submit($text{'index_ifaces_apply'}); print &ui_form_end(); } print &ui_hr(); # Show start/apply buttons print &ui_buttons_start(); print &ui_buttons_row("list_rules.cgi", $text{'index_listrules'}, &text("index_listrules_restartdesc", "<tt>".$zone->{'name'}."</tt>"), [ [ "zone", $zone->{'name'} ] ]); print &ui_buttons_row("restart.cgi", $text{'index_restart_firewalld'}, $text{'index_restart_firewallddesc'}, [ [ "zone", $zone->{'name'} ] ]); print &ui_buttons_row("stop.cgi", $text{'index_stop'}, $text{'index_stopdesc'}, [ [ "zone", $zone->{'name'} ] ]); } # Show Start and disable/enabled at boot button if (!$ok) { print &ui_buttons_start(); print &ui_buttons_row("start.cgi", $text{'index_start'}, $text{'index_startdesc'}, [ [ "zone", $zone->{'name'} ] ]); } # Enable at boot &foreign_require("init"); my $st = &init::action_status($config{'init_name'}); if ($st) { my $atboot = $st == 2 ? 1 : 0; print &ui_buttons_row("bootup.cgi", $text{'index_bootup'}, $text{'index_bootupdesc'}, [ [ "zone", $zone->{'name'} ] ], &ui_yesno_radio("boot", $atboot)); } print &ui_buttons_end(); &ui_print_footer("/", $text{'index'});
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
images | Folder | 0755 |
|
|
lang | Folder | 0755 |
|
|
CHANGELOG | File | 201 B | 0644 |
|
bootup.cgi | File | 456 B | 0755 |
|
config | File | 46 B | 0644 |
|
config.info | File | 88 B | 0644 |
|
config.info.ca | File | 103 B | 0644 |
|
config.info.de | File | 100 B | 0644 |
|
config.info.fr | File | 121 B | 0644 |
|
config.info.no | File | 96 B | 0644 |
|
config.info.pl | File | 98 B | 0644 |
|
create_zone.cgi | File | 2.09 KB | 0755 |
|
default_zone.cgi | File | 560 B | 0755 |
|
delete_rules.cgi | File | 915 B | 0755 |
|
delete_zone.cgi | File | 1.03 KB | 0755 |
|
edit_forward.cgi | File | 2.55 KB | 0755 |
|
edit_port.cgi | File | 1.78 KB | 0755 |
|
edit_serv.cgi | File | 1.23 KB | 0755 |
|
firewalld-lib.pl | File | 13.2 KB | 0644 |
|
index.cgi | File | 5.79 KB | 0755 |
|
install_check.pl | File | 469 B | 0755 |
|
list_rules.cgi | File | 4.84 KB | 0755 |
|
log_parser.pl | File | 794 B | 0755 |
|
module.info | File | 176 B | 0644 |
|
module.info.af | File | 0 B | 0644 |
|
module.info.af.auto | File | 116 B | 0644 |
|
module.info.ar | File | 0 B | 0644 |
|
module.info.ar.auto | File | 184 B | 0644 |
|
module.info.be | File | 0 B | 0644 |
|
module.info.be.auto | File | 177 B | 0644 |
|
module.info.bg | File | 0 B | 0644 |
|
module.info.bg.auto | File | 193 B | 0644 |
|
module.info.ca | File | 117 B | 0644 |
|
module.info.cs | File | 0 B | 0644 |
|
module.info.cs.auto | File | 140 B | 0644 |
|
module.info.da | File | 0 B | 0644 |
|
module.info.da.auto | File | 128 B | 0644 |
|
module.info.de | File | 124 B | 0644 |
|
module.info.el | File | 0 B | 0644 |
|
module.info.el.auto | File | 252 B | 0644 |
|
module.info.es | File | 0 B | 0644 |
|
module.info.es.auto | File | 131 B | 0644 |
|
module.info.eu | File | 0 B | 0644 |
|
module.info.eu.auto | File | 123 B | 0644 |
|
module.info.fa | File | 0 B | 0644 |
|
module.info.fa.auto | File | 185 B | 0644 |
|
module.info.fi | File | 0 B | 0644 |
|
module.info.fi.auto | File | 125 B | 0644 |
|
module.info.fr | File | 0 B | 0644 |
|
module.info.fr.auto | File | 134 B | 0644 |
|
module.info.he | File | 0 B | 0644 |
|
module.info.he.auto | File | 177 B | 0644 |
|
module.info.hr | File | 0 B | 0644 |
|
module.info.hr.auto | File | 125 B | 0644 |
|
module.info.hu | File | 0 B | 0644 |
|
module.info.hu.auto | File | 158 B | 0644 |
|
module.info.it | File | 0 B | 0644 |
|
module.info.it.auto | File | 128 B | 0644 |
|
module.info.ja | File | 0 B | 0644 |
|
module.info.ja.auto | File | 162 B | 0644 |
|
module.info.ko | File | 0 B | 0644 |
|
module.info.ko.auto | File | 143 B | 0644 |
|
module.info.lt | File | 0 B | 0644 |
|
module.info.lt.auto | File | 151 B | 0644 |
|
module.info.lv | File | 0 B | 0644 |
|
module.info.lv.auto | File | 131 B | 0644 |
|
module.info.ms | File | 0 B | 0644 |
|
module.info.ms.auto | File | 140 B | 0644 |
|
module.info.mt | File | 0 B | 0644 |
|
module.info.mt.auto | File | 124 B | 0644 |
|
module.info.nl | File | 0 B | 0644 |
|
module.info.nl.auto | File | 124 B | 0644 |
|
module.info.no | File | 0 B | 0644 |
|
module.info.no.auto | File | 129 B | 0644 |
|
module.info.pl | File | 132 B | 0644 |
|
module.info.pt | File | 0 B | 0644 |
|
module.info.pt.auto | File | 118 B | 0644 |
|
module.info.pt_BR | File | 0 B | 0644 |
|
module.info.pt_BR.auto | File | 124 B | 0644 |
|
module.info.ro | File | 0 B | 0644 |
|
module.info.ro.auto | File | 128 B | 0644 |
|
module.info.ru | File | 0 B | 0644 |
|
module.info.ru.auto | File | 185 B | 0644 |
|
module.info.sk | File | 0 B | 0644 |
|
module.info.sk.auto | File | 139 B | 0644 |
|
module.info.sl | File | 0 B | 0644 |
|
module.info.sl.auto | File | 126 B | 0644 |
|
module.info.sv | File | 0 B | 0644 |
|
module.info.sv.auto | File | 127 B | 0644 |
|
module.info.th | File | 0 B | 0644 |
|
module.info.th.auto | File | 211 B | 0644 |
|
module.info.tr | File | 0 B | 0644 |
|
module.info.tr.auto | File | 163 B | 0644 |
|
module.info.uk | File | 0 B | 0644 |
|
module.info.uk.auto | File | 181 B | 0644 |
|
module.info.ur | File | 0 B | 0644 |
|
module.info.ur.auto | File | 229 B | 0644 |
|
module.info.vi | File | 0 B | 0644 |
|
module.info.vi.auto | File | 165 B | 0644 |
|
module.info.zh | File | 0 B | 0644 |
|
module.info.zh.auto | File | 109 B | 0644 |
|
module.info.zh_TW | File | 0 B | 0644 |
|
module.info.zh_TW.auto | File | 115 B | 0644 |
|
open-ports.pl | File | 2.37 KB | 0755 |
|
restart.cgi | File | 346 B | 0755 |
|
save_forward.cgi | File | 1.55 KB | 0755 |
|
save_ifaces.cgi | File | 643 B | 0755 |
|
save_port.cgi | File | 1.13 KB | 0755 |
|
save_rules.cgi | File | 796 B | 0755 |
|
save_serv.cgi | File | 1.03 KB | 0755 |
|
start.cgi | File | 326 B | 0755 |
|
stop.cgi | File | 324 B | 0755 |
|
zone_form.cgi | File | 968 B | 0755 |
|