diff options
| author | Mark | 2013-01-01 09:16:48 -0800 |
|---|---|---|
| committer | Mark | 2013-01-01 09:16:48 -0800 |
| commit | d379997aba5b1e41309bbed8740ed704c0feb58b (patch) | |
| tree | 59743e78dd82cc677ccfd7862eb9b08f3bd843dd /rest_framework/serializers.py | |
| parent | eff833b39d2f41c9eb773214f5b45c3d991e1511 (diff) | |
| parent | f62acf025e938d14b1e74d3cecb4f42975793e9a (diff) | |
| download | django-rest-framework-d379997aba5b1e41309bbed8740ed704c0feb58b.tar.bz2 | |
Merge pull request #540 from maspwr/m2m-related
Don't persist relation changes in ModelSerializer#restore_object()
Diffstat (limited to 'rest_framework/serializers.py')
| -rw-r--r-- | rest_framework/serializers.py | 34 |
1 files changed, 17 insertions, 17 deletions
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py index ed173d85..24674f2a 100644 --- a/rest_framework/serializers.py +++ b/rest_framework/serializers.py @@ -498,28 +498,28 @@ class ModelSerializer(Serializer): self.m2m_data = {} self.related_data = {} + # Reverse fk relations + for (obj, model) in self.opts.model._meta.get_all_related_objects_with_model(): + field_name = obj.field.related_query_name() + if field_name in attrs: + self.related_data[field_name] = attrs.pop(field_name) + + # Reverse m2m relations + for (obj, model) in self.opts.model._meta.get_all_related_m2m_objects_with_model(): + field_name = obj.field.related_query_name() + if field_name in attrs: + self.m2m_data[field_name] = attrs.pop(field_name) + + # Forward m2m relations + for field in self.opts.model._meta.many_to_many: + if field.name in attrs: + self.m2m_data[field.name] = attrs.pop(field.name) + if instance is not None: for key, val in attrs.items(): setattr(instance, key, val) else: - # Reverse fk relations - for (obj, model) in self.opts.model._meta.get_all_related_objects_with_model(): - field_name = obj.field.related_query_name() - if field_name in attrs: - self.related_data[field_name] = attrs.pop(field_name) - - # Reverse m2m relations - for (obj, model) in self.opts.model._meta.get_all_related_m2m_objects_with_model(): - field_name = obj.field.related_query_name() - if field_name in attrs: - self.m2m_data[field_name] = attrs.pop(field_name) - - # Forward m2m relations - for field in self.opts.model._meta.many_to_many: - if field.name in attrs: - self.m2m_data[field.name] = attrs.pop(field.name) - instance = self.opts.model(**attrs) try: |
