views.py 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. # coding=utf-8
  2. from django.conf import settings
  3. from django.db import transaction
  4. from rest_framework.views import APIView
  5. from rest_framework.decorators import action
  6. from utils.custom_modelviewset import CustomModelViewSet
  7. from apps.log.models import BizLog
  8. from apps.tenant.models import Tenant
  9. from .serializers import TenantSerializer
  10. from utils.exceptions import CustomError
  11. from utils import response_ok, response_error
  12. from apps.tenant.employee.models import Employee
  13. from utils.permission import isLogin
  14. class SearchTenantView(APIView):
  15. permission_classes = [isLogin, ]
  16. def get(self, request, *args, **kwargs):
  17. company_no = request.GET.get('company_no')
  18. tenant = Tenant.objects.filter(company_no=company_no, status=settings.PASS).first()
  19. if tenant and tenant != request.user.employee.tenant:
  20. data = {
  21. 'company_no':tenant.company_no,
  22. 'company_name':tenant.company_name,
  23. }
  24. return response_ok(data)
  25. else:
  26. return response_ok()
  27. class GetTenantView(APIView):
  28. permission_classes = [isLogin]
  29. def get(self, request, *args, **kwargs):
  30. emplayee = Employee.objects.filter(user=request.user).first()
  31. if emplayee:
  32. data = {
  33. 'tenant_id':emplayee.tenant.id,
  34. 'company_no':emplayee.tenant.company_no,
  35. 'company_name':emplayee.tenant.company_name,
  36. 'position':emplayee.position,
  37. 'user_type_text':emplayee.get_type_display(),
  38. }
  39. return response_ok(data)
  40. else:
  41. return response_ok()
  42. class TenantViewSet(CustomModelViewSet):
  43. permission_classes = [isLogin, ]
  44. queryset = Tenant.objects.all()
  45. serializer_class = TenantSerializer
  46. def perform_create(self, serializer):
  47. super(TenantViewSet, self).perform_create(serializer)
  48. instance = serializer.instance
  49. validated_data = serializer.validated_data
  50. BizLog.objects.addnew(instance, self.request.user, BizLog.INSERT, u'申请企业[%s] id=%d' % (instance.company_name, instance.id), validated_data)
  51. @action(methods=['get'], detail=True)
  52. def bind_company(self, request, pk):
  53. # 绑定企业,pk 企业编号
  54. try:
  55. is_validity = Tenant.check_validity(pk)
  56. if not is_validity:
  57. raise CustomError('该企业认证已过期,请联系管理员续费!')
  58. user = self.request.user
  59. if user.type == Employee.SUPER:
  60. raise CustomError('您是企业超级管理员,不能绑定其他企业!')
  61. with transaction.atomic():
  62. user = self.request.user
  63. user.type = Employee.REPAIR
  64. user.save()
  65. tenant = Tenant.getByNo(pk)
  66. Employee.objects.filter(user=user).update(tenant=tenant, type=Employee.REPAIR,position='报修人')
  67. except CustomError as e:
  68. return response_error(e.get_error_msg())
  69. except Exception as e:
  70. return response_error(str(e))
  71. return response_ok('绑定成功!')