serializers.py 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. # coding=utf-8
  2. from django.contrib.auth import get_user_model, authenticate
  3. from rest_framework import serializers
  4. from rest_framework_jwt.serializers import JSONWebTokenSerializer
  5. from rest_framework_jwt.settings import api_settings
  6. from utils import get_remote_addr
  7. from apps.system.models import SysLog
  8. from .models import Department
  9. User = get_user_model()
  10. jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER
  11. jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER
  12. class AdminUserJWTSerializer(JSONWebTokenSerializer):
  13. def validate(self, attrs):
  14. credentials = {
  15. self.username_field: attrs.get(self.username_field),
  16. 'password': attrs.get('password')
  17. }
  18. if all(credentials.values()):
  19. user = authenticate(**credentials)
  20. if user:
  21. if not user.is_active:
  22. msg = u'禁用帐户,禁止登录'
  23. SysLog.objects.addnew(user, SysLog.INSERT,u'禁用帐户[%s]尝试登录管理系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  24. raise serializers.ValidationError(msg)
  25. if not user.is_administrator():
  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. payload = jwt_payload_handler(user)
  30. SysLog.objects.addnew(user, SysLog.INSERT, u'[%s]登录管理系统,IP[%s]' % (user.username,get_remote_addr(self.request)))
  31. return {
  32. 'token': jwt_encode_handler(payload),
  33. 'user_id': user.id,
  34. 'username': user.username
  35. }
  36. else:
  37. msg = u'账号或者密码错误!'
  38. SysLog.objects.addnew(None, SysLog.INSERT, u'登录管理系统失败[%s][%s],IP[%s]' % (attrs[self.username_field], attrs['password'], get_remote_addr(self.request)))
  39. raise serializers.ValidationError(msg)
  40. else:
  41. msg = u'必须包含“{username field}”和“password'
  42. msg = msg.format(username_field=self.username_field)
  43. raise serializers.ValidationError(msg)
  44. class StaffUserJWTSerializer(JSONWebTokenSerializer):
  45. def validate(self, attrs):
  46. credentials = {
  47. self.username_field: attrs.get(self.username_field),
  48. 'password': attrs.get('password')
  49. }
  50. if all(credentials.values()):
  51. user = authenticate(**credentials)
  52. if user:
  53. if not user.is_active:
  54. msg = u'禁用帐户,禁止登录'
  55. SysLog.objects.addnew(user, SysLog.INSERT,u'禁用帐户[%s]尝试登录答题系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  56. raise serializers.ValidationError(msg)
  57. if not user.is_staff():
  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. payload = jwt_payload_handler(user)
  62. SysLog.objects.addnew(user, SysLog.INSERT, u'[%s]登录答题系统,IP[%s]' % (user.username,get_remote_addr(self.request)))
  63. return {
  64. 'token': jwt_encode_handler(payload),
  65. 'user_id': user.id,
  66. 'username': user.username
  67. }
  68. else:
  69. msg = u'账号或者密码错误!'
  70. SysLog.objects.addnew(None, SysLog.INSERT, u'登录答题系统失败[%s][%s],IP[%s]' % (attrs[self.username_field], attrs['password'], get_remote_addr(self.request)))
  71. raise serializers.ValidationError(msg)
  72. else:
  73. msg = u'必须包含“{username field}”和“password'
  74. msg = msg.format(username_field=self.username_field)
  75. raise serializers.ValidationError(msg)
  76. class DepartmentSerializer(serializers.ModelSerializer):
  77. class Meta:
  78. model = Department
  79. fields = '__all__'
  80. def create(self, validated_data):
  81. instance = super(DepartmentSerializer, self).create(validated_data)
  82. return instance
  83. def update(self, instance, validated_data):
  84. instance = super(DepartmentSerializer, self).update(instance, validated_data)
  85. return instance