Skip to main content

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

gm2m_relations-1.0.3.tar.gz (3.7 kB view details)

Uploaded Source

Built Distribution

gm2m_relations-1.0.3-py3-none-any.whl (4.2 kB view details)

Uploaded Python 3

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

Hashes for gm2m_relations-1.0.3.tar.gz
Algorithm Hash digest
SHA256 ec3afe8bfccf362b22e9a451b36b5878a781f0484999c20c139289b7a2b4448f
MD5 5153b65b10c1769e4c796b0f95fb713b
BLAKE2b-256 700260f0389f3014e57e4e33383576c29bc66328697040f767b5bb5d7c00f887

See more details on using hashes here.

File details

Details for the file gm2m_relations-1.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for gm2m_relations-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ff5f81b412b947992fe968421c8310e632993dcf4fa2edaba2fae5ce85de2558
MD5 5b4de8284867ccc508d166d2e62c0f4d
BLAKE2b-256 9d5a7a1d2cfa06c590a8d7d11de25cdfdf4d4f82a6f7b85410cd931bba3f21dc

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page