limiter.py 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # lint: pylint
  3. # pyright: basic
  4. """see :ref:`limiter src`"""
  5. import flask
  6. from searx import redisdb
  7. from searx.plugins import logger
  8. from searx.botdetection import limiter
  9. from searx.botdetection import dump_request
  10. name = "Request limiter"
  11. description = "Limit the number of request"
  12. default_on = False
  13. preference_section = 'service'
  14. logger = logger.getChild('limiter')
  15. def pre_request():
  16. """See :ref:`flask.Flask.before_request`"""
  17. val = limiter.filter_request(flask.request)
  18. if val is not None:
  19. http_status, msg = val
  20. client_ip = flask.request.headers.get('X-Forwarded-For', '<unknown>')
  21. logger.error("BLOCK (IP %s): %s" % (client_ip, msg))
  22. return 'Too Many Requests', http_status
  23. logger.debug("OK: %s" % dump_request(flask.request))
  24. return None
  25. def init(app: flask.Flask, settings) -> bool:
  26. if not settings['server']['limiter']:
  27. return False
  28. if not redisdb.client():
  29. logger.error("The limiter requires Redis")
  30. return False
  31. limiter.init_cfg(logger)
  32. app.before_request(pre_request)
  33. return True