You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					159 lines
				
				5.2 KiB
			
		
		
			
		
	
	
					159 lines
				
				5.2 KiB
			| 
								 
											2 years ago
										 
									 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								namespace App\Http\Controllers;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								use App\CentralLogics\Helpers;
							 | 
						||
| 
								 | 
							
								use App\Models\Order;
							 | 
						||
| 
								 | 
							
								use Brian2694\Toastr\Facades\Toastr;
							 | 
						||
| 
								 | 
							
								use Illuminate\Http\Request;
							 | 
						||
| 
								 | 
							
								use Illuminate\Support\Facades\Config;
							 | 
						||
| 
								 | 
							
								use Illuminate\Support\Facades\DB;
							 | 
						||
| 
								 | 
							
								use Illuminate\Support\Facades\Redirect;
							 | 
						||
| 
								 | 
							
								use Illuminate\Support\Facades\Session;
							 | 
						||
| 
								 | 
							
								use Illuminate\Support\Facades\URL;
							 | 
						||
| 
								 | 
							
								use Illuminate\Support\Str;
							 | 
						||
| 
								 | 
							
								use PayPal\Api\Amount;
							 | 
						||
| 
								 | 
							
								use PayPal\Api\Item;
							 | 
						||
| 
								 | 
							
								use PayPal\Api\ItemList;
							 | 
						||
| 
								 | 
							
								use PayPal\Api\Payer;
							 | 
						||
| 
								 | 
							
								use PayPal\Api\Payment;
							 | 
						||
| 
								 | 
							
								use PayPal\Api\PaymentExecution;
							 | 
						||
| 
								 | 
							
								use PayPal\Api\RedirectUrls;
							 | 
						||
| 
								 | 
							
								use PayPal\Api\Transaction;
							 | 
						||
| 
								 | 
							
								use PayPal\Auth\OAuthTokenCredential;
							 | 
						||
| 
								 | 
							
								use PayPal\Common\PayPalModel;
							 | 
						||
| 
								 | 
							
								use PayPal\Rest\ApiContext;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class PaypalPaymentController extends Controller
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    public function __construct()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $paypal_conf = Config::get('paypal');
							 | 
						||
| 
								 | 
							
								        $this->_api_context = new ApiContext(new OAuthTokenCredential(
							 | 
						||
| 
								 | 
							
								                $paypal_conf['client_id'],
							 | 
						||
| 
								 | 
							
								                $paypal_conf['secret'])
							 | 
						||
| 
								 | 
							
								        );
							 | 
						||
| 
								 | 
							
								        $this->_api_context->setConfig($paypal_conf['settings']);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function payWithpaypal(Request $request)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $order = Order::with(['details','subscription'])->where(['id' => $request->order_id])->first();
							 | 
						||
| 
								 | 
							
								        $tr_ref = Str::random(6) . '-' . rand(1, 1000);
							 | 
						||
| 
								 | 
							
								        $quantity = $order->subscription ? $order->subscription->quantity : 1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $payer = new Payer();
							 | 
						||
| 
								 | 
							
								        $payer->setPaymentMethod('paypal');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $items_array = [];
							 | 
						||
| 
								 | 
							
								        $item = new Item();
							 | 
						||
| 
								 | 
							
								        $item->setName($order->customer['f_name'])
							 | 
						||
| 
								 | 
							
								            ->setCurrency(Helpers::currency_code())
							 | 
						||
| 
								 | 
							
								            ->setQuantity($quantity)
							 | 
						||
| 
								 | 
							
								            ->setPrice($order['order_amount']);
							 | 
						||
| 
								 | 
							
								        array_push($items_array, $item);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $item_list = new ItemList();
							 | 
						||
| 
								 | 
							
								        $item_list->setItems($items_array);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $amount = new Amount();
							 | 
						||
| 
								 | 
							
								        $amount->setCurrency(Helpers::currency_code())
							 | 
						||
| 
								 | 
							
								        ->setTotal($order['order_amount'] * $quantity);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        \session()->put('transaction_reference', $tr_ref);
							 | 
						||
| 
								 | 
							
								        $transaction = new Transaction();
							 | 
						||
| 
								 | 
							
								        $transaction->setAmount($amount)
							 | 
						||
| 
								 | 
							
								            ->setItemList($item_list)
							 | 
						||
| 
								 | 
							
								            ->setDescription($tr_ref);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $redirect_urls = new RedirectUrls();
							 | 
						||
| 
								 | 
							
								        $redirect_urls->setReturnUrl(URL::route('paypal-status'))
							 | 
						||
