Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yezz123/pyngo
Pydantic model support for Django & Django-Rest-Framework โจ
https://github.com/yezz123/pyngo
django django-rest-framework fastapi openapi pydantic python python3 typed
Last synced: about 22 hours ago
JSON representation
Pydantic model support for Django & Django-Rest-Framework โจ
- Host: GitHub
- URL: https://github.com/yezz123/pyngo
- Owner: yezz123
- License: mit
- Created: 2021-11-25T00:14:05.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-04-30T19:49:57.000Z (8 months ago)
- Last Synced: 2024-05-01T16:25:26.914Z (8 months ago)
- Topics: django, django-rest-framework, fastapi, openapi, pydantic, python, python3, typed
- Language: Python
- Homepage: https://pypi.org/project/pyngo/
- Size: 204 KB
- Stars: 76
- Watchers: 3
- Forks: 8
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# Pyngo :snake:
Utils to help integrate pydantic into Django projects---
## Installation
You can add pyngo in a few easy steps. First of all, install the dependency:
```sh
$ pip install pyngo---> 100%
Successfully installed pyngo
```---
## Features ๐
- Using Pydantic to Build your Models in Django Project.
- Using `OpenAPI` utilities to build params from a basic model.
- using `QueryDictModel` to build `Pydantic` models from a `QueryDict` object.
- propagate any errors from Pydantic in Django Rest Framework.
- Tested in Python 3.10 and up.## Examples ๐
### OpenAPI
- `pyngo.openapi_params()` can build params from a basic model
```py
from pydantic import BaseModel
from pyngo import openapi_paramsclass Model(BaseModel):
bingo: intprint(openapi_params(Model))
```- `pyngo.ParameterDict.required` is set according to the type of the variable
```py
from typing import Optional
from pydantic import BaseModel
from pyngo import openapi_paramsclass Model(BaseModel):
required_param: int
optional_param: Optional[int]print(openapi_params(Model))
```Other fields can be set through the fieldโs info:
```py
from pydantic import BaseModel, Field
from pyngo import openapi_paramsclass WithDescription(BaseModel):
described_param: str = Field(
description="Hello World Use Me!"
)class InPath(BaseModel):
path_param: str = Field(location="path")class WithDeprecated(BaseModel):
deprecated_field: bool = Field(deprecated=True)class WithNoAllowEmpty(BaseModel):
can_be_empty: bool = Field(allowEmptyValue=False)print(openapi_params(WithDescription)[0]["description"])
print(openapi_params(InPath)[0]["in"])
print(openapi_params(WithDeprecated)[0]["deprecated"])
print(openapi_params(WithNoAllowEmpty)[0]["allowEmptyValue"])
```### Django
- `pyngo.querydict_to_dict()` and `pyngo.QueryDictModel` are conveniences for building a `pydantic.BaseModel` from a `django.QueryDict`.
```py
from typing import List
from django.http import QueryDict
from pydantic import BaseModel
from pyngo import QueryDictModel, querydict_to_dictclass Model(BaseModel):
single_param: int
list_param: List[str]class QueryModel(QueryDictModel):
single_param: int
list_param: List[str]query_dict = QueryDict("single_param=20&list_param=Life")
print(Model.model_validate(querydict_to_dict(query_dict, Model)))
print(QueryModel.model_validate(query_dict))
```> **Note:** Don't forget to Setup the Django Project.
### Django Rest Framework
- `pyngo.drf_error_details()` will propagate any errors from Pydantic.
```py
from pydantic import BaseModel, ValidationError
from pyngo import drf_error_detailsclass Model(BaseModel):
foo: int
bar: strdata = {"foo": "Cat"}
try:
Model.model_validate(data)
except ValidationError as e:
print(drf_error_details(e))
```Errors descend into nested fields:
```py
from typing import List
from pydantic import BaseModel, ValidationError
from pyngo import drf_error_detailsclass Framework(BaseModel):
frm_id: intclass Language(BaseModel):
framework: List[Framework]data = {"framework": [{"frm_id": "not_a_number"}, {}]}
expected_details = {
"framework": {
"0": {"frm_id": ["value is not a valid integer"]},
"1": {"frm_id": ["field required"]},
}
}try:
Language.model_validate(data)
except ValidationError as e:
print(drf_error_details(e))
```## Development ๐ง
### Setup environment ๐ฆ
You should create a virtual environment and activate it:
```bash
python -m venv venv/
``````bash
source venv/bin/activate
```And then install the development dependencies:
```bash
# Install dependencies
pip install -e .[test,lint]
```### Run tests ๐
You can run all the tests with:
```bash
bash scripts/test.sh
```> Note: You can also generate a coverage report with:
```bash
bash scripts/test_html.sh
```### Format the code ๐
Execute the following command to apply `pre-commit` formatting:
```bash
bash scripts/format.sh
```Execute the following command to apply `mypy` type checking:
```bash
bash scripts/lint.sh
```## License ๐ป
This project is licensed under the terms of the MIT license.