You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

55 lines
2.1 KiB

  1. ###################################################################################
  2. #
  3. # Copyright (C) 2018 MuK IT GmbH
  4. #
  5. # This program is free software: you can redistribute it and/or modify
  6. # it under the terms of the GNU Affero General Public License as
  7. # published by the Free Software Foundation, either version 3 of the
  8. # License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU Affero General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU Affero General Public License
  16. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. #
  18. ###################################################################################
  19. import urllib
  20. import base64
  21. import logging
  22. from werkzeug.datastructures import CombinedMultiDict
  23. _logger = logging.getLogger(__name__)
  24. #----------------------------------------------------------
  25. # Header Helper
  26. #----------------------------------------------------------
  27. def decode_http_basic_authentication_value(value):
  28. try:
  29. username, password = base64.b64decode(value).decode().split(':', 1)
  30. return urllib.parse.unquote(username), urllib.parse.unquote(password)
  31. except:
  32. return None, None
  33. def decode_http_basic_authentication(encoded_header):
  34. header_values = encoded_header.strip().split(' ')
  35. if len(header_values) == 1:
  36. return decode_http_basic_authentication_value(header_values[0])
  37. if len(header_values) == 2 and header_values[0].strip().lower() == 'basic':
  38. return decode_http_basic_authentication_value(header_values[1])
  39. return None, None
  40. #----------------------------------------------------------
  41. # Werkzeug Helper
  42. #----------------------------------------------------------
  43. def request_params(httprequest):
  44. return CombinedMultiDict([
  45. httprequest.args,
  46. httprequest.form,
  47. httprequest.files
  48. ])