django-rest-auth/rest_auth/registration/views.py

110 lines
3.7 KiB
Python
Raw Normal View History

2016-02-23 13:59:47 +03:00
from django.utils.translation import ugettext_lazy as _
2016-02-29 15:57:54 +03:00
from django.conf import settings
from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework.permissions import AllowAny
2015-11-24 13:11:46 +03:00
from rest_framework.generics import CreateAPIView
from rest_framework import status
from allauth.account.adapter import get_adapter
2015-11-24 13:11:46 +03:00
from allauth.account.views import ConfirmEmailView
from allauth.account.utils import complete_signup
2015-11-24 13:11:46 +03:00
from allauth.account import app_settings as allauth_settings
from rest_auth.app_settings import (TokenSerializer,
JWTSerializer,
create_token)
2015-11-24 13:11:46 +03:00
from rest_auth.registration.serializers import (SocialLoginSerializer,
VerifyEmailSerializer)
2015-08-07 13:54:45 +03:00
from rest_auth.views import LoginView
2016-01-01 00:10:52 +03:00
from rest_auth.models import TokenModel
from .app_settings import RegisterSerializer
from rest_auth.utils import jwt_encode
2016-03-01 14:51:01 +03:00
2015-11-24 13:11:46 +03:00
class RegisterView(CreateAPIView):
serializer_class = RegisterSerializer
2015-11-24 17:07:20 +03:00
permission_classes = (AllowAny, )
2016-01-01 00:10:52 +03:00
token_model = TokenModel
2016-05-05 09:03:34 +03:00
throttle_scope = 'register_view'
def get_response_data(self, user):
if allauth_settings.EMAIL_VERIFICATION == \
allauth_settings.EmailVerificationMethod.MANDATORY:
return {}
if getattr(settings, 'REST_USE_JWT', False):
data = {
'user': user,
'token': self.token
}
return JWTSerializer(data).data
else:
return TokenSerializer(user.auth_token).data
2015-11-24 13:11:46 +03:00
def create(self, request, *args, **kwargs):
serializer = self.get_serializer(data=request.data)
serializer.is_valid(raise_exception=True)
user = self.perform_create(serializer)
headers = self.get_success_headers(serializer.data)
2014-11-12 05:52:06 +03:00
return Response(self.get_response_data(user), status=status.HTTP_201_CREATED, headers=headers)
2015-11-24 13:11:46 +03:00
def perform_create(self, serializer):
user = serializer.save(self.request)
if getattr(settings, 'REST_USE_JWT', False):
self.token = jwt_encode(user)
else:
create_token(self.token_model, user, serializer)
2015-11-24 13:11:46 +03:00
complete_signup(self.request._request, user,
allauth_settings.EMAIL_VERIFICATION,
None)
2015-11-24 13:11:46 +03:00
return user
2015-08-07 13:54:45 +03:00
class VerifyEmailView(APIView, ConfirmEmailView):
2014-10-01 18:34:51 +04:00
permission_classes = (AllowAny,)
2014-11-12 12:33:29 +03:00
allowed_methods = ('POST', 'OPTIONS', 'HEAD')
2014-10-01 18:34:51 +04:00
def post(self, request, *args, **kwargs):
2015-11-24 13:11:46 +03:00
serializer = VerifyEmailSerializer(data=request.data)
serializer.is_valid(raise_exception=True)
self.kwargs['key'] = serializer.validated_data['key']
2014-10-01 18:34:51 +04:00
confirmation = self.get_object()
confirmation.confirm(self.request)
return Response({'message': _('ok')}, status=status.HTTP_200_OK)
2015-08-07 13:54:45 +03:00
class SocialLoginView(LoginView):
"""
class used for social authentications
example usage for facebook with access_token
-------------
from allauth.socialaccount.providers.facebook.views import FacebookOAuth2Adapter
2015-08-07 13:54:45 +03:00
class FacebookLogin(SocialLoginView):
adapter_class = FacebookOAuth2Adapter
-------------
example usage for facebook with code
-------------
from allauth.socialaccount.providers.facebook.views import FacebookOAuth2Adapter
from allauth.socialaccount.providers.oauth2.client import OAuth2Client
2015-08-07 13:54:45 +03:00
class FacebookLogin(SocialLoginView):
adapter_class = FacebookOAuth2Adapter
client_class = OAuth2Client
callback_url = 'localhost:8000'
-------------
"""
2016-02-29 16:01:39 +03:00
serializer_class = SocialLoginSerializer
def process_login(self):
get_adapter(self.request).login(self.request, self.user)