]> git.ipfire.org Git - thirdparty/nftables.git/commitdiff
statement: fix print of ip dnat address
authorFlorian Westphal <fw@strlen.de>
Fri, 3 Feb 2017 14:22:28 +0000 (15:22 +0100)
committerFlorian Westphal <fw@strlen.de>
Sun, 5 Feb 2017 21:01:04 +0000 (22:01 +0100)
the change causes non-ipv6 addresses to not be printed at all in case
a nfproto was given.

Also add a test case to catch this.

Closes: https://bugzilla.netfilter.org/show_bug.cgi?id=1117
Fixes: 5ab0e10fc6e2c22363a ("src: support for RFC2732 IPv6 address format with brackets")
Signed-off-by: Florian Westphal <fw@strlen.de>
Acked-by: Pablo Neira Ayuso <pablo@netfilter.org>
src/statement.c
tests/py/ip/dnat.t
tests/py/ip/dnat.t.payload.ip

index 9cdabbb979e86bf1fe6831a830bb6c8ea4359848..3beb86ab42639ea6dd3b05ae661b7616e736a560 100644 (file)
@@ -508,6 +508,8 @@ static void nat_stmt_print(const struct stmt *stmt)
                                printf("]-[");
                                expr_print(stmt->nat.addr->right);
                                printf("]");
+                       } else {
+                               expr_print(stmt->nat.addr);
                        }
                } else {
                        expr_print(stmt->nat.addr);
index da00106edbb4f126ff091eab4271a2d39171eab6..089017c847043b2480c679a7be88b008947916ed 100644 (file)
@@ -7,6 +7,7 @@ iifname "eth0" tcp dport != 80-90 dnat to 192.168.3.2;ok
 iifname "eth0" tcp dport {80, 90, 23} dnat to 192.168.3.2;ok
 iifname "eth0" tcp dport != {80, 90, 23} dnat to 192.168.3.2;ok
 iifname "eth0" tcp dport != 23-34 dnat to 192.168.3.2;ok
+iifname "eth0" tcp dport 81 dnat to 192.168.3.2:8080;ok
 
 dnat to ct mark map { 0x00000014 : 1.2.3.4};ok
 dnat to ct mark . ip daddr map { 0x00000014 . 1.1.1.1 : 1.2.3.4};ok
index 66926990d8802bd148ca3792a12744debce0525c..7a7f5a82dd5af6ace65bebf73d3fa2a0cf198efc 100644 (file)
@@ -60,6 +60,18 @@ ip test-ip4 prerouting
   [ immediate reg 1 0x0203a8c0 ]
   [ nat dnat ip addr_min reg 1 addr_max reg 0 ]
 
+# iifname "eth0" tcp dport 81 dnat to 192.168.3.2:8080
+ip test-ip4 prerouting
+  [ meta load iifname => reg 1 ]
+  [ cmp eq reg 1 0x30687465 0x00000000 0x00000000 0x00000000 ]
+  [ payload load 1b @ network header + 9 => reg 1 ]
+  [ cmp eq reg 1 0x00000006 ]
+  [ payload load 2b @ transport header + 2 => reg 1 ]
+  [ cmp eq reg 1 0x00005100 ]
+  [ immediate reg 1 0x0203a8c0 ]
+  [ immediate reg 2 0x0000901f ]
+  [ nat dnat ip addr_min reg 1 addr_max reg 0 proto_min reg 2 proto_max reg 0 ]
+
 # dnat to ct mark map { 0x00000014 : 1.2.3.4}
 __map%d test-ip4 b
 __map%d test-ip4 0