2023-12-09 11:46:50 +08:00
|
|
|
package waf_test
|
2020-10-08 15:06:42 +08:00
|
|
|
|
|
|
|
|
import (
|
2023-11-16 08:43:31 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/firewallconfigs"
|
2023-12-09 11:46:50 +08:00
|
|
|
"github.com/TeaOSLab/EdgeNode/internal/waf"
|
2021-07-18 15:51:49 +08:00
|
|
|
"github.com/TeaOSLab/EdgeNode/internal/waf/requests"
|
2020-10-08 15:06:42 +08:00
|
|
|
"github.com/iwind/TeaGo/assert"
|
|
|
|
|
"net/http"
|
|
|
|
|
"testing"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestWAF_MatchRequest(t *testing.T) {
|
2023-12-09 11:46:50 +08:00
|
|
|
var a = assert.NewAssertion(t)
|
2020-10-08 15:06:42 +08:00
|
|
|
|
2023-12-09 11:46:50 +08:00
|
|
|
var set = waf.NewRuleSet()
|
2020-10-08 15:06:42 +08:00
|
|
|
set.Name = "Name_Age"
|
2023-12-09 11:46:50 +08:00
|
|
|
set.Connector = waf.RuleConnectorAnd
|
|
|
|
|
set.Rules = []*waf.Rule{
|
2020-10-08 15:06:42 +08:00
|
|
|
{
|
|
|
|
|
Param: "${arg.name}",
|
2023-12-09 11:46:50 +08:00
|
|
|
Operator: waf.RuleOperatorEqString,
|
2020-10-08 15:06:42 +08:00
|
|
|
Value: "lu",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
Param: "${arg.age}",
|
2023-12-09 11:46:50 +08:00
|
|
|
Operator: waf.RuleOperatorEq,
|
2020-10-08 15:06:42 +08:00
|
|
|
Value: "20",
|
|
|
|
|
},
|
|
|
|
|
}
|
2023-12-09 11:46:50 +08:00
|
|
|
set.AddAction(waf.ActionBlock, nil)
|
2020-10-08 15:06:42 +08:00
|
|
|
|
2023-12-09 11:46:50 +08:00
|
|
|
var group = waf.NewRuleGroup()
|
2020-10-08 15:06:42 +08:00
|
|
|
group.AddRuleSet(set)
|
|
|
|
|
group.IsInbound = true
|
|
|
|
|
|
2023-12-09 11:46:50 +08:00
|
|
|
var wafInstance = waf.NewWAF()
|
|
|
|
|
wafInstance.AddRuleGroup(group)
|
|
|
|
|
errs := wafInstance.Init()
|
2022-01-09 17:07:37 +08:00
|
|
|
if len(errs) > 0 {
|
|
|
|
|
t.Fatal(errs[0])
|
2020-10-08 15:06:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://teaos.cn/hello?name=lu&age=20", nil)
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
2023-12-09 11:46:50 +08:00
|
|
|
goNext, _, _, set, err := wafInstance.MatchRequest(requests.NewTestRequest(req), nil, firewallconfigs.ServerCaptchaTypeNone)
|
2020-10-08 15:06:42 +08:00
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
if set == nil {
|
|
|
|
|
t.Log("not match")
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
t.Log("goNext:", goNext, "set:", set.Name)
|
|
|
|
|
a.IsFalse(goNext)
|
|
|
|
|
}
|