aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework/serializers.py
diff options
context:
space:
mode:
authorMjumbe Wawatu Ukweli2013-03-11 03:23:44 -0400
committerMjumbe Wawatu Ukweli2013-03-11 03:23:44 -0400
commite7e470739fc4d2694d1c0e2dbf3f6465b44ad069 (patch)
tree45f8cc9170e2168e4dd08751f3a9737d09560665 /rest_framework/serializers.py
parent20880232930dd6f3a1de9dda1546c84b9279a258 (diff)
downloaddjango-rest-framework-e7e470739fc4d2694d1c0e2dbf3f6465b44ad069.tar.bz2
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.py7
1 files changed, 5 insertions, 2 deletions
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py
index 2ae7c215..1b044c5f 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 isinstance(pk_field, models.OneToOneField) 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]