.oO SearXNG Developer Documentation Oo.
Loading...
Searching...
No Matches
searx.network.network Namespace Reference

Classes

class  Network
 

Functions

 get_network (name=None)
 
 check_network_configuration ()
 
 initialize (settings_engines=None, settings_outgoing=None)
 
 done ()
 

Variables

 logger = logger.getChild('network')
 
str DEFAULT_NAME = '__DEFAULT__'
 
dict NETWORKS = {}
 
dict PROXY_PATTERN_MAPPING
 
dict ADDRESS_MAPPING = {'ipv4': '0.0.0.0', 'ipv6': '::'}
 

Function Documentation

◆ check_network_configuration()

searx.network.network.check_network_configuration ( )

Definition at line 311 of file network.py.

311def check_network_configuration():
312 async def check():
313 exception_count = 0
314 for network in NETWORKS.values():
315 if network.using_tor_proxy:
316 try:
317 await network.get_client()
318 except Exception: # pylint: disable=broad-except
319 network._logger.exception('Error') # pylint: disable=protected-access
320 exception_count += 1
321 return exception_count
322
323 future = asyncio.run_coroutine_threadsafe(check(), get_loop())
324 exception_count = future.result()
325 if exception_count > 0:
326 raise RuntimeError("Invalid network configuration")
327
328

◆ done()

searx.network.network.done ( )
Close all HTTP client

Avoid a warning at exit
See https://github.com/encode/httpx/pull/2026

Note: since Network.aclose has to be async, it is not possible to call this method on Network.__del__
So Network.aclose is called here using atexit.register

Definition at line 414 of file network.py.

414def done():
415 """Close all HTTP client
416
417 Avoid a warning at exit
418 See https://github.com/encode/httpx/pull/2026
419
420 Note: since Network.aclose has to be async, it is not possible to call this method on Network.__del__
421 So Network.aclose is called here using atexit.register
422 """
423 try:
424 loop = get_loop()
425 if loop:
426 future = asyncio.run_coroutine_threadsafe(Network.aclose_all(), loop)
427 # wait 3 seconds to close the HTTP clients
428 future.result(3)
429 finally:
430 NETWORKS.clear()
431
432

Referenced by initialize().

+ Here is the caller graph for this function:

◆ get_network()

searx.network.network.get_network ( name = None)

Definition at line 307 of file network.py.

307def get_network(name=None):
308 return NETWORKS.get(name or DEFAULT_NAME)
309
310

◆ initialize()

searx.network.network.initialize ( settings_engines = None,
settings_outgoing = None )

Definition at line 329 of file network.py.

329def initialize(settings_engines=None, settings_outgoing=None):
330 # pylint: disable=import-outside-toplevel)
331 from searx.engines import engines
332 from searx import settings
333
334 # pylint: enable=import-outside-toplevel)
335
336 settings_engines = settings_engines or settings['engines']
337 settings_outgoing = settings_outgoing or settings['outgoing']
338
339 # default parameters for AsyncHTTPTransport
340 # see https://github.com/encode/httpx/blob/e05a5372eb6172287458b37447c30f650047e1b8/httpx/_transports/default.py#L108-L121 # pylint: disable=line-too-long
341 default_params = {
342 'enable_http': False,
343 'verify': settings_outgoing['verify'],
344 'enable_http2': settings_outgoing['enable_http2'],
345 'max_connections': settings_outgoing['pool_connections'],
346 'max_keepalive_connections': settings_outgoing['pool_maxsize'],
347 'keepalive_expiry': settings_outgoing['keepalive_expiry'],
348 'local_addresses': settings_outgoing['source_ips'],
349 'using_tor_proxy': settings_outgoing['using_tor_proxy'],
350 'proxies': settings_outgoing['proxies'],
351 'max_redirects': settings_outgoing['max_redirects'],
352 'retries': settings_outgoing['retries'],
353 'retry_on_http_error': None,
354 }
355
356 def new_network(params, logger_name=None):
357 nonlocal default_params
358 result = {}
359 result.update(default_params)
360 result.update(params)
361 if logger_name:
362 result['logger_name'] = logger_name
363 return Network(**result)
364
365 def iter_networks():
366 nonlocal settings_engines
367 for engine_spec in settings_engines:
368 engine_name = engine_spec['name']
369 engine = engines.get(engine_name)
370 if engine is None:
371 continue
372 network = getattr(engine, 'network', None)
373 yield engine_name, engine, network
374
375 if NETWORKS:
376 done()
377 NETWORKS.clear()
378 NETWORKS[DEFAULT_NAME] = new_network({}, logger_name='default')
379 NETWORKS['ipv4'] = new_network({'local_addresses': '0.0.0.0'}, logger_name='ipv4')
380 NETWORKS['ipv6'] = new_network({'local_addresses': '::'}, logger_name='ipv6')
381
382 # define networks from outgoing.networks
383 for network_name, network in settings_outgoing['networks'].items():
384 NETWORKS[network_name] = new_network(network, logger_name=network_name)
385
386 # define networks from engines.[i].network (except references)
387 for engine_name, engine, network in iter_networks():
388 if network is None:
389 network = {}
390 for attribute_name, attribute_value in default_params.items():
391 if hasattr(engine, attribute_name):
392 network[attribute_name] = getattr(engine, attribute_name)
393 else:
394 network[attribute_name] = attribute_value
395 NETWORKS[engine_name] = new_network(network, logger_name=engine_name)
396 elif isinstance(network, dict):
397 NETWORKS[engine_name] = new_network(network, logger_name=engine_name)
398
399 # define networks from engines.[i].network (references)
400 for engine_name, engine, network in iter_networks():
401 if isinstance(network, str):
402 NETWORKS[engine_name] = NETWORKS[network]
403
404 # the /image_proxy endpoint has a dedicated network.
405 # same parameters than the default network, but HTTP/2 is disabled.
406 # It decreases the CPU load average, and the total time is more or less the same
407 if 'image_proxy' not in NETWORKS:
408 image_proxy_params = default_params.copy()
409 image_proxy_params['enable_http2'] = False
410 NETWORKS['image_proxy'] = new_network(image_proxy_params, logger_name='image_proxy')
411
412
413@atexit.register
::1337x
Definition 1337x.py:1

References done().

+ Here is the call graph for this function:

Variable Documentation

◆ ADDRESS_MAPPING

dict searx.network.network.ADDRESS_MAPPING = {'ipv4': '0.0.0.0', 'ipv6': '::'}

Definition at line 38 of file network.py.

◆ DEFAULT_NAME

str searx.network.network.DEFAULT_NAME = '__DEFAULT__'

Definition at line 22 of file network.py.

◆ logger

searx.network.network.logger = logger.getChild('network')

Definition at line 21 of file network.py.

◆ NETWORKS

dict searx.network.network.NETWORKS = {}

Definition at line 23 of file network.py.

◆ PROXY_PATTERN_MAPPING

dict searx.network.network.PROXY_PATTERN_MAPPING
Initial value:
1= {
2 'http': 'http://',
3 'https': 'https://',
4 'socks4': 'socks4://',
5 'socks5': 'socks5://',
6 'socks5h': 'socks5h://',
7 'http:': 'http://',
8 'https:': 'https://',
9 'socks4:': 'socks4://',
10 'socks5:': 'socks5://',
11 'socks5h:': 'socks5h://',
12}

Definition at line 25 of file network.py.