views.py 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. # coding=utf-8
  2. from django.db import transaction
  3. from django.contrib.auth import get_user_model
  4. from rest_framework.views import APIView
  5. from utils import response_ok
  6. from utils.permission import IsAdministratorUser
  7. from utils.custom_modelviewset import CustomModelViewSet
  8. from apps.log.models import BizLog
  9. from apps.admin import admin_log
  10. from apps.account.filters import UserFilter
  11. from .serializers import UserSerializer
  12. from apps.tenant.employee.serializers import Employee, EmployeeSerializer
  13. from apps.tenant.employee.filters import EmployeeFilter
  14. User = get_user_model()
  15. class EmployeeViewSet(CustomModelViewSet):
  16. permission_classes = [IsAdministratorUser]
  17. queryset = Employee.objects.filter()
  18. serializer_class = EmployeeSerializer
  19. def filter_queryset(self, queryset):
  20. queryset = queryset.filter()
  21. f = EmployeeFilter(self.request.GET, queryset=queryset)
  22. return f.qs
  23. class UserViewSet(CustomModelViewSet):
  24. permission_classes = [IsAdministratorUser, ]
  25. queryset = User.objects.filter(type=User.SUPER)
  26. serializer_class = UserSerializer
  27. def filter_queryset(self, queryset):
  28. f = UserFilter(self.request.GET, queryset=queryset)
  29. return f.qs
  30. def perform_create(self, serializer):
  31. super(UserViewSet, self).perform_create(serializer)
  32. instance = serializer.instance
  33. validated_data = serializer.validated_data
  34. admin_log(self.request.user, BizLog.INSERT, u'添加用户[%s],id=%d' % (instance.username, instance.id),validated_data)
  35. def perform_update(self, serializer):
  36. super(UserViewSet, self).perform_update(serializer)
  37. instance = serializer.instance
  38. validated_data = serializer.validated_data
  39. admin_log(self.request.user, BizLog.UPDATE, u'修改用户[%s],id=%d' % (instance.username, instance.id), validated_data)
  40. def destroy(self, request, *args, **kwargs):
  41. with transaction.atomic():
  42. instance = self.get_object()
  43. instance.is_active = False
  44. instance.save()
  45. admin_log(self.request.user, BizLog.DELETE, u'禁用用户[%s],id=%d' % (instance.username, instance.id))
  46. return response_ok()
  47. class ChangePasswrodView(APIView):
  48. permission_classes = [IsAdministratorUser, ]
  49. def post(self, request):
  50. new_password = request.POST.get('new_password')
  51. confirm_password = request.POST.get('confirm_password')
  52. old_password = request.POST.get('old_password')
  53. with transaction.atomic():
  54. request.user.change_password(new_password, confirm_password, old_password)
  55. request.user.save()
  56. return response_ok()