diff options
author | Florian Westphal <fw@strlen.de> | 2021-08-02 11:12:31 +0200 |
---|---|---|
committer | Florian Westphal <fw@strlen.de> | 2021-08-05 14:00:36 +0200 |
commit | e8008c016944c48dbb7045628f0f6e541544c7ea (patch) | |
tree | eab31c5b56441ddf510b227c995752055f7a2d8a | |
parent | 1a5828f491c6a1593f30cb5f1551fe9f9cf76a8d (diff) |
conntrack: add shorthand mnemonic for UNREPLIED
conntrack tool prints [UNREPLIED] if a conntrack entry lacks the
SEEN_REPLY bit. Accept this as '-u' argument too.
If requested, mask is set to SEEN_REPLY and value remains 0 (bit not set).
Signed-off-by: Florian Westphal <fw@strlen.de>
-rw-r--r-- | src/conntrack.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/conntrack.c b/src/conntrack.c index cc564a2..ef7f604 100644 --- a/src/conntrack.c +++ b/src/conntrack.c @@ -1199,6 +1199,7 @@ parse_parameter(const char *arg, unsigned int *status, int parse_type) static void parse_parameter_mask(const char *arg, unsigned int *status, unsigned int *mask, int parse_type) { + static const char unreplied[] = "UNREPLIED"; unsigned int *value; const char *comma; bool negated; @@ -1215,6 +1216,12 @@ parse_parameter_mask(const char *arg, unsigned int *status, unsigned int *mask, value = negated ? mask : status; + if (!negated && strncmp(arg, unreplied, strlen(unreplied)) == 0) { + *mask |= IPS_SEEN_REPLY; + arg = comma+1; + continue; + } + if (!do_parse_parameter(arg, comma-arg, value, parse_type)) exit_error(PARAMETER_PROBLEM,"Bad parameter `%s'", arg); arg = comma+1; @@ -1225,6 +1232,11 @@ parse_parameter_mask(const char *arg, unsigned int *status, unsigned int *mask, arg++; value = negated ? mask : status; + if (!negated && strncmp(arg, unreplied, strlen(unreplied)) == 0) { + *mask |= IPS_SEEN_REPLY; + return; + } + if (strlen(arg) == 0 || !do_parse_parameter(arg, strlen(arg), value, parse_type)) |