serializers.py 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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 utils.exceptions import CustomError
  8. from apps.log.models import BizLog
  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 JWTSerializer(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_administrator():
  22. msg = u"非工作帐号,禁止登录!"
  23. BizLog.objects.addnew(user, BizLog.INSERT, u'非管工作账号[%s]尝试登录系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  24. raise serializers.ValidationError(msg)
  25. if not user.is_active:
  26. msg = u'禁用帐户,禁止登录!'
  27. BizLog.objects.addnew(user, BizLog.INSERT,u'禁用帐户[%s]尝试登录系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  28. raise serializers.ValidationError(msg)
  29. payload = jwt_payload_handler(user)
  30. BizLog.objects.addnew(user, BizLog.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. 'name': user.name or '',
  36. }
  37. else:
  38. msg = u'账号或者密码错误!'
  39. BizLog.objects.addnew(None, BizLog.INSERT, u'登录失败[%s][%s],IP[%s]' % (attrs[self.username_field], attrs['password'], get_remote_addr(self.request)))
  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 UserSerializer(serializers.ModelSerializer):
  46. type = serializers.IntegerField(read_only=True)
  47. password = serializers.CharField(write_only=True, allow_blank=True)
  48. class Meta:
  49. model = User
  50. fields = '__all__'
  51. def create(self, validated_data):
  52. validated_data['type'] = User.ADMINSTRATOR
  53. if validated_data['password'].strip() == '':
  54. raise CustomError(u'密码不能为空!')
  55. instance = super(UserSerializer, self).create(validated_data)
  56. instance.set_password(validated_data['password'])
  57. instance.save()
  58. return instance
  59. def update(self, instance, validated_data):
  60. instance.update_item(validated_data)
  61. return instance