summaryrefslogtreecommitdiff
path: root/searx/network/network.py
diff options
context:
space:
mode:
authorMarkus Heiser <markus.heiser@darmarit.de>2024-11-23 11:18:49 +0100
committerMarkus Heiser <markus.heiser@darmarIT.de>2024-11-23 11:33:19 +0100
commit7c4e4ebd40d342735bf2e207d469aed2ca25cfa9 (patch)
tree78ebed6511bad68aea9e321e3346c9ae575aa7bf /searx/network/network.py
parentb8f1a329d3674695302bdd81702b5a2947c291d5 (diff)
downloadsearxng-7c4e4ebd40d342735bf2e207d469aed2ca25cfa9.tar.gz
searxng-7c4e4ebd40d342735bf2e207d469aed2ca25cfa9.zip
[log] warning with URL in case of 'raise_for_httperror'
In order to be able to implement error handling, it is necessary to know which URL triggered the exception / the URL has not yet been logged. Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
Diffstat (limited to 'searx/network/network.py')
-rw-r--r--searx/network/network.py12
1 files changed, 7 insertions, 5 deletions
diff --git a/searx/network/network.py b/searx/network/network.py
index 453c8d2fc..ff02d447a 100644
--- a/searx/network/network.py
+++ b/searx/network/network.py
@@ -233,8 +233,7 @@ class Network:
del kwargs['raise_for_httperror']
return do_raise_for_httperror
- @staticmethod
- def patch_response(response, do_raise_for_httperror):
+ def patch_response(self, response, do_raise_for_httperror):
if isinstance(response, httpx.Response):
# requests compatibility (response is not streamed)
# see also https://www.python-httpx.org/compatibility/#checking-for-4xx5xx-responses
@@ -242,8 +241,11 @@ class Network:
# raise an exception
if do_raise_for_httperror:
- raise_for_httperror(response)
-
+ try:
+ raise_for_httperror(response)
+ except:
+ self._logger.warning(f"HTTP Request failed: {response.request.method} {response.request.url}")
+ raise
return response
def is_valid_response(self, response):
@@ -269,7 +271,7 @@ class Network:
else:
response = await client.request(method, url, **kwargs)
if self.is_valid_response(response) or retries <= 0:
- return Network.patch_response(response, do_raise_for_httperror)
+ return self.patch_response(response, do_raise_for_httperror)
except httpx.RemoteProtocolError as e:
if not was_disconnected:
# the server has closed the connection: