views.py 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  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 user.is_superuser:
  18. token = get_token(user)
  19. return Response(token)
  20. if request_data["modules"] == "pestanalysis" and user.user_modules == 1:
  21. token = get_token(user)
  22. return Response(token)
  23. else:
  24. return Response(data={"msg": "账户无权限进入该模块", "data": ""}, status=status.HTTP_401_UNAUTHORIZED)
  25. else:
  26. return Response(data={"msg": "登录验证失败", "data": ""}, status=status.HTTP_401_UNAUTHORIZED)
  27. class RegisterView(GenericAPIView):
  28. authentication_classes = [MyJWTAuthentication]
  29. serializer_class = RegisterViewSerializer
  30. permission_classes = [RegisterViewPermission]
  31. def post(self, request):
  32. serializer = self.get_serializer(data=request.data)
  33. serializer.is_valid(raise_exception=True)
  34. serializer.save()
  35. return Response(serializer.data)