Release | CI | Coverage |
---|---|---|
Common exception for Django REST framework. Provides single generic interface of returning data structure for any kind of exceptions which are handled by Django REST framework. Includes error name, path to service with line where the error occurs and a list of actual error messages with extended fields info.
- Python (3.6+)
- Django (1.11.x, 2.0+)
- Django REST Framework (3.7+)
$ pip install drf-common-exceptions
You can define common exception handler for whole project. Just put the following line to your django settings inside drf section:
REST_FRAMEWORK = {
...
"EXCEPTION_HANDLER": "drf_common_exceptions.common_exception_handler",
...
}
Or use it just for particular view or viewset:
from drf_common_exceptions import CommonExceptionHandlerMixin
class MyView(CommonExceptionHandlerMixin, APIView):
pass
The output will looks like for example validation error:
{
"service": "path.to.views.MyView:20",
"error": "ValidationError",
"detail": [
{
"label": "Name",
"field": "name",
"messages": [
"This is required field."
]
}
]
}
The data structure will be the same for any other errors.
Install poetry and requirements:
$ curl -sSL https://raw.githubusercontent.com/sdispater/poetry/master/get-poetry.py | python
$ python3 -m venv path/to/venv
$ source path/to/venv/bin/activate
$ poetry install
Run main commands:
$ make test
$ make watch
$ make clean
$ make lint
Publish to pypi by default patch version:
$ make publish
or any level you want:
$ make publish minor