__init__.py 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # lint: pylint
  3. """Implement request processores used by engine-types.
  4. """
  5. __all__ = [
  6. 'EngineProcessor',
  7. 'OfflineProcessor',
  8. 'OnlineProcessor',
  9. 'OnlineDictionaryProcessor',
  10. 'OnlineCurrencyProcessor',
  11. 'PROCESSORS',
  12. ]
  13. import threading
  14. from typing import Dict
  15. from searx import logger
  16. from searx import engines
  17. from .online import OnlineProcessor
  18. from .offline import OfflineProcessor
  19. from .online_dictionary import OnlineDictionaryProcessor
  20. from .online_currency import OnlineCurrencyProcessor
  21. from .abstract import EngineProcessor
  22. logger = logger.getChild('search.processors')
  23. PROCESSORS: Dict[str, EngineProcessor] = {}
  24. """Cache request processores, stored by *engine-name* (:py:func:`initialize`)"""
  25. def get_processor_class(engine_type):
  26. """Return processor class according to the ``engine_type``"""
  27. for c in [OnlineProcessor, OfflineProcessor, OnlineDictionaryProcessor, OnlineCurrencyProcessor]:
  28. if c.engine_type == engine_type:
  29. return c
  30. return None
  31. def get_processor(engine, engine_name):
  32. """Return processor instance that fits to ``engine.engine.type``)"""
  33. engine_type = getattr(engine, 'engine_type', 'online')
  34. processor_class = get_processor_class(engine_type)
  35. if processor_class:
  36. return processor_class(engine, engine_name)
  37. return None
  38. def initialize_processor(processor):
  39. """Initialize one processor
  40. Call the init function of the engine
  41. """
  42. if processor.has_initialize_function:
  43. t = threading.Thread(target=processor.initialize, daemon=True)
  44. t.start()
  45. def initialize(engine_list):
  46. """Initialize all engines and store a processor for each engine in :py:obj:`PROCESSORS`."""
  47. for engine_data in engine_list:
  48. engine_name = engine_data['name']
  49. engine = engines.engines.get(engine_name)
  50. if engine:
  51. processor = get_processor(engine, engine_name)
  52. initialize_processor(processor)
  53. if processor is None:
  54. engine.logger.error('Error get processor for engine %s', engine_name)
  55. else:
  56. PROCESSORS[engine_name] = processor