1
0
mirror of https://gitlab.crans.org/bde/nk20 synced 2025-01-19 14:41:19 +00:00
nk20/apps/note/api/views.py

128 lines
4.9 KiB
Python
Raw Normal View History

2020-02-07 17:02:07 +01:00
# Copyright (C) 2018-2020 by BDE ENS Paris-Saclay
# SPDX-License-Identifier: GPL-3.0-or-later
from django.db.models import Q
2020-03-26 23:05:37 +01:00
from django.core.exceptions import ValidationError
2020-03-11 11:15:03 +01:00
from django_filters.rest_framework import DjangoFilterBackend
from rest_framework.filters import OrderingFilter, SearchFilter
2020-03-24 22:12:44 +01:00
from rest_framework import viewsets
2020-03-26 23:05:37 +01:00
from rest_framework.response import Response
from rest_framework import status
from api.viewsets import ReadProtectedModelViewSet, ReadOnlyProtectedModelViewSet
2020-03-20 02:14:43 +01:00
from .serializers import NotePolymorphicSerializer, AliasSerializer, TemplateCategorySerializer, \
TransactionTemplateSerializer, TransactionPolymorphicSerializer
from ..models.notes import Note, Alias
2020-03-11 11:15:03 +01:00
from ..models.transactions import TransactionTemplate, Transaction, TemplateCategory
2020-02-07 17:02:07 +01:00
class NotePolymorphicViewSet(ReadOnlyProtectedModelViewSet):
2020-02-07 20:47:49 +01:00
"""
REST API View set.
The djangorestframework plugin will get all `Note` objects (with polymorhism), serialize it to JSON with the given serializer,
then render it on /api/note/note/
2020-02-07 20:47:49 +01:00
"""
queryset = Note.objects.all()
serializer_class = NotePolymorphicSerializer
filter_backends = [DjangoFilterBackend, SearchFilter, OrderingFilter]
filterset_fields = ['polymorphic_ctype', 'is_active', ]
search_fields = ['$alias__normalized_name', '$alias__name', '$polymorphic_ctype__model', ]
ordering_fields = ['alias__name', 'alias__normalized_name']
2020-02-07 20:47:49 +01:00
def get_queryset(self):
"""
Parse query and apply filters.
:return: The filtered set of requested notes
"""
2020-03-20 01:46:59 +01:00
queryset = super().get_queryset()
alias = self.request.query_params.get("alias", ".*")
2020-02-18 12:31:15 +01:00
queryset = queryset.filter(
2020-03-20 14:43:35 +01:00
Q(alias__name__regex="^" + alias)
| Q(alias__normalized_name__regex="^" + Alias.normalize(alias))
| Q(alias__normalized_name__regex="^" + alias.lower()))
2020-03-12 11:12:21 +01:00
return queryset.distinct()
2020-02-07 20:47:49 +01:00
2020-03-27 13:26:47 +01:00
class AliasViewSet(ReadProtectedModelViewSet):
2020-02-08 15:08:55 +01:00
"""
REST API View set.
The djangorestframework plugin will get all `Alias` objects, serialize it to JSON with the given serializer,
then render it on /api/aliases/
"""
queryset = Alias.objects.all()
serializer_class = AliasSerializer
filter_backends = [SearchFilter, OrderingFilter]
2020-03-12 01:10:52 +01:00
search_fields = ['$normalized_name', '$name', '$note__polymorphic_ctype__model', ]
ordering_fields = ['name', 'normalized_name']
2020-02-08 15:08:55 +01:00
2020-03-26 17:45:24 +01:00
def get_serializer_class(self):
serializer_class = self.serializer_class
if self.request.method in ['PUT', 'PATCH']:
2020-03-27 14:19:55 +01:00
# alias owner cannot be change once establish
2020-03-26 17:45:24 +01:00
setattr(serializer_class.Meta, 'read_only_fields', ('note',))
return serializer_class
2020-03-27 14:19:55 +01:00
2020-03-26 23:05:37 +01:00
def destroy(self, request, *args, **kwargs):
instance = self.get_object()
try:
self.perform_destroy(instance)
except ValidationError as e:
print(e)
2020-03-27 14:19:55 +01:00
return Response({e.code: e.message}, status.HTTP_400_BAD_REQUEST)
2020-03-26 23:05:37 +01:00
return Response(status=status.HTTP_204_NO_CONTENT)
2020-03-27 14:19:55 +01:00
def get_queryset(self):
"""
Parse query and apply filters.
:return: The filtered set of requested aliases
"""
2020-03-20 01:46:59 +01:00
queryset = super().get_queryset()
alias = self.request.query_params.get("alias", ".*")
2020-02-18 12:31:15 +01:00
queryset = queryset.filter(
2020-03-20 14:43:35 +01:00
Q(name__regex="^" + alias)
| Q(normalized_name__regex="^" + Alias.normalize(alias))
| Q(normalized_name__regex="^" + alias.lower()))
return queryset
2020-02-08 15:08:55 +01:00
class TemplateCategoryViewSet(ReadProtectedModelViewSet):
2020-03-11 01:03:15 +01:00
"""
REST API View set.
The djangorestframework plugin will get all `TemplateCategory` objects, serialize it to JSON with the given serializer,
then render it on /api/note/transaction/category/
"""
queryset = TemplateCategory.objects.all()
serializer_class = TemplateCategorySerializer
2020-03-11 11:15:03 +01:00
filter_backends = [SearchFilter]
search_fields = ['$name', ]
2020-03-11 01:03:15 +01:00
2020-03-24 22:12:44 +01:00
class TransactionTemplateViewSet(viewsets.ModelViewSet):
2020-02-07 17:02:07 +01:00
"""
REST API View set.
The djangorestframework plugin will get all `TransactionTemplate` objects, serialize it to JSON with the given serializer,
then render it on /api/note/transaction/template/
"""
queryset = TransactionTemplate.objects.all()
serializer_class = TransactionTemplateSerializer
2020-03-23 20:21:25 +01:00
filter_backends = [SearchFilter, DjangoFilterBackend]
2020-03-11 11:15:03 +01:00
filterset_fields = ['name', 'amount', 'display', 'category', ]
2020-03-23 20:21:25 +01:00
search_fields = ['$name', ]
2020-02-07 17:02:07 +01:00
2020-03-25 00:12:56 +01:00
class TransactionViewSet(ReadProtectedModelViewSet):
2020-02-07 17:02:07 +01:00
"""
REST API View set.
The djangorestframework plugin will get all `Transaction` objects, serialize it to JSON with the given serializer,
then render it on /api/note/transaction/transaction/
"""
queryset = Transaction.objects.all()
2020-03-11 11:15:03 +01:00
serializer_class = TransactionPolymorphicSerializer
filter_backends = [SearchFilter]
search_fields = ['$reason', ]