支付回调

This commit is contained in:
liu 2024-06-05 12:45:14 +08:00
parent f12b537d71
commit cf384e724e
5 changed files with 67 additions and 5 deletions

View File

@ -28,12 +28,9 @@ class PayController extends BaseApiController
{
$app = new PayService(1);
$result = $app->wechat->callback(Request()->post());
Cache::set('log'.time(),$result);
Cache::set('logJ'.time(),json_encode($result));
if ($result && $result->event_type == 'TRANSACTION.SUCCESS') {
$ciphertext = $result->resource['ciphertext'];
if ($ciphertext['trade_state'] === 'SUCCESS') {
$extra['transaction_id'] = $ciphertext['transaction_id'];
$attach = $ciphertext['attach'];
switch ($attach) {
case 'wechat_common':

View File

@ -130,7 +130,7 @@ class OrderController extends BaseApiController
case PayEnum::WECHAT_PAY:
//微信支付
$redirectUrl = $params['redirect'] ?? '/pages/payment/payment';
$result = PaymentLogic::pay($pay_type, 'StoreOrder', $order, $this->userInfo['terminal'], $redirectUrl);
$result = PaymentLogic::pay($pay_type, 'wechat_common', $order, $this->userInfo['terminal'], $redirectUrl);
if (PaymentLogic::hasError()) {
return $this->fail(PaymentLogic::getError(), $params);
}

View File

@ -53,6 +53,14 @@ class OrderEnum
*/
const IS_OK = 1;
/**
* 回调订单相关
* @PAY 支付
* @IBACK 退款
*/
const PAY = 1;
const BACK = 0;
/**
* 账户类型
* @USER 用户

View File

@ -4,6 +4,7 @@ namespace app\common\logic;
use app\common\enum\OrderEnum;
use app\common\enum\PayEnum;
use app\common\model\pay\PayNotify;
use app\common\model\store_finance_flow\StoreFinanceFlow;
use app\common\model\store_order\StoreOrder;
use app\common\model\user\User;
@ -97,7 +98,7 @@ class PayNotifyLogic extends BaseLogic
} else {
PushService::push('store_merchant_' . $order['id'], $order['id'], ['type' => 'store_merchant', 'msg' => '您有一笔新的订单']);
Redis::send('push-platform-print', ['order_id' => $order['id']], 60);
Db::name('order_middle')->insert(['c_order_id' => $order['id']]);
// Db::name('order_middle')->insert(['c_order_id' => $order['id']]);
}
if (!empty($extra['payer']['openid']) && $order->pay_type != 9) {
Redis::send('push-delivery', ['order_sn' => $order['order_id'], 'openid' => $extra['payer']['openid']], 5);
@ -105,6 +106,31 @@ class PayNotifyLogic extends BaseLogic
return true;
}
public static function store_order($orderSn, $extra = [])
{
$order = StoreOrder::where('order_id', $orderSn)->findOrEmpty();
if ($order->isEmpty() || $order->paid == PayEnum::ISPAID) {
return true;
}
if ($order->pay_type != 10) {
$order->pay_price = bcdiv($extra['amount']['payer_total'], 100, 2);
$order->paid = 1;
$order->pay_time = time();
$order->status = 1;
$order->save();
} else {
$extra['transaction_id'] = time();
}
if ($order->pay_type == 9) {
$order->status = 2;
}
self::afterPay($order);
return true;
}
/**
* 现金支付
*/
@ -179,4 +205,25 @@ class PayNotifyLogic extends BaseLogic
$financeLogic->save();
}
/**
* 回调日志
* @param $order
* @param $extra
* @return void
*/
public static function notifyLog($order,$extra)
{
$data = [
'pay_type'=>'wechat',
'type'=>OrderEnum::PAY,
'amount'=>$extra['amount']['payer_total'],//分
'order_sn'=>$order,
'out_trade_no'=>$extra['transaction_id'],
'attach'=>$extra['attach'],
'create_time'=>date('Y-m-d H:i:s',time()),
];
PayNotify::create($data);
}
}

View File

@ -0,0 +1,10 @@
<?php
namespace app\common\model\pay;
use app\common\model\BaseModel;
class PayNotify extends BaseModel
{
protected $name = 'pay_notify_log';
}