[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: Paypal.php
<?php namespace App\Http\PaymentGateways\Gateways; use App\Enums\Activity; use App\Models\Currency; use App\Models\PaymentGateway; use App\Services\PaymentAbstract; use Exception; use App\Services\PaymentService; use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\Log; use Smartisan\Settings\Facades\Settings; use Srmklive\PayPal\Services\PayPal as PayPalClient; class Paypal extends PaymentAbstract { public mixed $response; /** * @throws \Exception */ public function __construct() { $paymentService = new PaymentService(); parent::__construct($paymentService); $this->paymentGateway = PaymentGateway::with('gatewayOptions')->where(['slug' => 'paypal'])->first(); if (!blank($this->paymentGateway)) { $currencyCode = 'USD'; $currencyId = Settings::group('site')->get('site_default_currency'); if (!blank($currencyId)) { $currency = Currency::find($currencyId); if ($currency) { $currencyCode = $currency->code; } } $this->paymentGatewayOption = $this->paymentGateway->gatewayOptions->pluck('value', 'option'); $config = [ "mode" => $this->paymentGatewayOption['paypal_mode'] == '5' ? 'sandbox' : 'live', 'sandbox' => [ 'client_id' => $this->paymentGatewayOption['paypal_client_id'], 'client_secret' => $this->paymentGatewayOption['paypal_client_secret'], 'app_id' => $this->paymentGatewayOption['paypal_app_id'], ], 'live' => [ 'client_id' => $this->paymentGatewayOption['paypal_client_id'], 'client_secret' => $this->paymentGatewayOption['paypal_client_secret'], 'app_id' => $this->paymentGatewayOption['paypal_app_id'], ], "payment_action" => "Sale", "currency" => $currencyCode, "notify_url" => "", "locale" => "en_US", "validate_ssl" => true ]; $this->gateway = new PayPalClient($config); } } public function payment($order, $request) : \Illuminate\Http\RedirectResponse { try { $currencyCode = 'USD'; $currencyId = Settings::group('site')->get('site_default_currency'); if (!blank($currencyId)) { $currency = Currency::find($currencyId); if ($currency) { $currencyCode = $currency->code; } } $this->gateway->getAccessToken(); $response = $this->gateway->createOrder([ "intent" => "CAPTURE", "application_context" => [ "return_url" => route('payment.success', ['order' => $order, 'paymentGateway' => 'paypal']), "cancel_url" => route('payment.cancel', ['order' => $order, 'paymentGateway' => 'paypal']), ], "purchase_units" => [ 0 => [ "amount" => [ "currency_code" => $currencyCode, "value" => (float)$order->total ] ] ] ]); if (isset($response['id']) && $response['id'] != null) { foreach ($response['links'] as $links) { if ($links['rel'] == 'approve') { return redirect()->away($links['href']); } } return redirect()->route('payment.index', ['order' => $order, 'paymentGateway' => 'paypal'])->with( 'error', trans('all.message.something_wrong') ); } else { return redirect()->route('payment.index', ['order' => $order, 'paymentGateway' => 'paypal'])->with( 'error', $response['message'] ?? trans('all.message.something_wrong') ); } } catch (Exception $e) { Log::info($e->getMessage()); return redirect()->route('payment.index', ['order' => $order, 'paymentGateway' => 'paypal'])->with( 'error', $e->getMessage() ); } } public function status() : bool { $paymentGateways = PaymentGateway::where(['slug' => 'paypal', 'status' => Activity::ENABLE])->first(); if ($paymentGateways) { return true; } return false; } public function success($order, $request) : \Illuminate\Http\RedirectResponse { try { DB::transaction(function () use ($order, $request) { $this->gateway->getAccessToken(); $this->response = $this->gateway->capturePaymentOrder($request['token']); }); if (isset($this->response['status']) && $this->response['status'] == 'COMPLETED') { $this->paymentService->payment($order, 'paypal', $this->response['id']); return redirect()->route('payment.successful', ['order' => $order])->with( 'success', trans('all.message.payment_successful') ); } else { return redirect()->route('payment.fail', ['order' => $order, 'paymentGateway' => 'paypal'])->with( 'error', $this->response['message'] ?? trans('all.message.something_wrong') ); } } catch (Exception $e) { Log::info($e->getMessage()); DB::rollBack(); return redirect()->route('payment.fail', ['order' => $order, 'paymentGateway' => 'paypal'])->with( 'error', $e->getMessage() ); } } public function fail($order, $request) : \Illuminate\Http\RedirectResponse { return redirect()->route('payment.index', ['order' => $order])->with( 'error', trans('all.message.something_wrong') ); } public function cancel($order, $request) : \Illuminate\Http\RedirectResponse { return redirect()->route('home')->with('error', trans('all.message.payment_canceled')); } }
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: server1.winmanyltd.com
Server IP: 203.161.60.52
PHP Version: 8.3.27
Server Software: Apache
System: Linux server1.winmanyltd.com 4.18.0-553.22.1.el8_10.x86_64 #1 SMP Tue Sep 24 05:16:59 EDT 2024 x86_64
HDD Total: 117.98 GB
HDD Free: 59.86 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
Yes
git:
Yes
User Info
Username: eliosofonline
User ID (UID): 1002
Group ID (GID): 1003
Script Owner UID: 1002
Current Dir Owner: 1002