views.py 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. # coding=utf-8
  2. from django.conf import settings
  3. from utils.custom_modelviewset import CustomModelViewSet
  4. from utils.permission import IsAdministratorUser
  5. from apps.tenant.models import Tenant
  6. from apps.tenant.employee.models import Employee
  7. from apps.admin import admin_log
  8. from apps.log.models import BizLog
  9. from .serializers import TenantSerializer
  10. from django.db import transaction
  11. from utils import response_ok
  12. from utils.exceptions import CustomError
  13. from rest_framework.decorators import action
  14. from utils import response_ok, response_error
  15. from apps.account.models import User
  16. from .filters import TenantFilter
  17. class TenantViewSet(CustomModelViewSet):
  18. permission_classes = [IsAdministratorUser, ]
  19. queryset = Tenant.objects.all()
  20. serializer_class = TenantSerializer
  21. def filter_queryset(self, queryset):
  22. f = TenantFilter(self.request.GET, queryset=queryset)
  23. return f.qs
  24. def perform_create(self, serializer):
  25. super(TenantViewSet, self).perform_create(serializer)
  26. instance = serializer.instance
  27. validated_data = serializer.validated_data
  28. admin_log(self.request.user, BizLog.INSERT, u'添加企业[%s] id=%d' % (instance.company_name, instance.id), validated_data)
  29. def perform_update(self, serializer):
  30. super(TenantViewSet, self).perform_update(serializer)
  31. instance = serializer.instance
  32. validated_data = serializer.validated_data
  33. admin_log(self.request.user, BizLog.INSERT, u'修改企业[%s] id=%d' % (instance.name, instance.id), validated_data)
  34. @action(methods=['post'], detail=True)
  35. def super_tenant(self, request, pk):
  36. name = request.POST.get('name')
  37. username = request.POST.get('username')
  38. password = request.POST.get('password')
  39. try:
  40. with transaction.atomic():
  41. tenant = Tenant.objects.filter(pk=pk).first()
  42. if not tenant:
  43. raise CustomError('当前企业无效,请刷新!')
  44. user = User.objects.filter(username=username).first()
  45. if user:
  46. user.type = User.SUPER
  47. user.save()
  48. Employee.objects.filter(user=user).update(tenant=tenant, type=Employee.SUPER)
  49. else:
  50. instance = Employee.create_super_admin(tenant, name, username, password)
  51. admin_log(request.user, BizLog.INSERT, u'企业[%s]添加超级账号[%s], id=%d' % (tenant.company_name,username, instance.id))
  52. return response_ok()
  53. except CustomError as e:
  54. return response_error(e.get_error_msg())
  55. except Exception as e:
  56. return response_error(str(e))
  57. @action(methods=['post'], detail=True)
  58. def check(self, request, pk):
  59. # 审核
  60. status = request.POST.get('status')
  61. reject_reason = request.POST.get('reason')
  62. try:
  63. with transaction.atomic():
  64. instance = Tenant.getById(pk)
  65. # 审核
  66. if instance.status > settings.DEFAULT:
  67. raise CustomError('当前企业已审核!')
  68. instance.status = status
  69. instance.reject_reason = reject_reason
  70. instance.save()
  71. BizLog.objects.addnew(None, request.user, BizLog.INSERT, u'审核企业[%s]状态为[%s],id=%d' % (instance.company_name, status, instance.id))
  72. except CustomError as e:
  73. return response_error(e.get_error_msg())
  74. except Exception as e:
  75. return response_error(str(e))
  76. return response_ok('审核完成!')