Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/imerica/dj-rest-auth
Authentication for Django Rest Framework
https://github.com/imerica/dj-rest-auth
authentication django django-rest-framework jwt python rest-api
Last synced: about 6 hours ago
JSON representation
Authentication for Django Rest Framework
- Host: GitHub
- URL: https://github.com/imerica/dj-rest-auth
- Owner: iMerica
- License: mit
- Created: 2020-02-28T19:35:48.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-08-21T12:36:48.000Z (5 months ago)
- Last Synced: 2024-10-29T11:16:54.261Z (3 months ago)
- Topics: authentication, django, django-rest-framework, jwt, python, rest-api
- Language: Python
- Homepage: https://dj-rest-auth.readthedocs.io/en/latest/index.html
- Size: 843 KB
- Stars: 1,670
- Watchers: 21
- Forks: 313
- Open Issues: 223
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
README
# Dj-Rest-Auth
[![](https://github.com/iMerica/dj-rest-auth/actions/workflows/main.yml/badge.svg)](https://github.com/iMerica/dj-rest-auth/actions/workflows/main.yml/)Drop-in API endpoints for handling authentication securely in Django Rest Framework. Works especially well
with SPAs (e.g., React, Vue, Angular), and Mobile applications.## Requirements
- Django >= 4.2 (See Unit Test Coverage in CI)
- Python >= 3.8## Quick Setup
Install package
pip install dj-rest-auth
Add `dj_rest_auth` app to INSTALLED_APPS in your django settings.py:```python
INSTALLED_APPS = (
...,
'rest_framework',
'rest_framework.authtoken',
...,
'dj_rest_auth'
)
```
Add URL patterns```python
urlpatterns = [
path('dj-rest-auth/', include('dj_rest_auth.urls')),
]
```
(Optional) Use Http-Only cookies
```python
REST_AUTH = {
'USE_JWT': True,
'JWT_AUTH_COOKIE': 'jwt-auth',
}
```### Testing
Install required modules with `pip install -r dj_rest_auth/tests/requirements.txt`
To run the tests within a virtualenv, run `python runtests.py` from the repository directory.
The easiest way to run test coverage is with [`coverage`](https://pypi.org/project/coverage/),
which runs the tests against all supported Django installs. To run the test coverage
within a virtualenv, run `coverage run ./runtests.py` from the repository directory then run `coverage report`.#### Tox
Testing may also be done using [`tox`](https://pypi.org/project/tox/), which
will run the tests against all supported combinations of Python and Django.Install tox, either globally or within a virtualenv, and then simply run `tox`
from the repository directory. As there are many combinations, you may run them
in [`parallel`](https://tox.readthedocs.io/en/latest/config.html#cmdoption-tox-p)
using `tox --parallel`.The `tox.ini` includes an environment for testing code [`coverage`](https://pypi.org/project/coverage/)
and you can run it and view this report with `tox -e coverage`.Linting may also be performed via [`flake8`](https://pypi.org/project/flake8/)
by running `tox -e flake8`.### Documentation
View the full documentation here: https://dj-rest-auth.readthedocs.io/en/latest/index.html
### Acknowledgements
This project began as a fork of `django-rest-auth`. Big thanks to everyone who contributed to that repo!
#### A note on Django AllAuth from @iMerica
This project has optional and very narrow support for Django-AllAuth. As the maintainer, I have no interest in making this package support all use cases in Django-AllAuth. I would rather focus on improving the quality of the base functionality or focus on OIDC support instead. Pull requests that extend or add more support for Django-AllAuth will most likely be declined. Do you disagree? Feel free to fork this repo!