diff options
author | Alexandre Flament <alex@al-f.net> | 2021-09-10 23:32:30 +0200 |
---|---|---|
committer | Alexandre Flament <alex@al-f.net> | 2021-09-11 11:15:51 +0200 |
commit | 2b53d718e4183b4721fb82d7a15f511db288c5e8 (patch) | |
tree | ddf3d85d0702746934b634ad966f22588d4580b2 /searx/network | |
parent | 76e0f6807ccddb12ca9efe3b2343735d6e1777d4 (diff) | |
download | searxng-2b53d718e4183b4721fb82d7a15f511db288c5e8.tar.gz searxng-2b53d718e4183b4721fb82d7a15f511db288c5e8.zip |
[fix] PR #257: use the image_proxy network instead of the default network
Diffstat (limited to 'searx/network')
-rw-r--r-- | searx/network/__init__.py | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/searx/network/__init__.py b/searx/network/__init__.py index 7b0396a12..21c4c27b5 100644 --- a/searx/network/__init__.py +++ b/searx/network/__init__.py @@ -173,9 +173,17 @@ async def stream_chunk_to_queue(network, queue, method, url, **kwargs): if len(chunk) > 0: queue.put(chunk) except httpx.ResponseClosed: - # the response was closed + # the response was queued before the exception. + # the exception was raised on aiter_raw. + # we do nothing here: in the finally block, None will be queued + # so stream(method, url, **kwargs) generator can stop pass - except (httpx.HTTPError, OSError, h2.exceptions.ProtocolError) as e: + except Exception as e: # pylint: disable=broad-except + # broad except to avoid this scenario: + # exception in network.stream(method, url, **kwargs) + # -> the exception is not catch here + # -> queue None (in finally) + # -> the function below steam(method, url, **kwargs) has nothing to return queue.put(e) finally: queue.put(None) @@ -201,8 +209,9 @@ def stream(method, url, **kwargs): the httpx.AsyncHTTPTransport declared above. """ queue = SimpleQueue() + network = get_context_network() future = asyncio.run_coroutine_threadsafe( - stream_chunk_to_queue(get_network(), queue, method, url, **kwargs), + stream_chunk_to_queue(network, queue, method, url, **kwargs), get_loop() ) |