2012-09-20 16:06:27 +04:00
|
|
|
"""
|
|
|
|
Basic building blocks for generic class based views.
|
|
|
|
|
|
|
|
We don't bind behaviour to http method handlers yet,
|
|
|
|
which allows mixin classes to be composed in interesting ways.
|
|
|
|
"""
|
|
|
|
from rest_framework import status
|
|
|
|
from rest_framework.response import Response
|
2014-01-15 00:35:09 +04:00
|
|
|
from rest_framework.settings import api_settings
|
2012-09-20 16:06:27 +04:00
|
|
|
|
|
|
|
|
2019-04-30 18:53:44 +03:00
|
|
|
class CreateModelMixin:
|
2012-09-20 16:06:27 +04:00
|
|
|
"""
|
|
|
|
Create a model instance.
|
|
|
|
"""
|
|
|
|
def create(self, request, *args, **kwargs):
|
2014-09-26 13:46:52 +04:00
|
|
|
serializer = self.get_serializer(data=request.data)
|
2014-09-05 19:29:46 +04:00
|
|
|
serializer.is_valid(raise_exception=True)
|
2014-10-08 15:17:30 +04:00
|
|
|
self.perform_create(serializer)
|
2014-09-05 19:29:46 +04:00
|
|
|
headers = self.get_success_headers(serializer.data)
|
|
|
|
return Response(serializer.data, status=status.HTTP_201_CREATED, headers=headers)
|
2012-11-17 01:27:34 +04:00
|
|
|
|
2014-10-08 15:17:30 +04:00
|
|
|
def perform_create(self, serializer):
|
2014-10-07 20:21:12 +04:00
|
|
|
serializer.save()
|
|
|
|
|
2012-11-14 16:24:20 +04:00
|
|
|
def get_success_headers(self, data):
|
2012-11-17 01:27:34 +04:00
|
|
|
try:
|
2017-10-30 16:08:52 +03:00
|
|
|
return {'Location': str(data[api_settings.URL_FIELD_NAME])}
|
2012-11-17 01:27:34 +04:00
|
|
|
except (TypeError, KeyError):
|
2012-11-13 22:15:42 +04:00
|
|
|
return {}
|
2012-11-17 01:27:34 +04:00
|
|
|
|
2012-09-20 16:06:27 +04:00
|
|
|
|
2019-04-30 18:53:44 +03:00
|
|
|
class ListModelMixin:
|
2012-09-20 16:06:27 +04:00
|
|
|
"""
|
|
|
|
List a queryset.
|
|
|
|
"""
|
|
|
|
def list(self, request, *args, **kwargs):
|
2015-01-09 18:30:36 +03:00
|
|
|
queryset = self.filter_queryset(self.get_queryset())
|
|
|
|
|
|
|
|
page = self.paginate_queryset(queryset)
|
2013-04-25 20:40:17 +04:00
|
|
|
if page is not None:
|
2015-01-09 18:30:36 +03:00
|
|
|
serializer = self.get_serializer(page, many=True)
|
|
|
|
return self.get_paginated_response(serializer.data)
|
|
|
|
|
|
|
|
serializer = self.get_serializer(queryset, many=True)
|
2012-09-20 16:06:27 +04:00
|
|
|
return Response(serializer.data)
|
|
|
|
|
|
|
|
|
2019-04-30 18:53:44 +03:00
|
|
|
class RetrieveModelMixin:
|
2012-09-20 16:06:27 +04:00
|
|
|
"""
|
|
|
|
Retrieve a model instance.
|
|
|
|
"""
|
|
|
|
def retrieve(self, request, *args, **kwargs):
|
2014-09-05 19:29:46 +04:00
|
|
|
instance = self.get_object()
|
|
|
|
serializer = self.get_serializer(instance)
|
2012-09-20 16:06:27 +04:00
|
|
|
return Response(serializer.data)
|
|
|
|
|
|
|
|
|
2019-04-30 18:53:44 +03:00
|
|
|
class UpdateModelMixin:
|
2012-09-20 16:06:27 +04:00
|
|
|
"""
|
|
|
|
Update a model instance.
|
|
|
|
"""
|
2013-05-18 01:09:23 +04:00
|
|
|
def update(self, request, *args, **kwargs):
|
|
|
|
partial = kwargs.pop('partial', False)
|
2014-09-05 19:29:46 +04:00
|
|
|
instance = self.get_object()
|
2014-09-26 13:46:52 +04:00
|
|
|
serializer = self.get_serializer(instance, data=request.data, partial=partial)
|
2014-09-05 19:29:46 +04:00
|
|
|
serializer.is_valid(raise_exception=True)
|
2014-10-12 09:19:14 +04:00
|
|
|
self.perform_update(serializer)
|
2016-10-11 13:07:40 +03:00
|
|
|
|
2024-03-22 01:23:30 +03:00
|
|
|
if getattr(instance, '_prefetched_objects_cache', None):
|
2016-10-11 13:07:40 +03:00
|
|
|
# If 'prefetch_related' has been applied to a queryset, we need to
|
2024-03-22 01:23:30 +03:00
|
|
|
# forcibly invalidate the prefetch cache on the instance.
|
2016-11-11 12:44:35 +03:00
|
|
|
instance._prefetched_objects_cache = {}
|
2016-10-11 13:07:40 +03:00
|
|
|
|
2014-09-05 19:29:46 +04:00
|
|
|
return Response(serializer.data)
|
|
|
|
|
2014-10-12 09:19:14 +04:00
|
|
|
def perform_update(self, serializer):
|
2014-10-07 20:21:12 +04:00
|
|
|
serializer.save()
|
|
|
|
|
2014-09-05 19:29:46 +04:00
|
|
|
def partial_update(self, request, *args, **kwargs):
|
|
|
|
kwargs['partial'] = True
|
|
|
|
return self.update(request, *args, **kwargs)
|
|
|
|
|
2013-05-18 01:09:23 +04:00
|
|
|
|
2019-04-30 18:53:44 +03:00
|
|
|
class DestroyModelMixin:
|
2014-09-05 19:29:46 +04:00
|
|
|
"""
|
|
|
|
Destroy a model instance.
|
|
|
|
"""
|
|
|
|
def destroy(self, request, *args, **kwargs):
|
|
|
|
instance = self.get_object()
|
2014-10-08 15:17:30 +04:00
|
|
|
self.perform_destroy(instance)
|
2014-09-05 19:29:46 +04:00
|
|
|
return Response(status=status.HTTP_204_NO_CONTENT)
|
2012-10-08 15:52:56 +04:00
|
|
|
|
2014-10-08 15:17:30 +04:00
|
|
|
def perform_destroy(self, instance):
|
|
|
|
instance.delete()
|