Skip to content

Commit

Permalink
flowint: add isnotset support
Browse files Browse the repository at this point in the history
Similar keywords use `isnotset`, while `flowint` only accepted `notset`
Opted to change the code, not only the regex, to keep the underlying
code also following the same patterns.

Task OISF#7426
  • Loading branch information
jufajardini authored and victorjulien committed Dec 5, 2024
1 parent 2fe2cf8 commit 6e4a501
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 11 deletions.
2 changes: 1 addition & 1 deletion doc/userguide/rules/flow-keywords.rst
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,7 @@ Define a var (not required), or check that one is set or not set.
::

flowint: name, < +,-,=,>,<,>=,<=,==, != >, value;
flowint: name, (isset|isnotset);
flowint: name, (isset|notset|isnotset);

Compare or alter a var. Add, subtract, compare greater than or less
than, greater than or equal to, and less than or equal to are
Expand Down
2 changes: 1 addition & 1 deletion src/detect-engine-sigorder.c
Original file line number Diff line number Diff line change
Expand Up @@ -235,7 +235,7 @@ static inline int SCSigGetFlowintType(Signature *sig)
fi->modifier == FLOWINT_MODIFIER_NE ||
fi->modifier == FLOWINT_MODIFIER_GE ||
fi->modifier == FLOWINT_MODIFIER_GT ||
fi->modifier == FLOWINT_MODIFIER_NOTSET ||
fi->modifier == FLOWINT_MODIFIER_ISNOTSET ||
fi->modifier == FLOWINT_MODIFIER_ISSET) {
read++;
} else {
Expand Down
16 changes: 8 additions & 8 deletions src/detect-flowint.c
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@
#include "util-profiling.h"

/* name modifiers value */
#define PARSE_REGEX "^\\s*([a-zA-Z][\\w\\d_./]+)\\s*,\\s*([+=-]{1}|==|!=|<|<=|>|>=|isset|notset)\\s*,?\\s*([a-zA-Z][\\w\\d]+|[\\d]{1,10})?\\s*$"
#define PARSE_REGEX "^\\s*([a-zA-Z][\\w\\d_./]+)\\s*,\\s*([+=-]{1}|==|!=|<|<=|>|>=|isset|notset|isnotset)\\s*,?\\s*([a-zA-Z][\\w\\d]+|[\\d]{1,10})?\\s*$"
/* Varnames must begin with a letter */

static DetectParseRegex parse_regex;
Expand Down Expand Up @@ -140,7 +140,7 @@ int DetectFlowintMatch(DetectEngineThreadCtx *det_ctx,
goto end;
}

if (sfd->modifier == FLOWINT_MODIFIER_NOTSET) {
if (sfd->modifier == FLOWINT_MODIFIER_ISNOTSET) {
SCLogDebug(" Not set %s? = %u", sfd->name,(fv) ? 0 : 1);
if (fv == NULL)
ret = 1;
Expand Down Expand Up @@ -280,8 +280,8 @@ static DetectFlowintData *DetectFlowintParse(DetectEngineCtx *de_ctx, const char
modifier = FLOWINT_MODIFIER_GT;
if (strcmp("isset", modstr) == 0)
modifier = FLOWINT_MODIFIER_ISSET;
if (strcmp("notset", modstr) == 0)
modifier = FLOWINT_MODIFIER_NOTSET;
if (strcmp("notset", modstr) == 0 || strcmp("isnotset", modstr) == 0)
modifier = FLOWINT_MODIFIER_ISNOTSET;

if (modifier == FLOWINT_MODIFIER_UNKNOWN) {
SCLogError("Unknown modifier");
Expand All @@ -293,7 +293,7 @@ static DetectFlowintData *DetectFlowintParse(DetectEngineCtx *de_ctx, const char
goto error;

/* If we need another arg, check it out(isset doesn't need another arg) */
if (modifier != FLOWINT_MODIFIER_ISSET && modifier != FLOWINT_MODIFIER_NOTSET) {
if (modifier != FLOWINT_MODIFIER_ISSET && modifier != FLOWINT_MODIFIER_ISNOTSET) {
if (ret < 4)
goto error;

Expand Down Expand Up @@ -394,7 +394,7 @@ static int DetectFlowintSetup(DetectEngineCtx *de_ctx, Signature *s, const char
case FLOWINT_MODIFIER_GE:
case FLOWINT_MODIFIER_GT:
case FLOWINT_MODIFIER_ISSET:
case FLOWINT_MODIFIER_NOTSET:
case FLOWINT_MODIFIER_ISNOTSET:
if (SigMatchAppendSMToList(de_ctx, s, DETECT_FLOWINT, (SigMatchCtx *)sfd,
DETECT_SM_LIST_MATCH) == NULL) {
goto error;
Expand Down Expand Up @@ -1000,7 +1000,7 @@ static int DetectFlowintTestParseIsset10(void)
DetectFlowintPrintData(sfd);
if (sfd != NULL && !strcmp(sfd->name, "myvar")
&& sfd->targettype == FLOWINT_TARGET_SELF
&& sfd->modifier == FLOWINT_MODIFIER_NOTSET) {
&& sfd->modifier == FLOWINT_MODIFIER_ISNOTSET) {

result &= 1;
} else {
Expand Down Expand Up @@ -1189,7 +1189,7 @@ static int DetectFlowintTestPacket02Real(void)
de_ctx->flags |= DE_QUIET;

const char *sigs[5];
sigs[0] = "alert tcp any any -> any any (msg:\"Setting a flowint counter\"; content:\"GET\"; flowint: myvar, notset; flowint:maxvar,notset; flowint: myvar,=,1; flowint: maxvar,=,6; sid:101;)";
sigs[0] = "alert tcp any any -> any any (msg:\"Setting a flowint counter\"; content:\"GET\"; flowint:myvar,notset; flowint:maxvar,isnotset; flowint: myvar,=,1; flowint: maxvar,=,6; sid:101;)";
sigs[1] = "alert tcp any any -> any any (msg:\"Adding to flowint counter\"; content:\"Unauthorized\"; flowint:myvar,isset; flowint: myvar,+,2; sid:102;)";
sigs[2] = "alert tcp any any -> any any (msg:\"if the flowint counter is 3 create a new counter\"; content:\"Unauthorized\"; flowint: myvar, isset; flowint: myvar,==,3; flowint:cntpackets,notset; flowint: cntpackets, =, 0; sid:103;)";
sigs[3] = "alert tcp any any -> any any (msg:\"and count the rest of the packets received without generating alerts!!!\"; flowint: cntpackets,isset; flowint: cntpackets, +, 1; noalert;sid:104;)";
Expand Down
2 changes: 1 addition & 1 deletion src/detect-flowint.h
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ enum {
FLOWINT_MODIFIER_GT,
/** Checking if a var is set (keyword isset/notset)*/
FLOWINT_MODIFIER_ISSET,
FLOWINT_MODIFIER_NOTSET,
FLOWINT_MODIFIER_ISNOTSET,

FLOWINT_MODIFIER_UNKNOWN
};
Expand Down

0 comments on commit 6e4a501

Please sign in to comment.