permissions.py 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. # Copyright (C) 2014 Andrey Antukh <niwi@niwi.be>
  2. # Copyright (C) 2014 Jesús Espino <jespinog@gmail.com>
  3. # Copyright (C) 2014 David Barragán <bameda@dbarragan.com>
  4. # This program is free software: you can redistribute it and/or modify
  5. # it under the terms of the GNU Affero General Public License as
  6. # published by the Free Software Foundation, either version 3 of the
  7. # License, or (at your option) any later version.
  8. #
  9. # This program is distributed in the hope that it will be useful,
  10. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. # GNU Affero General Public License for more details.
  13. #
  14. # You should have received a copy of the GNU Affero General Public License
  15. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. from taiga.base.api.permissions import (TaigaResourcePermission, HasProjectPerm,
  17. IsProjectOwner, AllowAny,
  18. IsObjectOwner, PermissionComponent)
  19. from taiga.permissions.service import is_project_owner
  20. from taiga.projects.history.services import get_model_from_key, get_pk_from_key
  21. class IsCommentDeleter(PermissionComponent):
  22. def check_permissions(self, request, view, obj=None):
  23. return obj.delete_comment_user and obj.delete_comment_user.get("pk", "not-pk") == request.user.pk
  24. class IsCommentOwner(PermissionComponent):
  25. def check_permissions(self, request, view, obj=None):
  26. return obj.user and obj.user.get("pk", "not-pk") == request.user.pk
  27. class IsCommentProjectOwner(PermissionComponent):
  28. def check_permissions(self, request, view, obj=None):
  29. model = get_model_from_key(obj.key)
  30. pk = get_pk_from_key(obj.key)
  31. project = model.objects.get(pk=pk)
  32. return is_project_owner(request.user, project)
  33. class UserStoryHistoryPermission(TaigaResourcePermission):
  34. retrieve_perms = HasProjectPerm('view_project')
  35. delete_comment_perms = IsCommentProjectOwner() | IsCommentOwner()
  36. undelete_comment_perms = IsCommentProjectOwner() | IsCommentDeleter()
  37. class TaskHistoryPermission(TaigaResourcePermission):
  38. retrieve_perms = HasProjectPerm('view_project')
  39. delete_comment_perms = IsCommentProjectOwner() | IsCommentOwner()
  40. undelete_comment_perms = IsCommentProjectOwner() | IsCommentDeleter()
  41. class IssueHistoryPermission(TaigaResourcePermission):
  42. retrieve_perms = HasProjectPerm('view_project')
  43. delete_comment_perms = IsCommentProjectOwner() | IsCommentOwner()
  44. undelete_comment_perms = IsCommentProjectOwner() | IsCommentDeleter()
  45. class WikiHistoryPermission(TaigaResourcePermission):
  46. retrieve_perms = HasProjectPerm('view_project')
  47. delete_comment_perms = IsCommentProjectOwner() | IsCommentOwner()
  48. undelete_comment_perms = IsCommentProjectOwner() | IsCommentDeleter()