You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
106 lines
3.4 KiB
106 lines
3.4 KiB
1 year ago
|
<?php
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Copyright (c) 2017~2023 https://www.yiovo.com All rights reserved.
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Author: 萤火科技 <admin@yiovo.com>
|
||
|
// +----------------------------------------------------------------------
|
||
|
declare (strict_types=1);
|
||
|
|
||
|
namespace app\common\model;
|
||
|
|
||
|
use cores\BaseModel;
|
||
|
use cores\exception\BaseException;
|
||
|
use app\common\enum\payment\trade\TradeStatus as TradeStatusEnum;
|
||
|
|
||
|
/**
|
||
|
* 模型类:第三方支付交易记录
|
||
|
* Class PaymentTrade
|
||
|
* @package app\common\model
|
||
|
*/
|
||
|
class PaymentTrade extends BaseModel
|
||
|
{
|
||
|
// 定义表名
|
||
|
protected $name = 'payment_trade';
|
||
|
|
||
|
// 定义主键
|
||
|
protected $pk = 'trade_id';
|
||
|
|
||
|
/**
|
||
|
* 交易记录详情
|
||
|
* @param $where
|
||
|
* @return static|array|null
|
||
|
*/
|
||
|
public static function detail($where)
|
||
|
{
|
||
|
return self::get($where);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 查询第三方支付交易记录详情
|
||
|
* @param string $outTradeNo 交易订单号
|
||
|
* @return static|array|null
|
||
|
* @throws BaseException
|
||
|
*/
|
||
|
public static function detailByOutTradeNo(string $outTradeNo)
|
||
|
{
|
||
|
$detail = static::detail(['out_trade_no' => $outTradeNo]);
|
||
|
if (empty($detail)) {
|
||
|
throwError('第三方支付交易记录不存在');
|
||
|
}
|
||
|
return $detail;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 将第三方交易记录更新为已支付状态
|
||
|
* @param int $tradeId 交易记录ID
|
||
|
* @param string $tradeNo 第三方交易流水号
|
||
|
* @return bool
|
||
|
*/
|
||
|
public static function updateToPaySuccess(int $tradeId, string $tradeNo): bool
|
||
|
{
|
||
|
return static::updateOne([
|
||
|
'trade_no' => $tradeNo,
|
||
|
'trade_state' => TradeStatusEnum::SUCCESS
|
||
|
], $tradeId);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 将第三方交易记录更新为已退款状态
|
||
|
* @param int $tradeId 交易记录ID
|
||
|
* @return bool
|
||
|
*/
|
||
|
public static function updateToRefund(int $tradeId): bool
|
||
|
{
|
||
|
return static::updateOne(['trade_state' => TradeStatusEnum::REFUND], $tradeId);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 根据商户订单号查询记录
|
||
|
* @param int $orderId 订单ID
|
||
|
* @param int $orderType 订单类型
|
||
|
* @return \app\api\model\PaymentTrade|array|\think\Model|null
|
||
|
* @throws BaseException
|
||
|
* @throws \think\db\exception\DataNotFoundException
|
||
|
* @throws \think\db\exception\DbException
|
||
|
* @throws \think\db\exception\ModelNotFoundException
|
||
|
*/
|
||
|
protected function detailByOrderId(int $orderId, string $method, string $client, int $orderType)
|
||
|
{
|
||
|
$detail = $this->where('order_id', '=', $orderId)
|
||
|
->where('order_type', '=', $orderType)
|
||
|
->where('client', '=', $client)
|
||
|
->where('pay_method', '=', $method)
|
||
|
->find();
|
||
|
if (empty($detail)) {
|
||
|
return null;
|
||
|
}
|
||
|
if (in_array($detail['trade_state'], [TradeStatusEnum::SUCCESS, TradeStatusEnum::REFUND])) {
|
||
|
throwError('商户订单号 out_trade_no 已存在');
|
||
|
}
|
||
|
return $detail;
|
||
|
}
|
||
|
}
|