<?php

namespace App\Http\Controllers\Gateway;

use Auth;
use Exception;
use Illuminate\Http\JsonResponse;
use InvalidArgumentException;
use Log;
use Payment\Client;
use Payment\Exceptions\ClassNotFoundException;
use Response;

class F2Fpay extends AbstractPayment
{
    private static $aliConfig;

    public function __construct()
    {
        self::$aliConfig = [
            'use_sandbox'     => false,
            'app_id'          => sysConfig('f2fpay_app_id'),
            'sign_type'       => 'RSA2',
            'ali_public_key'  => sysConfig('f2fpay_public_key'),
            'rsa_private_key' => sysConfig('f2fpay_private_key'),
            'limit_pay'       => [],
            'notify_url'      => route('payment.notify', ['method' => 'f2fpay']),
            'return_url'      => route('invoice'),
            'fee_type'        => 'CNY',
        ];
    }

    public function purchase($request): JsonResponse
    {
        $payment = $this->creatNewPayment(Auth::id(), $request->input('id'), $request->input('amount'));

        $data = [
            'body'        => '',
            'subject'     => sysConfig('subject_name') ?: sysConfig('website_name'),
            'trade_no'    => $payment->trade_no,
            'time_expire' => time() + 900, // 必须 15分钟 内付款
            'amount'      => $payment->amount,
        ];

        try {
            $result = (new Client(Client::ALIPAY, self::$aliConfig))->pay(Client::ALI_CHANNEL_QR, $data);
        } catch (InvalidArgumentException $e) {
            Log::error('【支付宝当面付】输入信息错误: '.$e->getMessage());
            exit;
        } catch (ClassNotFoundException $e) {
            Log::error('【支付宝当面付】未知类型: '.$e->getMessage());
            exit;
        } catch (Exception $e) {
            Log::error('【支付宝当面付】错误: '.$e->getMessage());
            exit;
        }

        $payment->update(['qr_code' => 1, 'url' => $result['qr_code']]);

        return Response::json(['status' => 'success', 'data' => $payment->trade_no, 'message' => '创建订单成功!']);
    }

    public function notify($request): void
    {
        $data = [
            'trade_no'       => $request->input('out_trade_no'),
            'transaction_id' => $request->input('trade_no'),
        ];

        try {
            $result = (new Client(Client::ALIPAY, self::$aliConfig))->tradeQuery($data);
            Log::info('【支付宝当面付】回调验证查询:'.var_export($result, true));
        } catch (InvalidArgumentException $e) {
            Log::error('【支付宝当面付】回调信息错误: '.$e->getMessage());
            exit;
        } catch (ClassNotFoundException $e) {
            Log::error('【支付宝当面付】未知类型: '.$e->getMessage());
            exit;
        } catch (Exception $e) {
            Log::error('【支付宝当面付】错误: '.$e->getMessage());
            exit;
        }

        if ($result['code'] == 10000 && $result['msg'] === 'Success') {
            if (($_POST['trade_status'] === 'TRADE_FINISHED' || $_POST['trade_status'] === 'TRADE_SUCCESS') && $request->has('out_trade_no')) {
                if ($this->paymentReceived($request->input('out_trade_no'))) {
                    exit('success');
                }
            } else {
                Log::info('支付宝当面付-POST:交易失败');
            }
        } else {
            Log::info('支付宝当面付-POST:验证失败');
        }

        // 返回验证结果
        exit('fail');
    }
}