views.py 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. from rest_framework.views import APIView
  2. from rest_framework.generics import GenericAPIView
  3. from rest_framework.response import Response
  4. from rest_framework import status
  5. from django.contrib.auth import authenticate
  6. from utils.JWTAuthentication_diy import get_token, MyJWTAuthentication
  7. from utils.permissions import RegisterViewPermission
  8. from .serializers import RegisterViewSerializer, LoginViewSerializer
  9. # Create your views here.
  10. class LoginView(APIView):
  11. def post(self, request):
  12. serializer = LoginViewSerializer(data=request.data)
  13. serializer.is_valid(raise_exception=True)
  14. request_data = serializer.validated_data
  15. user = authenticate(**request_data)
  16. if user is not None and user.is_active:
  17. if request_data["modules"] == "pestanalysis":
  18. if user.is_superuser or user.user_modules == 1:
  19. token = get_token(user)
  20. return Response(token)
  21. else:
  22. return Response(data={"msg": "账户无权限进入该模块", "data": ""}, status=status.HTTP_401_UNAUTHORIZED)
  23. else:
  24. return Response(data={"msg": "登录验证失败", "data": ""}, status=status.HTTP_401_UNAUTHORIZED)
  25. class RegisterView(GenericAPIView):
  26. authentication_classes = [MyJWTAuthentication]
  27. serializer_class = RegisterViewSerializer
  28. permission_classes = [RegisterViewPermission]
  29. def post(self, request):
  30. serializer = self.get_serializer(data=request.data)
  31. serializer.is_valid(raise_exception=True)
  32. serializer.save()
  33. return Response(serializer.data)