summaryrefslogtreecommitdiff
path: root/utils/templates
diff options
context:
space:
mode:
authorMarkus Heiser <markus.heiser@darmarit.de>2020-01-13 18:37:05 +0100
committerMarkus Heiser <markus.heiser@darmarit.de>2020-01-13 18:37:05 +0100
commitb5449ec47cff805a05329a3e5f925cd661457530 (patch)
treeb9072fa2302cea834f512cda125472fe748435a7 /utils/templates
parent39feb141bc8361915b3d80a976852b38851e0419 (diff)
filtron: log suspiciously frequent queries (WIP)
Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
Diffstat (limited to 'utils/templates')
-rw-r--r--utils/templates/etc/filtron/rules.json59
1 files changed, 40 insertions, 19 deletions
diff --git a/utils/templates/etc/filtron/rules.json b/utils/templates/etc/filtron/rules.json
index b54e097a5..634f5f2d6 100644
--- a/utils/templates/etc/filtron/rules.json
+++ b/utils/templates/etc/filtron/rules.json
@@ -1,42 +1,63 @@
[{
+ "name":"suspiciously frequent queries",
+ "filters":[
+ "Param:q",
+ "Path=^(/|/search)$"
+ ],
+ "interval":120,
+ "limit":9,
+ "actions":[
+ {"name":"log"}
+ ]
+ },
+ {
"name":"search request",
"filters":[
"Param:q",
"Path=^(/|/search)$"
],
- "interval":60,
- "limit":15,
+ "interval":120,
+ "limit":19,
+ "actions":[
+ {
+ "name":"block",
+ "params":{
+ "message":"common rate limit exceeded"
+ }
+ }
+ ],
"subrules":[
{
"name":"roboagent limit",
"interval":60,
- "limit":15,
+ "limit":3,
"filters":[
- "Header:User-Agent=(curl|cURL|Wget|python-requests|Scrapy|FeedFetcher|Go-http-client)"
+ "Header:User-Agent=(curl|cURL|Wget|python-requests|Scrapy|FeedFetcher|Go-http-client|Ruby)"
],
"actions":[
- {"name": "log"},
- {
+ {"name":"log"},
+ {
"name":"block",
"params":{
- "message":"Rate limit exceeded"
+ "message":"rate limit exceeded"
}
}
]
},
{
"name":"botlimit",
+ "interval":60,
"limit":0,
"stop":true,
"filters":[
"Header:User-Agent=(Googlebot|bingbot|Baiduspider|yacybot|YandexMobileBot|YandexBot|Yahoo! Slurp|MJ12bot|AhrefsBot|archive.org_bot|msnbot|MJ12bot|SeznamBot|linkdexbot|Netvibes|SMTBot|zgrab|James BOT)"
],
"actions":[
- {"name": "log"},
+ {"name":"log"},
{
"name":"block",
"params":{
- "message":"Rate limit exceeded"
+ "message":"rate limit exceeded"
}
}
]
@@ -44,17 +65,17 @@
{
"name":"IP limit",
"interval":60,
- "limit":15,
+ "limit":13,
"stop":true,
"aggregations":[
"Header:X-Forwarded-For"
],
"actions":[
- {"name": "log"},
+ {"name":"log"},
{
"name":"block",
"params":{
- "message":"Rate limit exceeded"
+ "message":"rate limit exceeded"
}
}
]
@@ -62,34 +83,34 @@
{
"name":"rss/json limit",
"interval":60,
- "limit":15,
+ "limit":13,
"stop":true,
"filters":[
"Param:format=(csv|json|rss)"
],
"actions":[
- {"name": "log"},
+ {"name":"log"},
{
"name":"block",
"params":{
- "message":"Rate limit exceeded"
+ "message":"rate limit exceeded"
}
}
]
- },
+ },
{
"name":"useragent limit",
"interval":60,
- "limit":15,
+ "limit":13,
"aggregations":[
"Header:User-Agent"
],
"actions":[
- {"name": "log"},
+ {"name":"log"},
{
"name":"block",
"params":{
- "message":"Rate limit exceeded"
+ "message":"rate limit exceeded"
}
}
]