diff options
| author | Jamie Matthews | 2012-10-24 12:12:27 +0100 | 
|---|---|---|
| committer | Jamie Matthews | 2012-10-24 12:12:27 +0100 | 
| commit | 607c31c6d880501e5dc524fc5a5e1fc136b162fc (patch) | |
| tree | b04c90dd1e15b09d76bf0ae83199bf62742b7231 /rest_framework/serializers.py | |
| parent | d60d598e0255fb3d55a1213d1025447d83523658 (diff) | |
| download | django-rest-framework-607c31c6d880501e5dc524fc5a5e1fc136b162fc.tar.bz2 | |
Move per-field and cross-field validation into a single method
Diffstat (limited to 'rest_framework/serializers.py')
| -rw-r--r-- | rest_framework/serializers.py | 28 | 
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']  | 
