1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- # coding=utf-8
- import json
- from django.db import transaction
- from django.contrib.auth import get_user_model
- from utils.permission import IsAdministrator
- from utils import response_error, response_ok
- from utils.custom_modelviewset import CustomModelViewSet
- from utils.exceptions import CustomError
- from rest_framework.views import APIView
- from apps.staff.serializers import UserSerializer
- from apps.staff.filters import UserFilter
- from apps.system.models import SysLog
- User = get_user_model()
- class UserViewSet(CustomModelViewSet):
- permission_classes = [IsAdministrator, ]
- queryset = User.objects.filter()
- serializer_class = UserSerializer
- def filter_queryset(self, queryset):
- f = UserFilter(self.request.GET, queryset=queryset)
- return f.qs
- def perform_create(self, serializer):
- super(UserViewSet, self).perform_create(serializer)
- instance = serializer.instance
- validated_data = serializer.validated_data
- SysLog.objects.addnew(self.request.user, SysLog.INSERT, u'添加账户[%s],id=%d' % (instance.username, instance.id), validated_data)
- def perform_update(self, serializer):
- super(UserViewSet, self).perform_update(serializer)
- instance = serializer.instance
- validated_data = serializer.validated_data
- SysLog.objects.addnew(self.request.user, SysLog.UPDATE, u'修改账户[%s],id=%d' % (instance.username, instance.id), validated_data)
- class ChangePasswordView(APIView):
- permission_classes = [IsAdministrator, ]
- def post(self, request):
- data = json.loads(request.body)
- new_password = data['new_password'].strip(' ')
- confirm_password = data['confirm_password'].strip(u' ')
- old_password = data['old_password'].strip(u' ')
- with transaction.atomic():
- request.user.change_password(new_password, confirm_password, old_password)
- request.user.save()
- SysLog.objects.addnew(self.request.user, SysLog.UPDATE, u'修改账户密码')
- return response_ok()
|