serializers.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. # coding=utf-8
  2. import json
  3. from django.contrib.auth import get_user_model, authenticate
  4. from utils.exceptions import CustomError
  5. from rest_framework import serializers
  6. from rest_framework_jwt.serializers import JSONWebTokenSerializer
  7. from rest_framework_jwt.settings import api_settings
  8. from apps.foundation.models import BizLog
  9. from apps.account import tenant_log
  10. from utils import get_remote_addr
  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 TenantJWTSerializer(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 user.status != User.INSERVICE:
  24. msg = u'禁用帐户,禁止登录'
  25. tenant_log(user, BizLog.INSERT,u'禁用帐户[%s]尝试登录系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  26. raise serializers.ValidationError(msg)
  27. permissions = list(user.get_all_permissions())
  28. payload = jwt_payload_handler(user)
  29. tenant_log(user, BizLog.INSERT, u'[%s]登录系统,IP[%s]' % (user.username,get_remote_addr(self.request)))
  30. return {
  31. 'token': jwt_encode_handler(payload),
  32. 'user_id': user.id,
  33. 'username': user.username,
  34. 'permissions': permissions
  35. }
  36. else:
  37. msg = u'账号或者密码错误!'
  38. raise serializers.ValidationError(msg)
  39. else:
  40. msg = u'必须包含“{username field}”和“password.'
  41. msg = msg.format(username_field=self.username_field)
  42. raise serializers.ValidationError(msg)
  43. class EmployeeSerializer(serializers.ModelSerializer):
  44. create_time = serializers.DateTimeField(source='date_joined', read_only=True)
  45. status_text = serializers.SerializerMethodField()
  46. def get_status_text(self, obj):
  47. return User.STATUS_CHOICES[obj.status][1]
  48. class Meta:
  49. model = User
  50. fields = '__all__'
  51. def create(self, validated_data):
  52. if validated_data['password'].strip() == '':
  53. raise CustomError(u'密码不能为空!')
  54. instance = super(EmployeeSerializer, self).create(validated_data)
  55. instance.set_password(validated_data['password'])
  56. instance.save()
  57. return instance
  58. def update(self, instance, validated_data):
  59. if 'user' in validated_data:
  60. instance.user.update_item(validated_data['user'])
  61. validated_data.pop('user')
  62. instance = super(EmployeeSerializer, self).update(instance, validated_data)
  63. instance.set_password(validated_data['password'])
  64. instance.save()
  65. return instance