views.py 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. # coding=utf-8
  2. import traceback
  3. import datetime
  4. import time
  5. from django.db import transaction
  6. from rest_framework.decorators import action
  7. from rest_framework_jwt.views import ObtainJSONWebToken,VerifyJSONWebToken,RefreshJSONWebToken
  8. from rest_framework.serializers import ValidationError
  9. from utils.custom_modelviewset import CustomModelViewSet
  10. from utils import response_error, response_ok
  11. from .serializers import TenantJWTSerializer
  12. from utils.permission import IsTenantUser, IsAdministratorUser
  13. from .models import Tenant, Pay
  14. from apps.admin.tenant.serializers import TenantSerializer
  15. from apps.admin.tenant.filters import TenantFilter
  16. from apps.log.models import BizLog
  17. from apps.tenant.config.models import Config
  18. from utils.exceptions import CustomError
  19. from apps.base import Formater
  20. class TenantLoginView(ObtainJSONWebToken):
  21. serializer_class = TenantJWTSerializer
  22. def post(self, request, *args, **kwargs):
  23. try:
  24. ser = self.serializer_class(data=request.data)
  25. ser.request = request
  26. if ser.is_valid(raise_exception=True):
  27. return response_ok(ser.validated_data)
  28. except ValidationError as e:
  29. return response_error(e.detail['error'][0])
  30. class TenantVerifyTokenView(VerifyJSONWebToken):
  31. def post(self, request, *args, **kwargs):
  32. try:
  33. ser = self.serializer_class(data=request.data)
  34. if ser.is_valid(raise_exception=True):
  35. return response_ok({'token': ser.validated_data['token']})
  36. except ValidationError as e:
  37. return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
  38. class TenantRefreshTokenView(RefreshJSONWebToken):
  39. def post(self, request, *args, **kwargs):
  40. try:
  41. ser = self.serializer_class(data=request.data)
  42. if ser.is_valid(raise_exception=True):
  43. return response_ok({'token': ser.validated_data['token']})
  44. except ValidationError as e:
  45. return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
  46. class CompanyViewSet(CustomModelViewSet):
  47. permission_classes = [IsAdministratorUser,]
  48. queryset = Tenant.objects.filter(delete=False)
  49. serializer_class = TenantSerializer
  50. def filter_queryset(self, queryset):
  51. queryset = queryset.filter(id=self.request.user.employee.tenant.id)
  52. f = TenantFilter(self.request.GET, queryset=queryset)
  53. return f.qs
  54. @action(methods=['post'], detail=True)
  55. def update_company(self,request,pk):
  56. name = request.POST.get('name')
  57. tel = request.POST.get('tel')
  58. Tenant.objects.filter(id=pk).update(name=name,tel=tel)
  59. BizLog.objects.addnew(self.request.user.employee.tenant, self.request.user, BizLog.INSERT, u'修改企业联系人,id=%s' % pk, request.POST)
  60. return response_ok()
  61. @action(methods=['get'], detail=True)
  62. def get_code(self, request, pk):
  63. pay_channel = request.GET.get('pay_channel')
  64. config = Config.objects.filter(property=Config.KEY_RENEW_AMOUNT_1).first()
  65. year = Config.objects.filter(property=Config.KEY_RENEW_YEAR_1).first()
  66. if config:
  67. amount = Formater.formatAmount(config.value)
  68. year = year.value
  69. else:
  70. raise CustomError('续费金额错误')
  71. try:
  72. tenant = Tenant.objects.filter(id=pk).first()
  73. if tenant:
  74. today = datetime.datetime.now().strftime('%Y-%m-%d')
  75. today_stamp = time.mktime(time.strptime(today,"%Y-%m-%d"))
  76. end_date = time.mktime(time.strptime(tenant.end_date.strftime('%Y-%m-%d'), '%Y-%m-%d'))
  77. diff = int(end_date) - int(today_stamp)
  78. if diff >= 0:
  79. start_date = tenant.end_date
  80. renew_date = (tenant.end_date + datetime.timedelta(days=365*int(year))).strftime('%Y-%m-%d')
  81. else:
  82. start_date = today
  83. renew_date = (datetime.datetime.now() + datetime.timedelta(days=365 * int(year))).strftime('%Y-%m-%d')
  84. else:
  85. raise CustomError('获取企业信息失败,请刷新重试!')
  86. with transaction.atomic():
  87. if int(pay_channel) == Pay.WECHAT:
  88. line_data = Pay.wechatPay(request.user, pk ,amount)
  89. elif int(pay_channel) == Pay.ALIPAY:
  90. line_data = Pay.alipayPay(request.user, pk ,amount)
  91. else:
  92. raise CustomError('请选择正确的支付方式')
  93. data = {
  94. 'renew_date': '{} — {}'.format(start_date,renew_date),
  95. 'year': year,
  96. 'amount': Formater.formatAmountShow(amount),
  97. 'id': line_data.id,
  98. 'qrcode': line_data.qrcode
  99. }
  100. return response_ok(data)
  101. except CustomError as e:
  102. return response_error(str(e))
  103. except Exception as e:
  104. traceback.print_exc()
  105. return response_error(u'支付失败', request)
  106. @action(methods=['get'], detail=True)
  107. def confirm_pay(self, request, pk):
  108. pay_id = request.GET.get('pay_id')
  109. try:
  110. with transaction.atomic():
  111. payment = Pay.objects.filter(id=int(pay_id)).first()
  112. if not payment:
  113. raise CustomError(u'无法找到付款单')
  114. if payment.status == Pay.WAIT:
  115. raise CustomError(u'暂无付款信息,请付款')
  116. if payment.status == Pay.CONFIRM:
  117. raise CustomError(u'已确认付款')
  118. payment.payConfirm(payment.pay_no)
  119. except CustomError as e:
  120. return response_error(str(e))
  121. except Exception as e:
  122. traceback.print_exc()
  123. return response_error(u'验证失败', request)
  124. return response_ok()