| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190 |
- <?php
- /**
- * Created by PhpStorm.
- * Author: 芸众商城 www.yunzshop.com
- * Date: 2017/2/24
- * Time: 下午4:35
- */
- namespace app\frontend\modules\order\services;
- use app\backend\modules\order\services\OrderPackageService;
- use app\common\events\payment\ChargeComplatedEvent;
- use app\common\events\payment\RechargeComplatedEvent;
- use app\common\exceptions\AppException;
- use app\common\exceptions\ShopException;
- use app\common\facades\Setting;
- use app\common\models\DispatchType;
- use app\common\models\Order;
- use app\common\models\order\Express;
- use app\common\models\order\OrderGoodsChangePriceLog;
- use app\common\models\order\OrderPackage;
- use app\common\models\PayOrder;
- use app\common\modules\orderGoods\OrderGoodsCollection;
- use \app\common\models\MemberCart;
- use app\common\repositories\ExpressCompany;
- use app\common\services\CreateRandomNumber;
- use app\frontend\models\OrderGoods;
- use app\frontend\modules\order\services\behavior\OrderCancelPay;
- use app\frontend\modules\order\services\behavior\OrderCancelSend;
- use app\frontend\modules\order\services\behavior\OrderChangePrice;
- use app\frontend\modules\order\services\behavior\OrderClose;
- use app\frontend\modules\order\services\behavior\OrderDelete;
- use app\frontend\modules\order\services\behavior\OrderForceClose;
- use app\frontend\modules\order\services\behavior\OrderOperation;
- use app\frontend\modules\order\services\behavior\OrderPay;
- use app\frontend\modules\order\services\behavior\OrderReceive;
- use app\frontend\modules\order\services\behavior\OrderSend;
- use app\frontend\modules\orderGoods\models\PreOrderGoods;
- use app\frontend\modules\orderGoods\models\PreOrderGoodsCollection;
- use Carbon\Carbon;
- use Illuminate\Support\Collection;
- use Illuminate\Support\Facades\DB;
- use Illuminate\Support\Facades\Redis;
- use Yunshop\ClockIn\models\ClockPayLogModel;
- use Yunshop\Gold\frontend\services\RechargeService;
- class OrderPaySuccessService
- {
- /** 支付方式
- *
- * @param $order_id
- * @return string
- */
- public function getPayType($order_id)
- {
- if (!empty($order_id)) {
- $tag = substr($order_id, 0, 2);
- if ('PN' == strtoupper($tag)) {
- return 'charge.succeeded';
- } elseif ('RV' == strtoupper($tag) || "RF" == strtoupper($tag) || "RL" == strtoupper($tag) || "KA" == strtoupper($tag) || "RI" == strtoupper($tag) || "RS" == strtoupper($tag) || "RI" == strtoupper($tag)) {
- return 'recharge.succeeded';
- } elseif ('RG' == strtoupper($tag)) {
- return 'gold_recharge.succeeded';
- } elseif ('CI' == strtoupper($tag)) {
- return 'card_charge.succeeded';
- } elseif ('DS' == strtoupper($tag) || "PG" == strtoupper($tag)) {
- return 'dashang_charge.succeeded';
- }
- }
- return '';
- }
- protected function _payResutl($data)
- {
- $type = $this->getPayType($data['out_trade_no']);
- $pay_order_model = PayOrder::getPayOrderInfo($data['out_trade_no'])->first();
- if ($pay_order_model) {
- $pay_order_model->status = 2;
- $pay_order_model->trade_no = $data['trade_no'];
- $pay_order_model->third_type = $data['pay_type'];
- $pay_order_model->save();
- }
- switch ($type) {
- case "charge.succeeded":
- \Log::debug("{$data['out_trade_no']}支付操作", ['charge.succeeded']);
- $orderPay = \app\common\models\OrderPay::where('pay_sn', $data['out_trade_no'])->orderBy('id', 'desc')->first();
- if ($data['unit'] == 'fen') {
- $orderPay->amount = $orderPay->amount * 100;
- }
- if (bccomp($orderPay->amount, $data['total_fee'], 2) == 0) {
- \Log::debug('更新订单状态');
- OrderService::ordersPay(['order_pay_id' => $orderPay->id, 'pay_type_id' => $data['pay_type_id']]);
- event(new ChargeComplatedEvent([
- 'order_sn' => $data['out_trade_no'],
- 'pay_sn' => $data['trade_no'],
- 'order_pay_id' => $orderPay->id
- ]));
- } else {
- \Log::debug("金额校验失败", "{$orderPay->amount}不等于{$data['total_fee']}");
- throw new ShopException("金额校验失败:{$orderPay->amount}不等于{$data['total_fee']}");
- }
- break;
- case "recharge.succeeded":
- \Log::debug('支付操作', ['recharge.succeeded', $data['out_trade_no']]);
- //充值成功事件
- event(new RechargeComplatedEvent([
- 'order_sn' => $data['out_trade_no'],
- 'pay_sn' => $data['trade_no'],
- 'total_fee' => $data['total_fee'],
- 'unit' => $data['unit']
- ]));
- break;
- case "gold_recharge.succeeded":
- \Log::debug('金币支付操作', ['gold_recharge.succeeded', $data['out_trade_no']]);
- RechargeService::payResult([
- 'order_sn' => $data['out_trade_no'],
- 'pay_sn' => $data['trade_no'],
- 'total_fee' => $data['total_fee']
- ]);
- //充值成功事件
- event(new RechargeComplatedEvent([
- 'order_sn' => $data['out_trade_no'],
- 'pay_sn' => $data['trade_no'],
- 'total_fee' => $data['total_fee']
- ]));
- break;
- case "card_charge.succeeded":
- \Log::debug('打卡支付操作', ['card_charge.succeeded', $data['out_trade_no']]);
- $orderPay = ClockPayLogModel::where('order_sn', $data['out_trade_no'])->first();
- if ($data['unit'] == 'fen') {
- $orderPay->amount = $orderPay->amount * 100;
- }
- if (bccomp($orderPay->amount, $data['total_fee'], 2) == 0) {
- \Log::debug('更新订单状态');
- event(new ChargeComplatedEvent([
- 'order_sn' => $data['out_trade_no'],
- 'pay_sn' => $data['trade_no'],
- 'total_fee' => $data['total_fee']
- ]));
- }
- break;
- case "dashang_charge.succeeded":
- \Log::debug('打赏支付操作', ['dashang_charge.succeeded', $data['out_trade_no']]);
- event(new ChargeComplatedEvent([
- 'order_sn' => $data['out_trade_no'],
- 'pay_sn' => '',
- 'unit' => $data['unit'],
- 'total_fee' => $data['total_fee']
- ]));
- break;
- }
- }
- /**
- * 支付回调操作
- * @param $data
- */
- public function payResutl($data)
- {
- try {
- $this->_payResutl($data);
- return ['result' => 1, 'msg' => '成功', 'data' => []];
- } catch (\Exception $e) {
- $msg = $e->getMessage();
- \Log::debug('回调失败:', $msg);
- return ['result' => 0, 'msg' => $msg, 'data' => []];
- }
- }
- }
|