views.py 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. from rest_framework import status, permissions
  2. from rest_framework.decorators import permission_classes
  3. from rest_framework.response import Response
  4. from rest_framework.views import APIView
  5. from rest_framework.viewsets import ModelViewSet
  6. from django.contrib.auth import login, logout
  7. from django.contrib.auth.backends import ModelBackend
  8. from workreport.models import DailyReport
  9. from workreport.serializer import DailyReportSerializer
  10. class DailyReportViews(APIView):
  11. def get(self, request):
  12. data = DailyReport.objects.values('title', 'content', 'create_at', 'create_by', 'id')
  13. return Response(data=data, status=status.HTTP_200_OK)
  14. def post(self, request):
  15. data = request.data
  16. report = DailyReport(title=data['title'], content=data['content'], create_by_id=data['create_by_id'])
  17. report.save()
  18. return Response(status=status.HTTP_201_CREATED)
  19. class ReportViews(ModelViewSet):
  20. queryset = DailyReport.objects.all()
  21. serializer_class = DailyReportSerializer
  22. filter_fields = {'title': ['exact']}
  23. @permission_classes((permissions.AllowAny,))
  24. class LoginView(APIView):
  25. def post(self, request):
  26. data = request.data
  27. user = ModelBackend().authenticate(username=data['username'], password=data['password'], request=request)
  28. if user is None:
  29. return Response(data={'msg': '用户名或密码不正确'}, status=status.HTTP_404_NOT_FOUND)
  30. else:
  31. login(request, user=user, backend='django.contrib.auth.backends.ModelBackend')
  32. return Response(status=status.HTTP_200_OK)
  33. class LogoutView(APIView):
  34. def post(self, request):
  35. logout(request)
  36. return Response(data={'msg': 'logout success!'}, status=status.HTTP_200_OK)