Django JSON Schema Field.
Project description
# Django JSON Schema
[![Build Status](https://travis-ci.org/m19t12/django-json-schema.svg?branch=master)](https://travis-ci.org/m19t12/django-json-schema)
[![Coverage Status](https://coveralls.io/repos/github/m19t12/django-json-schema/badge.svg?branch=master)](https://coveralls.io/github/m19t12/django-json-schema?branch=master)
Django JSON Schema Field.
## Table of content
- [Introduction](#introduction)
- [Installing](#installing)
- [Usage](#usage)
- [TODO](#TODO)
## Introduction
Django JSON Schema is a library for displaying and validating
postgresql jsonb data.
## Installing
```
pip install django_jsonb_schema
```
## Usage
First you create a schema class.
Schema class is a django abstract model class (abstract = True).
You can import SchemaMeta class or create an abstract class.
If you want to validate and display nested data you can do this with the SchemaForeignKey.
For example to validating this dict data.
```python
{
'name': 'parent',
'age': 50,
'son': {
'name': 'son',
'age': '15',
'school': {
'name': 'school',
'address': 'school address'
}
}
}
```
We create this three schema classes.
We can use any django model or third party field.
```python
#schemas.py
from json_schema.models import SchemaForeignKey, SchemaMeta
class SchoolSchema(models.Model):
name = models.CharField(max_length=128)
address = models.CharField(max_length=128)
Meta = SchemaMeta()
class SonSchema(models.Model):
name = models.CharField(max_length=128)
age = models.IntegerField()
school = SchemaForeignKey(SchoolSchema, on_delete=models.CASCADE)
Meta = SchemaMeta()
class ParentSchema(models.Model):
name = models.CharField(max_length=128, default="test")
age = models.IntegerField()
son = SchemaForeignKey(SonSchema, on_delete=models.CASCADE)
Meta = SchemaMeta()
```
After we create our model.
```python
#models.py
from django.db import models
from json_schema.fields import JSONSchemaField
from .schemas import ParentSchema
class JSONSchemaModel(models.Model):
simple_text = models.CharField(blank=True, null=True, max_length=256)
simple_int = models.IntegerField(blank=True, null=True)
parent = JSONSchemaField(schema=ParentSchema, blank=True)
```
## TODO
Support array elements.
[![Build Status](https://travis-ci.org/m19t12/django-json-schema.svg?branch=master)](https://travis-ci.org/m19t12/django-json-schema)
[![Coverage Status](https://coveralls.io/repos/github/m19t12/django-json-schema/badge.svg?branch=master)](https://coveralls.io/github/m19t12/django-json-schema?branch=master)
Django JSON Schema Field.
## Table of content
- [Introduction](#introduction)
- [Installing](#installing)
- [Usage](#usage)
- [TODO](#TODO)
## Introduction
Django JSON Schema is a library for displaying and validating
postgresql jsonb data.
## Installing
```
pip install django_jsonb_schema
```
## Usage
First you create a schema class.
Schema class is a django abstract model class (abstract = True).
You can import SchemaMeta class or create an abstract class.
If you want to validate and display nested data you can do this with the SchemaForeignKey.
For example to validating this dict data.
```python
{
'name': 'parent',
'age': 50,
'son': {
'name': 'son',
'age': '15',
'school': {
'name': 'school',
'address': 'school address'
}
}
}
```
We create this three schema classes.
We can use any django model or third party field.
```python
#schemas.py
from json_schema.models import SchemaForeignKey, SchemaMeta
class SchoolSchema(models.Model):
name = models.CharField(max_length=128)
address = models.CharField(max_length=128)
Meta = SchemaMeta()
class SonSchema(models.Model):
name = models.CharField(max_length=128)
age = models.IntegerField()
school = SchemaForeignKey(SchoolSchema, on_delete=models.CASCADE)
Meta = SchemaMeta()
class ParentSchema(models.Model):
name = models.CharField(max_length=128, default="test")
age = models.IntegerField()
son = SchemaForeignKey(SonSchema, on_delete=models.CASCADE)
Meta = SchemaMeta()
```
After we create our model.
```python
#models.py
from django.db import models
from json_schema.fields import JSONSchemaField
from .schemas import ParentSchema
class JSONSchemaModel(models.Model):
simple_text = models.CharField(blank=True, null=True, max_length=256)
simple_int = models.IntegerField(blank=True, null=True)
parent = JSONSchemaField(schema=ParentSchema, blank=True)
```
## TODO
Support array elements.
Project details
Release history Release notifications | RSS feed
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
File details
Details for the file django-jsonb-schema-0.7.0.tar.gz
.
File metadata
- Download URL: django-jsonb-schema-0.7.0.tar.gz
- Upload date:
- Size: 4.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e85f228bf2a75b9bfd5f0104712653730cdbb9af026afc2de93456eb6aefa88f |
|
MD5 | 03e19a0b55d5903bbe6a619122166c34 |
|
BLAKE2b-256 | b6759832e1f23c77e5eb77e90bccd7c79da8003a0a58c7fa9ddf040239f0a70f |
File details
Details for the file django_jsonb_schema-0.7.0-py3-none-any.whl
.
File metadata
- Download URL: django_jsonb_schema-0.7.0-py3-none-any.whl
- Upload date:
- Size: 17.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4c8a8775f5f0cba823f574c37a0d12693fa2aa4d76fe449a397243cc29d14bec |
|
MD5 | f63acf63c4dd1a2c60adc5278dfb1abd |
|
BLAKE2b-256 | ca1aa9788bc1a6d2dd69f8920c9a1c4f800c8ac2eecf8dac9d6581f999e9a258 |