Files
EdgeNode/internal/waf/checkpoints/cc2.go

120 lines
3.1 KiB
Go
Raw Normal View History

2021-07-19 10:49:56 +08:00
// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
package checkpoints
import (
2023-03-08 16:59:44 +08:00
"fmt"
"github.com/TeaOSLab/EdgeNode/internal/utils/counters"
2021-07-19 10:49:56 +08:00
"github.com/TeaOSLab/EdgeNode/internal/waf/requests"
2023-10-11 12:21:10 +08:00
"github.com/TeaOSLab/EdgeNode/internal/waf/utils"
"github.com/TeaOSLab/EdgeNode/internal/zero"
2021-07-19 10:49:56 +08:00
"github.com/iwind/TeaGo/maps"
"github.com/iwind/TeaGo/types"
"path/filepath"
2021-07-19 10:49:56 +08:00
"strings"
)
var commonFileExtensionsMap = map[string]zero.Zero{
".ico": zero.New(),
".jpg": zero.New(),
".jpeg": zero.New(),
".gif": zero.New(),
".png": zero.New(),
".webp": zero.New(),
".woff2": zero.New(),
".js": zero.New(),
".css": zero.New(),
2023-07-13 16:20:46 +08:00
".ttf": zero.New(),
".otf": zero.New(),
".fnt": zero.New(),
".svg": zero.New(),
}
2021-07-19 10:49:56 +08:00
// CC2Checkpoint 新的CC
type CC2Checkpoint struct {
Checkpoint
}
2023-10-11 12:21:10 +08:00
func (this *CC2Checkpoint) RequestValue(req requests.Request, param string, options maps.Map, ruleId int64) (value any, hasRequestBody bool, sysErr error, userErr error) {
2021-07-19 10:49:56 +08:00
var keys = options.GetSlice("keys")
var keyValues = []string{}
2023-03-08 16:59:44 +08:00
var hasRemoteAddr = false
2021-07-19 10:49:56 +08:00
for _, key := range keys {
2023-03-08 16:59:44 +08:00
if key == "${remoteAddr}" || key == "${rawRemoteAddr}" {
hasRemoteAddr = true
}
2021-07-19 10:49:56 +08:00
keyValues = append(keyValues, req.Format(types.String(key)))
}
if len(keyValues) == 0 {
return
}
var period = options.GetInt("period")
2021-07-19 10:49:56 +08:00
if period <= 0 {
period = 60
} else if period > 7*86400 {
period = 7 * 86400
2021-07-19 10:49:56 +08:00
}
2023-08-08 12:02:21 +08:00
/**var threshold = options.GetInt64("threshold")
2021-07-19 10:49:56 +08:00
if threshold <= 0 {
threshold = 1000
2023-08-08 12:02:21 +08:00
}**/
2021-07-19 10:49:56 +08:00
var ignoreCommonFiles = options.GetBool("ignoreCommonFiles")
if ignoreCommonFiles {
var rawReq = req.WAFRaw()
if len(rawReq.Referer()) > 0 {
var ext = filepath.Ext(rawReq.URL.Path)
if len(ext) > 0 {
_, ok := commonFileExtensionsMap[strings.ToLower(ext)]
if ok {
return
}
}
}
}
var ccKey = "WAF-CC-" + types.String(ruleId) + "-" + strings.Join(keyValues, "@")
2023-11-15 15:57:41 +08:00
var ccValue = counters.SharedCounter.IncreaseKey(ccKey, period)
value = ccValue
2023-03-08 16:59:44 +08:00
// 基于指纹统计
var enableFingerprint = true
if options.Has("enableFingerprint") && !options.GetBool("enableFingerprint") {
enableFingerprint = false
}
if hasRemoteAddr && enableFingerprint {
2023-03-08 16:59:44 +08:00
var fingerprint = req.WAFFingerprint()
if len(fingerprint) > 0 {
var fpKeyValues = []string{}
for _, key := range keys {
if key == "${remoteAddr}" || key == "${rawRemoteAddr}" {
fpKeyValues = append(fpKeyValues, fmt.Sprintf("%x", fingerprint))
continue
}
fpKeyValues = append(fpKeyValues, req.Format(types.String(key)))
}
var fpCCKey = "WAF-CC-" + types.String(ruleId) + "-" + strings.Join(fpKeyValues, "@")
var fpValue = counters.SharedCounter.IncreaseKey(fpCCKey, period)
2023-11-15 15:57:41 +08:00
if fpValue > ccValue {
2023-03-08 16:59:44 +08:00
value = fpValue
}
}
}
2021-07-19 10:49:56 +08:00
return
}
2023-10-11 12:21:10 +08:00
func (this *CC2Checkpoint) ResponseValue(req requests.Request, resp *requests.Response, param string, options maps.Map, ruleId int64) (value any, hasRequestBody bool, sysErr error, userErr error) {
if this.IsRequest() {
return this.RequestValue(req, param, options, ruleId)
}
2021-07-19 10:49:56 +08:00
return
}
2023-10-11 12:21:10 +08:00
func (this *CC2Checkpoint) CacheLife() utils.CacheLife {
return utils.CacheDisabled
}