GroupOrder.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. <?php
  2. namespace app\common\command;
  3. use think\facade\Db;
  4. use think\facade\Log;
  5. use think\console\Input;
  6. use think\console\Output;
  7. use think\console\Command;
  8. use app\common\enum\RefundEnum;
  9. use app\common\model\equity\UserEquity;
  10. use app\common\model\equity\EquityConfig;
  11. use app\common\model\refund\RefundRecord;
  12. use app\common\model\group_activity\GroupUserOrder;
  13. use app\common\model\group_activity\GroupOrder as GroupOrderModel;
  14. use app\common\logic\RefundLogic;
  15. /*
  16. ** 拼团订单,活动结束,校验是否拼团成功, 如果成功,则给用户发放权益卡,失败批量退款
  17. */
  18. class GroupOrder extends Command
  19. {
  20. protected function configure()
  21. {
  22. $this->setName('group_order')
  23. ->setDescription('拼团结束,发放权益卡或批量退款');
  24. }
  25. protected function execute(Input $input, Output $output)
  26. {
  27. //更新拼团结束的订单状态
  28. $this->updateGroupOrder();
  29. }
  30. /**
  31. * 更新拼团结束的订单状态
  32. */
  33. protected function updateGroupOrder()
  34. {
  35. $last_id = 0;
  36. while($last_id >= 0) {
  37. $list = GroupOrderModel::alias('a')
  38. ->leftJoin('group_activity b','a.group_activity_id=b.id')
  39. ->leftJoin('group_activity_category c','b.group_category_id=c.id')
  40. ->where('a.status',0)
  41. ->where('a.end_time','<',time())
  42. ->where('a.id','>',$last_id)
  43. ->field('a.id,a.num,a.equity_id,c.participant_num,c.is_simulate_form,c.simulate_num')
  44. ->order('a.id','asc')
  45. ->limit(30)
  46. ->select()->toArray();
  47. if (!$list) {
  48. $last_id = -1;
  49. break;
  50. }
  51. foreach($list as $item) {
  52. $last_id = $item['id'];
  53. $orderList = GroupUserOrder::where([
  54. 'group_order_id' => $item['id'],
  55. 'pay_status' => 1,
  56. 'status' => 1,
  57. 'refund_status' => 0,
  58. ])
  59. ->field('id,user_id,sn,remark,order_amount,pay_way,transaction_id,order_terminal')->order('id','asc')->select()->toArray();
  60. $num = count($orderList);
  61. if (($item['is_simulate_form'] == 1 && $num >= $item['simulate_num']) || ($item['is_simulate_form'] == 0 && $num >= $item['participant_num'])) {
  62. //模拟成团
  63. $this->gruopSuccess($item,$orderList);
  64. } else {
  65. //拼团失败
  66. $this->groupFail($item,$orderList);
  67. }
  68. }
  69. }
  70. }
  71. /**
  72. * 拼团成功(给已支付的用户发放权益卡)
  73. * @param $item
  74. */
  75. protected function gruopSuccess($order,$orderList)
  76. {
  77. $max_id = UserEquity::max('id');
  78. try {
  79. Db::startTrans();
  80. $equityConfig = EquityConfig::where('id',$order['equity_id'])->findOrEmpty()->toArray();
  81. foreach($orderList as $item) {
  82. //用户发放权益卡
  83. $max_id++;
  84. //创建用户权益卡
  85. $userEquity = UserEquity::create([
  86. 'user_id' => $item['user_id'],
  87. 'equity_id' => $order['equity_id'],
  88. 'goods_id' => $equityConfig['goods_id'],
  89. 'number' => $equityConfig['number'],
  90. 'create_time' => time(),
  91. 'end_time' => time() + $equityConfig['day_num'] * 86400,
  92. 'remark' => '拼团单id:'.$item['id'],
  93. 'code' => generateRandomString((8-strlen($max_id)),2).$max_id,
  94. ]);
  95. //更新用户拼团订单
  96. GroupUserOrder::where('id',$item['id'])->update(['user_equity_id' => $userEquity->id]);
  97. }
  98. //更新拼团订单
  99. GroupOrderModel::where('id',$order['id'])->update([
  100. 'status' => 1,
  101. 'num' => count($orderList)
  102. ]);
  103. Db::commit();
  104. } catch (\Exception $e) {
  105. Db::rollback();
  106. Log::error('拼团失败,批量退款失败:'.$e->getMessage());
  107. }
  108. }
  109. /*
  110. * 批量退款,关闭订单
  111. * @param $item
  112. */
  113. protected function groupFail($order,$list)
  114. {
  115. try {
  116. Db::startTrans();
  117. foreach($list as $item) {
  118. $remark = $item['remark'] ?? '';
  119. // 生成退款记录
  120. $recordSn = generate_sn(RefundRecord::class, 'sn');
  121. $record = RefundRecord::create([
  122. 'sn' => $recordSn,
  123. 'user_id' => $item['user_id'],
  124. 'order_id' => $item['id'],
  125. 'order_sn' => $item['sn'],
  126. 'order_type' => RefundEnum::ORDER_TYPE_GROUP,
  127. 'order_amount' => $item['order_amount'],
  128. 'refund_amount' => $item['order_amount'],
  129. 'refund_type' => RefundEnum::TYPE_ADMIN,
  130. 'transaction_id' => $item['transaction_id'] ?? '',
  131. 'refund_way' => RefundEnum::getRefundWayByPayWay($item['pay_way']),
  132. ]);
  133. // 退款
  134. $result = RefundLogic::refund($item, $record['id'], $item['order_amount'], 1);
  135. if ($result !== true) {
  136. //退款失败
  137. $remark .= RefundLogic::getError();
  138. GroupUserOrder::where('id',$item['id'])->update(['remark' => $remark]);
  139. } else {
  140. //退款成功
  141. GroupUserOrder::where('id',$item['id'])->update(['status' => 2,'refund_status' => 1]);
  142. }
  143. }
  144. //更新拼团订单
  145. GroupOrderModel::where('id',$order['id'])->update([
  146. 'status' => 2,
  147. 'num' => count($list)
  148. ]);
  149. Db::commit();
  150. } catch (\Exception $e) {
  151. Db::rollback();
  152. Log::error('拼团失败,批量退款失败:'.$e->getMessage());
  153. }
  154. }
  155. }