diff options
| author | Phil Sutter <phil@nwl.cc> | 2025-10-07 17:51:32 +0200 |
|---|---|---|
| committer | Phil Sutter <phil@nwl.cc> | 2025-10-08 14:14:05 +0200 |
| commit | 11b9415fd63d245b1a3230aa4f7cd1e2b0639ddd (patch) | |
| tree | 4e9b296161784d7f6c1a438bb0a6f59004f1cc2b /src | |
| parent | b134dc218066911a9ddab8fd82957b2e48da48f3 (diff) | |
mnl: Drop asterisk from end of NFTA_DEVICE_PREFIX strings
The asterisk left in place becomes part of the prefix by accident and is thus
both included when matching interface names as well as dumped back to user
space.
Fixes: c31e887504a90 ("mnl: Support simple wildcards in netdev hooks")
Signed-off-by: Phil Sutter <phil@nwl.cc>
Reviewed-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src')
| -rw-r--r-- | src/mnl.c | 11 |
1 files changed, 9 insertions, 2 deletions
@@ -815,9 +815,16 @@ static bool is_wildcard_str(const char *str) static void mnl_nft_attr_put_ifname(struct nlmsghdr *nlh, const char *ifname) { - uint16_t attr = is_wildcard_str(ifname) ? - NFTA_DEVICE_PREFIX : NFTA_DEVICE_NAME; + uint16_t attr = NFTA_DEVICE_NAME; + char pfx[IFNAMSIZ]; + if (is_wildcard_str(ifname)) { + snprintf(pfx, IFNAMSIZ, "%s", ifname); + pfx[strlen(pfx) - 1] = '\0'; + + attr = NFTA_DEVICE_PREFIX; + ifname = pfx; + } mnl_attr_put_strz(nlh, attr, ifname); } |
