__init__.py 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. # -*- coding: utf-8 -*-
  2. #
  3. # This file is part of Radicale Server - Calendar Server
  4. # Copyright © 2008 Nicolas Kandel
  5. # Copyright © 2008 Pascal Halter
  6. # Copyright © 2008-2013 Guillaume Ayoub
  7. #
  8. # This library is free software: you can redistribute it and/or modify
  9. # it under the terms of the GNU General Public License as published by
  10. # the Free Software Foundation, either version 3 of the License, or
  11. # (at your option) any later version.
  12. #
  13. # This library is distributed in the hope that it will be useful,
  14. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. # GNU General Public License for more details.
  17. #
  18. # You should have received a copy of the GNU General Public License
  19. # along with Radicale. If not, see <http://www.gnu.org/licenses/>.
  20. """
  21. Authentication management.
  22. """
  23. import sys
  24. from .. import config, log
  25. def load():
  26. """Load list of available authentication managers."""
  27. auth_type = config.get("auth", "type")
  28. log.LOGGER.debug("Authentication type is %s" % auth_type)
  29. if auth_type == "None":
  30. return None
  31. elif auth_type == 'custom':
  32. auth_module = config.get("auth", "custom_handler")
  33. __import__(auth_module)
  34. module = sys.modules[auth_module]
  35. else:
  36. root_module = __import__(
  37. "auth.%s" % auth_type, globals=globals(), level=2)
  38. module = getattr(root_module, auth_type)
  39. # Override auth.is_authenticated
  40. sys.modules[__name__].is_authenticated = module.is_authenticated
  41. return module
  42. def is_authenticated(user, password):
  43. """Check if the user is authenticated.
  44. This method is overriden if an auth module is loaded.
  45. """
  46. return True # Default is always True: no authentication