serializers.py 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. # coding=utf-8
  2. import json
  3. from rest_framework import serializers
  4. from apps.tenant.employee.models import Employee
  5. from utils.exceptions import CustomError
  6. from apps.account.models import User
  7. class EmployeeSerializer(serializers.ModelSerializer):
  8. gender_text = serializers.CharField(source='get_gender_display', read_only=True)
  9. status_text = serializers.CharField(source='get_status_display', read_only=True)
  10. type_text = serializers.CharField(source='get_type_display', read_only=True)
  11. create_time = serializers.DateTimeField(source='user.date_joined', read_only=True)
  12. tenant = serializers.DateTimeField(source='tenant.company_name', read_only=True)
  13. username = serializers.CharField(source='user.username', read_only=True)
  14. class Meta:
  15. model = Employee
  16. fields = '__all__'
  17. def create(self, validated_data):
  18. if int(self.initial_data['type']) == Employee.SUPER and Employee.checkSuper(self.context['request'].user.employee.tenant):
  19. raise CustomError(u'已存在一个平台管理员,禁止操作!')
  20. username = self.initial_data['tel']
  21. # 判断用户是否已经注册登陆过
  22. password = None
  23. if self.initial_data['password']:
  24. password = self.initial_data['password']
  25. user = User.objects.filter(username=username).first()
  26. if not user:
  27. # 创建user实例
  28. user = User.objects.create_tenant_user(validated_data['type'], username, password)
  29. validated_data['user'] = user
  30. validated_data['tenant'] = self.context['request'].user.employee.tenant
  31. try:
  32. instance = super(EmployeeSerializer, self).create(validated_data)
  33. return instance
  34. except Exception as e:
  35. if e.args[0] == 1062:
  36. raise CustomError(u'该手机号已被游客或者其他员工使用,请检查!')
  37. def update(self, instance, validated_data):
  38. if instance.tenant != self.context['request'].user.employee.tenant:
  39. raise CustomError(u'禁止跨企业操作!')
  40. if int(self.initial_data['type']) == Employee.SUPER and Employee.checkSuper(instance.tenant, instance.id):
  41. raise CustomError(u'已存在一个平台管理员,禁止操作!')
  42. username = self.initial_data['tel']
  43. if username and self.initial_data['password'].strip() != '':
  44. if instance.user:
  45. user = {
  46. 'username': username,
  47. 'password': self.initial_data['password'],
  48. 'is_active': 1 if self.initial_data['status'] == '1' else 0,
  49. 'type': self.initial_data['type'],
  50. }
  51. instance.user.update_item(user)
  52. else:
  53. is_active = 1 if self.initial_data['status'] == '1' else 0
  54. user = User.objects.create_tenant_user(validated_data['type'],
  55. username,
  56. self.initial_data['password'],
  57. is_active=is_active)
  58. validated_data['user'] = user
  59. instance = super(EmployeeSerializer, self).update(instance, validated_data)
  60. return instance