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.
yanzong/app/common/model/PaymentTrade.php

106 lines
3.4 KiB

11 months 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;
}
}