hostname_replace.py 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. import re
  3. from urllib.parse import urlunparse, urlparse
  4. from searx import settings
  5. from searx.plugins import logger
  6. from flask_babel import gettext
  7. name = gettext('Hostname replace')
  8. description = gettext('Rewrite result hostnames or remove results based on the hostname')
  9. default_on = False
  10. preference_section = 'general'
  11. plugin_id = 'hostname_replace'
  12. replacements = {re.compile(p): r for (p, r) in settings[plugin_id].items()} if plugin_id in settings else {}
  13. logger = logger.getChild(plugin_id)
  14. parsed = 'parsed_url'
  15. def on_result(request, search, result):
  16. if parsed not in result:
  17. return True
  18. for (pattern, replacement) in replacements.items():
  19. if pattern.search(result[parsed].netloc):
  20. if not replacement:
  21. return False
  22. result[parsed] = result[parsed]._replace(netloc=pattern.sub(replacement, result[parsed].netloc))
  23. result['url'] = urlunparse(result[parsed])
  24. if result.get('data_src', False):
  25. parsed_data_src = urlparse(result['data_src'])
  26. if pattern.search(parsed_data_src.netloc):
  27. parsed_data_src = parsed_data_src._replace(netloc=pattern.sub(replacement, parsed_data_src.netloc))
  28. result['data_src'] = urlunparse(parsed_data_src)
  29. if result.get('audio_src', False):
  30. parsed_audio_src = urlparse(result['audio_src'])
  31. if pattern.search(parsed_audio_src.netloc):
  32. parsed_audio_src = parsed_audio_src._replace(netloc=pattern.sub(replacement, parsed_audio_src.netloc))
  33. result['audio_src'] = urlunparse(parsed_audio_src)
  34. return True