summaryrefslogtreecommitdiffstats
path: root/src/conntrack.c
diff options
context:
space:
mode:
authorFlorian Westphal <fw@strlen.de>2021-08-02 11:12:31 +0200
committerFlorian Westphal <fw@strlen.de>2021-08-05 14:00:36 +0200
commite8008c016944c48dbb7045628f0f6e541544c7ea (patch)
treeeab31c5b56441ddf510b227c995752055f7a2d8a /src/conntrack.c
parent1a5828f491c6a1593f30cb5f1551fe9f9cf76a8d (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>
Diffstat (limited to 'src/conntrack.c')
-rw-r--r--src/conntrack.c12
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))