mirror of
https://github.com/Steffo99/sophon.git
synced 2024-12-22 14:54:22 +00:00
🔧 Split ProjectViewSet in multiple sub-viewsets
This commit is contained in:
parent
7d24b40cc9
commit
c6abc1bd0e
4 changed files with 105 additions and 19 deletions
|
@ -4,15 +4,16 @@ from rest_framework import permissions
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class ProjectPermissions(permissions.BasePermission):
|
class CanViewObject(permissions.BasePermission):
|
||||||
def has_object_permission(self, request, view, obj):
|
def has_object_permission(self, request, view, obj):
|
||||||
if view.action == "retrieve":
|
|
||||||
return obj.can_be_viewed_by(request.user)
|
return obj.can_be_viewed_by(request.user)
|
||||||
elif view.action == "update":
|
|
||||||
|
|
||||||
|
class CanEditObject(permissions.BasePermission):
|
||||||
|
def has_object_permission(self, request, view, obj):
|
||||||
return obj.can_be_edited_by(request.user)
|
return obj.can_be_edited_by(request.user)
|
||||||
elif view.action == "partial_update":
|
|
||||||
return obj.can_be_edited_by(request.user)
|
|
||||||
elif view.action == "destroy":
|
class CanAdministrateObject(permissions.BasePermission):
|
||||||
|
def has_object_permission(self, request, view, obj):
|
||||||
return obj.can_be_administrated_by(request.user)
|
return obj.can_be_administrated_by(request.user)
|
||||||
log.warning(f"Rejecting permissions for unknown action: {view.action}")
|
|
||||||
return False
|
|
||||||
|
|
|
@ -30,6 +30,10 @@ class DataSourceSerializer(serializers.ModelSerializer):
|
||||||
"builtin",
|
"builtin",
|
||||||
"last_sync",
|
"last_sync",
|
||||||
]
|
]
|
||||||
|
read_only_fields = [
|
||||||
|
"builtin",
|
||||||
|
"last_sync",
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
class DataFlowSerializer(serializers.ModelSerializer):
|
class DataFlowSerializer(serializers.ModelSerializer):
|
||||||
|
@ -45,11 +49,35 @@ class DataFlowSerializer(serializers.ModelSerializer):
|
||||||
"id",
|
"id",
|
||||||
"description",
|
"description",
|
||||||
]
|
]
|
||||||
|
read_only_fields = [
|
||||||
|
"surrogate_id",
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
class ProjectSerializer(serializers.ModelSerializer):
|
class ProjectExternalSerializer(serializers.ModelSerializer):
|
||||||
"""
|
"""
|
||||||
Serializer for :class:`.models.Project` .
|
Serializer for :class:`.models.Project` when accessed from outside.
|
||||||
|
"""
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = models.Project
|
||||||
|
fields = [
|
||||||
|
"slug",
|
||||||
|
"name",
|
||||||
|
"visibility",
|
||||||
|
"owner",
|
||||||
|
]
|
||||||
|
read_only_fields = [
|
||||||
|
"slug",
|
||||||
|
"name",
|
||||||
|
"visibility",
|
||||||
|
"owner",
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
class ProjectCollaboratorSerializer(serializers.ModelSerializer):
|
||||||
|
"""
|
||||||
|
Serializer for :class:`.models.Project` when accessed as a collaborator.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
@ -63,3 +91,30 @@ class ProjectSerializer(serializers.ModelSerializer):
|
||||||
"collaborators",
|
"collaborators",
|
||||||
"flows",
|
"flows",
|
||||||
]
|
]
|
||||||
|
read_only_fields = [
|
||||||
|
"slug",
|
||||||
|
"visibility",
|
||||||
|
"owner",
|
||||||
|
"collaborators",
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
class ProjectOwnerSerializer(serializers.ModelSerializer):
|
||||||
|
"""
|
||||||
|
Serializer for :class:`.models.Project` when accessed as the project owner.
|
||||||
|
"""
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = models.Project
|
||||||
|
fields = [
|
||||||
|
"slug",
|
||||||
|
"name",
|
||||||
|
"description",
|
||||||
|
"visibility",
|
||||||
|
"owner",
|
||||||
|
"collaborators",
|
||||||
|
"flows",
|
||||||
|
]
|
||||||
|
read_only_fields = [
|
||||||
|
"slug",
|
||||||
|
]
|
||||||
|
|
|
@ -4,7 +4,9 @@ from . import views
|
||||||
|
|
||||||
|
|
||||||
router = DefaultRouter()
|
router = DefaultRouter()
|
||||||
router.register("projects", views.ProjectViewSet)
|
router.register("projects_external", views.ProjectExternalViewSet)
|
||||||
|
router.register("projects_contributor", views.ProjectContributorViewSet)
|
||||||
|
router.register("projects_owner", views.ProjectOwnerViewSet)
|
||||||
router.register("datasources", views.DataSourceViewSet)
|
router.register("datasources", views.DataSourceViewSet)
|
||||||
router.register("dataflows", views.DataFlowViewSet)
|
router.register("dataflows", views.DataFlowViewSet)
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from rest_framework import viewsets, decorators, response, permissions
|
from rest_framework import viewsets, decorators, response, permissions, mixins
|
||||||
from . import models, serializers, permissions as custom_permissions
|
from . import models, serializers, permissions as custom_permissions
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from logging import getLogger
|
from logging import getLogger
|
||||||
|
@ -6,19 +6,46 @@ from logging import getLogger
|
||||||
log = getLogger(__name__)
|
log = getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class ProjectViewSet(viewsets.ModelViewSet):
|
class ProjectExternalViewSet(viewsets.ReadOnlyModelViewSet):
|
||||||
"""
|
"""
|
||||||
Viewset for :class:`.models.Project` instances.
|
Viewset for :class:`.models.Project` instances when viewed by the outside.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
queryset = models.Project.objects.all()
|
queryset = models.Project.objects.all()
|
||||||
serializer_class = serializers.ProjectSerializer
|
serializer_class = serializers.ProjectExternalSerializer
|
||||||
permission_classes = [custom_permissions.ProjectPermissions]
|
permission_classes = []
|
||||||
|
|
||||||
|
|
||||||
|
class ProjectContributorViewSet(viewsets.GenericViewSet,
|
||||||
|
mixins.RetrieveModelMixin,
|
||||||
|
mixins.UpdateModelMixin):
|
||||||
|
"""
|
||||||
|
Viewset for :class:`.models.Project` instances when viewed by a project contributor.
|
||||||
|
"""
|
||||||
|
|
||||||
|
queryset = models.Project.objects.all()
|
||||||
|
serializer_class = serializers.ProjectCollaboratorSerializer
|
||||||
|
permission_classes = [custom_permissions.CanEditObject]
|
||||||
|
|
||||||
|
|
||||||
|
class ProjectOwnerViewSet(viewsets.GenericViewSet,
|
||||||
|
mixins.RetrieveModelMixin,
|
||||||
|
mixins.UpdateModelMixin,
|
||||||
|
mixins.DestroyModelMixin):
|
||||||
|
"""
|
||||||
|
Viewset for :class:`.models.Project` instances when viewed by a project owner.
|
||||||
|
"""
|
||||||
|
|
||||||
|
queryset = models.Project.objects.all()
|
||||||
|
serializer_class = serializers.ProjectOwnerSerializer
|
||||||
|
permission_classes = [custom_permissions.CanAdministrateObject]
|
||||||
|
|
||||||
|
|
||||||
class DataFlowViewSet(viewsets.ModelViewSet):
|
class DataFlowViewSet(viewsets.ModelViewSet):
|
||||||
"""
|
"""
|
||||||
Viewset for :class:`.models.DataFlow` instances.
|
Viewset for :class:`.models.DataFlow` instances.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
queryset = models.DataFlow.objects.all()
|
queryset = models.DataFlow.objects.all()
|
||||||
serializer_class = serializers.DataFlowSerializer
|
serializer_class = serializers.DataFlowSerializer
|
||||||
permission_classes = [permissions.DjangoModelPermissionsOrAnonReadOnly]
|
permission_classes = [permissions.DjangoModelPermissionsOrAnonReadOnly]
|
||||||
|
@ -28,6 +55,7 @@ class DataSourceViewSet(viewsets.ModelViewSet):
|
||||||
"""
|
"""
|
||||||
Viewset for :class:`.models.DataSource` instances.
|
Viewset for :class:`.models.DataSource` instances.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
queryset = models.DataSource.objects.all()
|
queryset = models.DataSource.objects.all()
|
||||||
serializer_class = serializers.DataSourceSerializer
|
serializer_class = serializers.DataSourceSerializer
|
||||||
permission_classes = [permissions.DjangoModelPermissionsOrAnonReadOnly]
|
permission_classes = [permissions.DjangoModelPermissionsOrAnonReadOnly]
|
||||||
|
|
Loading…
Reference in a new issue