2024-02-07 01:26:49 +00:00
|
|
|
# Copyright (C) 2018-2024 by BDE ENS Paris-Saclay
|
2020-02-06 22:49:33 +00:00
|
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
2020-03-18 13:42:35 +00:00
|
|
|
|
2020-08-10 13:30:39 +00:00
|
|
|
from api.viewsets import ReadProtectedModelViewSet
|
2024-08-01 12:49:52 +00:00
|
|
|
from django.core.exceptions import ValidationError
|
2020-03-11 10:15:03 +00:00
|
|
|
from django_filters.rest_framework import DjangoFilterBackend
|
|
|
|
from rest_framework.filters import SearchFilter
|
2024-08-01 12:49:52 +00:00
|
|
|
from rest_framework.response import Response
|
|
|
|
from rest_framework import status
|
2020-03-20 01:14:43 +00:00
|
|
|
|
2024-08-01 12:49:52 +00:00
|
|
|
from .serializers import ActivitySerializer, ActivityTypeSerializer, EntrySerializer, GuestSerializer, OpenerSerializer
|
|
|
|
from ..models import Activity, ActivityType, Entry, Guest, Opener
|
2020-02-17 13:08:40 +00:00
|
|
|
|
2020-02-06 22:49:33 +00:00
|
|
|
|
2020-03-18 13:42:35 +00:00
|
|
|
class ActivityTypeViewSet(ReadProtectedModelViewSet):
|
2020-02-06 23:29:04 +00:00
|
|
|
"""
|
|
|
|
REST API View set.
|
|
|
|
The djangorestframework plugin will get all `ActivityType` objects, serialize it to JSON with the given serializer,
|
|
|
|
then render it on /api/activity/type/
|
|
|
|
"""
|
2020-12-23 13:54:21 +00:00
|
|
|
queryset = ActivityType.objects.order_by('id')
|
2020-02-06 22:49:33 +00:00
|
|
|
serializer_class = ActivityTypeSerializer
|
2020-03-11 10:15:03 +00:00
|
|
|
filter_backends = [DjangoFilterBackend]
|
2020-12-22 02:18:43 +00:00
|
|
|
filterset_fields = ['name', 'manage_entries', 'can_invite', 'guest_entry_fee', ]
|
2020-02-06 22:49:33 +00:00
|
|
|
|
|
|
|
|
2020-03-18 13:42:35 +00:00
|
|
|
class ActivityViewSet(ReadProtectedModelViewSet):
|
2020-02-06 23:29:04 +00:00
|
|
|
"""
|
|
|
|
REST API View set.
|
|
|
|
The djangorestframework plugin will get all `Activity` objects, serialize it to JSON with the given serializer,
|
|
|
|
then render it on /api/activity/activity/
|
|
|
|
"""
|
2020-12-23 13:54:21 +00:00
|
|
|
queryset = Activity.objects.order_by('id')
|
2020-02-06 22:49:33 +00:00
|
|
|
serializer_class = ActivitySerializer
|
2020-12-22 02:18:43 +00:00
|
|
|
filter_backends = [DjangoFilterBackend, SearchFilter]
|
|
|
|
filterset_fields = ['name', 'description', 'activity_type', 'location', 'creater', 'organizer', 'attendees_club',
|
|
|
|
'date_start', 'date_end', 'valid', 'open', ]
|
|
|
|
search_fields = ['$name', '$description', '$location', '$creater__last_name', '$creater__first_name',
|
|
|
|
'$creater__email', '$creater__note__alias__name', '$creater__note__alias__normalized_name',
|
|
|
|
'$organizer__name', '$organizer__email', '$organizer__note__alias__name',
|
|
|
|
'$organizer__note__alias__normalized_name', '$attendees_club__name', '$attendees_club__email',
|
|
|
|
'$attendees_club__note__alias__name', '$attendees_club__note__alias__normalized_name', ]
|
2020-02-06 22:49:33 +00:00
|
|
|
|
|
|
|
|
2020-03-18 13:42:35 +00:00
|
|
|
class GuestViewSet(ReadProtectedModelViewSet):
|
2020-02-06 23:29:04 +00:00
|
|
|
"""
|
|
|
|
REST API View set.
|
|
|
|
The djangorestframework plugin will get all `Guest` objects, serialize it to JSON with the given serializer,
|
|
|
|
then render it on /api/activity/guest/
|
|
|
|
"""
|
2020-12-23 13:54:21 +00:00
|
|
|
queryset = Guest.objects.order_by('id')
|
2020-02-17 13:08:40 +00:00
|
|
|
serializer_class = GuestSerializer
|
2020-12-22 02:18:43 +00:00
|
|
|
filter_backends = [DjangoFilterBackend, SearchFilter]
|
|
|
|
filterset_fields = ['activity', 'activity__name', 'last_name', 'first_name', 'inviter', 'inviter__alias__name',
|
|
|
|
'inviter__alias__normalized_name', ]
|
|
|
|
search_fields = ['$activity__name', '$last_name', '$first_name', '$inviter__user__email', '$inviter__alias__name',
|
|
|
|
'$inviter__alias__normalized_name', ]
|
2020-03-28 12:38:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
class EntryViewSet(ReadProtectedModelViewSet):
|
|
|
|
"""
|
|
|
|
REST API View set.
|
|
|
|
The djangorestframework plugin will get all `Entry` objects, serialize it to JSON with the given serializer,
|
|
|
|
then render it on /api/activity/entry/
|
|
|
|
"""
|
2020-12-23 13:54:21 +00:00
|
|
|
queryset = Entry.objects.order_by('id')
|
2020-03-28 12:38:31 +00:00
|
|
|
serializer_class = EntrySerializer
|
2020-12-22 02:18:43 +00:00
|
|
|
filter_backends = [DjangoFilterBackend, SearchFilter]
|
|
|
|
filterset_fields = ['activity', 'time', 'note', 'guest', ]
|
|
|
|
search_fields = ['$activity__name', '$note__user__email', '$note__alias__name', '$note__alias__normalized_name',
|
|
|
|
'$guest__last_name', '$guest__first_name', ]
|
2024-08-01 12:49:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
class OpenerViewSet(ReadProtectedModelViewSet):
|
|
|
|
"""
|
|
|
|
REST Opener View set.
|
|
|
|
The djangorestframework plugin will get all `Opener` objects, serialize it to JSON with the given serializer,
|
|
|
|
then render it on /api/activity/opener/
|
|
|
|
"""
|
|
|
|
queryset = Opener.objects
|
|
|
|
serializer_class = OpenerSerializer
|
|
|
|
filter_backends = [SearchFilter, DjangoFilterBackend]
|
|
|
|
search_fields = ['$opener__alias__name', '$opener__alias__normalized_name',
|
|
|
|
'$activity__name']
|
|
|
|
filterset_fields = ['opener', 'opener__noteuser__user', 'activity']
|
|
|
|
|
|
|
|
def get_serializer_class(self):
|
|
|
|
serializer_class = self.serializer_class
|
|
|
|
if self.request.method in ['PUT', 'PATCH']:
|
|
|
|
# opener-activity can't change
|
|
|
|
serializer_class.Meta.read_only_fields = ('opener', 'acitivity',)
|
|
|
|
return serializer_class
|
|
|
|
|
|
|
|
def destroy(self, request, *args, **kwargs):
|
|
|
|
instance = self.get_object()
|
|
|
|
try:
|
|
|
|
self.perform_destroy(instance)
|
|
|
|
except ValidationError as e:
|
|
|
|
return Response({e.code: str(e)}, status.HTTP_400_BAD_REQUEST)
|
|
|
|
return Response(status=status.HTTP_204_NO_CONTENT)
|