From 91a6d80e8291852264abdcda83c203dfb5770381 Mon Sep 17 00:00:00 2001 From: Alexandre Flament Date: Mon, 6 Sep 2021 21:42:30 +0200 Subject: [mod] debug mode: log HTTP requests with network name For example wikipedia requests use the logger name "searx.network.wikipedia" Log is disable when searx_debug is False --- searx/network/client.py | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) (limited to 'searx/network/client.py') diff --git a/searx/network/client.py b/searx/network/client.py index 187ae5366..e1abff05a 100644 --- a/searx/network/client.py +++ b/searx/network/client.py @@ -194,7 +194,7 @@ def new_client( # pylint: disable=too-many-arguments enable_http, verify, enable_http2, max_connections, max_keepalive_connections, keepalive_expiry, - proxies, local_address, retries, max_redirects ): + proxies, local_address, retries, max_redirects, hook_log_response ): limit = httpx.Limits( max_connections=max_connections, max_keepalive_connections=max_keepalive_connections, @@ -221,7 +221,17 @@ def new_client( mounts['http://'] = AsyncHTTPTransportNoHttp() transport = get_transport(verify, enable_http2, local_address, None, limit, retries) - return httpx.AsyncClient(transport=transport, mounts=mounts, max_redirects=max_redirects) + + event_hooks = None + if hook_log_response: + event_hooks = {'response': [ hook_log_response ]} + + return httpx.AsyncClient( + transport=transport, + mounts=mounts, + max_redirects=max_redirects, + event_hooks=event_hooks, + ) def get_loop(): @@ -231,7 +241,7 @@ def get_loop(): def init(): # log - for logger_name in ('hpack.hpack', 'hpack.table'): + for logger_name in ('hpack.hpack', 'hpack.table', 'httpx._client'): logging.getLogger(logger_name).setLevel(logging.WARNING) # loop -- cgit v1.2.3