Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 15 additions & 5 deletions g4/SecLangParser.g4
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,8 @@ stmt:
| comment? rule_script_directive file_path actions?
| comment? rule_script_directive QUOTE file_path QUOTE actions?
| comment? remove_rule_by_id remove_rule_by_id_values+
| comment? string_remove_rules values
| comment? string_remove_rules QUOTE values QUOTE
| comment? string_remove_rules string_remove_rules_values
| comment? string_remove_rules QUOTE string_remove_rules_values QUOTE
| comment? update_target_rules update_target_rules_values update_variables
| comment? update_target_rules QUOTE update_target_rules_values QUOTE update_variables
| comment? update_target_rules update_target_rules_values update_variables PIPE new_target
Expand Down Expand Up @@ -151,6 +151,12 @@ string_remove_rules:
| CONFIG_SEC_RULE_REMOVE_BY_TAG # remove_rule_by_tag
;

string_remove_rules_values:
STRING
| VARIABLE_NAME
| COMMA_SEPARATED_STRING
;

update_target_rules:
CONFIG_SEC_RULE_UPDATE_TARGET_BY_ID # update_target_by_id
| CONFIG_SEC_RULE_UPDATE_TARGET_BY_MSG # update_target_by_msg
Expand Down Expand Up @@ -232,9 +238,8 @@ values:
;

action_ctl_target_value:
(INT | IDENT | SINGLE_QUOTE string_literal SINGLE_QUOTE | VARIABLE_NAME) SEMI variable_enum
| (INT | IDENT | SINGLE_QUOTE string_literal SINGLE_QUOTE | VARIABLE_NAME) SEMI collection_enum (COLON collection_value)?

(ctl_id | SINGLE_QUOTE string_literal SINGLE_QUOTE | VARIABLE_NAME) SEMI variable_enum
| (ctl_id | SINGLE_QUOTE string_literal SINGLE_QUOTE | VARIABLE_NAME) SEMI collection_enum (COLON collection_value)?
;

update_target_rules_values:
Expand Down Expand Up @@ -493,4 +498,9 @@ assignment:

var_assignment:
VAR_ASSIGNMENT
;

ctl_id:
INT
| IDENT
;
14 changes: 11 additions & 3 deletions listener.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ type ParserResult struct {
rangeEndEvents []int
setvarCollections []string
setvarNames []string
setvarOperations []string
assignmentOperations []string
}

type TreeShapeListener struct {
Expand Down Expand Up @@ -104,7 +104,7 @@ func (l *TreeShapeListener) EnterRemove_rule_by_tag(ctx *parser.Remove_rule_by_t
l.results.directiveList = append(l.results.directiveList, ctx.GetText())
}

func (l *TreeShapeListener) EnterValues(ctx *parser.ValuesContext) {
func (l *TreeShapeListener) EnterString_remove_rules_values(ctx *parser.String_remove_rules_valuesContext) {
l.results.directiveValues = append(l.results.directiveValues, ctx.GetText())
}

Expand Down Expand Up @@ -169,9 +169,17 @@ func (l *TreeShapeListener) EnterSetvar_stmt(ctx *parser.Setvar_stmtContext) {
}

func (l *TreeShapeListener) EnterAssignment(ctx *parser.AssignmentContext) {
l.results.setvarOperations = append(l.results.setvarOperations, ctx.GetText())
l.results.assignmentOperations = append(l.results.assignmentOperations, ctx.GetText())
}

func (l *TreeShapeListener) EnterVar_assignment(ctx *parser.Var_assignmentContext) {
l.results.directiveValues = append(l.results.directiveValues, ctx.GetText())
}

func (l *TreeShapeListener) EnterCtl_action(ctx *parser.Ctl_actionContext) {
l.results.directiveValues = append(l.results.directiveValues, ctx.GetText())
}

func (l *TreeShapeListener) EnterCtl_id(ctx *parser.Ctl_idContext) {
l.results.directiveValues = append(l.results.directiveValues, ctx.GetText())
}
1,772 changes: 986 additions & 786 deletions parser/seclang_parser.go

Large diffs are not rendered by default.

14 changes: 14 additions & 0 deletions parser/seclangparser_base_listener.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

12 changes: 12 additions & 0 deletions parser/seclangparser_listener.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

15 changes: 14 additions & 1 deletion parser_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -342,10 +342,23 @@ var checkOutputTests = map[string]struct {
directiveList: []string{"SecRule", "SecRule", "SecRule"},
setvarCollections: []string{"tx", "tx", "tx", "tx", "tx", "tx"},
setvarNames: []string{"var1", "var2", "var2", "var2", "header_name_920450_%{tx.0}", "inbound_anomaly_score_pl1"},
setvarOperations: []string{"=", "=", "=+", "=-", "=", "=+"},
assignmentOperations: []string{"=", "=", "=+", "=-", "=", "=+"},
directiveValues: []string{"bar", "0", "2", "1", "/%{tx.0}/", "%{tx.critical_anomaly_score}"},
},
},
"testdata/test_43_colon.conf": {
0,
"",
ParserResult{
collections: []string{"TX", "TX"},
operatorList: []string{"unconditionalMatch"},
directiveList: []string{"SecRule"},
collectionArgs: []string{"paramcounter_ARGS_NAMES:folders.folders", "paramcounter_ARGS_NAMES:folders.folders"},
directiveValues: []string{"ruleRemoveTargetById", "921180"},
// directiveValues: []string{"ruleRemoveTargetById", "921180;TX:paramcounter_ARGS_NAMES:folders.folders", "921180"},
assignmentOperations: []string{"="},
},
},
}

func TestSecLang(t *testing.T) {
Expand Down
Loading