public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
From: Michael Tremer <michael.tremer@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH] BUG10940: remove leading zeros in ip address
Date: Mon, 09 Nov 2015 18:33:46 +0000	[thread overview]
Message-ID: <1447094026.2699.70.camel@ipfire.org> (raw)
In-Reply-To: <1447069367-7823-1-git-send-email-alexander.marx@ipfire.org>

[-- Attachment #1: Type: text/plain, Size: 5508 bytes --]

Hi,

this does not look like the cleanest solution to be honest, but I guess
this is acceptable. It solves the issue at hand, but generally I would
like to have this solved one time so that one does not have to keep
this problem in mind when writing new code.

Merged.

Best,
-Michael

On Mon, 2015-11-09 at 12:42 +0100, Alexander Marx wrote:
> in firewallgroups (hosts) an error was created when using ip adresses
> like 192.168.000.008. Now all leading zeros are deleted in
> firewallgroups and in the firewall itself when using single ip
> addresses
> as source or target.
> 
> Signed-off-by: Alexander Marx <alexander.marx(a)ipfire.org>
> ---
>  config/cfgroot/network-functions.pl | 13 +++++++++++++
>  html/cgi-bin/firewall.cgi           |  8 ++++++++
>  html/cgi-bin/fwhosts.cgi            | 13 +++++++------
>  3 files changed, 28 insertions(+), 6 deletions(-)
> 
> diff --git a/config/cfgroot/network-functions.pl
> b/config/cfgroot/network-functions.pl
> index cb4ca3d..70fa5ed 100644
> --- a/config/cfgroot/network-functions.pl
> +++ b/config/cfgroot/network-functions.pl
> @@ -122,6 +122,19 @@ sub network2bin($) {
>  	return ($network_start, $netmask_bin);
>  }
>  
> +# Deletes leading zeros in ip address
> +sub ip_remove_zero{
> +	my $address = shift;
> +	my @ip = split (/\./, $address);
> +
> +	foreach my $octet (@ip) {
> +		$octet = int($octet);
> +	}
> +
> +	$address = join (".", @ip);
> +
> +	return $address;
> +}
>  # Returns True for all valid IP addresses
>  sub check_ip_address($) {
>  	my $address = shift;
> diff --git a/html/cgi-bin/firewall.cgi b/html/cgi-bin/firewall.cgi
> index 682c285..8007182 100644
> --- a/html/cgi-bin/firewall.cgi
> +++ b/html/cgi-bin/firewall.cgi
> @@ -31,6 +31,7 @@ no warnings 'uninitialized';
>  #use CGI::Carp 'fatalsToBrowser';
>  
>  require '/var/ipfire/general-functions.pl';
> +require '/var/ipfire/network-functions.pl';
>  require "${General::swroot}/lang.pl";
>  require "${General::swroot}/header.pl";
>  require "${General::swroot}/geoip-functions.pl";
> @@ -465,6 +466,9 @@ sub checksource
>  			}
>  		}
>  		if ($fwdfwsettings{'isip'} eq 'on'){
> +			#remove leading zero
> +			$ip = &Network::ip_remove_zero($ip);
> +
>  			##check if ip is valid
>  			if (! &General::validip($ip)){
>  				$errormessage.=$Lang::tr{'fwdfw err
> src_addr'}."<br>";
> @@ -569,11 +573,15 @@ sub checktarget
>  			($ip,$subnet)=split
> (/\//,$fwdfwsettings{'tgt_addr'});
>  			$subnet = &General::iporsubtocidr($subnet);
>  		}
> +
>  		#check if only ip
>  		if($fwdfwsettings{'tgt_addr'}=~/^(\d{1,3})\.(\d{1,3}
> )\.(\d{1,3})\.(\d{1,3})$/){
>  			$ip=$fwdfwsettings{'tgt_addr'};
>  			$subnet='32';
>  		}
> +		#remove leading zero
> +		$ip = &Network::ip_remove_zero($ip);
> +
>  		#check if ip is valid
>  		if (! &General::validip($ip)){
>  			$errormessage.=$Lang::tr{'fwdfw err
> tgt_addr'}."<br>";
> diff --git a/html/cgi-bin/fwhosts.cgi b/html/cgi-bin/fwhosts.cgi
> index 994a50a..35afad3 100644
> --- a/html/cgi-bin/fwhosts.cgi
> +++ b/html/cgi-bin/fwhosts.cgi
> @@ -27,6 +27,7 @@ use Sort::Naturally;
>  use CGI::Carp 'fatalsToBrowser';
>  no warnings 'uninitialized';
>  require '/var/ipfire/general-functions.pl';
> +require '/var/ipfire/network-functions.pl';
>  require "/var/ipfire/geoip-functions.pl";
>  require "/usr/lib/firewall/firewall-lib.pl";
>  require "${General::swroot}/lang.pl";
> @@ -277,6 +278,9 @@ if ($fwhostsettings{'ACTION'} eq 'savenet' )
>  		&addnet;
>  		&viewtablenet;
>  	}else{
> +		#convert ip if leading '0' exists
> +		$fwhostsettings{'IP'} =
> &Network::ip_remove_zero($fwhostsettings{'IP'});
> +
>  		#check valid ip 
>  		if
> (!&General::validipandmask($fwhostsettings{'IP'}."/".$fwhostsettings{
> 'SUBNET'}))
>  		{
> @@ -372,9 +376,6 @@ if ($fwhostsettings{'ACTION'} eq 'savenet' )
>  			foreach my $i (0 .. 3) {
> $customnetwork{$key}[$i] = "";}
>  			$fwhostsettings{'SUBNET'}	=
> &General::iporsubtocidr($fwhostsettings{'SUBNET'});
>  			$customnetwork{$key}[0] 	=
> $fwhostsettings{'HOSTNAME'};
> -			#convert ip when leading '0' in byte
> -			$fwhostsettings{'IP'}		=&Gener
> al::ip2dec($fwhostsettings{'IP'});
> -			$fwhostsettings{'IP'}		=&Gener
> al::dec2ip($fwhostsettings{'IP'});
>  			$customnetwork{$key}[1] 	=
> &General::getnetworkip($fwhostsettings{'IP'},$fwhostsettings{'SUBNET'
> }) ;
>  			$customnetwork{$key}[2] 	=
> &General::iporsubtodec($fwhostsettings{'SUBNET'}) ;
>  			$customnetwork{$key}[3] 	=
> $fwhostsettings{'NETREMARK'};
> @@ -423,6 +424,9 @@ if ($fwhostsettings{'ACTION'} eq 'savehost')
>  		}
>  		#CHECK IP-PART
>  		if ($fwhostsettings{'type'} eq 'ip'){
> +			#convert ip if leading '0' exists
> +			$fwhostsettings{'IP'} =
> &Network::ip_remove_zero($fwhostsettings{'IP'});
> +
>  			#check for subnet
>  			if (rindex($fwhostsettings{'IP'},'/') eq '
> -1' ){
>  				if($fwhostsettings{'type'} eq 'ip'
> && !&General::validipandmask($fwhostsettings{'IP'}."/32"))
> @@ -503,9 +507,6 @@ if ($fwhostsettings{'ACTION'} eq 'savehost')
>  			$customhost{$key}[0] =
> $fwhostsettings{'HOSTNAME'} ;
>  			$customhost{$key}[1] =
> $fwhostsettings{'type'} ;
>  			if ($fwhostsettings{'type'} eq 'ip'){
> -				#convert ip when leading '0' in byte
> -				$fwhostsettings{'IP'}=&General::ip2d
> ec($fwhostsettings{'IP'});
> -				$fwhostsettings{'IP'}=&General::dec2
> ip($fwhostsettings{'IP'});
>  				$customhost{$key}[2] =
> $fwhostsettings{'IP'}."/".&General::iporsubtodec($fwhostsettings{'SUB
> NET'});
>  			}else{
>  				$customhost{$key}[2] =
> $fwhostsettings{'IP'};

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 819 bytes --]

  reply	other threads:[~2015-11-09 18:33 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-11-09 11:42 Alexander Marx
2015-11-09 18:33 ` Michael Tremer [this message]
     [not found] <5640F09E.6070708@oab.de>
2015-11-09 22:16 ` Michael Tremer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1447094026.2699.70.camel@ipfire.org \
    --to=michael.tremer@ipfire.org \
    --cc=development@lists.ipfire.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox