views.py 3.0 KB

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