Viewing file: StripePayment.php (2.91 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace Modules\PaymentGateway\PaymentGatewayProvider;
use App\Models\BillingRequest; use App\Models\Deposit; use Illuminate\Support\Facades\Log;
class StripePayment implements PaymentInterface { public $planReq; public $redirect_url; public $error_message; public $return_view; public $will_redirect = false;
public function __construct() {
}
public function pay() { // TODO: Implement pay() method. }
public function deposit($deposit){ $this->deposit = $deposit; return $this; }
public function getCredentials() { $credentials = json_decode(get_settings('payment_gateway')); if (!$credentials->stripe_pub_key || !$credentials->stripe_secret_key) { throw new \Exception('Credentials not found. Please contact with the administrator'); } return $credentials; }
public function request($request) { $this->request = $request; return $this; }
public function plan($plan) { $this->plan = $plan; return $this; }
public function will_redirect() { // TODO: Implement will_redirect() method. return $this->will_redirect; }
public function redirect_url() { // TODO: Implement redirect_url() method. return $this->redirect_url; }
public function return_view() { // TODO: Implement redirect_url() method. return $this->return_view; }
public function error_message() { // TODO: Implement error_message() method. return $this->error_message; }
public function process() { try { $deposit = $this->deposit; $request = $this->request; $payment = $this->stripePayment($request); if (isset($payment->id)) { $deposit->status = 'accepted'; $deposit->save(); $user = auth('customer')->user(); } $this->redirect_url = null; $this->return_view = null;
} catch (\Exception $ex) { Log::error($ex->getMessage()); $this->error_message= $ex->getMessage(); } }
/*Custom Function*/ function stripePayment($req) { $credentials = json_decode(get_settings('payment_gateway')); $local_settings = json_decode(get_settings('local_setting')); if (!$credentials->stripe_pub_key || !$credentials->stripe_secret_key) { throw new \Exception(trans('Invalid payment')); }
$stripe = new \Stripe\StripeClient($credentials->stripe_secret_key);
return $stripe->charges->create([ 'amount' => $req->amount * 100, 'currency' => isset($local_settings->currency_code)?$local_settings->currency_code:'USD', 'source' => $req->stripeToken, 'description' => 'add deposit', ]); } }
|