12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- # Copyright (C) 2014 Andrey Antukh <niwi@niwi.be>
- # Copyright (C) 2014 Jesús Espino <jespinog@gmail.com>
- # Copyright (C) 2014 David Barragán <bameda@dbarragan.com>
- # This program is free software: you can redistribute it and/or modify
- # it under the terms of the GNU Affero General Public License as
- # published by the Free Software Foundation, either version 3 of the
- # License, or (at your option) any later version.
- #
- # This program is distributed in the hope that it will be useful,
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- # GNU Affero General Public License for more details.
- #
- # You should have received a copy of the GNU Affero General Public License
- # along with this program. If not, see <http://www.gnu.org/licenses/>.
- from taiga.base.api.permissions import (TaigaResourcePermission, HasProjectPerm,
- IsProjectOwner, AllowAny,
- IsObjectOwner, PermissionComponent)
- from taiga.permissions.service import is_project_owner
- from taiga.projects.history.services import get_model_from_key, get_pk_from_key
- class IsCommentDeleter(PermissionComponent):
- def check_permissions(self, request, view, obj=None):
- return obj.delete_comment_user and obj.delete_comment_user.get("pk", "not-pk") == request.user.pk
- class IsCommentOwner(PermissionComponent):
- def check_permissions(self, request, view, obj=None):
- return obj.user and obj.user.get("pk", "not-pk") == request.user.pk
- class IsCommentProjectOwner(PermissionComponent):
- def check_permissions(self, request, view, obj=None):
- model = get_model_from_key(obj.key)
- pk = get_pk_from_key(obj.key)
- project = model.objects.get(pk=pk)
- return is_project_owner(request.user, project)
- class UserStoryHistoryPermission(TaigaResourcePermission):
- retrieve_perms = HasProjectPerm('view_project')
- delete_comment_perms = IsCommentProjectOwner() | IsCommentOwner()
- undelete_comment_perms = IsCommentProjectOwner() | IsCommentDeleter()
- class TaskHistoryPermission(TaigaResourcePermission):
- retrieve_perms = HasProjectPerm('view_project')
- delete_comment_perms = IsCommentProjectOwner() | IsCommentOwner()
- undelete_comment_perms = IsCommentProjectOwner() | IsCommentDeleter()
- class IssueHistoryPermission(TaigaResourcePermission):
- retrieve_perms = HasProjectPerm('view_project')
- delete_comment_perms = IsCommentProjectOwner() | IsCommentOwner()
- undelete_comment_perms = IsCommentProjectOwner() | IsCommentDeleter()
- class WikiHistoryPermission(TaigaResourcePermission):
- retrieve_perms = HasProjectPerm('view_project')
- delete_comment_perms = IsCommentProjectOwner() | IsCommentOwner()
- undelete_comment_perms = IsCommentProjectOwner() | IsCommentDeleter()
|