mirror of
https://github.com/Steffo99/sophon.git
synced 2024-12-22 14:54:22 +00:00
🔧 Conditionally display jupyter tokens in /notebooks/by-project/.../
(fixes #69)
This commit is contained in:
parent
2886c4598d
commit
4e17c9dd96
3 changed files with 23 additions and 14 deletions
|
@ -51,9 +51,11 @@ class ReadSophonViewSet(ReadOnlyModelViewSet, metaclass=abc.ABCMeta):
|
||||||
return permissions.AllowAny,
|
return permissions.AllowAny,
|
||||||
|
|
||||||
def get_serializer_class(self):
|
def get_serializer_class(self):
|
||||||
|
if self.action in ["list"]:
|
||||||
|
return self.get_queryset().model.get_view_serializer()
|
||||||
if self.action in ["create", "metadata"]:
|
if self.action in ["create", "metadata"]:
|
||||||
return self.get_queryset().model.get_creation_serializer()
|
return self.get_queryset().model.get_creation_serializer()
|
||||||
elif self.action in ["list", "retrieve", "update", "partial_update", "destroy"]:
|
elif self.action in ["retrieve", "update", "partial_update", "destroy"]:
|
||||||
return self.get_object().get_access_serializer(self.request.user)
|
return self.get_object().get_access_serializer(self.request.user)
|
||||||
else:
|
else:
|
||||||
return self.get_custom_serializer_classes()
|
return self.get_custom_serializer_classes()
|
||||||
|
|
|
@ -11,10 +11,8 @@ import docker.models.networks
|
||||||
import docker.models.volumes
|
import docker.models.volumes
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from rest_framework.serializers import ModelSerializer
|
|
||||||
|
|
||||||
from sophon.core.models import SophonGroupModel, ResearchGroup
|
from sophon.core.models import SophonGroupModel, ResearchGroup
|
||||||
from sophon.core.serializers import dynamic_serializer
|
|
||||||
from sophon.notebooks.apache import db as apache_db
|
from sophon.notebooks.apache import db as apache_db
|
||||||
from sophon.notebooks.apache import get_ephemeral_port, base_domain, http_protocol
|
from sophon.notebooks.apache import get_ephemeral_port, base_domain, http_protocol
|
||||||
from sophon.notebooks.docker import client as docker_client
|
from sophon.notebooks.docker import client as docker_client
|
||||||
|
@ -162,17 +160,6 @@ class Notebook(SophonGroupModel):
|
||||||
"container_image",
|
"container_image",
|
||||||
}
|
}
|
||||||
|
|
||||||
def get_access_serializer(self, user: User) -> t.Type[ModelSerializer]:
|
|
||||||
access = super().get_access_serializer(user)
|
|
||||||
if self.can_edit(user):
|
|
||||||
# noinspection PyUnresolvedReferences
|
|
||||||
fields = tuple(set(access.Meta.fields).union(self.get_member_fields()))
|
|
||||||
# noinspection PyUnresolvedReferences
|
|
||||||
read_only_fields = tuple(set(access.Meta.read_only_fields).union(self.get_member_fields()))
|
|
||||||
return dynamic_serializer(_model=self.__class__, _fields=fields, _read_only_fields=read_only_fields)
|
|
||||||
else:
|
|
||||||
return access
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def container_name(self) -> str:
|
def container_name(self) -> str:
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -8,6 +8,7 @@ from rest_framework.request import Request
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
|
|
||||||
from sophon.core.models import ResearchGroup
|
from sophon.core.models import ResearchGroup
|
||||||
|
from sophon.core.serializers import dynamic_serializer
|
||||||
from sophon.core.views import SophonGroupViewSet
|
from sophon.core.views import SophonGroupViewSet
|
||||||
from sophon.notebooks.models import Notebook
|
from sophon.notebooks.models import Notebook
|
||||||
from sophon.projects.models import ResearchProject
|
from sophon.projects.models import ResearchProject
|
||||||
|
@ -101,6 +102,25 @@ class NotebooksByProjectViewSet(NotebooksViewSet):
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def get_serializer_class(self):
|
||||||
|
# Get the base serializer
|
||||||
|
base = super().get_serializer_class()
|
||||||
|
|
||||||
|
# Get the specific project we are retrieving the notebooks of
|
||||||
|
project: ResearchProject = ResearchProject.objects.filter(pk=self.kwargs["project_slug"]).first()
|
||||||
|
# Check if we have edit access on the project
|
||||||
|
if project.can_edit(self.request.user):
|
||||||
|
# Add the member fields to the base serializer
|
||||||
|
|
||||||
|
# noinspection PyUnresolvedReferences
|
||||||
|
fields = tuple(set(base.Meta.fields).union(Notebook.get_member_fields()))
|
||||||
|
# noinspection PyUnresolvedReferences
|
||||||
|
read_only_fields = tuple(set(base.Meta.read_only_fields).union(Notebook.get_member_fields()))
|
||||||
|
|
||||||
|
return dynamic_serializer(_model=Notebook, _fields=fields, _read_only_fields=read_only_fields)
|
||||||
|
else:
|
||||||
|
return base
|
||||||
|
|
||||||
def hook_create(self, serializer) -> dict[str, t.Any]:
|
def hook_create(self, serializer) -> dict[str, t.Any]:
|
||||||
result = super().hook_create(serializer)
|
result = super().hook_create(serializer)
|
||||||
project = ResearchProject.objects.filter(pk=self.kwargs["project_slug"]).get()
|
project = ResearchProject.objects.filter(pk=self.kwargs["project_slug"]).get()
|
||||||
|
|
Loading…
Reference in a new issue