Laravel HyperPay provides an easy way to handle all the transactions with different states.
You can install the package via composer:
composer require devinweb/laravel-hyperpay
Laravel-hyperpay
provides a migration to handle its own transaction, don't forget to publish the migration after installation
php artisan vendor:publish --tag="hyperpay-migrations"
Then migrate
php artisan migrate
This migration has a model named Transaction
, if your app use multi-tenancy, you can create a new transaction model based on the hyperpay transaction
model.
use Hyn\Tenancy\Traits\UsesTenantConnection;
use Devinweb\LaravelHyperpay\Models\Transaction as ModelsTransaction;
class Transaction extends ModelsTransaction
{
use UsesTenantConnection;
}
then don't forget the update the transaction_model
path in the config file app/hyperpay.php
<?php
return [
//
"transaction_model" => 'YOUR_NEW_TRANSACTION_MODEL_NAMESPACE',
//
];
You can also publish the config file using
php artisan vendor:publish --tag="hyperpay-config"
After that you can see the file in app/hyperpay.php
Before start using Laravel-hyperpay
, add the ManageUserTransaction
trait to your User model, this trait provides mutliple tasks to allow you to perform the transaction process from the given user.
use Devinweb\LaravelHyperpay\Traits\ManageUserTransactions;
class User extends Authenticatable
{
use ManageUserTransactions;
}
This package use User model that will be App\User
or App\Models\User
, if else you can define your user model using the .env
PAYMENT_MODEL=App\Models\User
Next, you should configure your hyperpay environment in your application's .env
SANDBOX_MODE=true
ACCESS_TOKEN=
ENTITY_ID_MADA=
ENTITY_ID=
# default SAR
CURRENCY=
To create a transaction in hyperpay using this package, we need to to prepare the checkout then generate the form.
use Devinweb\LaravelHyperpay\Facades\LaravelHyperpay;
class PaymentController extends Controller
{
public function prepareCheckout(Request $request)
{
$trackable = [
'product_id'=> 'bc842310-371f-49d1-b479-ad4b387f6630',
'product_type' => 't-shirt'
];
$user = User::first();
$amount = 10;
$brand = 'VISA' // MASTER OR MADA
return LaravelHyperpay::checkout($trackable_data, $user, $amount, $brand, $request);
}
}
you can also attach the billing data to the checkout by creating the billing class using this command, all billing files you can find them in app/Billing
folder.
php artisan make:billing HyperPayBilling
then use
use Devinweb\LaravelHyperpay\Facades\LaravelHyperpay;
use App\Billing\HyperPayBilling
LaravelHyperpay::addBilling(new HyperPayBilling())->checkout($trackable_data, $user, $amount, $brand, $request);
You can also generate your own merchantTransactionId and tell the package to use it, by using addMerchantTransactionId($id)
use Illuminate\Support\Str;
$id = Str::random('64');
LaravelHyperpay::addMerchantTransactionId($id)->addBilling(new HyperPayBilling())->checkout($trackable_data, $user, $amount, $brand, $request);
Next the response returned by the prepareCheckout
actions
{
"buildNumber": "",
"id": "RANDOME_ID.uat01-vm-tx04",
"message": "successfully created checkout",
"ndc": "RANDOME_ID.uat01-vm-tx04",
"result": {
"code": "000.200.100",
"description": "successfully created checkout"
},
"script_url": "https://test.oppwa.com/v1/paymentWidgets.js?checkoutId=RANDOME_ID.uat01-vm-tx04",
"shopperResultUrl": "shopperResultUrl",
"status": "200",
"timestamp": "2021-04-05 11:16:50+0000"
}
To create the payment form you just need to add the following lines of HTML/JavaScript to your page.
<script src="{{ script_url }}"></script>
<form
action="{{shopperResultUrl}}"
class="paymentWidgets"
data-brands="VISA MASTER"
></form>
After the transaction process hyperpay redirect the user to the merchant page using the shopperResultUrl
that you can configure it in the config file app/hyperpay.php
, by updating the redirect_url
value.
// app/hyperpay.php
return [
//
"redirect_url" => "/hyperpay/finalize",
//
]
You can also add redirect_url
dynamically via addRedirectUrl($url)
that can override the default config redirect_url
if you want to add a dynamic url like if you use multi-tenant or add some parameters to your redirection url.
$redirect_url = $req->headers->get('origin'). '/finalize';
LaravelHyperpay::addRedirectUrl($redirect_url)->addBilling(new HyperPayBilling())->checkout($trackable_data, $user, $amount, $brand, $request);
After redirection you can use an action the handle the finalize step
use Devinweb\LaravelHyperpay\Facades\LaravelHyperpay;
class PaymentController extends Controller
{
public function paymentStatus(Request $request)
{
$resourcePath = $request->get('resourcePath');
$checkout_id = $request->get('id');
return LaravelHyperpay::paymentStatus($resourcePath, $checkout_id);
}
}
Laravel-hyperpay
providers two events during the transaction process, after finalize this package fire for successfull transaction
Event | Description |
---|---|
Devinweb\LaravelHyperpay\Events\SuccessTransaction | success transaction |
Devinweb\LaravelHyperpay\Events\FailTransaction | fail transaction |
Each event of them contains the trackable_data
and hyperpay_data
that used to prepare the checkout
First we start by creating a new listener using
php artisan make:listener TransactionSuccessListener
After that go to app/Providers/EventServiceProvider
and register the event with your listener
class EventServiceProvider extends ServiceProvider
{
/**
* The event listener mappings for the application.
*
* @var array
*/
protected $listen = [
Registered::class => [
SendEmailVerificationNotification::class,
],
'Devinweb\LaravelHyperpay\Events\SuccessTransaction' => [
'App\Listeners\TransactionSuccessListener',
],
];
//
}
In each success transaction laravel-hyperpay
package fire an event with the necessary data take a look at our TransactionSuccessListener
class.
<?php
namespace App\Listeners;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Support\Facades\Log;
class TransactionSuccessListener
{
/**
* Create the event listener.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Handle the event.
*
* @param object $event
* @return void
*/
public function handle($event)
{
$hyperpay_data = $event->transaction['hyperpay_data'];
$trackable_data = $event->transaction['trackable_data'];
}
}
The same you can do with Devinweb\LaravelHyperpay\Events\FailTransaction
event.
composer test
Please see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email imad@devinweb.com instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.
You can use this repository to check the integration of the package laravel-hyperpay-boilerplate.