aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework/mixins.py
diff options
context:
space:
mode:
authorTom Christie2014-10-08 12:17:30 +0100
committerTom Christie2014-10-08 12:17:30 +0100
commit0cbb57b40fdb073c7ca09c9d1078926260c646db (patch)
treeecb869965a0fb31428382d0f2ab60855e8f97268 /rest_framework/mixins.py
parentaf0f01c5b6597fe2f146268f7632f7e3954d17c2 (diff)
downloaddjango-rest-framework-0cbb57b40fdb073c7ca09c9d1078926260c646db.tar.bz2
Tweak pre/post save hooks. Return instance in .update().
Diffstat (limited to 'rest_framework/mixins.py')
-rw-r--r--rest_framework/mixins.py13
1 files changed, 8 insertions, 5 deletions
diff --git a/rest_framework/mixins.py b/rest_framework/mixins.py
index 03ebb034..4c62debb 100644
--- a/rest_framework/mixins.py
+++ b/rest_framework/mixins.py
@@ -20,11 +20,11 @@ class CreateModelMixin(object):
def create(self, request, *args, **kwargs):
serializer = self.get_serializer(data=request.data)
serializer.is_valid(raise_exception=True)
- self.create_valid(serializer)
+ self.perform_create(serializer)
headers = self.get_success_headers(serializer.data)
return Response(serializer.data, status=status.HTTP_201_CREATED, headers=headers)
- def create_valid(self, serializer):
+ def perform_create(self, serializer):
serializer.save()
def get_success_headers(self, data):
@@ -67,10 +67,10 @@ class UpdateModelMixin(object):
instance = self.get_object()
serializer = self.get_serializer(instance, data=request.data, partial=partial)
serializer.is_valid(raise_exception=True)
- self.update_valid(serializer)
+ self.preform_update(serializer)
return Response(serializer.data)
- def update_valid(self, serializer):
+ def preform_update(self, serializer):
serializer.save()
def partial_update(self, request, *args, **kwargs):
@@ -84,9 +84,12 @@ class DestroyModelMixin(object):
"""
def destroy(self, request, *args, **kwargs):
instance = self.get_object()
- instance.delete()
+ self.perform_destroy(instance)
return Response(status=status.HTTP_204_NO_CONTENT)
+ def perform_destroy(self, instance):
+ instance.delete()
+
# The AllowPUTAsCreateMixin was previously the default behaviour
# for PUT requests. This has now been removed and must be *explicitly*