diff options
| author | Tom Christie | 2011-07-11 12:33:52 -0700 |
|---|---|---|
| committer | Tom Christie | 2011-07-11 12:33:52 -0700 |
| commit | d1ed9884d8b479b177dfb06e3b246e3c9e3e8593 (patch) | |
| tree | 4c3a7cddbc099fe6ea65424a9595b87104b55967 /djangorestframework/mixins.py | |
| parent | 5433cb3e27058c2f7da6118ffa9ee7712846048d (diff) | |
| parent | 91b9d0b2a3fa55ff163f64bc689a59ca01cff8bb (diff) | |
| download | django-rest-framework-d1ed9884d8b479b177dfb06e3b246e3c9e3e8593.tar.bz2 | |
Merge pull request #46 from jakul/m2m_create_through
Update to existing pull request "Support for creating objects with m2m relationsM2m"
Diffstat (limited to 'djangorestframework/mixins.py')
| -rw-r--r-- | djangorestframework/mixins.py | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/djangorestframework/mixins.py b/djangorestframework/mixins.py index 4d8b2d35..bb26ad96 100644 --- a/djangorestframework/mixins.py +++ b/djangorestframework/mixins.py @@ -524,7 +524,9 @@ class CreateModelMixin(object): for field in model._meta.many_to_many: if content.has_key(field.name): - m2m_data[field.name] = content[field.name] + m2m_data[field.name] = ( + field.m2m_reverse_field_name(), content[field.name] + ) del content[field.name] all_kw_args = dict(content.items() + kwargs.items()) @@ -536,7 +538,17 @@ class CreateModelMixin(object): instance.save() for fieldname in m2m_data: - getattr(instance, fieldname).add(*m2m_data[fieldname]) + manager = getattr(instance, fieldname) + + if hasattr(manager, 'add'): + manager.add(*m2m_data[fieldname][1]) + else: + data = {} + data[manager.source_field_name] = instance + + for related_item in m2m_data[fieldname][1]: + data[m2m_data[fieldname][0]] = related_item + manager.through(**data).save() headers = {} if hasattr(instance, 'get_absolute_url'): |
