django-rest-auth/dj_rest_auth/utils.py

54 lines
1.8 KiB
Python
Raw Normal View History

from importlib import import_module
2020-03-20 00:09:20 +03:00
from .app_settings import JWT_AUTH_COOKIE
def import_callable(path_or_callable):
if hasattr(path_or_callable, '__call__'):
return path_or_callable
else:
assert isinstance(path_or_callable, str)
package, attr = path_or_callable.rsplit('.', 1)
return getattr(import_module(package), attr)
2016-01-01 00:10:52 +03:00
def default_create_token(token_model, user, serializer):
2016-01-01 00:10:52 +03:00
token, _ = token_model.objects.get_or_create(user=user)
return token
2016-03-01 14:51:01 +03:00
def jwt_encode(user):
2016-03-01 14:51:01 +03:00
try:
from rest_framework_simplejwt.serializers import TokenObtainPairSerializer
except ImportError:
raise ImportError("rest-framework-simplejwt needs to be installed")
refresh = TokenObtainPairSerializer.get_token(user)
return refresh.access_token, refresh
2020-03-20 00:09:20 +03:00
try:
from rest_framework_simplejwt.authentication import JWTAuthentication
class JWTCookieAuthentication(JWTAuthentication):
"""
An authentication plugin that hopefully authenticates requests through a JSON web
token provided in a request cookie (and through the header as normal, with a preference to the header).
"""
def authenticate(self, request):
header = self.get_header(request)
if header is None:
if JWT_AUTH_COOKIE: # or settings.JWT_AUTH_COOKIE
raw_token = request.COOKIES.get(JWT_AUTH_COOKIE) # or settings.jwt_auth_cookie
else:
return None
else:
raw_token = self.get_raw_token(header)
if raw_token is None:
return None
validated_token = self.get_validated_token(raw_token)
return self.get_user(validated_token), validated_token
except ImportError as I:
pass