You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
from django.db import IntegrityError from django.shortcuts import get_object_or_404 from rest_framework import generics, status from rest_framework.permissions import IsAuthenticated from rest_framework.response import Response
from ..exceptions import RoleAlreadyAssignedException, RoleConstraintException from ..models import Project, Role, RoleMapping from ..permissions import IsProjectAdmin from ..serializers import RoleMappingSerializer, RoleSerializer
class Roles(generics.ListAPIView): serializer_class = RoleSerializer pagination_class = None permission_classes = [IsAuthenticated] queryset = Role.objects.all()
class RoleMappingList(generics.ListCreateAPIView): serializer_class = RoleMappingSerializer pagination_class = None permission_classes = [IsAuthenticated & IsProjectAdmin]
@property def project(self): return get_object_or_404(Project, pk=self.kwargs['project_id'])
def get_queryset(self): return self.project.role_mappings
def perform_create(self, serializer): try: serializer.save(project=self.project) except IntegrityError: raise RoleAlreadyAssignedException
def delete(self, request, *args, **kwargs): delete_ids = request.data['ids'] RoleMapping.objects.filter(project=self.project, pk__in=delete_ids)\ .exclude(user=self.request.user)\ .delete() return Response(status=status.HTTP_204_NO_CONTENT)
class RoleMappingDetail(generics.RetrieveUpdateAPIView): queryset = RoleMapping.objects.all() serializer_class = RoleMappingSerializer lookup_url_kwarg = 'rolemapping_id' permission_classes = [IsAuthenticated & IsProjectAdmin]
def perform_update(self, serializer): project_id = self.kwargs['project_id'] id = self.kwargs['rolemapping_id'] role = serializer.validated_data['role'] if not RoleMapping.objects.can_update(project_id, id, role.name): raise RoleConstraintException try: super().perform_update(serializer) except IntegrityError: raise RoleAlreadyAssignedException
|