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.
 
 

207 lines
7.4 KiB

<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\CentralLogics\Helpers;
use App\Models\Order;
class BkashPaymentController extends Controller
{
private $base_url;
private $app_key;
private $app_secret;
private $username;
private $password;
public function __construct()
{
$config=\App\CentralLogics\Helpers::get_business_settings('bkash');
// You can import it from your Database
$bkash_app_key = $config['api_key']; // bKash Merchant API APP KEY
$bkash_app_secret = $config['api_secret']; // bKash Merchant API APP SECRET
$bkash_username = $config['username']; // bKash Merchant API USERNAME
$bkash_password = $config['password']; // bKash Merchant API PASSWORD
$bkash_base_url = (env('APP_MODE') == 'live') ? 'https://checkout.pay.bka.sh/v1.2.0-beta' : 'https://checkout.sandbox.bka.sh/v1.2.0-beta';
$this->app_key = $bkash_app_key;
$this->app_secret = $bkash_app_secret;
$this->username = $bkash_username;
$this->password = $bkash_password;
$this->base_url = $bkash_base_url;
}
public function getToken()
{
session()->forget('bkash_token');
$request_data = array(
'app_key' => $this->app_key,
'app_secret' => $this->app_secret
);
$url = curl_init('https://tokenized.sandbox.bka.sh/v1.2.0-beta/tokenized/checkout/token/grant');
$request_data_json = json_encode($request_data);
$header = array(
'Content-Type:application/json',
'username:'.$this->username,
'password:'.$this->password
);
curl_setopt($url, CURLOPT_HTTPHEADER, $header);
curl_setopt($url, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($url, CURLOPT_RETURNTRANSFER, true);
curl_setopt($url, CURLOPT_POSTFIELDS, $request_data_json);
curl_setopt($url, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($url, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4);
$resultdata = curl_exec($url);
curl_close($url);
$response = json_decode($resultdata, true);
if (array_key_exists('msg', $response)) {
return $response;
}
session()->put('bkash_token', $response['id_token']);
return $response;
}
// public function createPayment(Request $request)
// {
// $token = session()->get('bkash_token');
// $request['intent'] = 'sale';
// $request['currency'] = 'BDT';
// $request['merchantInvoiceNumber'] = rand();
// $url = curl_init("$this->base_url/checkout/payment/create");
// $request_data_json = json_encode($request->all());
// $header = array(
// 'Content-Type:application/json',
// "authorization: $token",
// "x-app-key: $this->app_key"
// );
// curl_setopt($url, CURLOPT_HTTPHEADER, $header);
// curl_setopt($url, CURLOPT_CUSTOMREQUEST, "POST");
// curl_setopt($url, CURLOPT_RETURNTRANSFER, true);
// curl_setopt($url, CURLOPT_POSTFIELDS, $request_data_json);
// curl_setopt($url, CURLOPT_FOLLOWLOCATION, 1);
// curl_setopt($url, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4);
// $resultdata = curl_exec($url);
// curl_close($url);
// return json_decode($resultdata, true);
// }
// public function executePayment(Request $request)
// {
// $token = session()->get('bkash_token');
// $paymentID = $request->paymentID;
// $url = curl_init("$this->base_url/checkout/payment/execute/" . $paymentID);
// $header = array(
// 'Content-Type:application/json',
// "authorization:$token",
// "x-app-key:$this->app_key"
// );
// curl_setopt($url, CURLOPT_HTTPHEADER, $header);
// curl_setopt($url, CURLOPT_CUSTOMREQUEST, "POST");
// curl_setopt($url, CURLOPT_RETURNTRANSFER, true);
// curl_setopt($url, CURLOPT_FOLLOWLOCATION, 1);
// $resultdata = curl_exec($url);
// curl_close($url);
// return json_decode($resultdata, true);
// }
// public function queryPayment(Request $request)
// {
// $token = session()->get('bkash_token');
// $paymentID = $request->payment_info['payment_id'];
// $url = curl_init("$this->base_url/checkout/payment/query/" . $paymentID);
// $header = array(
// 'Content-Type:application/json',
// "authorization:$token",
// "x-app-key:$this->app_key"
// );
// curl_setopt($url, CURLOPT_HTTPHEADER, $header);
// curl_setopt($url, CURLOPT_CUSTOMREQUEST, "GET");
// curl_setopt($url, CURLOPT_RETURNTRANSFER, true);
// curl_setopt($url, CURLOPT_FOLLOWLOCATION, 1);
// $resultdata = curl_exec($url);
// curl_close($url);
// return json_decode($resultdata, true);
// }
public function make_tokenize_payment(Request $request)
{
$order = Order::with(['details','customer'])->where(['id' => $request->order_id])->first();
$response = self::getToken();
$auth = $response['id_token'];
$callbackURL = route('bkash-success');
$requestbody = array(
'mode' => '0011',
'amount' => (string)$order->order_amount,
'currency' => 'BDT',
'intent' => 'sale',
'payerReference' => (string)$order->customer->phone,
'merchantInvoiceNumber' => 'commonPayment001',
'callbackURL' => $callbackURL
);
$url = curl_init('https://tokenized.sandbox.bka.sh/v1.2.0-beta/tokenized/checkout/create');
$requestbodyJson = json_encode($requestbody);
$header = array(
'Content-Type:application/json',
'Authorization:' . $auth,
'X-APP-Key:' . $this->app_key
);
curl_setopt($url, CURLOPT_HTTPHEADER, $header);
curl_setopt($url, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($url, CURLOPT_RETURNTRANSFER, true);
curl_setopt($url, CURLOPT_POSTFIELDS, $requestbodyJson);
curl_setopt($url, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($url, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4);
$resultdata = curl_exec($url);
curl_close($url);
echo $resultdata;
$obj = json_decode($resultdata);
return redirect()->away($obj->{'bkashURL'});
}
public function bkashSuccess(Request $request)
{
$order = Order::with(['details'])->where(['id' => session('order_id'), 'user_id'=>session('customer_id')])->first();
if ($request->paymentID != null && $request->status == 'success') {
$order->transaction_reference = $request->paymentID;
$order->payment_method = 'bkash';
$order->payment_status = 'paid';
$order->order_status = 'confirmed';
$order->confirmed = now();
$order->save();
Helpers::send_order_notification($order);
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');
}
}
}