serializers.py 7.4 KB

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