summaryrefslogtreecommitdiffstats
path: root/iptables
diff options
context:
space:
mode:
authorLiping Zhang <liping.zhang@spreadtrum.com>2016-07-30 13:20:59 +0800
committerPablo Neira Ayuso <pablo@netfilter.org>2016-08-01 14:21:27 +0200
commit0ddd663e9c167f9f0451dac8c02bbfcda25fe15e (patch)
treecf45f737d411decb39d13c4bec30a3872a94f7f9 /iptables
parent68c57e809f69108694cce2d502a3ed1c328d13e8 (diff)
iptables-translate: add in/out ifname wildcard match translation to nft
In iptables, "-i eth+" means match all in ifname with the prefix "eth". But in nftables, this was changed to "iifname eth*". So we should handle this subtle difference. Apply this patch, translation will become: # iptables-translate -A INPUT -i eth+ nft add rule ip filter INPUT iifname eth* counter # ip6tables-translate -A OUTPUT ! -o eth+ nft add rule ip6 filter OUTPUT oifname != eth* counter Signed-off-by: Liping Zhang <liping.zhang@spreadtrum.com> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'iptables')
-rw-r--r--iptables/nft-ipv4.c14
-rw-r--r--iptables/nft-ipv6.c16
-rw-r--r--iptables/nft.h2
-rw-r--r--iptables/xtables-translate.c17
4 files changed, 27 insertions, 22 deletions
diff --git a/iptables/nft-ipv4.c b/iptables/nft-ipv4.c
index 814ca14d..50706cb0 100644
--- a/iptables/nft-ipv4.c
+++ b/iptables/nft-ipv4.c
@@ -444,16 +444,10 @@ static int nft_ipv4_xlate(const void *data, struct xt_xlate *xl)
const char *comment;
int ret;
- if (cs->fw.ip.iniface[0] != '\0') {
- xt_xlate_add(xl, "iifname %s%s ",
- cs->fw.ip.invflags & IPT_INV_VIA_IN ? "!= " : "",
- cs->fw.ip.iniface);
- }
- if (cs->fw.ip.outiface[0] != '\0') {
- xt_xlate_add(xl, "oifname %s%s ",
- cs->fw.ip.invflags & IPT_INV_VIA_OUT? "!= " : "",
- cs->fw.ip.outiface);
- }
+ xlate_ifname(xl, "iifname", cs->fw.ip.iniface,
+ cs->fw.ip.invflags & IPT_INV_VIA_IN);
+ xlate_ifname(xl, "oifname", cs->fw.ip.outiface,
+ cs->fw.ip.invflags & IPT_INV_VIA_OUT);
if (cs->fw.ip.flags & IPT_F_FRAG) {
xt_xlate_add(xl, "ip frag-off %s%x ",
diff --git a/iptables/nft-ipv6.c b/iptables/nft-ipv6.c
index bfbf8dff..8ca523c8 100644
--- a/iptables/nft-ipv6.c
+++ b/iptables/nft-ipv6.c
@@ -404,18 +404,10 @@ static int nft_ipv6_xlate(const void *data, struct xt_xlate *xl)
const char *comment;
int ret;
- if (cs->fw6.ipv6.iniface[0] != '\0') {
- xt_xlate_add(xl, "iifname %s%s ",
- cs->fw6.ipv6.invflags & IP6T_INV_VIA_IN ?
- "!= " : "",
- cs->fw6.ipv6.iniface);
- }
- if (cs->fw6.ipv6.outiface[0] != '\0') {
- xt_xlate_add(xl, "oifname %s%s ",
- cs->fw6.ipv6.invflags & IP6T_INV_VIA_OUT ?
- "!= " : "",
- cs->fw6.ipv6.outiface);
- }
+ xlate_ifname(xl, "iifname", cs->fw6.ipv6.iniface,
+ cs->fw6.ipv6.invflags & IP6T_INV_VIA_IN);
+ xlate_ifname(xl, "oifname", cs->fw6.ipv6.outiface,
+ cs->fw6.ipv6.invflags & IP6T_INV_VIA_OUT);
if (cs->fw6.ipv6.proto != 0) {
const struct protoent *pent =
diff --git a/iptables/nft.h b/iptables/nft.h
index 9e02eeb1..88674340 100644
--- a/iptables/nft.h
+++ b/iptables/nft.h
@@ -165,6 +165,8 @@ bool xlate_find_match(const struct iptables_command_state *cs, const char *p_nam
int xlate_matches(const struct iptables_command_state *cs, struct xt_xlate *xl);
int xlate_action(const struct iptables_command_state *cs, bool goto_set,
struct xt_xlate *xl);
+void xlate_ifname(struct xt_xlate *xl, const char *nftmeta, const char *ifname,
+ bool invert);
/*
* ARP
diff --git a/iptables/xtables-translate.c b/iptables/xtables-translate.c
index 9044d27c..3c577ed2 100644
--- a/iptables/xtables-translate.c
+++ b/iptables/xtables-translate.c
@@ -34,6 +34,23 @@
#include "xshared.h"
#include "nft-shared.h"
+void xlate_ifname(struct xt_xlate *xl, const char *nftmeta, const char *ifname,
+ bool invert)
+{
+ char iface[IFNAMSIZ];
+ int ifaclen;
+
+ if (ifname[0] == '\0')
+ return;
+
+ strcpy(iface, ifname);
+ ifaclen = strlen(iface);
+ if (iface[ifaclen - 1] == '+')
+ iface[ifaclen - 1] = '*';
+
+ xt_xlate_add(xl, "%s %s%s ", nftmeta, invert ? "!= " : "", iface);
+}
+
int xlate_action(const struct iptables_command_state *cs, bool goto_set,
struct xt_xlate *xl)
{