lockForUpdate()->first(); return $this->handleSuccess($payLog, $params); } /** * 处理支付成功业务 * * @param \App\Models\PayLog $payLog * @param array $params * @return \App\Models\PayLog * * @throws \App\Exceptions\BizException */ public function handleSuccess(PayLog $payLog, array $params = []): PayLog { if (! $payLog->isPending()) { throw new BizException('支付记录状态异常'); } $payLog->update([ 'pay_at' => $params['pay_at'] ?? now(), 'out_trade_no' => $params['out_trade_no'] ?? null, 'status' => PayLog::STATUS_SUCCESS, ]); if ($payLog->payable instanceof Order) { $order = $payLog->payable; if ($order->isPaid()) { throw new BizException('订单已支付'); } if ($order->isCompleted()) { throw new BizException('订单已完成'); } // 支付方式 $payWay = $payLog->pay_way; if ($payLog->isWxpay()) { $payWay = Order::PAY_WAY_WXPAY; } $order->update([ 'pay_sn' => $payLog->pay_sn, 'pay_way' => $payWay, 'pay_at' => $payLog->pay_at, 'out_trade_no' => $payLog->out_trade_no, 'status' => Order::STATUS_PAID, ]); DistributionPreIncomeJob::create([ 'jobable_id' => $order->id, 'jobable_type' => $order->getMorphClass(), 'remarks' => '支付订单', ]); } return $payLog; } /** * 根据支付流水号处理支付失败业务 * * @param string $sn * @param array $params * @return \App\Models\PayLog * * @throws \App\Exceptions\BizException */ public function handleFailedByPaySerialNumber(string $paySerialNumber, array $params = []): PayLog { $payLog = PayLog::where('pay_sn', $paySerialNumber)->lockForUpdate()->first(); return $this->handleFailed($payLog, $params); } /** * 处理支付失败业务 * * @param \App\Models\PayLog $payLog * @param array $params * @return \App\Models\PayLog * * @throws \App\Exceptions\BizException */ public function handleFailed(PayLog $payLog, array $params = []): PayLog { if (! $payLog->isPending()) { throw new BizException('支付记录状态异常'); } $payLog->update([ 'out_trade_no' => $params['out_trade_no'] ?? null, 'status' => PayLog::STATUS_FAILED, 'failed_reason' => $params['failed_reason'] ?? null, ]); return $payLog; } }