summaryrefslogtreecommitdiff
path: root/searx/network/raise_for_httperror.py
diff options
context:
space:
mode:
authorAlexandre Flament <alex@al-f.net>2023-01-15 10:07:44 +0100
committerGitHub <noreply@github.com>2023-01-15 10:07:44 +0100
commit52d415599727f88a77041d7bc162aabfa49cef36 (patch)
treebf76db64f14e00515bd7fd64aa73e1cfab902bf5 /searx/network/raise_for_httperror.py
parentb720a495f0cc5372d07ed68e0d8a5ffa89a14b51 (diff)
parent0cedb1c6d8d38c911176cab954d858fe937cef71 (diff)
downloadsearxng-52d415599727f88a77041d7bc162aabfa49cef36.tar.gz
searxng-52d415599727f88a77041d7bc162aabfa49cef36.zip
Merge pull request #1967 from tiekoetter/suspended_time-settings
settings.yml: add search.suspended_times
Diffstat (limited to 'searx/network/raise_for_httperror.py')
-rw-r--r--searx/network/raise_for_httperror.py14
1 files changed, 11 insertions, 3 deletions
diff --git a/searx/network/raise_for_httperror.py b/searx/network/raise_for_httperror.py
index 414074977..7fc2b7877 100644
--- a/searx/network/raise_for_httperror.py
+++ b/searx/network/raise_for_httperror.py
@@ -9,6 +9,7 @@ from searx.exceptions import (
SearxEngineTooManyRequestsException,
SearxEngineAccessDeniedException,
)
+from searx import get_setting
def is_cloudflare_challenge(resp):
@@ -33,15 +34,22 @@ def raise_for_cloudflare_captcha(resp):
if is_cloudflare_challenge(resp):
# https://support.cloudflare.com/hc/en-us/articles/200170136-Understanding-Cloudflare-Challenge-Passage-Captcha-
# suspend for 2 weeks
- raise SearxEngineCaptchaException(message='Cloudflare CAPTCHA', suspended_time=3600 * 24 * 15)
+ raise SearxEngineCaptchaException(
+ message='Cloudflare CAPTCHA', suspended_time=get_setting('search.suspended_times.cf_SearxEngineCaptcha')
+ )
if is_cloudflare_firewall(resp):
- raise SearxEngineAccessDeniedException(message='Cloudflare Firewall', suspended_time=3600 * 24)
+ raise SearxEngineAccessDeniedException(
+ message='Cloudflare Firewall',
+ suspended_time=get_setting('search.suspended_times.cf_SearxEngineAccessDenied'),
+ )
def raise_for_recaptcha(resp):
if resp.status_code == 503 and '"https://www.google.com/recaptcha/' in resp.text:
- raise SearxEngineCaptchaException(message='ReCAPTCHA', suspended_time=3600 * 24 * 7)
+ raise SearxEngineCaptchaException(
+ message='ReCAPTCHA', suspended_time=get_setting('search.suspended_times.recaptcha_SearxEngineCaptcha')
+ )
def raise_for_captcha(resp):