views.py 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. # coding=utf-8
  2. from django.db import transaction
  3. from rest_framework_jwt.views import ObtainJSONWebToken,VerifyJSONWebToken,RefreshJSONWebToken
  4. from rest_framework.serializers import ValidationError
  5. from utils.custom_modelviewset import CustomModelViewSet
  6. from utils import response_error, response_ok
  7. from .serializers import *
  8. from .models import User
  9. from apps.account import tenant_log
  10. from apps.foundation.models import BizLog
  11. from django.contrib.auth.decorators import login_required
  12. from .filters import *
  13. class LoginView(ObtainJSONWebToken):
  14. serializer_class = TenantJWTSerializer
  15. def post(self, request, *args, **kwargs):
  16. try:
  17. ser = self.serializer_class(data=request.data)
  18. ser.request = request
  19. if ser.is_valid(raise_exception=True):
  20. return response_ok(ser.validated_data)
  21. except ValidationError as e:
  22. return response_error(e.detail['error'][0])
  23. class VerifyTokenView(VerifyJSONWebToken):
  24. def post(self, request, *args, **kwargs):
  25. try:
  26. ser = self.serializer_class(data=request.data)
  27. if ser.is_valid(raise_exception=True):
  28. return response_ok({'token': ser.validated_data['token']})
  29. except ValidationError as e:
  30. return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
  31. class RefreshTokenView(RefreshJSONWebToken):
  32. def post(self, request, *args, **kwargs):
  33. try:
  34. ser = self.serializer_class(data=request.data)
  35. if ser.is_valid(raise_exception=True):
  36. return response_ok({'token': ser.validated_data['token']})
  37. except ValidationError as e:
  38. return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
  39. class EmployeeViewSet(CustomModelViewSet):
  40. queryset = User.objects.filter()
  41. serializer_class = EmployeeSerializer
  42. def filter_queryset(self, queryset):
  43. queryset = queryset.filter()
  44. f = EmployeeFilter(self.request.GET, queryset=queryset)
  45. return f.qs
  46. def perform_create(self, serializer):
  47. super(EmployeeViewSet, self).perform_create(serializer)
  48. instance = serializer.instance
  49. validated_data = serializer.validated_data
  50. tenant_log(self.request.user, BizLog.INSERT, u'添加用户[%s],id=%d' % (instance.name, instance.id),validated_data)
  51. def perform_update(self, serializer):
  52. super(EmployeeViewSet, self).perform_update(serializer)
  53. instance = serializer.instance
  54. validated_data = serializer.validated_data
  55. tenant_log(self.request.user, BizLog.UPDATE, u'修改用户[%s],id=%d' % (instance.name, instance.id), validated_data)
  56. def destroy(self, request, *args, **kwargs):
  57. with transaction.atomic():
  58. instance = self.get_object()
  59. instance.user.is_active = False
  60. instance.user.save()
  61. tenant_log(self.request.user, BizLog.DELETE, u'禁用用户[%s],id=%d' % (instance.name, instance.id))
  62. return response_ok()