xenon / bkash-php
This is a php sdk for integrating with your php application easily
This package's canonical repository appears to be gone and the package has been frozen as a result.
Requires
- php: ^7.4|^8.0
- ext-curl: *
- ext-json: *
- guzzlehttp/guzzle: ^6.5.8 | ^7.8
This package is auto-updated.
Last update: 2024-06-25 23:19:28 UTC
README
xenon/bkash-php is a Bkash PHP SDK for integrating bkash api in website easily. Follow below steps for better understanding.
- Step 1: Installation
- Step 2: Format Configuration
- Step 3: Exception
- Create Payment Url
- Execute Payment
- Query Payment
- Stargazers
- Forkers
- Contributors
Step 1: Installation
composer require xenon/bkash-php
Step 2: Format Configuration
Create your credentials (array) to use along with Xenon\BkashPhp\BkashPhp
class
$configuration = [ 'config' => [ "app_key" => "app key goes here", "app_secret" => "app secret goes here", ], 'headers' => [ "username" => "username goes here", "password" => "password goes here", ] ];
Step 3: Exception
Exception Handling
use Xenon\BkashPhp\Handler\Exception\RenderBkashPHPException
Always call below methods under try block. After any of this method failed or exception occurs then it will throw RenderBkashPHPException
createTokenizedPayment()
executePayment()
searchTransaction()
Create Payment Url
Bkash payment gateway allows you to create payment url based on different parameters. Follow below code sample
use Xenon\BkashPhp\Handler\Exception\RenderBkashPHPException use Xenon\BkashPhp\BkashPhp; try{ $paymentData = [ 'mode' => '0011', //fixed 'payerReference' => '017AAXXYYZZ', 'callbackURL' => 'http://example.com/callback', 'merchantAssociationInfo' => 'xxxxxxxxxx', 'amount' => 10, 'currency' => 'BDT', //fixed 'intent' => 'sale', //fixed 'merchantInvoiceNumber' => "invoice number goes here", ]; $createTokenizedPaymentResponse = $bkash->createTokenizedPayment($paymentData); }catch(RenderBkashPHPException $e){ //do whatever you want }
If everything goes well then it will return below object. After that redirect to bkashURL from below object
stdClass Object ( [statusCode] => 0000 [statusMessage] => Successful [paymentID] => TR0011DVJQOkh169400XXX [bkashURL] => https://sandbox.payment.bkash.com/redirect/tokenized/?paymentID=TR0011DVJQOkh1694007349990&hash=yaJMHgVb_BW_pJuxErXXXdf8-QFyHHG0bqkwBdUU(NLFwI(-ltH8z36kpnxtxa5Xs5tJxFxW5KoyKN5nWPisXXXXXXXXXXX50209&mode=0011&apiVersion=v1.2.0-beta [callbackURL] => http://example.com/callback [successCallbackURL] => http://example.com/callback?paymentID=TR0011DVJQOkh169400XXX&status=success [failureCallbackURL] => http://example.com/callback?paymentID=TR0011DVJQOkh169400XXX&status=failure [cancelledCallbackURL] => http://example.com/callback?paymentID=TR0011DVJQOkh169400XXX&status=cancel [amount] => 10 [intent] => sale [currency] => BDT [paymentCreateTime] => 2023-09-06T19:35:50:209 GMT+0600 [transactionStatus] => Initiated [merchantInvoiceNumber] => dsf64f8803XXX93 )
Execute Payment
After payment done customer will be redirected to merchant callback url having query string like below
"https://example.com?paymentID=TR0011ZCxlJhC1693137759378&status=success"
Now it's time to call executePayment() method with paymentID
use Xenon\BkashPhp\Handler\Exception\RenderBkashPHPException use Xenon\BkashPhp\BkashPhp; try{ $bkash = new BkashPhp($configuration); $executePaymentResponse = $bkash->executePayment($paymentId); }catch(RenderBkashPHPException $e){ //do whatever you want }
stdClass Object ( [statusCode] => 0000 [statusMessage] => Successful [paymentID] => TR0011DVJQOkh169400XXX [payerReference] => 017AAXXYYZZ [customerMsisdn] => 01877722345 [trxID] => AI620D4DVQ [amount] => 10 [transactionStatus] => Completed [paymentExecuteTime] => 2023-09-06T19:11:01:698 GMT+0600 [currency] => BDT [intent] => sale [merchantInvoiceNumber] => dsf64f8803XXX93 )
Query Payment
After successful payment execution, it needs to call searchTransaction() method.
use Xenon\BkashPhp\Handler\Exception\RenderBkashPHPException use Xenon\BkashPhp\BkashPhp; try{ $trxID = request()->trxID; //get trxID from executePayment() method $bkash = new BkashPhp($configuration); $searchPaymentResponse = $bkash->searchTransaction($trxID); }catch(RenderBkashPHPException $e){ //do whatever you want }
This will match trxID with bkash database. After getting response object you will do further according to your web application requirements. stdClass Object ( [trxID] => AI620D4DVQ [initiationTime] => 2023-09-06T22:15:34:000 GMT+0600 [completedTime] => 2023-09-06T22:15:34:000 GMT+0600 [transactionType] => bKash Tokenized Checkout via API [customerMsisdn] => 01877722345 [transactionStatus] => Completed [amount] => 10 [currency] => BDT [organizationShortCode] => 50022 [statusCode] => 0000 [statusMessage] => Successful )
Stargazers
Forkers
Contributors
This is a start only. This package will be more enriched in future. If you find any issues or bug , please create an issue in this repository. Any technical suggestion or opinion will be highly appreciated