Installation¶
- Install package:
pip install django-rest-auth
- Add
rest_authapp to INSTALLED_APPS in your django settings.py:
INSTALLED_APPS = (
...,
'rest_framework',
'rest_framework.authtoken',
...,
'rest_auth'
)
Note
This project depends on django-rest-framework library, so install it if you haven’t done yet. Make sure also you have installed rest_framework and rest_framework.authtoken apps
- Add rest_auth urls:
urlpatterns = [
...,
url(r'^rest-auth/', include('rest_auth.urls'))
]
- Migrate your database
python manage.py migrate
You’re good to go now!
Registration (optional)¶
- If you want to enable standard registration process you will need to install
django-allauthby usingpip install django-rest-auth[with_social]. - Add
django.contrib.sites,allauth,allauth.accountandrest_auth.registrationapps to INSTALLED_APPS in your django settings.py: - Add
SITE_ID = 1to your django settings.py
INSTALLED_APPS = (
...,
'django.contrib.sites',
'allauth',
'allauth.account',
'rest_auth.registration',
)
SITE_ID = 1
- Add rest_auth.registration urls:
urlpatterns = [
...,
url(r'^rest-auth/', include('rest_auth.urls')),
url(r'^rest-auth/registration/', include('rest_auth.registration.urls'))
]
JWT Support (optional)¶
By default django-rest-auth uses Django’s Token-based authentication. If you want to use JWT authentication, follow these steps:
- Install djangorestframework-jwt
djangorestframework-jwtis currently the only supported JWT library.
- The
JWT_PAYLOAD_HANDLERandJWT_ENCODE_HANDLERsettings are imported from thedjango-rest-framework-jwtsettings object. - Refer to the library’s documentation for information on using different encoders.
- The
- Add the following configuration value to your settings file to enable JWT authentication.
REST_USE_JWT = True
Social Authentication (optional)¶
Using
django-allauth,django-rest-authprovides helpful class for creating social media authentication view.Note
Points 1 and 2 are related to
django-allauthconfiguration, so if you have already configured social authentication, then please go to step 3. Seedjango-allauthdocumentation for more details.allauth.socialaccountandallauth.socialaccount.providers.facebookorallauth.socialaccount.providers.twitterapps to INSTALLED_APPS in your django settings.py:Facebook¶
rest_auth.registration.views.SocialLoginViewwithFacebookOAuth2Adapteradapter as an attribute:Twitter¶
If you are using Twitter for your social authentication, it is a bit different since Twitter uses OAuth 1.0.
rest_auth.registration.views.SocialLoginViewwithTwitterOAuthAdapteradapter andTwitterLoginSerializeras an attribute:Note
Starting from v0.21.0, django-allauth has dropped support for context processors. Check out http://django-allauth.readthedocs.org/en/latest/changelog.html#from-0-21-0 for more details.
GitHub¶
If you are using GitHub for your social authentication, it uses code and not AccessToken directly.
rest_auth.views.SocialLoginViewwithGitHubOAuth2Adapteradapter, anOAuth2Clientand a callback_url as attributes:Additional Social Connect Views¶
If you want to allow connecting existing accounts in addition to login, you can use connect views:
In urls.py:
You can also use the following views to check all social accounts attached to the current authenticated user and disconnect selected social accounts: