serializers.py 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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 apps.employee.models import Employee
  8. from apps.log.models import BizLog
  9. from utils import get_remote_addr
  10. from utils.exceptions import CustomError
  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 JWTSerializer(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_employee():
  24. msg = u'非工作账号,禁止登录'
  25. raise serializers.ValidationError(msg)
  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, u'[%s]登录系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  32. return {
  33. 'token': jwt_encode_handler(payload),
  34. 'user_id': user.id,
  35. 'username': user.username,
  36. }
  37. else:
  38. msg = u'账号或者密码错误!'
  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 EmployeeSerializer(serializers.ModelSerializer):
  45. password = serializers.CharField(source='user.password', write_only=True, allow_blank=True)
  46. username = serializers.CharField(source='user.username')
  47. is_active = serializers.IntegerField(source='user.is_active')
  48. gender_text = serializers.CharField(source='get_gender_display', read_only=True)
  49. create_time = serializers.DateTimeField(source='user.date_joined', format='%Y-%m-%d %H:%M', read_only=True)
  50. is_active_text = serializers.SerializerMethodField()
  51. class Meta:
  52. model = Employee
  53. fields = '__all__'
  54. def get_is_active_text(self, obj):
  55. if obj.user.is_active:
  56. return u'是'
  57. return u'否'
  58. def create(self, validated_data):
  59. if validated_data['user']['password'].strip() == '':
  60. raise CustomError(u'密码不能为空!')
  61. user = User.objects.create_employee(validated_data['user']['username'], validated_data['user']['password'], is_active=validated_data['user']['is_active'])
  62. validated_data['user'] = user
  63. instance = super(EmployeeSerializer, self).create(validated_data)
  64. return instance
  65. def update(self, instance, validated_data):
  66. if 'user' in validated_data:
  67. instance.user.update_item(validated_data['user'])
  68. validated_data.pop('user')
  69. instance = super(EmployeeSerializer, self).update(instance, validated_data)
  70. return instance