offline.py 1.0 KB

123456789101112131415161718192021222324252627282930
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # lint: pylint
  3. """Processores for engine-type: ``offline``
  4. """
  5. from searx import logger
  6. from .abstract import EngineProcessor
  7. logger = logger.getChild('searx.search.processor.offline')
  8. class OfflineProcessor(EngineProcessor):
  9. """Processor class used by ``offline`` engines"""
  10. engine_type = 'offline'
  11. def _search_basic(self, query, params):
  12. return self.engine.search(query, params)
  13. def search(self, query, params, result_container, start_time, timeout_limit):
  14. try:
  15. search_results = self._search_basic(query, params)
  16. self.extend_container(result_container, start_time, search_results)
  17. except ValueError as e:
  18. # do not record the error
  19. logger.exception('engine {0} : invalid input : {1}'.format(self.engine_name, e))
  20. except Exception as e: # pylint: disable=broad-except
  21. self.handle_exception(result_container, e)
  22. logger.exception('engine {0} : exception : {1}'.format(self.engine_name, e))