GroupOrder.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  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\WorkEnum;
  9. use app\common\enum\RefundEnum;
  10. use app\common\logic\RefundLogic;
  11. use app\common\model\equity\UserEquity;
  12. use app\common\model\equity\EquityConfig;
  13. use app\common\model\recharge\OrderGoods;
  14. use app\common\model\refund\RefundRecord;
  15. use app\common\model\equity\UserEquityLog;
  16. use app\common\model\works\GroupServiceWork;
  17. use app\common\model\group_activity\GroupUserOrder;
  18. use app\common\model\group_activity\GroupOrder as GroupOrderModel;
  19. /*
  20. ** 拼团订单,活动结束,校验是否拼团成功, 如果成功,则给用户发放权益卡,失败批量退款
  21. */
  22. class GroupOrder extends Command
  23. {
  24. protected function configure()
  25. {
  26. $this->setName('group_order')
  27. ->setDescription('拼团结束,发放权益卡或批量退款');
  28. }
  29. protected function execute(Input $input, Output $output)
  30. {
  31. //更新拼团结束的订单状态
  32. $this->updateGroupOrder();
  33. //生成拼团工单
  34. $this->createGroupServiceWork();
  35. }
  36. /**
  37. * 生成拼团工单
  38. */
  39. public function createGroupServiceWork()
  40. {
  41. $list = GroupOrderModel::where(['status' => 1, 'work_status' => 1])->limit(100)->column('id');
  42. foreach($list as $group_order_id) {
  43. $goods = [];
  44. $category = GroupOrderModel::alias('a')
  45. ->leftJoin('group_activity_category b','a.group_category_id=b.id')
  46. ->leftJoin('group_activity c','a.group_activity_id=c.id')
  47. ->where('a.id', $group_order_id)
  48. ->field('b.service_time,c.price,c.work_amount,c.settlement_amount')
  49. ->findOrEmpty()
  50. ->toArray();
  51. try {
  52. //查询拼团用户订单
  53. $userOrder = GroupUserOrder::alias('a')
  54. ->leftJoin('user b','a.user_id=b.id')
  55. ->where('group_order_id', $group_order_id)
  56. ->where('pay_status', 1)
  57. ->where('refund_status', 0)
  58. ->field('a.*,b.mobile')
  59. ->select()
  60. ->toArray();
  61. if (empty($userOrder)) {
  62. return true;
  63. }
  64. Db::startTrans();
  65. foreach ($userOrder as $k => $item) {
  66. if (empty($goods)) {
  67. $goods = UserEquity::alias('a')->leftJoin('goods b','a.goods_id=b.id')
  68. ->where('a.id', $item['user_equity_id'])
  69. ->field('a.number,a.goods_id,b.*')
  70. ->findOrEmpty()
  71. ->toArray();
  72. }
  73. //生成拼团服务工单
  74. $work_data = [
  75. 'work_sn' => generate_sn(GroupServiceWork::class, 'work_sn'),
  76. 'real_name' => '',
  77. 'mobile' => $item['mobile'],
  78. 'address' => $item['area'].$item['address'],
  79. 'title' => $goods['goods_name']."*".$item['num'],
  80. 'category_type' => $goods['category_type'],
  81. 'goods_category_ids' => $goods['goods_category_ids'],
  82. 'goods_category_id' => $goods['goods_category_id'],
  83. 'work_pay_status'=>WorkEnum::IS_PAY_STATUS,
  84. 'appointment_time' => $category['service_time'],
  85. 'user_id'=>$item['user_id'],
  86. 'user_equity_id'=>0,
  87. 'third_type'=>1,
  88. 'work_total'=>$item['paid_amount'],
  89. 'remark' => '拼团用户订单:'.$item['id'],
  90. 'user_equity_id' => $item['user_equity_id'],
  91. 'group_order_id' => $group_order_id,
  92. 'group_user_order_id' => $item['id'],
  93. 'work_total' => $category['price'],
  94. 'work_amount' => $category['work_amount'],
  95. 'settlement_amount' => $category['settlement_amount'],
  96. 'work_pay_status' => 2,
  97. ];
  98. $service_work = GroupServiceWork::create($work_data);
  99. //生成订单服务详情
  100. OrderGoods::create([
  101. 'sn' => $service_work['work_sn'],
  102. 'goods_id' => $goods['goods_id'],
  103. 'category_type' => $goods['category_type'],
  104. 'goods_category_ids' => $goods['goods_category_ids'],
  105. 'goods_category_id' => $goods['goods_category_id'],
  106. 'goods_name' => $goods['goods_name'],
  107. 'goods_image' => $goods['goods_image'],
  108. 'goods_video' => $goods['goods_video'],
  109. 'goods_number' => $goods['goods_number'],
  110. 'good_unit' => $goods['good_unit'],
  111. 'goods_size' => $goods['goods_size'],
  112. 'goods_type' => $goods['goods_type'],
  113. 'goods_brand' => $goods['goods_brand'],
  114. 'install_guide' => $goods['install_guide'],
  115. 'goods_payment_type'=>$goods['goods_payment_type'],
  116. 'base_service_fee' => $goods['base_service_fee'],
  117. 'service_total' => $goods['service_total'],
  118. 'service_fee' => $goods['service_fee'],
  119. 'service_image' => $goods['service_image'],
  120. 'warranty_period'=>$goods['warranty_period'],
  121. 'fee_schedule' => $goods['fee_schedule'],
  122. 'goods_status' => $goods['goods_status'],
  123. ]);
  124. //更新用户的权益卡剩余次数
  125. UserEquity::where('id', $item['user_equity_id'])->update(['number' => 0, 'update_time' => time()]);
  126. //记录用户的权益卡使用记录
  127. UserEquityLog::create([
  128. 'user_id' => $item['user_id'],
  129. 'number' => $goods['number'],
  130. 'user_equity_id' => $item['user_equity_id'],
  131. 'create_time' => time(),
  132. ]);
  133. }
  134. GroupOrderModel::where('id', $group_order_id)->update(['work_status' => 2]);
  135. Db::commit();
  136. return true;
  137. } catch (\Exception $e) {
  138. Db::rollback();
  139. Log::write("拼团订单批量生成服务工单异常:".$e->getMessage());
  140. return false;
  141. }
  142. }
  143. }
  144. /**
  145. * 更新拼团结束的订单状态
  146. */
  147. protected function updateGroupOrder()
  148. {
  149. $last_id = 0;
  150. while($last_id >= 0) {
  151. $list = GroupOrderModel::alias('a')
  152. ->leftJoin('group_activity_category b','a.group_category_id=b.id')
  153. ->where('a.status',0)
  154. ->where('a.end_time','<',time())
  155. ->where('a.id','>',$last_id)
  156. ->field('a.id,a.num,a.equity_id,b.participant_num,b.is_simulate_form,b.simulate_num')
  157. ->order('a.id','asc')
  158. ->limit(30)
  159. ->select()->toArray();
  160. if (!$list) {
  161. $last_id = -1;
  162. break;
  163. }
  164. foreach($list as $item) {
  165. $last_id = $item['id'];
  166. $orderList = GroupUserOrder::where([
  167. 'group_order_id' => $item['id'],
  168. 'pay_status' => 1,
  169. 'status' => 1,
  170. 'refund_status' => 0,
  171. ])
  172. ->field('id,user_id,sn,remark,order_amount,pay_way,transaction_id,order_terminal')->order('id','asc')->select()->toArray();
  173. $num = count($orderList);
  174. if (($item['is_simulate_form'] == 1 && $num >= $item['simulate_num']) || ($item['is_simulate_form'] == 0 && $num >= $item['participant_num'])) {
  175. //模拟成团
  176. $this->gruopSuccess($item,$orderList);
  177. } else {
  178. //拼团失败
  179. $this->groupFail($item,$orderList);
  180. }
  181. }
  182. }
  183. }
  184. /**
  185. * 拼团成功(给已支付的用户发放权益卡)
  186. * @param $item
  187. */
  188. protected function gruopSuccess($order,$orderList)
  189. {
  190. $max_id = UserEquity::max('id');
  191. try {
  192. Db::startTrans();
  193. $equityConfig = EquityConfig::where('id',$order['equity_id'])->findOrEmpty()->toArray();
  194. foreach($orderList as $item) {
  195. //用户发放权益卡
  196. $max_id++;
  197. //创建用户权益卡
  198. $userEquity = UserEquity::create([
  199. 'user_id' => $item['user_id'],
  200. 'equity_id' => $order['equity_id'],
  201. 'goods_id' => $equityConfig['goods_id'],
  202. 'number' => $equityConfig['number'],
  203. 'create_time' => time(),
  204. 'end_time' => time() + $equityConfig['day_num'] * 86400,
  205. 'remark' => '拼团单id:'.$item['id'],
  206. 'code' => generateRandomString((8-strlen($max_id)),2).$max_id,
  207. ]);
  208. //更新用户拼团订单
  209. GroupUserOrder::where('id',$item['id'])->update(['user_equity_id' => $userEquity->id]);
  210. }
  211. //更新拼团订单
  212. GroupOrderModel::where('id',$order['id'])->update([
  213. 'status' => 1,
  214. 'num' => count($orderList)
  215. ]);
  216. Db::commit();
  217. } catch (\Exception $e) {
  218. Db::rollback();
  219. Log::error('拼团失败,批量退款失败:'.$e->getMessage());
  220. }
  221. }
  222. /*
  223. * 批量退款,关闭订单
  224. * @param $item
  225. */
  226. protected function groupFail($order,$list)
  227. {
  228. try {
  229. Db::startTrans();
  230. foreach($list as $item) {
  231. $remark = $item['remark'] ?? '';
  232. // 生成退款记录
  233. $recordSn = generate_sn(RefundRecord::class, 'sn');
  234. $record = RefundRecord::create([
  235. 'sn' => $recordSn,
  236. 'user_id' => $item['user_id'],
  237. 'order_id' => $item['id'],
  238. 'order_sn' => $item['sn'],
  239. 'order_type' => RefundEnum::ORDER_TYPE_GROUP,
  240. 'order_amount' => $item['order_amount'],
  241. 'refund_amount' => $item['order_amount'],
  242. 'refund_type' => RefundEnum::TYPE_ADMIN,
  243. 'transaction_id' => $item['transaction_id'] ?? '',
  244. 'refund_way' => RefundEnum::getRefundWayByPayWay($item['pay_way']),
  245. ]);
  246. // 退款
  247. $result = RefundLogic::refund($item, $record['id'], $item['order_amount'], 1);
  248. if ($result !== true) {
  249. //退款失败
  250. $remark .= RefundLogic::getError();
  251. GroupUserOrder::where('id',$item['id'])->update(['remark' => $remark]);
  252. } else {
  253. //退款成功
  254. GroupUserOrder::where('id',$item['id'])->update(['status' => 2,'refund_status' => 2]);
  255. }
  256. }
  257. //更新拼团订单
  258. GroupOrderModel::where('id',$order['id'])->update([
  259. 'status' => 2,
  260. 'num' => count($list)
  261. ]);
  262. Db::commit();
  263. } catch (\Exception $e) {
  264. Db::rollback();
  265. Log::error('拼团失败,批量退款失败:'.$e->getMessage());
  266. }
  267. }
  268. }