views.py 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  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. User = get_user_model()
  14. class UserViewSet(CustomModelViewSet):
  15. permission_classes = [IsAdministrator, ]
  16. queryset = User.objects.filter()
  17. serializer_class = UserSerializer
  18. def filter_queryset(self, queryset):
  19. f = UserFilter(self.request.GET, queryset=queryset)
  20. return f.qs
  21. def perform_create(self, serializer):
  22. super(UserViewSet, self).perform_create(serializer)
  23. instance = serializer.instance
  24. validated_data = serializer.validated_data
  25. SysLog.objects.addnew(self.request.user, SysLog.INSERT, u'添加账户[%s],id=%d' % (instance.username, instance.id), validated_data)
  26. def perform_update(self, serializer):
  27. super(UserViewSet, self).perform_update(serializer)
  28. instance = serializer.instance
  29. validated_data = serializer.validated_data
  30. SysLog.objects.addnew(self.request.user, SysLog.UPDATE, u'修改账户[%s],id=%d' % (instance.username, instance.id), validated_data)
  31. class ChangePasswordView(APIView):
  32. permission_classes = [IsAdministrator, ]
  33. def post(self, request):
  34. data = json.loads(request.body)
  35. new_password = data['new_password'].strip(' ')
  36. confirm_password = data['confirm_password'].strip(u' ')
  37. old_password = data['old_password'].strip(u' ')
  38. with transaction.atomic():
  39. request.user.change_password(new_password, confirm_password, old_password)
  40. request.user.save()
  41. SysLog.objects.addnew(self.request.user, SysLog.UPDATE, u'修改账户密码')
  42. return response_ok()