FinishAccountListeners.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <?php
  2. namespace App\Listeners;
  3. use App\Events\FinishAccount;
  4. use App\Models\Amount;
  5. use App\Models\OrderW;
  6. use App\Models\Store;
  7. use App\Models\OrderFinishFailsW;
  8. use App\Handlers\SignHandler;
  9. use App\Models\User;
  10. use Illuminate\Contracts\Queue\ShouldQueue;
  11. use Illuminate\Http\Request;
  12. use Illuminate\Queue\InteractsWithQueue;
  13. use Illuminate\Support\Facades\Auth;
  14. use Illuminate\Support\Facades\DB;
  15. use Illuminate\Support\Facades\Log;
  16. class FinishAccountListeners
  17. {
  18. /**
  19. * Create the event listener.
  20. *
  21. * @return void
  22. */
  23. public function __construct()
  24. {
  25. }
  26. /**
  27. * Handle the event.
  28. *
  29. * @param FinishAccount $event
  30. * @return void
  31. */
  32. public function handle(FinishAccount $event)
  33. {
  34. $order_no=$event->data;
  35. Log::info('订单:'.$order_no.'开始分账完结');
  36. $order=OrderW::where('order_no',$order_no)->first();
  37. if($order->apply_cancel==2){
  38. Log::info($order->order_no.'订单已取消,不能完结订单。');
  39. exit;
  40. }
  41. $sub_mchid = Store::where('id',$order->store_id)->value('sub_mchid');
  42. $url='https://api.mch.weixin.qq.com/v3/ecommerce/profitsharing/finish-order';//地址
  43. $merchant_id=config('wechat.payment.default.mch_id');//商户号
  44. $serial_no=config('wechat.payment.default.serial_no');//不是平台证书序列号
  45. $handler=new SignHandler();
  46. $mch_private_key=$handler->getPublicKey();//读取商户api证书公钥 getPublicKey()获取方法 见下文
  47. $timestamp=time();//时间戳
  48. $nonce=$handler->nonce_str();//随机字符串
  49. $data=[
  50. 'sub_mchid' => $sub_mchid,
  51. 'transaction_id'=> $order->wechat_pay_no,//微信支付单号
  52. 'out_order_no' =>'WJ'.substr($order->order_no,2),//订单号
  53. 'description' =>'分账完结',
  54. ];
  55. $sign=$handler->sign($url,'POST',$timestamp,$nonce,json_encode($data),$mch_private_key,$merchant_id,$serial_no);//签名
  56. $header=[
  57. 'Authorization:WECHATPAY2-SHA256-RSA2048 ' . $sign,
  58. 'Accept:application/json',
  59. 'User-Agent:' . $merchant_id,
  60. 'Content-Type:application/json',
  61. 'Wechatpay-Serial:' . $handler->getzhengshu()//获取平台证书序列号
  62. ];
  63. $result=$handler->curl($url,json_encode($data),$header);
  64. Log::info($result);
  65. $result=json_decode($result,true);
  66. if(isset($result['order_id']) && !empty($result['order_id'])){
  67. Log::info('分账完结成功');
  68. DB::transaction(function()use($order,$result) {
  69. OrderW::where('order_no',$order->order_no)->update(['is_finish'=>1,'finish_no'=>$result['order_id']]);
  70. $total_fee=round($order->pay_money*(1-0.006),2);
  71. // $total_fee=$order->pay_money;
  72. //店铺信息
  73. $store = Store::where('id', $order->store_id)->lockForUpdate()->first();
  74. $start_amount = $store->available_amount;
  75. $store->available_amount += $total_fee;
  76. $start_money = $store->pending_amount;
  77. $store->pending_amount -= $order->pay_money;
  78. $store->save();
  79. Amount::create([
  80. 'user_id' => $order->user_id,
  81. 'store_id' => $order->store_id,
  82. 'order_no' => 'WJ'.substr($order->order_no,2),
  83. 'transaction_id' => $order->wechat_pay_no,
  84. 'money' => $order->pay_money,
  85. 'type' => 2, //结账
  86. 'status' => 1, //成功
  87. 'service_fee' => $order->pay_money-$total_fee,
  88. 'start_money' => $start_money,//结账前冻结金额
  89. 'end_money' => $store->pending_amount,//结账后冻结金额
  90. 'start_amount' => $start_amount,//结账前可用金额
  91. 'end_amount' => $store->available_amount,//结账后可用金额
  92. 'remark' => '到账',
  93. ]);
  94. OrderFinishFailsW::where('order_no',$order->order_no)->update([
  95. 'status'=>1
  96. ]);
  97. },5);
  98. Log::info('订单:'.$order_no.'分账完结成功');
  99. }else{
  100. Log::info('分账完结失败,记录失败订单');
  101. $finish_fails=OrderFinishFailsW::where('order_no',$order->order_no)->where('status',0)->first();
  102. if(empty($finish_fails)){
  103. OrderFinishFailsW::create([
  104. 'order_no'=>$order->order_no,
  105. 'store_id'=>$order->store_id,
  106. 'code'=>$result['code'],
  107. 'message'=>$result['message'],
  108. 'status'=>0,
  109. ]);
  110. }
  111. }
  112. }
  113. }