views.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. # coding=utf-8
  2. import traceback
  3. from django.db.models import Sum, F
  4. from rest_framework.decorators import action
  5. from rest_framework.views import APIView
  6. from utils.file_operation import attachment_save
  7. from django.db import transaction
  8. from django.db.models import Q
  9. from utils.custom_modelviewset import CustomModelViewSet
  10. from .serializers import *
  11. from .filters import *
  12. from .resources import *
  13. from apps.log.models import BizLog
  14. from apps.base import Formater
  15. from utils import response_ok, response_error
  16. from utils.permission import isLogin, permission_required
  17. from apps.order.models import Order
  18. from apps.WeChatResponse import WechatAppletPay, WeChatResponse
  19. from django.contrib.auth import get_user_model
  20. User = get_user_model()
  21. class OrderViewSet(CustomModelViewSet):
  22. permission_classes = [isLogin, ]
  23. queryset = Order.objects.filter()
  24. serializer_class = OrderSerializer
  25. def list(self, request, *args, **kwargs):
  26. # 底栏合计
  27. export = request.GET.get('export')
  28. queryset = self.filter_queryset(self.get_queryset())
  29. if export:
  30. queryset = queryset.filter(status=Order.FINISH).order_by('-student__classes_id',
  31. '-student__classes__grade_id')
  32. export_data = OrderResource().export(queryset)
  33. filename = attachment_save(export_data, '用户订单{}'.format(timezone.now().date()))
  34. return response_ok({'filename': filename})
  35. total = queryset.aggregate(total_amount=Sum('total_amount'), coupon_deduction=Sum('coupon_deduction'),
  36. actual_amount=Sum('actual_amount'))
  37. totalRow = {'totalRow': 1,
  38. 'total_amount': Formater.formatPriceShow(total['total_amount']),
  39. 'coupon_deduction': Formater.formatPriceShow(total['coupon_deduction']),
  40. 'actual_amount': Formater.formatPriceShow(total['actual_amount'], )}
  41. page = self.paginate_queryset(queryset)
  42. if page is not None:
  43. serializer = self.get_serializer(page, many=True)
  44. data = serializer.data
  45. if len(data) > 0:
  46. data.append(totalRow)
  47. return self.get_paginated_response(data)
  48. serializer = self.get_serializer(queryset, many=True)
  49. return response_ok(serializer.data)
  50. def filter_queryset(self, queryset):
  51. queryset = queryset.filter()
  52. if self.request.user.type == User.CUSTOMER:
  53. queryset = queryset.filter(create_user=self.request.user)
  54. elif self.request.user.type == User.AGENT:
  55. # 代理商,筛选代理的类别和学校
  56. queryset = queryset.filter(
  57. Q(commodity__cogetory__in=self.request.user.cogetory) | Q(student__school=self.request.user.school))
  58. f = OrderFilter(self.request.GET, queryset=queryset)
  59. return f.qs
  60. def create(self, request, *args, **kwargs):
  61. commodity_id = request.POST.get('commodity')
  62. openid = request.POST.get('openid')
  63. appid = request.POST.get('appid')
  64. coupon = request.POST.get('coupon')
  65. count = request.POST.get('count')
  66. try:
  67. # if request.user.id != 17 and request.user.id != 18:
  68. # raise CustomError(u'系统升级中,请稍后再试!')
  69. count = int(count)
  70. commodity = Commodity.objects.filter(id=commodity_id, status=settings.ONLINE, stock__gte=count).first()
  71. if not commodity:
  72. raise CustomError(u'当前商品库存不足!')
  73. with transaction.atomic():
  74. serializer = self.get_serializer(data=request.data)
  75. if serializer.is_valid(raise_exception=True):
  76. instance = serializer.save()
  77. instance.total_amount = count * commodity.price * commodity.discount / 100
  78. actual_amount = instance.total_amount
  79. if coupon:
  80. coupon = Coupon.objects.filter(id=coupon).first()
  81. actual_amount -= coupon.amount
  82. instance.coupon = coupon
  83. data = ''
  84. if actual_amount:
  85. # 小程序在线支付
  86. pay = Pay.wechatAppPay(self.request.user, actual_amount, Pay.CUSTOMER)
  87. wechatpay = WechatAppletPay(appid)
  88. data = wechatpay.weChatUnifiedOrder(openid, pay.pay_no,
  89. Formater.formatPriceShow(actual_amount))
  90. instance.pay = pay
  91. instance.save()
  92. commodity.stock -= count
  93. commodity.save()
  94. BizLog.objects.addnew(self.request.user, BizLog.INSERT,
  95. u'添加订单[%s],id=%d' % (instance.no, instance.id), request.data)
  96. return response_ok(data)
  97. except CustomError as e:
  98. return response_error(e.get_error_msg())
  99. except Exception as e:
  100. import traceback
  101. traceback.print_exc()
  102. return response_error(str(e))
  103. @action(methods=['post'], detail=True)
  104. def pay_order(self, request, pk):
  105. # 待付款订单付款
  106. openid = request.POST.get('openid')
  107. appid = request.POST.get('appid')
  108. data = {}
  109. try:
  110. instance = self.get_object()
  111. with transaction.atomic():
  112. total_amount = instance.total_amount
  113. if instance.status != Order.WAIT_PAY:
  114. raise CustomError('订单非待付款状态,禁止付款!')
  115. if instance.pay:
  116. pay_no = instance.pay.pay_no
  117. # 先查询订单状态
  118. checkRexponse = WeChatResponse(appid)
  119. total_fee = checkRexponse.orderquery(pay_no)
  120. if int(total_fee) == int(total_amount):
  121. wechatpay = WechatAppletPay(appid)
  122. data = wechatpay.weChatUnifiedOrder(openid, pay_no,
  123. Formater.formatPriceShow(total_amount))
  124. return response_ok(data)
  125. # 支付金额变动后,关闭原订单,重新发起支付
  126. instance.pay.payClosed()
  127. pay = Pay.wechatAppPay(self.request.user, total_amount)
  128. wechatpay = WechatAppletPay(appid)
  129. data = wechatpay.weChatUnifiedOrder(openid, pay.pay_no,
  130. Formater.formatPriceShow(total_amount))
  131. instance.pay = pay
  132. instance.save()
  133. return response_ok(data)
  134. except CustomError as e:
  135. return response_error(e.get_error_msg())
  136. except Exception as e:
  137. return response_error(str(e))
  138. class ExportOrderDictView(APIView):
  139. permission_classes = [isLogin]
  140. def get(self, request):
  141. queryset = Order.objects.filter(status=Order.FINISH).order_by('-student__classes_id',
  142. '-student__classes__grade_id')
  143. export_data = OrderResource().export(queryset)
  144. filename = attachment_save(export_data, '用户订单{}'.format(timezone.now().date()))
  145. return response_ok({'filename': filename})
  146. class WXGetCoupon(APIView):
  147. permission_classes = [isLogin]
  148. def get(self, request):
  149. commodity_id = request.GET.get('commodity')
  150. student_id = request.GET.get('student')
  151. commodity = Commodity.objects.filter(id=commodity_id).first()
  152. data = {
  153. 'coupon_name': '',
  154. 'coupon_amount': 0,
  155. }
  156. if not commodity:
  157. return response_ok(data)
  158. student = Student.objects.filter(id=student_id).first()
  159. coupons = Coupon.objects.filter(enable=True, begin_date__lte=timezone.now().date(),
  160. end_date__gte=timezone.now().date())
  161. for coupon in coupons:
  162. if coupon.category:
  163. categorys = coupon.category.split(',')
  164. if commodity.category and str(commodity.category.id) in categorys:
  165. data = {
  166. 'coupon_id': coupon.id,
  167. 'coupon_name': coupon.name,
  168. 'coupon_amount': Formater.formatPriceShow(coupon.amount),
  169. }
  170. return response_ok(data)
  171. if student and coupon.school:
  172. schools = coupon.school.split(',')
  173. if str(student.school.id) in schools:
  174. data = {
  175. 'coupon_id': coupon.id,
  176. 'coupon_name': coupon.name,
  177. 'coupon_amount': Formater.formatPriceShow(coupon.amount),
  178. }
  179. return response_ok(data)
  180. return response_ok(data)
  181. class ShoppingCartViewSet(CustomModelViewSet):
  182. permission_classes = [isLogin]
  183. queryset = ShoppingCart.objects.filter()
  184. serializer_class = ShoppingCartSerializer
  185. def filter_queryset(self, queryset):
  186. queryset = queryset.filter(create_user=self.request.user)
  187. return queryset
  188. @action(methods=['post'], detail=True)
  189. def modify_quantity(self, request, pk):
  190. quantity = self.request.POST.get('quantity')
  191. try:
  192. with transaction.atomic():
  193. instance = ShoppingCart.objects.filter(id=pk, create_user=self.request.user).first()
  194. if instance:
  195. instance.quantity = quantity
  196. instance.save()
  197. return response_ok()
  198. except CustomError as e:
  199. return response_error(e.get_error_msg())
  200. except Exception as e:
  201. traceback.print_exc()
  202. return response_error(str(e))
  203. @action(methods=['post'], detail=False)
  204. def del_shopping_carts(self, request):
  205. item = request.POST.get('ids').split(',')
  206. try:
  207. with transaction.atomic():
  208. ShoppingCart.objects.filter(id__in=item, create_user=self.request.user).delete()
  209. return response_ok()
  210. except CustomError as e:
  211. return response_error(e.get_error_msg())
  212. except Exception as e:
  213. traceback.print_exc()
  214. return response_error(str(e))
  215. class CouponViewSet(CustomModelViewSet):
  216. permission_classes = [isLogin]
  217. queryset = Coupon.objects.filter()
  218. serializer_class = CouponSerializer
  219. @permission_required('order.view_coupon')
  220. def filter_queryset(self, queryset):
  221. queryset = queryset.filter(create_user=self.request.user)
  222. return queryset