2020-02-07 16:02:07 +00:00
|
|
|
# Copyright (C) 2018-2020 by BDE ENS Paris-Saclay
|
|
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
2020-02-08 16:17:00 +00:00
|
|
|
from django.db.models import Q
|
2020-03-11 10:15:03 +00:00
|
|
|
from django_filters.rest_framework import DjangoFilterBackend
|
2020-03-13 09:29:27 +00:00
|
|
|
from rest_framework.filters import OrderingFilter, SearchFilter
|
2020-02-17 13:08:40 +00:00
|
|
|
|
2020-03-19 18:29:52 +00:00
|
|
|
from api.viewsets import ReadProtectedModelViewSet, ReadOnlyProtectedModelViewSet
|
|
|
|
from .serializers import NotePolymorphicSerializer, AliasSerializer, TemplateCategorySerializer, \
|
|
|
|
TransactionTemplateSerializer, TransactionPolymorphicSerializer
|
|
|
|
from ..models.notes import Note, Alias
|
2020-03-11 10:15:03 +00:00
|
|
|
from ..models.transactions import TransactionTemplate, Transaction, TemplateCategory
|
2020-02-07 16:02:07 +00:00
|
|
|
|
|
|
|
|
2020-03-19 18:29:52 +00:00
|
|
|
class NotePolymorphicViewSet(ReadOnlyProtectedModelViewSet):
|
2020-02-07 19:47:49 +00:00
|
|
|
"""
|
|
|
|
REST API View set.
|
2020-02-08 16:17:00 +00:00
|
|
|
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 19:47:49 +00:00
|
|
|
"""
|
|
|
|
queryset = Note.objects.all()
|
|
|
|
serializer_class = NotePolymorphicSerializer
|
2020-03-13 09:29:27 +00:00
|
|
|
filter_backends = [SearchFilter, OrderingFilter]
|
|
|
|
search_fields = ['$alias__normalized_name', '$alias__name', '$polymorphic_ctype__model', ]
|
|
|
|
ordering_fields = ['alias__name', 'alias__normalized_name']
|
2020-02-07 19:47:49 +00:00
|
|
|
|
2020-02-08 16:17:00 +00:00
|
|
|
def get_queryset(self):
|
|
|
|
"""
|
|
|
|
Parse query and apply filters.
|
|
|
|
:return: The filtered set of requested notes
|
|
|
|
"""
|
2020-03-20 00:46:59 +00:00
|
|
|
queryset = super().get_queryset()
|
2020-02-08 16:17:00 +00:00
|
|
|
|
|
|
|
alias = self.request.query_params.get("alias", ".*")
|
2020-02-18 11:31:15 +00:00
|
|
|
queryset = queryset.filter(
|
2020-03-19 13:25:43 +00:00
|
|
|
Q(alias__name__regex="^" + alias) | Q(alias__normalized_name__regex="^" + alias.lower()))
|
2020-02-08 16:17:00 +00:00
|
|
|
|
2020-03-12 10:12:21 +00:00
|
|
|
return queryset.distinct()
|
2020-02-08 16:17:00 +00:00
|
|
|
|
2020-02-07 19:47:49 +00:00
|
|
|
|
2020-03-18 13:42:35 +00:00
|
|
|
class AliasViewSet(ReadProtectedModelViewSet):
|
2020-02-08 14:08:55 +00: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
|
2020-03-13 09:29:27 +00:00
|
|
|
filter_backends = [SearchFilter, OrderingFilter]
|
2020-03-12 00:10:52 +00:00
|
|
|
search_fields = ['$normalized_name', '$name', '$note__polymorphic_ctype__model', ]
|
2020-03-13 09:29:27 +00:00
|
|
|
ordering_fields = ['name', 'normalized_name']
|
2020-02-08 14:08:55 +00:00
|
|
|
|
2020-02-08 16:17:00 +00:00
|
|
|
def get_queryset(self):
|
|
|
|
"""
|
|
|
|
Parse query and apply filters.
|
|
|
|
:return: The filtered set of requested aliases
|
|
|
|
"""
|
|
|
|
|
2020-03-20 00:46:59 +00:00
|
|
|
queryset = super().get_queryset()
|
2020-02-08 16:17:00 +00:00
|
|
|
|
|
|
|
alias = self.request.query_params.get("alias", ".*")
|
2020-02-18 11:31:15 +00:00
|
|
|
queryset = queryset.filter(
|
2020-03-10 16:16:03 +00:00
|
|
|
Q(name__regex="^" + alias) | Q(normalized_name__regex="^" + alias.lower()))
|
2020-02-08 16:17:00 +00:00
|
|
|
|
|
|
|
return queryset
|
|
|
|
|
2020-02-08 14:08:55 +00:00
|
|
|
|
2020-03-18 13:42:35 +00:00
|
|
|
class TemplateCategoryViewSet(ReadProtectedModelViewSet):
|
2020-03-11 00:03:15 +00: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 10:15:03 +00:00
|
|
|
filter_backends = [SearchFilter]
|
|
|
|
search_fields = ['$name', ]
|
2020-03-11 00:03:15 +00:00
|
|
|
|
|
|
|
|
2020-03-18 13:42:35 +00:00
|
|
|
class TransactionTemplateViewSet(ReadProtectedModelViewSet):
|
2020-02-07 16:02:07 +00: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-11 10:15:03 +00:00
|
|
|
filter_backends = [DjangoFilterBackend]
|
|
|
|
filterset_fields = ['name', 'amount', 'display', 'category', ]
|
2020-02-07 16:02:07 +00:00
|
|
|
|
|
|
|
|
2020-03-18 13:42:35 +00:00
|
|
|
class TransactionViewSet(ReadProtectedModelViewSet):
|
2020-02-07 16:02:07 +00: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 10:15:03 +00:00
|
|
|
serializer_class = TransactionPolymorphicSerializer
|
|
|
|
filter_backends = [SearchFilter]
|
|
|
|
search_fields = ['$reason', ]
|