.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 309 of file network.py.

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

◆ 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 412 of file network.py.

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

Referenced by initialize().

+ Here is the caller graph for this function:

◆ get_network()

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

Definition at line 305 of file network.py.

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

◆ initialize()

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

Definition at line 327 of file network.py.

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