public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
* [PATCH] BUG10941: fix single ip-addresses when no subnet given
@ 2015-10-17 17:27 Alexander Marx
  0 siblings, 0 replies; 4+ messages in thread
From: Alexander Marx @ 2015-10-17 17:27 UTC (permalink / raw)
  To: development

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

Some functions when adding a new route where senseless.
Now the ip address is checked and in case of a missing / wrong
subnetmask an errormessage is raised. The ip address is preserved.
ELSE
we convert the subnetmask to cidr notation and calculate the network ip
correctly.

Signed-off-by: Alexander Marx <alexander.marx(a)ipfire.org>
---
 html/cgi-bin/routing.cgi | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)

diff --git a/html/cgi-bin/routing.cgi b/html/cgi-bin/routing.cgi
index c460a74..2c60f67 100644
--- a/html/cgi-bin/routing.cgi
+++ b/html/cgi-bin/routing.cgi
@@ -118,12 +118,16 @@ if ($settings{'ACTION'} eq $Lang::tr{'toggle enable disable'}) {
 }
 
 if ($settings{'ACTION'} eq $Lang::tr{'add'}) {
-	# Convert subnet masks to CIDR notation.
-	$settings{'IP'} = &General::iporsubtocidr($settings{'IP'});
 
-# Validate inputs
-	if (( !&General::validip($settings{'IP'})) and ( !&General::validipandmask($settings{'IP'}))){
+	# Validate inputs
+	if (!&General::validipandmask($settings{'IP'}))){
 	$errormessage = $Lang::tr{'invalid ip'}." / ".$Lang::tr{'invalid netmask'};
+	}else{
+		#set networkip if not already correctly defined
+		my($ip,$cidr) = split(/\//,$settings{'IP'});
+		$cidr = &General::iporsubtocidr($cidr);
+		my $netip=&General::getnetworkip($ip,$cidr);
+		$settings{'IP'} = "$netip/$cidr";
 	}
 
 	if ($settings{'IP'} =~ /^0\.0\.0\.0/){
-- 
1.9.1


^ permalink raw reply	[flat|nested] 4+ messages in thread
* [PATCH] BUG10941: fix single ip-addresses when no subnet given
@ 2015-10-16  7:57 Alexander Marx
  2015-10-16 15:54 ` Michael Tremer
  0 siblings, 1 reply; 4+ messages in thread
From: Alexander Marx @ 2015-10-16  7:57 UTC (permalink / raw)
  To: development

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

Signed-off-by: Alexander Marx <alexander.marx(a)ipfire.org>
---
 html/cgi-bin/routing.cgi | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/html/cgi-bin/routing.cgi b/html/cgi-bin/routing.cgi
index c460a74..3b5a2f7 100644
--- a/html/cgi-bin/routing.cgi
+++ b/html/cgi-bin/routing.cgi
@@ -118,6 +118,11 @@ if ($settings{'ACTION'} eq $Lang::tr{'toggle enable disable'}) {
 }
 
 if ($settings{'ACTION'} eq $Lang::tr{'add'}) {
+
+	if (!&Network::check_prefix($settings{'IP'})){
+		$settings{'IP'} .= '/32';
+	}
+
 	# Convert subnet masks to CIDR notation.
 	$settings{'IP'} = &General::iporsubtocidr($settings{'IP'});
 
-- 
1.9.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2015-10-17 17:27 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
     [not found] <56213868.1020004@oab.de>
2015-10-16 20:56 ` [PATCH] BUG10941: fix single ip-addresses when no subnet given Michael Tremer
2015-10-17 17:27 Alexander Marx
  -- strict thread matches above, loose matches on Subject: below --
2015-10-16  7:57 Alexander Marx
2015-10-16 15:54 ` Michael Tremer

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox