-
-
Notifications
You must be signed in to change notification settings - Fork 234
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: removes multiline from default regex modifiers (#876)
* removes multiline from default regex modifiers * relies on coraza.rule.no_regex_multiline * adds coraza.rule.no_regex_multiline to TagsMatrix --------- Co-authored-by: Juan Pablo Tosso <jptosso@gmail.com>
- Loading branch information
Showing
7 changed files
with
162 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
// Copyright 2024 Juan Pablo Tosso and the OWASP Coraza contributors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
//go:build coraza.rule.no_regex_multiline | ||
|
||
package operators | ||
|
||
var shouldNotUseMultilineRegexesOperatorByDefault = true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
// Copyright 2024 Juan Pablo Tosso and the OWASP Coraza contributors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
//go:build !coraza.rule.no_regex_multiline | ||
|
||
package operators | ||
|
||
var shouldNotUseMultilineRegexesOperatorByDefault = false |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,119 @@ | ||
// Copyright 2022 Juan Pablo Tosso and the OWASP Coraza contributors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
//go:build coraza.rule.no_regex_multiline | ||
|
||
package operators | ||
|
||
import ( | ||
"fmt" | ||
"testing" | ||
|
||
"github.com/corazawaf/coraza/v3/experimental/plugins/plugintypes" | ||
"github.com/corazawaf/coraza/v3/internal/corazawaf" | ||
) | ||
|
||
func TestRx(t *testing.T) { | ||
tests := []struct { | ||
pattern string | ||
input string | ||
want bool | ||
}{ | ||
{ | ||
pattern: "som(.*)ta", | ||
input: "somedata", | ||
want: true, | ||
}, | ||
{ | ||
pattern: "som(.*)ta", | ||
input: "notdata", | ||
want: false, | ||
}, | ||
{ | ||
pattern: "ハロー", | ||
input: "ハローワールド", | ||
want: true, | ||
}, | ||
{ | ||
pattern: "ハロー", | ||
input: "グッバイワールド", | ||
want: false, | ||
}, | ||
{ | ||
pattern: `\xac\xed\x00\x05`, | ||
input: "\xac\xed\x00\x05t\x00\x04test", | ||
want: true, | ||
}, | ||
{ | ||
pattern: `\xac\xed\x00\x05`, | ||
input: "\xac\xed\x00t\x00\x04test", | ||
want: false, | ||
}, | ||
{ | ||
// Requires dotall | ||
pattern: `hello.*world`, | ||
input: "hello\nworld", | ||
want: true, | ||
}, | ||
{ | ||
// Requires multiline disabled by default | ||
pattern: `^hello.*world`, | ||
input: "test\nhello\nworld", | ||
want: false, | ||
}, | ||
{ | ||
// Makes sure multiline can be enabled by the user | ||
pattern: `(?m)^hello.*world`, | ||
input: "test\nhello\nworld", | ||
want: true, | ||
}, | ||
{ | ||
// Makes sure, (?s) passed by the user does not | ||
// break the regex. | ||
pattern: `(?s)hello.*world`, | ||
input: "hello\nworld", | ||
want: true, | ||
}, | ||
{ | ||
// Make sure user flags are also applied | ||
pattern: `(?i)hello.*world`, | ||
input: "testHELLO\nworld", | ||
want: true, | ||
}, | ||
{ | ||
// The so called DOLLAR_ENDONLY modifier in PCRE2 is meant to tweak the meaning of dollar '$' | ||
// so that it matches only at the very end of the string (see: https://www.pcre.org/current/doc/html/pcre2pattern.html#SEC6) | ||
// It seems that re2 already behaves like that by default. | ||
pattern: `123$`, | ||
input: "123\n", | ||
want: false, | ||
}, | ||
{ | ||
// Dollar endonly match | ||
pattern: `123$`, | ||
input: "test123", | ||
want: true, | ||
}, | ||
} | ||
|
||
for _, tc := range tests { | ||
tt := tc | ||
t.Run(fmt.Sprintf("%s/%s", tt.pattern, tt.input), func(t *testing.T) { | ||
|
||
opts := plugintypes.OperatorOptions{ | ||
Arguments: tt.pattern, | ||
} | ||
rx, err := newRX(opts) | ||
if err != nil { | ||
t.Error(err) | ||
} | ||
waf := corazawaf.NewWAF() | ||
tx := waf.NewTransaction() | ||
tx.Capture = true | ||
res := rx.Evaluate(tx, tt.input) | ||
if res != tt.want { | ||
t.Errorf("want %v, got %v", tt.want, res) | ||
} | ||
}) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters