core: use rest_framework in accounts
This commit is contained in:
@ -1,32 +1,15 @@
|
||||
from django.shortcuts import render
|
||||
from django.views import View
|
||||
from django.http import HttpResponse, HttpRequest, JsonResponse
|
||||
from django.contrib.auth.models import User
|
||||
from django.contrib.auth import authenticate, login, logout
|
||||
from django.db.models.query import QuerySet
|
||||
from django.contrib.auth.decorators import user_passes_test
|
||||
from rest_framework import permissions, status
|
||||
from ..serializers.register import RegisterSerialiser
|
||||
from rest_framework.views import APIView
|
||||
from rest_framework.response import Response
|
||||
from django.http import HttpRequest
|
||||
|
||||
from ..status_code import *
|
||||
from ..forms.register import RegisterForm
|
||||
|
||||
|
||||
class RegisterView(View):
|
||||
|
||||
def get(self, request: HttpRequest):
|
||||
if request.user.is_authenticated:
|
||||
logout(request)
|
||||
return render(request, 'register.html', {'form': RegisterForm})
|
||||
|
||||
def post(self, request: HttpRequest):
|
||||
if request.user.is_authenticated:
|
||||
logout(request)
|
||||
|
||||
form: RegisterForm = RegisterForm(request.POST)
|
||||
if not form.is_valid():
|
||||
return JsonResponse(form.errors)
|
||||
|
||||
user: User = User.objects.create_user(username=form.cleaned_data['username'], password=form.cleaned_data['password'])
|
||||
|
||||
login(request, user)
|
||||
|
||||
return HttpResponse(USER_ADDED)
|
||||
class RegisterView(APIView):
|
||||
permission_classes = (permissions.AllowAny,)
|
||||
def post(self, request: HttpRequest):
|
||||
serializer = RegisterSerialiser(data=request.POST)
|
||||
if serializer.is_valid(raise_exception=True):
|
||||
user = serializer.create(request.POST)
|
||||
if user:
|
||||
return Response("user created", status=status.HTTP_201_CREATED)
|
||||
return Response(status=status.HTTP_400_BAD_REQUEST)
|
Reference in New Issue
Block a user