| 
								 | 
							
								        ->setCancelUrl(URL::route('payment-fail'));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $payment = new Payment();
							 | 
						||
| 
								 | 
							
								        $payment->setIntent('Sale')
							 | 
						||
| 
								 | 
							
								            ->setPayer($payer)
							 | 
						||
| 
								 | 
							
								            ->setRedirectUrls($redirect_urls)
							 | 
						||
| 
								 | 
							
								            ->setTransactions(array($transaction));
							 | 
						||
| 
								 | 
							
								        try {
							 | 
						||
| 
								 | 
							
								            $payment->create($this->_api_context);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            foreach ($payment->getLinks() as $link) {
							 | 
						||
| 
								 | 
							
								                if ($link->getRel() == 'approval_url') {
							 | 
						||
| 
								 | 
							
								                    $redirect_url = $link->getHref();
							 | 
						||
| 
								 | 
							
								                    break;
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            DB::table('orders')
							 | 
						||
| 
								 | 
							
								                ->where('id', $order->id)
							 | 
						||
| 
								 | 
							
								                ->update([
							 | 
						||
| 
								 | 
							
								                    'transaction_reference' => $payment->getId(),
							 | 
						||
| 
								 | 
							
								                    'payment_method' => 'paypal',
							 | 
						||
| 
								 | 
							
								                    'order_status' => 'failed',
							 | 
						||
| 
								 | 
							
								                    'failed' => now(),
							 | 
						||
| 
								 | 
							
								                    'updated_at' => now()
							 | 
						||
| 
								 | 
							
								                ]);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            Session::put('paypal_payment_id', $payment->getId());
							 | 
						||
| 
								 | 
							
								            if (isset($redirect_url)) {
							 | 
						||
| 
								 | 
							
								                return Redirect::away($redirect_url);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        } catch (\Exception $ex) {
							 | 
						||
| 
								 | 
							
								            Toastr::error(translate('messages.your_currency_is_not_supported',['method'=>translate('messages.paypal')]));
							 | 
						||
| 
								 | 
							
								            return back();
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        Session::put('error', translate('messages.config_your_account',['method'=>translate('messages.paypal')]));
							 | 
						||
| 
								 | 
							
								        return back();
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function getPaymentStatus(Request $request)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $payment_id = Session::get('paypal_payment_id');
							 | 
						||
| 
								 | 
							
								        if (empty($request['PayerID']) || empty($request['token'])) {
							 | 
						||
| 
								 | 
							
								            Session::put('error', translate('messages.payment_failed'));
							 | 
						||
| 
								 | 
							
								            return Redirect::back();
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $payment = Payment::get($payment_id, $this->_api_context);
							 | 
						||
| 
								 | 
							
								        $execution = new PaymentExecution();
							 | 
						||
| 
								 | 
							
								        $execution->setPayerId($request['PayerID']);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        /**Execute the payment **/
							 | 
						||
| 
								 | 
							
								        $result = $payment->execute($execution, $this->_api_context);
							 | 
						||
| 
								 | 
							
								        $order = Order::where('transaction_reference', $payment_id)->first();
							 | 
						||
| 
								 | 
							
								        if ($result->getState() == 'approved') {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            $order->transaction_reference = $payment_id;
							 | 
						||
| 
								 | 
							
								            $order->payment_method = 'paypal';
							 | 
						||
| 
								 | 
							
								            $order->payment_status = 'paid';
							 | 
						||
| 
								 | 
							
								            $order->order_status = 'confirmed';
							 | 
						||
| 
								 | 
							
								            $order->confirmed = now();
							 | 
						||
| 
								 | 
							
								            $order->save();
							 | 
						||
| 
								 | 
							
								            try {
							 | 
						||
| 
								 | 
							
								                Helpers::send_order_notification($order);
							 | 
						||
| 
								 | 
							
								            } catch (\Exception $e) {
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            if ($order->callback != null) {
							 | 
						||
| 
								 | 
							
								                return redirect($order->callback . '&status=success');
							 | 
						||
| 
								 | 
							
								            }else{
							 | 
						||
| 
								 | 
							
								                return \redirect()->route('payment-success');
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $order->order_status = 'failed';
							 | 
						||
| 
								 | 
							
								        $order->failed = now();
							 | 
						||
| 
								 | 
							
								        $order->save();
							 | 
						||
| 
								 | 
							
								        if ($order->callback != null) {
							 | 
						||
| 
								 | 
							
								            return redirect($order->callback . '&status=fail');
							 | 
						||
| 
								 | 
							
								        }else{
							 | 
						||
| 
								 | 
							
								            return \redirect()->route('payment-fail');
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |