/mypesapal

A simplified PesaPal integration for your Laravel App.

Primary LanguagePHP

Simplified Laravel Pesapal

A simplified PesaPal integration for your Laravel App.

Installation

Via Composer

composer require jchegenye/mypesapal

Usage

Add this class to your Controller.

use App\Http\JTech\PesaPal\PesaPalIframe;

Run this vendor:publish command to publish Pesapal configaration file.

What's inside config file?

    1. Application Environment:

        | Pesapal will utilize this option to determine which 
        | mode your App is running, either Sandbox or Live
        |
        | Local - Means your App is running on a Sandbox Mode.
        | Production - Means your App is running on a Live Mode

    2. Authentication / Configuration

        | 'token_params' => NULL,
        | 'consumer_key' => env('PESAPAL_CONSUMER_KEY', '*** CONSUMER KEY ***'),
        | 'consumer_secret' => env('PESAPAL_CONSUMER_SECRET', '*** YOUR CONSUMER SECRET ***'),
        | 'live_iframelink' => 'https://www.pesapal.com/API/PostPesapalDirectOrderV4',
        | 'demo_iframelink' => 'http://demo.pesapal.com/api/PostPesapalDirectOrderV4'

    3. Define the callback_url

        | This is the full url pointing to the page the iframe redirects to 
        | after processing the order on pesapal.com

        'callback_url' => env('PESAPAL_CALLBACK_URL', 'http://test.com/payment-gateways-php/pesapal-php/'),

    4. Field Names

        | You may wish for to select prefered form details posted by your 
        | App to be used by pesapal.
        |
        | You can add more `Fields` here if you wish.
        |
        | NOTE: default value = MERCHANT

        'fields' => [

            'amount' => 'number_format(PESAPAL_FIELD_AMOUNT, 2)', //format amount to 2 decimal places
            'description' => 'PESAPAL_FIELD_DESC',
            'type' => 'MERCHANT', //default value = MERCHANT
            'reference' => 'PESAPAL_FIELD_REF', //unique order id of the transaction, generated by merchant
            'first_name' => 'PESAPAL_FIELD_FNAME',
            'last_name' => 'PESAPAL_FIELD_LNAME',
            'email' => 'PESAPAL_FIELD_EMAIL',
            'phonenumber' => 'PESAPAL_FIELD_PHONE' //ONE of email or phonenumber is required

        ]

To return Pesapal Response use this pesapal() Method.

In-order for Pesapal to obtain an instance of the current HTTP Request add this $request variable.

See below example:

response()->pesapal($request);