serializers.py 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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 apps.log.models import BizLog
  7. from apps.tenant import tenant_log
  8. from utils import get_remote_addr
  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 TenantJWTSerializer(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_admin():
  22. msg = u'非工作账号,禁止登录'
  23. raise serializers.ValidationError(msg)
  24. employee = user.employee
  25. if not user.is_active:
  26. msg = u'禁用帐户,禁止登录'
  27. tenant_log(employee, BizLog.INSERT,u'禁用帐户[%s]尝试登录系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  28. raise serializers.ValidationError(msg)
  29. permissions = list(user.get_all_permissions())
  30. payload = jwt_payload_handler(user)
  31. tenant_log(employee, 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.employee.name,
  36. 'permissions': permissions
  37. }
  38. else:
  39. msg = u'账号或者密码错误!'
  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)