diff options
-rw-r--r-- | iptables/nft-ipv4.c | 14 | ||||
-rw-r--r-- | iptables/nft-ipv6.c | 16 | ||||
-rw-r--r-- | iptables/nft.h | 2 | ||||
-rw-r--r-- | iptables/xtables-translate.c | 17 |
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) { |