views.py 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. # coding=utf-8
  2. import json
  3. from django.db import transaction
  4. from django.contrib.auth import get_user_model
  5. from utils.permission import IsAdministrator
  6. from utils import response_error, response_ok
  7. from utils.custom_modelviewset import CustomModelViewSet
  8. from utils.exceptions import CustomError
  9. from rest_framework.views import APIView
  10. from apps.staff.serializers import UserSerializer
  11. from apps.staff.filters import UserFilter
  12. from apps.system.models import SysLog
  13. from apps.examination.exam.models import ExamLog
  14. User = get_user_model()
  15. class UserViewSet(CustomModelViewSet):
  16. permission_classes = [IsAdministrator, ]
  17. queryset = User.objects.filter()
  18. serializer_class = UserSerializer
  19. def filter_queryset(self, queryset):
  20. f = UserFilter(self.request.GET, queryset=queryset)
  21. return f.qs
  22. def perform_create(self, serializer):
  23. super(UserViewSet, self).perform_create(serializer)
  24. instance = serializer.instance
  25. validated_data = serializer.validated_data
  26. SysLog.objects.addnew(self.request.user, SysLog.INSERT, u'添加账户[%s],id=%d' % (instance.username, instance.id), validated_data)
  27. def perform_update(self, serializer):
  28. super(UserViewSet, self).perform_update(serializer)
  29. instance = serializer.instance
  30. validated_data = serializer.validated_data
  31. SysLog.objects.addnew(self.request.user, SysLog.UPDATE, u'修改账户[%s],id=%d' % (instance.username, instance.id), validated_data)
  32. def destroy(self, request, *args, **kwargs):
  33. with transaction.atomic():
  34. instance = self.get_object()
  35. log_count = SysLog.objects.filter(user_id=instance.id).count()
  36. exam_log_count = ExamLog.objects.filter(user_id=instance.id).count()
  37. if log_count > 0 or exam_log_count > 0:
  38. raise CustomError(u'该账号有使用记录,禁止删除!')
  39. SysLog.objects.addnew(self.request.user, SysLog.DELETE, u'删除用户[%s],id=%d' % (instance.name, instance.id))
  40. instance.delete()
  41. return response_ok()
  42. class ChangePasswordView(APIView):
  43. permission_classes = [IsAdministrator, ]
  44. def post(self, request):
  45. data = json.loads(request.body)
  46. new_password = data['new_password'].strip(' ')
  47. confirm_password = data['confirm_password'].strip(u' ')
  48. old_password = data['old_password'].strip(u' ')
  49. with transaction.atomic():
  50. request.user.change_password(new_password, confirm_password, old_password)
  51. request.user.save()
  52. SysLog.objects.addnew(self.request.user, SysLog.UPDATE, u'修改账户密码')
  53. return response_ok()