views.py 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. # coding=utf-8
  2. from django.db import transaction
  3. from django.contrib.auth import get_user_model
  4. from rest_framework.decorators import action
  5. from rest_framework.serializers import ValidationError
  6. from rest_framework_jwt.views import ObtainJSONWebToken, RefreshJSONWebToken, VerifyJSONWebToken
  7. from utils.permission import IsAdministratorUser
  8. from utils.custom_modelviewset import CustomModelViewSet
  9. from utils.exceptions import CustomError
  10. from utils import response_error, response_ok
  11. from apps.log.models import BizLog
  12. from apps.account.serializers import JWTSerializer, UserSerializer
  13. from apps.account.filters import UserFilter
  14. User = get_user_model()
  15. class LoginView(ObtainJSONWebToken):
  16. serializer_class = JWTSerializer
  17. def post(self, request, *args, **kwargs):
  18. try:
  19. ser = self.serializer_class(data=request.data)
  20. ser.request = request
  21. if ser.is_valid(raise_exception=True):
  22. return response_ok(ser.validated_data)
  23. except ValidationError as e:
  24. return response_error(e.detail['error'][0])
  25. except CustomError as e:
  26. return response_error(str(e))
  27. class RefreshTokenView(RefreshJSONWebToken):
  28. def post(self, request, *args, **kwargs):
  29. try:
  30. ser = self.serializer_class(data=request.data)
  31. if ser.is_valid(raise_exception=True):
  32. return response_ok({'token': ser.validated_data['token']})
  33. except ValidationError as e:
  34. return response_ok({'error':True})
  35. except CustomError as e:
  36. return response_error(str(e))
  37. class VerifyTokenView(VerifyJSONWebToken):
  38. def post(self, request, *args, **kwargs):
  39. try:
  40. ser = self.serializer_class(data=request.data)
  41. if ser.is_valid(raise_exception=True):
  42. return response_ok({'token': ser.validated_data['token']})
  43. except ValidationError as e:
  44. return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
  45. class EmployeeViewSet(CustomModelViewSet):
  46. permission_classes = [IsAdministratorUser, ]
  47. queryset = User.objects.filter(is_active=True, type=User.ADMINSTRATOR)
  48. serializer_class = UserSerializer
  49. def filter_queryset(self, queryset):
  50. f = UserFilter(self.request.GET, queryset=queryset)
  51. return f.qs
  52. def perform_create(self, serializer):
  53. super(EmployeeViewSet, self).perform_create(serializer)
  54. instance = serializer.instance
  55. validated_data = serializer.validated_data
  56. BizLog.objects.addnew(self.request.user, BizLog.INSERT, u'添加用户[%s],id=%d' % (instance.name, instance.id), validated_data)
  57. def perform_update(self, serializer):
  58. super(EmployeeViewSet, self).perform_update(serializer)
  59. instance = serializer.instance
  60. validated_data = serializer.validated_data
  61. BizLog.objects.addnew(self.request.user, BizLog.UPDATE, u'修改用户[%s],id=%d' % (instance.name, instance.id), validated_data)
  62. @action(methods=['post'], detail=False)
  63. def change_password(self, request):
  64. new_password = request.POST.get('new_password')
  65. confirm_password = request.POST.get('confirm_password')
  66. old_password = request.POST.get('old_password')
  67. with transaction.atomic():
  68. request.user.change_password(new_password, confirm_password, old_password)
  69. request.user.save()
  70. BizLog.objects.addnew(request.user, BizLog.UPDATE, u"修改密码[%s],id=%d" % (request.user.username, request.user.id))
  71. return response_ok()