serializers.py 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. # coding=utf-8
  2. import datetime
  3. from django.utils import timezone
  4. from django.contrib.auth import get_user_model, authenticate
  5. from django.db.models import F
  6. from rest_framework import serializers
  7. from rest_framework_jwt.serializers import JSONWebTokenSerializer
  8. from rest_framework_jwt.settings import api_settings
  9. from utils import get_remote_addr
  10. from utils.exceptions import CustomError
  11. from apps.system.models import SysLog
  12. from .models import Department
  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 AdminUserJWTSerializer(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. SysLog.objects.addnew(user, SysLog.INSERT,u'禁用帐户[%s]尝试登录管理系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  28. raise serializers.ValidationError(msg)
  29. if not user.is_administrator():
  30. msg = u'非管理员账号,禁止登录'
  31. SysLog.objects.addnew(user, SysLog.INSERT,u'非管理员账号[%s]尝试登录管理系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  32. raise serializers.ValidationError(msg)
  33. User.objects.filter(pk=user.pk).update(status=User.ONLINE)
  34. payload = jwt_payload_handler(user)
  35. SysLog.objects.addnew(user, SysLog.INSERT, u'[%s]登录管理系统,IP[%s]' % (user.username,get_remote_addr(self.request)))
  36. return {
  37. 'token': jwt_encode_handler(payload),
  38. 'user_id': user.id,
  39. 'username': user.username,
  40. 'name': user.name
  41. }
  42. else:
  43. msg = u'账号或者密码错误!'
  44. SysLog.objects.addnew(None, SysLog.INSERT, u'登录管理系统失败[%s][%s],IP[%s]' % (attrs[self.username_field], attrs['password'], get_remote_addr(self.request)))
  45. raise serializers.ValidationError(msg)
  46. else:
  47. msg = u'必须包含“{username field}”和“password'
  48. msg = msg.format(username_field=self.username_field)
  49. raise serializers.ValidationError(msg)
  50. class StaffUserJWTSerializer(JSONWebTokenSerializer):
  51. def validate(self, attrs):
  52. credentials = {
  53. self.username_field: attrs.get(self.username_field),
  54. 'password': attrs.get('password')
  55. }
  56. if all(credentials.values()):
  57. user = authenticate(**credentials)
  58. if user:
  59. if not user.is_active:
  60. msg = u'禁用帐户,禁止登录'
  61. SysLog.objects.addnew(user, SysLog.INSERT,u'禁用帐户[%s]尝试登录答题系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  62. raise serializers.ValidationError(msg)
  63. if not user.is_staff():
  64. msg = u'非工作账号,禁止登录'
  65. SysLog.objects.addnew(user, SysLog.INSERT,u'非工作账号[%s]尝试登录答题系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  66. raise serializers.ValidationError(msg)
  67. User.objects.filter(pk=user.pk).update(status=User.ONLINE)
  68. payload = jwt_payload_handler(user)
  69. SysLog.objects.addnew(user, SysLog.INSERT, u'[%s]登录答题系统,IP[%s]' % (user.username,get_remote_addr(self.request)))
  70. return {
  71. 'token': jwt_encode_handler(payload),
  72. 'user_id': user.id,
  73. 'username': user.username,
  74. 'name': user.name
  75. }
  76. else:
  77. msg = u'账号或者密码错误!'
  78. SysLog.objects.addnew(None, SysLog.INSERT, u'登录答题系统失败[%s][%s],IP[%s]' % (attrs[self.username_field], attrs['password'], get_remote_addr(self.request)))
  79. raise serializers.ValidationError(msg)
  80. else:
  81. msg = u'必须包含“{username field}”和“password'
  82. msg = msg.format(username_field=self.username_field)
  83. raise serializers.ValidationError(msg)
  84. class DepartmentSerializer(serializers.ModelSerializer):
  85. lft = serializers.IntegerField(read_only=True)
  86. rgt = serializers.IntegerField(read_only=True)
  87. out_parent_id = serializers.SerializerMethodField()
  88. class Meta:
  89. model = Department
  90. fields = '__all__'
  91. def get_out_parent_id(self, obj):
  92. if obj.parent_id:
  93. return obj.parent_id
  94. return 0
  95. def create(self, validated_data):
  96. count = Department.objects.filter(name=validated_data['name']).count()
  97. if count:
  98. raise CustomError(u'名称为[%s]的部门已存在!' % validated_data['name'])
  99. parent = None
  100. if 'parent_id' in validated_data:
  101. parent = Department.getById(validated_data['parent_id'])
  102. validated_data['parent_id'] = parent.id
  103. lft = Department.getLft(parent)
  104. Department.objects.filter(rgt__gt=lft).update(rgt=F('rgt') + 2)
  105. Department.objects.filter(lft__gt=lft).update(lft=F('lft') + 2)
  106. validated_data['lft'] = lft + 1
  107. validated_data['rgt'] = lft + 2
  108. instance = super(DepartmentSerializer, self).create(validated_data)
  109. return instance
  110. def update(self, instance, validated_data):
  111. print(validated_data)
  112. name = validated_data['name']
  113. count = Department.objects.filter(name=name).exclude(id=instance.id).count()
  114. if count:
  115. raise CustomError(u'名称为[%s]的部门已存在!' % name)
  116. instance = super(DepartmentSerializer, self).update(instance, validated_data)
  117. return instance
  118. class UserSerializer(serializers.ModelSerializer):
  119. password = serializers.CharField(write_only=True, allow_blank=True)
  120. status_text = serializers.SerializerMethodField()
  121. department_text = serializers.CharField(source='department.name', read_only=True)
  122. type_text = serializers.SerializerMethodField()
  123. online_text = serializers.SerializerMethodField()
  124. class Meta:
  125. model = User
  126. fields = '__all__'
  127. def get_status_text(self, obj):
  128. if obj.is_active:
  129. return u'是'
  130. return u'否'
  131. def get_type_text(self, obj):
  132. if obj.type == User.ADMINSTRATOR:
  133. return u'管理员'
  134. elif obj.type == User.STAFF:
  135. return u'普通'
  136. return ''
  137. def get_online_text(self, obj):
  138. start = timezone.now() - datetime.timedelta(hours=0, minutes=10, seconds=0)
  139. if obj.status == User.ONLINE and obj.last_refresh > start:
  140. return '是'
  141. return '否'
  142. def create(self, validated_data):
  143. if validated_data['password'].strip() == '':
  144. raise CustomError(u'密码不能为空!')
  145. if len(validated_data['password']) < 6:
  146. raise CustomError(u'密码长度不能少于6位字符!')
  147. if validated_data['password'] == validated_data['username']:
  148. raise CustomError(u'密码不能和用户名相同!')
  149. if 'type' in validated_data and validated_data['type'] == User.STAFF:
  150. user = User.objects.create_staff(validated_data['username'], validated_data['password'], name=validated_data['name'], department=validated_data['department'])
  151. else:
  152. user = User.objects.create_administrator(validated_data['username'], validated_data['password'], name=validated_data['name'], department=validated_data['department'])
  153. return user
  154. def update(self, instance, validated_data):
  155. instance.update_item(validated_data)
  156. return instance