[ Avaa Bypassed ]




Upload:

Command:

www-data@18.218.26.136: ~ $
#!/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'}&nbsp;\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'});

Filemanager

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