OrderPaySuccess.php 3.6 KB

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