serializers.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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 utils import get_remote_addr
  8. from apps.tenant.employee.models import Employee
  9. from apps.tenant.models import Pay,Invoice
  10. from apps.base import Formater
  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 not user.is_admin():
  24. msg = u'非工作账号,禁止登录'
  25. raise serializers.ValidationError(msg)
  26. employee = Employee.objects.filter(user=user).first()
  27. if not user.is_active:
  28. msg = u'禁用帐户,禁止登录'
  29. BizLog.objects.addnew(employee.tenant, user, BizLog.INSERT,u'禁用帐户[%s]尝试登录系统,IP[%s]' % (user.username, get_remote_addr(self.request)))
  30. raise serializers.ValidationError(msg)
  31. payload = jwt_payload_handler(user)
  32. BizLog.objects.addnew(employee.tenant, user, BizLog.INSERT,
  33. u'[%s]登录系统,IP[%s]' % (user.username,get_remote_addr(self.request)))
  34. return {
  35. 'token': jwt_encode_handler(payload),
  36. 'user_id': user.id,
  37. 'username': user.username,
  38. 'user_type': user.type,
  39. }
  40. else:
  41. msg = u'账号或者密码错误!'
  42. raise serializers.ValidationError(msg)
  43. else:
  44. msg = u'必须包含“{username field}”和“password.'
  45. msg = msg.format(username_field=self.username_field)
  46. raise serializers.ValidationError(msg)
  47. class PaySerializer(serializers.ModelSerializer):
  48. status_text = serializers.CharField(source='get_status_display', read_only=True)
  49. pay_channel_text = serializers.CharField(source='get_pay_channel_display', read_only=True)
  50. tenant = serializers.DateTimeField(source='tenant.company_name', read_only=True)
  51. username = serializers.CharField(source='user.employee.name', read_only=True)
  52. amount = serializers.SerializerMethodField()
  53. def get_amount(self, obj):
  54. return Formater.formatAmountShow(obj.amount)
  55. class Meta:
  56. model = Pay
  57. fields = '__all__'
  58. class InvoiceSerializer(serializers.ModelSerializer):
  59. status_text = serializers.CharField(source='get_status_display', read_only=True)
  60. tenant = serializers.DateTimeField(source='tenant.company_name', read_only=True)
  61. username = serializers.CharField(source='user.employee.name', read_only=True)
  62. class Meta:
  63. model = Invoice
  64. fields = '__all__'
  65. def create(self, validated_data):
  66. validated_data['user'] = self.context['request'].user
  67. validated_data['tenant'] = self.context['request'].user.employee.tenant
  68. instance = super(InvoiceSerializer, self).create(validated_data)
  69. return instance