serializers.py 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. # coding=utf-8
  2. import json
  3. from django.contrib.auth import get_user_model, authenticate
  4. from rest_framework import serializers
  5. from rest_framework_jwt.serializers import JSONWebTokenSerializer
  6. from rest_framework_jwt.settings import api_settings
  7. from django.contrib.auth.models import Group, Permission
  8. from apps.log.models import BizLog
  9. from utils import get_remote_addr
  10. from utils.booleancharfield import BooleanCharField
  11. from utils.exceptions import CustomError
  12. from apps.account.models import ManageStoreUser,OfficeStoreUser
  13. User = get_user_model()
  14. jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER
  15. jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER
  16. class JWTSerializer(JSONWebTokenSerializer):
  17. def validate(self, attrs):
  18. credentials = {
  19. self.username_field: attrs.get(self.username_field),
  20. 'password': attrs.get('password')
  21. }
  22. if all(credentials.values()):
  23. user = authenticate(**credentials)
  24. if user:
  25. if not user.is_active:
  26. msg = u'禁用帐户,禁止登录!'
  27. BizLog.objects.addnew(user, BizLog.INSERT,u'禁用帐户[%s]尝试登录系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  28. raise serializers.ValidationError(msg)
  29. if user.status != User.INSERVICE:
  30. raise serializers.ValidationError('当前账号非在职状态,禁止登录!')
  31. payload = jwt_payload_handler(user)
  32. BizLog.objects.addnew(user, BizLog.INSERT,
  33. u'[%s]登录系统,IP[%s]' % (user.username,get_remote_addr(self.request)))
  34. permissions = list(user.get_all_permissions())
  35. return {
  36. 'token': jwt_encode_handler(payload),
  37. 'user_id': user.id,
  38. 'username': user.username,
  39. 'permissions': permissions,
  40. 'manager_stores': len(user.get_manager_range()),
  41. }
  42. else:
  43. msg = u'账号或者密码错误!'
  44. raise serializers.ValidationError(msg)
  45. else:
  46. msg = u'必须包含“{username field}”和“password.'
  47. msg = msg.format(username_field=self.username_field)
  48. raise serializers.ValidationError(msg)
  49. class EmployeeSerializer(serializers.ModelSerializer):
  50. enable_text = BooleanCharField(source='is_active', read_only=True)
  51. agent_text = serializers.CharField(source='agent.name', read_only=True)
  52. store_text = serializers.CharField(source='store.name', read_only=True)
  53. general_agent_text = serializers.CharField(source='general_agent.name', read_only=True)
  54. gender_text = serializers.CharField(source='get_gender_display', read_only=True)
  55. status_text = serializers.CharField(source='get_status_display', read_only=True)
  56. check_user_text = serializers.CharField(source='check_user.name', read_only=True)
  57. groups = serializers.SerializerMethodField()
  58. group_ids = serializers.PrimaryKeyRelatedField(source='groups', many=True, read_only=True)
  59. manager_barnchs = serializers.SerializerMethodField()
  60. office_stores = serializers.SerializerMethodField()
  61. def get_manager_barnchs(self, obj):
  62. stores = ManageStoreUser.objects.filter(manage_user=obj)
  63. return ','.join(stores.values_list('store__name', flat=True))
  64. def get_groups(self, obj):
  65. return ','.join(obj.groups.values_list('name', flat=True))
  66. def get_office_stores(self, obj):
  67. stores = OfficeStoreUser.objects.filter(office_user=obj)
  68. return ','.join(stores.values_list('store__name', flat=True))
  69. class Meta:
  70. model = User
  71. # fields = '__all__'
  72. exclude = ('password',)
  73. def create(self, validated_data):
  74. username = self.initial_data['username']
  75. user = User.objects.filter(username=username).first()
  76. if user:
  77. raise CustomError(u'账号[{0}]已存在。'.format(username))
  78. # 代理商添加的账号,默认就是操作人所在的代理商
  79. user = self.context['request'].user
  80. validated_data['create_user'] = user
  81. validated_data['check_user'] = user
  82. validated_data['status'] = User.INSERVICE
  83. instance = super(EmployeeSerializer, self).create(validated_data)
  84. instance.set_password(self.initial_data['password'])
  85. instance.save()
  86. groups = self.context['request'].data.get('groups', None)
  87. if groups:
  88. groups = json.loads(groups)
  89. else:
  90. groups = []
  91. for group in groups:
  92. instance.groups.add(group)
  93. return instance
  94. def update(self, instance, validated_data):
  95. instance.groups.clear()
  96. password = instance.password
  97. validated_data['is_superuser'] = instance.is_superuser
  98. instance = super(EmployeeSerializer, self).update(instance, validated_data)
  99. if not 'password' in self.initial_data or not self.initial_data['password']:
  100. instance.password = password
  101. else:
  102. instance.set_password(self.initial_data['password'])
  103. instance.save()
  104. groups = self.context['request'].data.get('groups', None)
  105. if groups:
  106. groups = json.loads(groups)
  107. else:
  108. groups = []
  109. for group in groups:
  110. instance.groups.add(group)
  111. return instance
  112. class PermissionSerializer(serializers.ModelSerializer):
  113. class Meta:
  114. model = Permission
  115. fields = ('id', 'name',)
  116. class GroupSerializer(serializers.ModelSerializer):
  117. employees = serializers.SerializerMethodField()
  118. permissions = PermissionSerializer(many=True, read_only=True)
  119. def get_employees(self, obj):
  120. users = obj.user_set.all()
  121. data = []
  122. for user in users:
  123. data.append(user.name)
  124. return data
  125. class Meta:
  126. model = Group
  127. fields = ('id', 'name', 'permissions', 'employees',)
  128. def create(self, validated_data):
  129. user = self.context['request'].user
  130. validated_data['create_user'] = user
  131. group = Group.objects.filter(name=validated_data['name']).first()
  132. if group:
  133. raise CustomError(u'名称为[%s]的权限组已存在' % validated_data['name'])
  134. permissions = self.context['request'].data.get('permissions', None)
  135. if permissions:
  136. permissions = json.loads(permissions)
  137. else:
  138. permissions = []
  139. instance = super(GroupSerializer, self).create(validated_data)
  140. instance.permissions.set(permissions)
  141. return instance
  142. def update(self, instance, validated_data):
  143. group = Group.objects.filter(name=validated_data['name']).exclude(id=instance.id).first()
  144. if group:
  145. raise CustomError(u'名称为[%s]的权限组已存在' % validated_data['name'])
  146. permissions = self.context['request'].data.get('permissions', None)
  147. if permissions:
  148. permissions = json.loads(permissions)
  149. else:
  150. permissions = []
  151. instance = super(GroupSerializer, self).update(instance, validated_data)
  152. instance.permissions.set(permissions)
  153. return instance
  154. class GroupDictSerializer(serializers.ModelSerializer):
  155. value = serializers.CharField(source='id', read_only=True)
  156. class Meta:
  157. model = Group
  158. fields = ('value', 'name',)