1
0

__init__.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. # -*- coding: utf-8 -*-
  2. #
  3. # This file is part of Radicale Server - Calendar Server
  4. # Copyright © 2008-2012 Guillaume Ayoub
  5. # Copyright © 2008 Nicolas Kandel
  6. # Copyright © 2008 Pascal Halter
  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. Rights management.
  22. """
  23. import sys
  24. from .. import config, log
  25. def load():
  26. """Load list of available ACL managers."""
  27. rights_type = config.get("rights", "type")
  28. log.LOGGER.debug("Rights type is %s" % rights_type)
  29. if rights_type == "None":
  30. return None
  31. else:
  32. root_module = __import__(
  33. "rights.%s" % rights_type, globals=globals(), level=2)
  34. module = getattr(root_module, rights_type)
  35. # Override rights.[read|write]_authorized
  36. sys.modules[__name__].read_authorized = module.read_authorized
  37. sys.modules[__name__].write_authorized = module.write_authorized
  38. return module
  39. def read_authorized(user, collection):
  40. """Check if the user is allowed to read the collection.
  41. This method is overriden if an auth module is loaded.
  42. """
  43. return True
  44. def write_authorized(user, collection):
  45. """Check if the user is allowed to write the collection.
  46. This method is overriden if an auth module is loaded.
  47. """
  48. return True