This library implements Django REST Framework serializers to handle generic many to many relations.
Project description
gm2m_relations
The rest-framework-gm2m-relations library provides read/write serialization for django-gm2m field.
Requirements
Any currently-supported combination of rest-framework-generic-relations, Django REST Framework, Python, and Django.
Installation
Install using pip :
pip install gm2m-relations
API Reference
GM2MSerializer
serializes django generic many-to-many field. For a primer on generic many-to-many field, first see: https://github.com/tkhyn/django-gm2m
Let's assume a Post model which has a generic m2m relationship with other arbitrary models:
from gm2m import GM2MField
class Post(models.Model):
text = models.SlugField()
author = GM2MField()
And the following two models, which may have associated authors:
class User(models.Model):
name = models.CharField()
class Organ(models.Model):
name = models.CharField()
Now we define serializers for each model that may get associated with posts.
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = User
fields = ('name',)
class OragnSerializer(serializers.ModelSerializer):
class Meta:
model = Organ
fields = ('name',)
The model serializer for the Post model could look like this:
from gm2m_relations.serializers import GM2MSerializer
class PostSerializer(serializers.ModelSerializer):
"""
A `Post` serializer with a `GM2MField` mapping all possible
models to their respective serializers.
"""
author = GM2MSerializer(
{
User: UserSerializer(),
Organ: OragnSerializer(),
},
many=True,
)
class Meta:
model = Post
fields = ('text', 'author')
The JSON representation of a Post object with text='django' and its generic m2m field pointing to User object with name='Ali' would look like this:
{
"author": [
{
"name" : "Ali",
}
],
"text": "django"
}
Writing to generic many to many field
The above PostSerializer is also writable. By default, a GenericRelatedField iterates over its nested serializers and returns the value of the first serializer that is actually able to perform to_internal_value() without any errors.
post_serializer = PostSerializer(
data={
'text': 'python',
'author': [
{
"name" : "Ali",
},
],
},
)
post_serializer.is_valid()
post_serializer.save()
If you feel that this default behavior doesn't suit your needs, implement your own way of decision-making.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gm2m_relations-1.0.3.tar.gz.
File metadata
- Download URL: gm2m_relations-1.0.3.tar.gz
- Upload date:
- Size: 3.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ec3afe8bfccf362b22e9a451b36b5878a781f0484999c20c139289b7a2b4448f
|
|
| MD5 |
5153b65b10c1769e4c796b0f95fb713b
|
|
| BLAKE2b-256 |
700260f0389f3014e57e4e33383576c29bc66328697040f767b5bb5d7c00f887
|
File details
Details for the file gm2m_relations-1.0.3-py3-none-any.whl.
File metadata
- Download URL: gm2m_relations-1.0.3-py3-none-any.whl
- Upload date:
- Size: 4.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ff5f81b412b947992fe968421c8310e632993dcf4fa2edaba2fae5ce85de2558
|
|
| MD5 |
5b4de8284867ccc508d166d2e62c0f4d
|
|
| BLAKE2b-256 |
9d5a7a1d2cfa06c590a8d7d11de25cdfdf4d4f82a6f7b85410cd931bba3f21dc
|