diff options
author | Alexandre Flament <alex@al-f.net> | 2022-02-17 20:27:02 +0100 |
---|---|---|
committer | Alexandre Flament <alex@al-f.net> | 2022-02-17 20:27:02 +0100 |
commit | d1b7debac684bb426faa11839f788afb6f7a679f (patch) | |
tree | 81b93b9f8d8ba924f97596afc2dd606422eb4cbe /searx/plugins | |
parent | 288e3086d2a67aaee45576f13b032f31ab782b45 (diff) | |
download | searxng-d1b7debac684bb426faa11839f788afb6f7a679f.tar.gz searxng-d1b7debac684bb426faa11839f788afb6f7a679f.zip |
[limiter] update
Diffstat (limited to 'searx/plugins')
-rw-r--r-- | searx/plugins/limiter.py | 14 |
1 files changed, 5 insertions, 9 deletions
diff --git a/searx/plugins/limiter.py b/searx/plugins/limiter.py index e028e3e4a..6accf2c1c 100644 --- a/searx/plugins/limiter.py +++ b/searx/plugins/limiter.py @@ -42,19 +42,16 @@ def is_accepted_request(inc_get_counter) -> bool: return False return True - if request.path == '/search' and ('q' in request.args or 'q' in request.form): - c = inc_get_counter(interval=20, keys=[b'IP limit, burst', x_forwarded_for]) - if c > 30: - return False - - c = inc_get_counter(interval=600, keys=[b'IP limit, 10 minutes', x_forwarded_for]) - if c > 300: + if request.path == '/search': + c_burst = inc_get_counter(interval=20, keys=[b'IP limit, burst', x_forwarded_for]) + c_10min = inc_get_counter(interval=600, keys=[b'IP limit, 10 minutes', x_forwarded_for]) + if c_burst > 15 or c_10min > 150: return False if re_bot.match(user_agent): return False - if 'Accept-Language' not in request.headers: + if len(request.headers.get('Accept-Language', '').strip()) == '': return False if request.headers.get('Connection') == 'close': @@ -113,7 +110,6 @@ def create_pre_request(get_aggregation_count): def init(app, settings): - if not settings['server']['limiter']: return False |