| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247 | <?phpnamespace App\Http\Controllers\User;use App\Http\Controllers\Controller;use App\Http\Requests\User\OrderSave;use App\Models\Payment;use App\Services\CouponService;use App\Services\OrderService;use App\Services\PaymentService;use App\Services\UserService;use Illuminate\Http\Request;use Illuminate\Support\Facades\Cache;use Illuminate\Support\Facades\DB;use App\Models\Order;use App\Models\Plan;use App\Models\User;use App\Utils\Helper;use Omnipay\Omnipay;use Stripe\Stripe;use Stripe\Source;use Library\BitpayX;use Library\MGate;use Library\Epay;class OrderController extends Controller{    public function fetch(Request $request)    {        $model = Order::where('user_id', $request->session()->get('id'))            ->orderBy('created_at', 'DESC');        if ($request->input('status') !== null) {            $model->where('status', $request->input('status'));        }        $order = $model->get();        $plan = Plan::get();        for ($i = 0; $i < count($order); $i++) {            for ($x = 0; $x < count($plan); $x++) {                if ($order[$i]['plan_id'] === $plan[$x]['id']) {                    $order[$i]['plan'] = $plan[$x];                }            }        }        return response([            'data' => $order->makeHidden(['id', 'user_id'])        ]);    }    public function details(Request $request)    {        $order = Order::where('user_id', $request->session()->get('id'))            ->where('trade_no', $request->input('trade_no'))            ->first();        if (!$order) {            abort(500, __('Order does not exist or has been paid'));        }        $order['plan'] = Plan::find($order->plan_id);        $order['try_out_plan_id'] = (int)config('v2board.try_out_plan_id');        if (!$order['plan']) {            abort(500, __('Subscription plan does not exist'));        }        return response([            'data' => $order        ]);    }    public function save(OrderSave $request)    {        $userService = new UserService();        if ($userService->isNotCompleteOrderByUserId($request->session()->get('id'))) {            abort(500, __('You have an unpaid or pending order, please try again later or cancel it'));        }        $plan = Plan::find($request->input('plan_id'));        $user = User::find($request->session()->get('id'));        if (!$plan) {            abort(500, __('Subscription plan does not exist'));        }        if ($plan[$request->input('period')] === NULL) {            abort(500, __('This payment period cannot be purchased, please choose another period'));        }        if ($request->input('period') === 'reset_price') {            if ($user->expired_at <= time() || !$user->plan_id) {                abort(500, __('Subscription has expired or no active subscription, unable to purchase Data Reset Package'));            }        }        if ((!$plan->show && !$plan->renew) || (!$plan->show && $user->plan_id !== $plan->id)) {            if ($request->input('period') !== 'reset_price') {                abort(500, __('This subscription has been sold out, please choose another subscription'));            }        }        if (!$plan->renew && $user->plan_id == $plan->id && $request->input('period') !== 'reset_price') {            abort(500, __('This subscription cannot be renewed, please change to another subscription'));        }        if (!$plan->show && $plan->renew && !$userService->isAvailable($user)) {            abort(500, __('This subscription has expired, please change to another subscription'));        }        DB::beginTransaction();        $order = new Order();        $orderService = new OrderService($order);        $order->user_id = $request->session()->get('id');        $order->plan_id = $plan->id;        $order->period = $request->input('period');        $order->trade_no = Helper::generateOrderNo();        $order->total_amount = $plan[$request->input('period')];        if ($request->input('coupon_code')) {            $couponService = new CouponService($request->input('coupon_code'));            if (!$couponService->use($order)) {                DB::rollBack();                abort(500, __('Coupon failed'));            }            $order->coupon_id = $couponService->getId();        }        $orderService->setVipDiscount($user);        $orderService->setOrderType($user);        $orderService->setInvite($user);        if ($user->balance && $order->total_amount > 0) {            $remainingBalance = $user->balance - $order->total_amount;            $userService = new UserService();            if ($remainingBalance > 0) {                if (!$userService->addBalance($order->user_id, - $order->total_amount)) {                    DB::rollBack();                    abort(500, __('Insufficient balance'));                }                $order->balance_amount = $order->total_amount;                $order->total_amount = 0;            } else {                if (!$userService->addBalance($order->user_id, - $user->balance)) {                    DB::rollBack();                    abort(500, __('Insufficient balance'));                }                $order->balance_amount = $user->balance;                $order->total_amount = $order->total_amount - $user->balance;            }        }        if (!$order->save()) {            DB::rollback();            abort(500, __('Failed to create order'));        }        DB::commit();        return response([            'data' => $order->trade_no        ]);    }    public function checkout(Request $request)    {        $tradeNo = $request->input('trade_no');        $method = $request->input('method');        $order = Order::where('trade_no', $tradeNo)            ->where('user_id', $request->session()->get('id'))            ->where('status', 0)            ->first();        if (!$order) {            abort(500, __('Order does not exist or has been paid'));        }        // free process        if ($order->total_amount <= 0) {            $orderService = new OrderService($order);            if (!$orderService->paid($order->trade_no)) abort(500, '');            return response([                'type' => -1,                'data' => true            ]);        }        $payment = Payment::find($method);        if (!$payment || $payment->enable !== 1) abort(500, __('Payment method is not available'));        $paymentService = new PaymentService($payment->payment, $payment->id);        $result = $paymentService->pay([            'trade_no' => $tradeNo,            'total_amount' => $order->total_amount,            'user_id' => $order->user_id,            'stripe_token' => $request->input('token')        ]);        $order->update(['payment_id' => $method]);        return response([            'type' => $result['type'],            'data' => $result['data']        ]);    }    public function check(Request $request)    {        $tradeNo = $request->input('trade_no');        $order = Order::where('trade_no', $tradeNo)            ->where('user_id', $request->session()->get('id'))            ->first();        if (!$order) {            abort(500, __('Order does not exist'));        }        return response([            'data' => $order->status        ]);    }    public function getPaymentMethod()    {        $methods = Payment::select([            'id',            'name',            'payment',            'icon'        ])            ->where('enable', 1)->get();        return response([            'data' => $methods        ]);    }    public function cancel(Request $request)    {        if (empty($request->input('trade_no'))) {            abort(500, __('Invalid parameter'));        }        $order = Order::where('trade_no', $request->input('trade_no'))            ->where('user_id', $request->session()->get('id'))            ->first();        if (!$order) {            abort(500, __('Order does not exist'));        }        if ($order->status !== 0) {            abort(500, __('You can only cancel pending orders'));        }        $orderService = new OrderService($order);        if (!$orderService->cancel()) {            abort(500, __('Cancel failed'));        }        return response([            'data' => true        ]);    }}
 |