diff options
| author | Tom Christie | 2013-03-12 13:56:34 -0700 |
|---|---|---|
| committer | Tom Christie | 2013-03-12 13:56:34 -0700 |
| commit | 0cf94cbd8b88de5da65f940351da2c2701ed877d (patch) | |
| tree | 1322ce0e135b69a68727670b8018ba8bb4cace7a /rest_framework/serializers.py | |
| parent | 1aecd71eb49111009f2c55fe8bd3901b3ea35dd5 (diff) | |
| parent | bd3fe75e1a41e45b0c9ff1e39707ee059ad0e06a (diff) | |
| download | django-rest-framework-0cf94cbd8b88de5da65f940351da2c2701ed877d.tar.bz2 | |
Merge pull request #723 from mjumbewu/multitable-inheritance
Use parent's primary key when model is derived via multitable inheritance
Diffstat (limited to 'rest_framework/serializers.py')
| -rw-r--r-- | rest_framework/serializers.py | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py index 2ae7c215..cd2bb8f1 100644 --- a/rest_framework/serializers.py +++ b/rest_framework/serializers.py @@ -456,8 +456,11 @@ class ModelSerializer(Serializer): "Serializer class '%s' is missing 'model' Meta option" % self.__class__.__name__ opts = get_concrete_model(cls)._meta pk_field = opts.pk - # while pk_field.rel: - # pk_field = pk_field.rel.to._meta.pk + + # If model is a child via multitable inheritance, use parent's pk + while pk_field.rel and pk_field.rel.parent_link: + pk_field = pk_field.rel.to._meta.pk + fields = [pk_field] fields += [field for field in opts.fields if field.serialize] fields += [field for field in opts.many_to_many if field.serialize] |
