dgvai / laravel-nagad
Nagad Payment Gateway for Laravel (Bangladesh)
Installs: 1 589
Dependents: 0
Suggesters: 0
Security: 0
Stars: 9
Watchers: 2
Forks: 3
Open Issues: 1
This package is auto-updated.
Last update: 2024-10-24 22:57:05 UTC
README
Nagad is one of the Financial Services in Bangladesh. This package is built for Nagad Payment Gateway for Laravel 6.x, 7.x and 8.x+
Contents
Installation
You can install the package via composer:
composer require dgvai/laravel-nagad
Setting up your configuration
Extract the nagad config files:
php artisan vendor:publish --tag=nagad-config
-
This will publish and config file in
config_path()
of your application. Eg.config/nagad.php
-
Configure the configurations for the nagad merchant acocunt. Use
sandbox = true
for development stage. -
Be sure to set the timezone of you application to
Asia/Dhaka
in order to work with Nagad PG. To do this: go toconfig/app.php
and set'timezone' => 'Asia/Dhaka'
Usage
NagadPG uses three stages of payment process, and two of theme are simultaneous. To get started, first you have to setup
a callback route (GET
) for the Nagad Callback and name the route in the nagad config file.
// in routes/web.php Route::get('/nagad/callback', 'NagadController@callback')->name('nagad.callback'); //in config/nagad.php 'callback' => 'nagad.callback' // or use env variable to store
To Start payment, in your controller:
// in SomeController.php use DGvai\Nagad\Facades\Nagad; public function createPayement() { /** * Method 1: Quickest * This will automatically redirect you to the Nagad PG Page * */ return Nagad::setOrderID('ORDERID123') ->setAmount('540') ->checkout() ->redirect(); /** * Method 2: Manual Redirection * This will return only the redirect URL and manually redirect to the url * */ $url = Nagad::setOrderID('ORDERID123') ->setAmount('540') ->checkout() ->getRedirectUrl(); return ['url' => $url]; /** * Method 3: Advanced * You set additional params which will be return at the callback * */ return Nagad::setOrderID('ORDERID123') ->setAmount('540') ->setAddionalInfo(['pid' => 9, 'myName' => 'DG']) ->checkout() ->redirect(); /** * Method 4: Advanced Custom Callabck * You can set/override callback url while creating payment * */ return Nagad::setOrderID('ORDERID123') ->setAmount('540') ->setAddionalInfo(['pid' => 9, 'myName' => 'DG']) ->setCallbackUrl("https://manual-callback.url/callback") ->checkout() ->redirect(); }
To receive the callback response, in your callback controller method:
// in CallbackController.php use DGvai\Nagad\Facades\Nagad; use Illuminate\Http\Request; /** * This is the routed callback method * which receives a GET request. * * */ public function callback(Request $request) { $verified = Nagad::callback($request)->verify(); if($verified->success()) { // Get Additional Data dd($verified->getAdditionalData()); // Get Full Response dd($verified->getVerifiedResponse()); } else { dd($verified->getErrors()); } }
Available Methods
For Checking-out
setOrderID(string $orderID)
:$orderID
to be any unique AlphaNumeric StringsetAmount(string $amount)
:$amount
to be any valid currency numeric StringsetAddionalInfo(array $array)
:$array
to be any array to be returned at callbacksetCallbackUrl(string $url)
:$url
to be any url string to be overidden the defualt callback url set in configcheckout()
: to initiate checkout process.redirect()
: to direct redirect to the NagadPG Web Page.getRedirectUrl()
: instead of redirecting, getting the redirect url manually.
For Callback
callback($request)
:$request
to beIlluminate\Http\Request
instanceverify()
: to verify the response.success()
: to check if transaction is succeed.getErrors()
: to get the error and errorCode if fails transactions | returnsarray[]
getVerifiedResponse()
: to get the full verified response | returnsarray[]
getAdditionalData(bool $object)
: to get the additional info passed during checkout.$object
is to set return object or array.
Changelog
Please see CHANGELOG for more information what has changed recently.
License
The MIT License (MIT). Please see License File for more information.