aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework
diff options
context:
space:
mode:
authorJamie Matthews2012-10-24 12:12:27 +0100
committerJamie Matthews2012-10-24 12:12:27 +0100
commit607c31c6d880501e5dc524fc5a5e1fc136b162fc (patch)
treeb04c90dd1e15b09d76bf0ae83199bf62742b7231 /rest_framework
parentd60d598e0255fb3d55a1213d1025447d83523658 (diff)
downloaddjango-rest-framework-607c31c6d880501e5dc524fc5a5e1fc136b162fc.tar.bz2
Move per-field and cross-field validation into a single method
Diffstat (limited to 'rest_framework')
-rw-r--r--rest_framework/serializers.py28
1 files changed, 13 insertions, 15 deletions
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py
index 2f8108d1..c9f025bc 100644
--- a/rest_framework/serializers.py
+++ b/rest_framework/serializers.py
@@ -208,33 +208,32 @@ class BaseSerializer(Field):
return reverted_data
- def validate_fields(self, attrs):
+ def perform_validation(self, attrs):
"""
- Run validate_<fieldname> methods on the serializer
+ Run `validate_<fieldname>()` and `validate()` methods on the serializer
"""
fields = self.get_fields(serialize=False, data=attrs, nested=self.opts.nested)
for field_name, field in fields.items():
try:
- clean_method = getattr(self, 'validate_%s' % field_name, None)
- if clean_method:
+ validate_method = getattr(self, 'validate_%s' % field_name, None)
+ if validate_method:
source = field.source or field_name
- attrs = clean_method(attrs, source)
+ attrs = validate_method(attrs, source)
except ValidationError as err:
self._errors[field_name] = self._errors.get(field_name, []) + list(err.messages)
+ try:
+ attrs = self.validate(attrs)
+ except ValidationError as err:
+ self._errors['non_field_errors'] = err.messages
+
return attrs
- def validate_all(self, attrs):
+ def validate(self, attrs):
"""
- Run the `validate` method on the serializer, if it exists
+ Stub method, to be overridden in Serializer subclasses
"""
- try:
- validate_method = getattr(self, 'validate', None)
- if validate_method:
- attrs = validate_method(attrs)
- except ValidationError as err:
- self._errors['non_field_errors'] = err.messages
return attrs
def restore_object(self, attrs, instance=None):
@@ -270,8 +269,7 @@ class BaseSerializer(Field):
self._errors = {}
if data is not None:
attrs = self.restore_fields(data)
- attrs = self.validate_fields(attrs)
- attrs = self.validate_all(attrs)
+ attrs = self.perform_validation(attrs)
else:
self._errors['non_field_errors'] = ['No input provided']