| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 | <?phpnamespace app\admin\controller\notify;use app\admin\service\notify\RechargeService;use app\model\Member;use app\model\MemberAccount;use app\model\PayDetail;use support\Db;use support\exception\BusinessException;use support\Request;class RechargeController{    /**     * @Desc 计划任务     * @Author Gorden     * @Date 2024/5/29 11:31     *     * @return void     */    public function disposePaySuccess()    {//        $unix = strtotime(date("Y-m-d H:i",strtotime("-1 minute")).':00');        $payDetails = PayDetail::where('pay_category', 'RECHARGE')            ->where('pay_status', 'SUCCESS')            ->where(function ($query) {                $query->whereRaw("JSON_EXTRACT(`pay_extend_json`, '$.notify') IS NULL")                    ->orWhereJsonDoesntContain('pay_extend_json->notify', 'success');            })            ->get()            ->toArray();        if (!$payDetails) {            return;        }        foreach ($payDetails as $payDetail) {            $this->paySuccess($payDetail['pay_id']);        }    }//    public function paySuccess(Request $request)//    {//        $id = $request->post('pay_id', null);    public function paySuccess($id)    {        if (!$id) {            return json_fail('参数异常');        }        $payDetail = PayDetail::find($id);        if ($payDetail->pay_status != 'SUCCESS') {            return json_fail("支付状态异常");        }        $extendJson = [];        if (!empty($payDetail->pay_extend_json)) {            $extendJson = json_decode($payDetail->pay_extend_json, true);            if (isset($extendJson['notify']) && $extendJson['notify'] == 'success') {                return json_success('处理完成');            }        }        try {            Db::beginTransaction();            $extendJson['notify'] = 'success';            $payDetail->pay_extend_json = json_encode($extendJson);            $payDetail->save();            // 赠送比例            $addedNbr = RechargeService::disposeOrder($payDetail->join_pay_order_id);            // 赠送金额累加到 账户表 member_account_added            MemberAccount::where('join_account_member_id', $payDetail->join_pay_member_id)                ->where('member_account_classify', 'CASH')                ->increment('member_account_added', $payDetail->pay_amount * $addedNbr);            MemberAccount::where('join_account_member_id', $payDetail->join_pay_member_id)                ->where('member_account_classify', 'CASH')                ->increment('member_account_income', floatval($payDetail->pay_amount));            // 根据最新的数据,更新用户等级            $member = Member::find($payDetail->join_pay_member_id);            $roleId = RechargeService::disposeRole($payDetail->join_pay_member_id, $payDetail->pay_amount);            if ($roleId && $member->join_member_role_id != $roleId) {                $member->join_member_role_id = $roleId;                $member->save();                // 处理增值套包、组件                RechargeService::disposeAdded($roleId, $payDetail->join_pay_member_id);            }            Db::commit();            return json_success('success');        } catch (BusinessException $e) {            dump($e->getMessage());            Db::rollBack();            return json_fail('处理失败');        } catch (\Exception $e) {            dump($e->getMessage());            Db::rollBack();            return json_fail('处理失败');        }    }}
 |