OrderPaySuccess.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <?php
  2. namespace App\Modules\Trade\Pay;
  3. use App\Modules\Book\Services\BookConfigService;
  4. use App\Modules\Subscribe\Models\Order;
  5. use DB;
  6. use App\Jobs\QappOrder;
  7. /**
  8. *
  9. */
  10. class OrderPaySuccess
  11. {
  12. /**
  13. * 支付成功回调处理订单
  14. * @param string $trade_no 订单号
  15. * @param string $transaction_id 微信商户号
  16. * @return bool
  17. */
  18. public static function handle(string $trade_no, string $transaction_id)
  19. {
  20. $order = Order::where('trade_no', $trade_no)->first();
  21. \Log::info('OrderPaySuccess_handle:trade_no:'.$trade_no.' transaction_id:'.$transaction_id);
  22. //订单跨天
  23. $is_change = self::orderAcrossDay($order);
  24. $order->transaction_id = $transaction_id;
  25. if ($order) {
  26. if ($order->status == 'PAID') {
  27. try {
  28. //添加异步任务队列
  29. $job = new QappOrder($trade_no);
  30. dispatch($job->onConnection('redis')->delay(30)->onQueue('{qapp_order_pay_success}'));
  31. } catch (Exception $e) {
  32. sendNotice($e->getMessage());
  33. }
  34. myLog('pay_notify')->info('has_pay:' . $trade_no);
  35. return true;
  36. }
  37. if ($order->order_type == 'YEAR') {
  38. $app = new YearOrderPaySuccess($order);
  39. } elseif ($order->order_type == 'BOOK') {
  40. $app = new BookOrderPaySuccess($order);
  41. } elseif ($order->order_type == 'QUARTER') {
  42. $app = new QuarterOrderPaySuccess($order);
  43. } elseif ($order->order_type == 'RECHARGE') {
  44. $app = new RechargeOrderPaySuccess($order);
  45. }
  46. $status = $app->success();
  47. if ($is_change) {
  48. DB::table('orders')->where('id', $order->id)->update([
  49. 'pay_end_at' => date('Y-m-d H:i:s', time() + 5),
  50. 'updated_at' => date('Y-m-d H:i:s', time() + 5),
  51. 'created_at' => date('Y-m-d H:i:s')
  52. ]);
  53. }
  54. self::freeBookStats($order->from_bid,$order->price,$order->uid);
  55. return $status;
  56. } else {
  57. return false;
  58. }
  59. }
  60. private static function freeBookStats($bid,$price,$uid){
  61. if(!$bid) return ;
  62. $free_book = BookConfigService::getByBidNoFilter($bid);
  63. if(!$free_book) return ;
  64. if(strtotime($free_book->end_time)+7*86400 < time()) return ;
  65. BookConfigService::chargeStats($free_book->id,$price,$uid);
  66. }
  67. private static function orderAcrossDay($order_info)
  68. {
  69. if (date('Y-m-d', strtotime($order_info->created_at)) == date('Y-m-d')) return false;
  70. $created_at = date('Y-m-d H:i:s', strtotime($order_info->created_at));
  71. $trade_no = $order_info->trade_no;
  72. $init_order = [
  73. 'distribution_channel_id' => $order_info->distribution_channel_id,
  74. 'uid' => $order_info->uid,
  75. 'product_id' => $order_info->product_id,
  76. 'price' => $order_info->price,
  77. 'pay_type' => $order_info->pay_type,
  78. 'trade_no' => 'cd-' . $trade_no,
  79. 'pay_merchant_source' => $order_info->pay_merchant_source,
  80. 'pay_merchant_id' => $order_info->pay_merchant_id,
  81. 'create_ip' => $order_info->create_ip,
  82. 'send_order_id' => $order_info->send_order_id,
  83. 'send_order_name' => $order_info->send_order_name,
  84. 'order_type' => $order_info->order_type,
  85. 'from_bid' => $order_info->from_bid,
  86. 'from_type' => $order_info->from_type,
  87. 'activity_id' => $order_info->activity_id,
  88. 'inner_send_order_id' => $order_info->inner_send_order_id,
  89. 'status' => 'UNPAID',
  90. 'transaction_id' => '',
  91. 'pay_end_at' => '0000-00-00 00:00:00',
  92. 'created_at' => $created_at,
  93. 'updated_at' => $created_at
  94. ];
  95. try {
  96. DB::table('orders')->insert($init_order);
  97. } catch (\Exception $e) {
  98. return false;
  99. }
  100. return true;
  101. }
  102. }