Skip to main content

Add a schema with validation to your jsonfield

Project description

django_validated_jsonfield

django_validated_jsonfield is an inplace replacement for django JSONField which is validated against a json_schema

  • A json_schema can be added to the field description
  • The json_schema is used to validate the jsonfield data during full_clean or during restframework validation
  • The field is also documented on Swagger (via drf_yasg specific inspectors)
  • Missing data in the json structure is initialized/filled to the schema's default values

Usage

import

Replace your JSONField import

from django.db.models import JSONField` or `from django.contrib.postgres.fields import JSONField

by

from django_validated_jsonfield import ValidatedJSONField as JSONField

models

class MyModel(models.Model):
    _data_schema = {
        "type": "object",
        "properties": {
            "en": {"type": ["string", "null"], "default":"",   "example":"Name", "title":"Name"}
            "fr": {"type": ["string", "null"], "default":"",   "example":"Nom",  "title":"Nom"}
        },
        "default": {}, #note the top level default
        "additionalProperties": False,
    }

    data = JSONField(schema=_data_schema, editable=True)

Rest Framework serializers

As defined field:

replace

from rest_framework.serializers import JSONField

by

from django_validated_jsonfield import ValidatedJSONFieldSerializer as JSONField

The updated JSONField expect to receive a "schema" and "json_validator_cls" argument at initilization.

In serializers.ModelSerializer:

Add the ValidatedJsonModelSerializerMixin to your ModelSerializer classes.

from django_validated_jsonfield import ValidatedJsonModelSerializerMixin

class MyModelSerializer(ValidatedJsonModelSerializerMixin, serializers.ModelSerializer):
    class Meta:
        model = MyModel
        exclude = []

Swagger documentation (drf_yasg)

add the following block to your django settings.py file

from django_validated_jsonfield.yasg import DEFAULT_FIELD_INSPECTORS
SWAGGER_SETTINGS = {
    'DEFAULT_FIELD_INSPECTORS': DEFAULT_FIELD_INSPECTORS
}

you should see the json field of your model being documented in Swagger

Additional remarks

json schema default

if the default field is provided in the json schema, the data will be initialized to the default value (if missing). The feature works well only parents of nested fields in the json schema have a default themselves (to list or dict) --> Note the "top level default" in the example above.

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

django-validated-jsonfield-1.2.3.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file django-validated-jsonfield-1.2.3.tar.gz.

File metadata

  • Download URL: django-validated-jsonfield-1.2.3.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.8.5 Linux/5.4.0-73-generic

File hashes

Hashes for django-validated-jsonfield-1.2.3.tar.gz
Algorithm Hash digest
SHA256 8881d38178c50d8d995b6e8deb793b716104a82a9ad09ca16e5ab4a946c34e71
MD5 af2261a718c7133bdae572a2614485b0
BLAKE2b-256 c86d0c4f959c6c7c2651398c9e167ff93e8f7913e792c66937c4bc371e501cf6

See more details on using hashes here.

File details

Details for the file django_validated_jsonfield-1.2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for django_validated_jsonfield-1.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 4ffa76be4bb0f6c171efeb5f3648c991a2e8167e028219a2feaebaed67d7d4c1
MD5 18c2496df2810653c7cda76d8854eba9
BLAKE2b-256 496c867dc85364330aa936326b563e2ca6455c066e374a9f5f63af132badb207

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