Utilities to use pydantic with the django orm
Project description
djdantic
A utility library to integrate and use pydantic with the django orm. This package includes optional sentry integration using sentry-tools
.
🚧 This project is WIP and is subject to change at any time
This project is currently in the alpha state, even though it can be used in production with some caution. Make sure to fix the version in your requirements.txt and review changes frequently.
Installation
pip install djdantic
Features
pydantic to django Data Schema Conversion
djdantic.BaseModel
Providesfrom_orm
method on pydantic schemadjdantic.Field
Provides a custom implementation of pydantic'sField
, used for the custom optionsdjdantic.utils.pydantic_django.transfer_from_orm
djdantic.utils.pydantic_django.transfer_to_orm
If automatic route generation is used, it is not neccessary to use the transfer_*
methods manually.
Options for djdantic.Field
For mapping pydantic schemas to django models, it is required to add at least one of the following extra arguments to each field defined in a pydantic schema.
Using these options on pydantic's
Field
is also possible but deprecated!
orm_field
:django.db.models.Field
(required)
Pointer (reference) to the corresponding model field, e. g.myapp.models.MyModel.id
orm_method
:Optional[Callable[[Self], Any] | Callable[[Self, Any], None]]
Pointer to a orm model method, which is called when the object is loaded from the orm into a pydantic model or written into the orm from a pydantic model, e. g.myapp.models.MyModel.get_calculated_value
scopes
:Optional[List[str]]
Limit access to specific fields based on jwt token scopes. For read operations, only scopes with the actionread
are taken into account, for write all other scopes are taken into account.is_critical
:Optional[bool]
Limit write access to the field based on the presence of thecrt
flag in the jwt token.is_sync_matching_field
:Optional[bool]
Alternative tosync_matching
to define search fields for the matcher on the field itselfsync_matching
:Optional[List[Tuple[str, django.db.models.Field]]]
Used for performing atransfer_to_orm
with actionTransferAction.SYNC
for included sub-records (in a list), used when noid
field is present on the object. Mapping from pydantic field (dot notation for nested fields can be used) to the corresponding django model field.
⚠️ Deprecated in favor ofis_sync_matching_field
Example for Schemas
from djdantic import Field, BaseModel
from ... import models
class User(BaseModel):
email: str = Field(orm_field=models.User.email)
is_password_usable: bool = Field(orm_method=models.User.has_usable_password)
is_superuser: bool = Field(scopes=['access.users.update.any'], is_critical=True, orm_field=models.User.is_superuser)
class UserUpdate(User):
password: Optional[SecretStr] = Field(orm_method=models.User.set_password, is_critical=True)
class OrderUpdate(BaseModel):
items: Optional[List['OrderItemUpdate']] = Field(
orm_field=models.Order.items,
sync_matching=[
('product', models.OrderItem.product),
],
)
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 djdantic-0.0.24.tar.gz
.
File metadata
- Download URL: djdantic-0.0.24.tar.gz
- Upload date:
- Size: 26.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 528a960bc5ec0243f7c6719b55cea47597aec7cc0bb30c7e628e89d5a72454c7 |
|
MD5 | f5fbb89dc5f141615737a08111d07b13 |
|
BLAKE2b-256 | 4b131d5d510abbdc51008a0ef40e15c9629faa9f066940ad29cd930438b8f670 |
File details
Details for the file djdantic-0.0.24-py3-none-any.whl
.
File metadata
- Download URL: djdantic-0.0.24-py3-none-any.whl
- Upload date:
- Size: 30.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 14048af6b16bd7b1a501f42ab05e0b7302acc6461791e201bdb77b2dc7f11e37 |
|
MD5 | 2e3e7f9b163dd8aab320e007a5d1e34f |
|
BLAKE2b-256 | aa49662cd6e876a1a40fcb82975bdffa253dfe2a65c56db65d3a35fd9f2e9792 |