serializers.py 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. # coding=utf-8
  2. import json
  3. from django.conf import settings
  4. from django.contrib.auth import get_user_model, authenticate
  5. from rest_framework import serializers
  6. from rest_framework_jwt.serializers import JSONWebTokenSerializer
  7. from rest_framework_jwt.settings import api_settings
  8. from django.contrib.auth.models import Group, Permission
  9. from apps.log.models import BizLog
  10. from utils import get_remote_addr
  11. from utils.booleancharfield import BooleanCharField
  12. from utils.exceptions import CustomError
  13. from apps.account.models import CustomerWechat
  14. User = get_user_model()
  15. jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER
  16. jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER
  17. class JWTSerializer(JSONWebTokenSerializer):
  18. def validate(self, attrs):
  19. credentials = {
  20. self.username_field: attrs.get(self.username_field),
  21. 'password': attrs.get('password')
  22. }
  23. if all(credentials.values()):
  24. user = authenticate(**credentials)
  25. if user:
  26. if not user.is_active:
  27. msg = u'禁用帐户,禁止登录!'
  28. BizLog.objects.addnew(user, BizLog.INSERT,u'禁用帐户[%s]尝试登录系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  29. raise serializers.ValidationError(msg)
  30. payload = jwt_payload_handler(user)
  31. BizLog.objects.addnew(user, BizLog.INSERT,
  32. u'[%s]登录系统,IP[%s]' % (user.username,get_remote_addr(self.request)))
  33. return {
  34. 'token': jwt_encode_handler(payload),
  35. 'user_id': user.id,
  36. 'username': user.username,
  37. }
  38. else:
  39. msg = u'账号或者密码错误!'
  40. raise serializers.ValidationError(msg)
  41. else:
  42. msg = u'必须包含“{username field}”和“password.'
  43. msg = msg.format(username_field=self.username_field)
  44. raise serializers.ValidationError(msg)
  45. class EmployeeSerializer(serializers.ModelSerializer):
  46. enable_text = BooleanCharField(source='is_active', read_only=True)
  47. create_user_text = serializers.CharField(source='create_user.name', read_only=True)
  48. gender_text = serializers.CharField(source='get_gender_display', read_only=True)
  49. type_text = serializers.CharField(source='get_type_display', read_only=True)
  50. date_joined_f = serializers.DateTimeField(source='date_joined', format=settings.SHORT_DATETIME_FORMAT,
  51. read_only=True)
  52. class Meta:
  53. model = User
  54. # fields = '__all__'
  55. exclude = ('password',)
  56. def create(self, validated_data):
  57. username = self.initial_data['username']
  58. user = User.objects.filter(username=username).first()
  59. if user:
  60. raise CustomError(u'账号[{0}]已存在。'.format(username))
  61. # 代理商添加的账号,默认就是操作人所在的代理商
  62. validated_data['is_active'] = self.initial_data['is_active'] == '1'
  63. user = self.context['request'].user
  64. validated_data['create_user'] = user
  65. validated_data['type'] = User.EMPLOYEE
  66. instance = super(EmployeeSerializer, self).create(validated_data)
  67. instance.set_password(self.initial_data['password'])
  68. instance.save()
  69. return instance
  70. def update(self, instance, validated_data):
  71. password = instance.password
  72. validated_data['is_superuser'] = instance.is_superuser
  73. validated_data['is_active'] = self.initial_data['is_active'] == '1'
  74. instance = super(EmployeeSerializer, self).update(instance, validated_data)
  75. if not 'password' in self.initial_data or not self.initial_data['password']:
  76. instance.password = password
  77. else:
  78. instance.set_password(self.initial_data['password'])
  79. instance.save()
  80. return instance
  81. class PermissionSerializer(serializers.ModelSerializer):
  82. class Meta:
  83. model = Permission
  84. fields = ('id', 'name',)
  85. class GroupSerializer(serializers.ModelSerializer):
  86. employees = serializers.SerializerMethodField()
  87. permissions = PermissionSerializer(many=True, read_only=True)
  88. def get_employees(self, obj):
  89. users = obj.user_set.all()
  90. data = []
  91. for user in users:
  92. data.append(user.name)
  93. return data
  94. class Meta:
  95. model = Group
  96. fields = ('id', 'name', 'permissions', 'employees',)
  97. def create(self, validated_data):
  98. user = self.context['request'].user
  99. validated_data['create_user'] = user
  100. group = Group.objects.filter(name=validated_data['name']).first()
  101. if group:
  102. raise CustomError(u'名称为[%s]的权限组已存在' % validated_data['name'])
  103. permissions = self.context['request'].data.get('permissions', None)
  104. if permissions:
  105. permissions = json.loads(permissions)
  106. else:
  107. permissions = []
  108. instance = super(GroupSerializer, self).create(validated_data)
  109. instance.permissions.set(permissions)
  110. return instance
  111. def update(self, instance, validated_data):
  112. group = Group.objects.filter(name=validated_data['name']).exclude(id=instance.id).first()
  113. if group:
  114. raise CustomError(u'名称为[%s]的权限组已存在' % validated_data['name'])
  115. permissions = self.context['request'].data.get('permissions', None)
  116. if permissions:
  117. permissions = json.loads(permissions)
  118. else:
  119. permissions = []
  120. instance = super(GroupSerializer, self).update(instance, validated_data)
  121. instance.permissions.set(permissions)
  122. return instance
  123. class GroupDictSerializer(serializers.ModelSerializer):
  124. value = serializers.CharField(source='id', read_only=True)
  125. class Meta:
  126. model = Group
  127. fields = ('value', 'name',)
  128. class WechatLoginSerializer(serializers.Serializer):
  129. def validate(self, attrs):
  130. code = self.initial_data.get('code') # 用户code
  131. appid = self.initial_data.get('appid') # 小程序appid
  132. if code and appid:
  133. customer_wechat = CustomerWechat.login(code, appid)
  134. if not customer_wechat.customer:
  135. return {
  136. 'openid': customer_wechat.openid,
  137. }
  138. user = customer_wechat.customer
  139. if not user.is_active:
  140. msg = '用户帐户已禁用.'
  141. raise serializers.ValidationError(msg)
  142. payload = jwt_payload_handler(user)
  143. return {
  144. 'user_id': user.id,
  145. 'token': jwt_encode_handler(payload),
  146. 'openid': customer_wechat.openid,
  147. 'name': customer_wechat.customer.name or '',
  148. 'tel': customer_wechat.customer.username or '',
  149. 'face': customer_wechat.customer.face,
  150. }
  151. else:
  152. msg = '参数无效'
  153. raise serializers.ValidationError(msg)
  154. class WechatBindSerializer(serializers.Serializer):
  155. def validate(self, attrs):
  156. appid = self.initial_data.get('appid')
  157. openid = self.initial_data.get('openid')
  158. phoneEncryptedData = self.initial_data.get('encryptedData')
  159. phoneIv = self.initial_data.get('iv')
  160. if openid and phoneEncryptedData and phoneIv:
  161. customer = CustomerWechat.bindWechat(appid, openid, phoneEncryptedData, phoneIv)
  162. payload = jwt_payload_handler(customer)
  163. return {
  164. 'token': jwt_encode_handler(payload),
  165. 'user_id': customer.id,
  166. 'name': customer.name or '',
  167. 'tel': customer.username or '',
  168. 'face': customer.face,
  169. }
  170. else:
  171. msg = '参数无效'
  172. raise serializers.ValidationError(msg)