owner_write.py 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. # This file is part of Radicale - CalDAV and CardDAV server
  2. # Copyright © 2012-2017 Guillaume Ayoub
  3. # Copyright © 2017-2018 Unrud <unrud@outlook.com>
  4. #
  5. # This library is free software: you can redistribute it and/or modify
  6. # it under the terms of the GNU General Public License as published by
  7. # the Free Software Foundation, either version 3 of the License, or
  8. # (at your option) any later version.
  9. #
  10. # This library 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 General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with Radicale. If not, see <http://www.gnu.org/licenses/>.
  17. """
  18. Rights backend that allows authenticated users to read all calendars and
  19. address books but only grants write access to their own.
  20. """
  21. import radicale.rights.authenticated as authenticated
  22. from radicale import pathutils
  23. class Rights(authenticated.Rights):
  24. def authorization(self, user: str, path: str) -> str:
  25. if self._verify_user and not user:
  26. return ""
  27. sane_path = pathutils.strip_path(path)
  28. if not sane_path:
  29. return "R"
  30. if self._verify_user:
  31. owned = user == sane_path.split("/", maxsplit=1)[0]
  32. else:
  33. owned = True
  34. if "/" not in sane_path:
  35. return "RW" if owned else "R"
  36. if sane_path.count("/") == 1:
  37. return "rw" if owned else "r"
  38. return ""