Bearer auth for DRF.
Project description
Django rest Bearer Auth
---
Must have installed `rest_framework`, then install `bearer-auth` via pip and add it to `settings.py`
```python
pip install django-rest-auth-bearer
```
```python
INSTALLED_APPS: [
...,
'rest_framework',
'bearer_auth',
]
```
Add custom authentication to `BearerTokenAuth`
```python
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework.authentication.SessionAuthentication',
'bearer_auth.authentication.BearerTokenAuth',
),
```
Add `TOKEN_EXPIRES_IN` timespan to `settings.py`
```python
TOKEN_EXPIRES_IN = 2 #2hours
```
Customize `urls.py`
```python
from bearer_auth.views import ObtainToken
...
path('auth/token', ObtainToken.as_view()),
```
From frontend side, send request as following for acquire token
```json
"username": "username",
"password": "password123",
"grant_type": "password" //must be password
```
As for response:
```json
{
"token_type":"Bearer",
"access_token":"c2fbea30732f113bbf879e51b2e49544d2de2d10"
"refresh_token":"8ab39baa8f29041a891767a9323500073c9ee8e89e944af759",
"expires_in":1
}
```
Moreover to refresh current token, send `refresh_token` value with grant_type `refresh_token` to same endpoint
```json
{
"refresh_token":"8ab39baa8f29041a891767a9323500073c9ee8e89e944af759",
"grant_type": "refresh_token"
}
```
---
Must have installed `rest_framework`, then install `bearer-auth` via pip and add it to `settings.py`
```python
pip install django-rest-auth-bearer
```
```python
INSTALLED_APPS: [
...,
'rest_framework',
'bearer_auth',
]
```
Add custom authentication to `BearerTokenAuth`
```python
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework.authentication.SessionAuthentication',
'bearer_auth.authentication.BearerTokenAuth',
),
```
Add `TOKEN_EXPIRES_IN` timespan to `settings.py`
```python
TOKEN_EXPIRES_IN = 2 #2hours
```
Customize `urls.py`
```python
from bearer_auth.views import ObtainToken
...
path('auth/token', ObtainToken.as_view()),
```
From frontend side, send request as following for acquire token
```json
"username": "username",
"password": "password123",
"grant_type": "password" //must be password
```
As for response:
```json
{
"token_type":"Bearer",
"access_token":"c2fbea30732f113bbf879e51b2e49544d2de2d10"
"refresh_token":"8ab39baa8f29041a891767a9323500073c9ee8e89e944af759",
"expires_in":1
}
```
Moreover to refresh current token, send `refresh_token` value with grant_type `refresh_token` to same endpoint
```json
{
"refresh_token":"8ab39baa8f29041a891767a9323500073c9ee8e89e944af759",
"grant_type": "refresh_token"
}
```
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
Close
Hashes for django-rest-auth-bearer-0.1.1.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 998c8421491d2a333e42948dd8a17bc10494dd713b2a5cb5dbddda2ea435a484 |
|
MD5 | 1b3271835a2be881b17b1c4bd842c689 |
|
BLAKE2b-256 | 95cc02351dd3254e610d183b7fc2779f32c4bbfcdf1b2abe369f6801b176181f |