knox/mpesa-rest

There is no license information available for the latest version (v1.5.8) of this package.

Laravel Package implementation of the MPESA REST API

v1.5.8 2023-03-15 11:27 UTC

This package is auto-updated.

Last update: 2024-04-15 13:49:40 UTC


README

Laravel Package for the MPESA REST API

Installation

Add this package using Composer

From the command line inside your project directory, simply type:

composer require knox/mpesa-rest

Update your config

NB: from laravel 5.5 due to autodiscovery the below can be skipped

Add the service provider to the providers array in config/app.php:

Knox\MPESA\MpesaServiceProvider::class

Add the facade to the aliases array in config/app.php:

'MPESA' => Knox\MPESA\Facades\MPESA::class

Publish the package configuration

Publish the configuration file and migrations by running the provided console command:

php artisan vendor:publish --provider="Knox\MPESA\MpesaServiceProvider"

Setup

Environmental Variables

MPESA_ENV='live' for production and 'test' for sandbox
MPESA_VERSION='v1' or 'v2'
MPESA_CONSUMER_KEY=consumer key
MPESA_CONSUMER_SECRET=consumer secret
MPESA_IDENTIFIER=shortcode shortcode or till
MPESA_SHORT_CODE=shortcode
MPESA_PASSKEY=passkey

MPESA_INITIATOR_NAME=initiator username
MPESA_INITIATOR_PASSWORD=initiator password

MPESA_B2C_TIMEOUT_URL=url in your site
MPESA_B2C_RESULT_URL=url in your site
MPESA_B2B_TIMEOUT_URL=url in your site
MPESA_B2B_RESULT_URL=url in your site

MPESA_STK_CALLBACK_URL=url in your site
MPESA_C2B_VALIDATION_URL=url in your site
MPESA_C2B_CONFIRMATION_URL=url in your site

MPESA_ACCOUNT_BALANCE_TIMEOUT_URL=url in your site
MPESA_ACCOUNT_BALANCE_CONFIRMATION_URL=url in your site

MPESA_REVERSAL_TIMEOUT_URL=url in your site
MPESA_REVERSAL_CONFIRMATION_URL=url in your site

MPESA_TRANSACTION_STATUS_TIMEOUT_URL=url in your site
MPESA_TRANSACTION_STATUS_CONFIRMATION_URL=url in your site

MPESA_IDENTITY_CALLBACK_URL=url in your site

Usage

At the top of your controller include the facade
use MPESA;

Registration of C2B Urls

If you haven't registered the mpesa url callbacks then use the below

use MPESA;
use Illuminate\Http\Request;

class PaymentsController extends Controller
{
    public function registerURL(){
        $mpesa = MPESA::registerC2bUrl();
    }
}

Posible Operations

<!-- @param(phone_number, amount, payment_type, @remarks) -->
mpesa = MPESA::b2c('254700123456',10,'PromotionPayment', 'No Remarks');

<!-- @param(short_code, amount, command, sender_identifier, receiver_identifier, @remarks, @account = '') -->
mpesa = MPESA::b2b('600000',100,'BusinessPayBill',4,4, 'No Remarks',123456);

<!-- @param(short_code, amount, command, sender_identifier, receiver_identifier, @remarks, @account = '') -->
mpesa = MPESA::b2b('600000',100,'BusinessBuyGoods',4,4, 'No Remarks');

<!-- @param() -->
mpesa = MPESA::registerC2bUrl();

<!-- @param(phone, amount, command, account, @short_code) -->
mpesa = MPESA::c2bSimulate('254700123456',100,'CustomerPayBillOnline','123456');
mpesa = MPESA::c2bSimulate('254700123456',1000,'CustomerBuyGoodsOnline');

<!-- @param(@remarks) -->
mpesa = MPESA::getAccountBalance();

<!-- @param(transaction, amount, receiver = null, receiver_identifier = 11, @remarks, @occassion) -->
mpesa = MPESA::doReversal('ND893KKHX1', 100, 602984, 4);

<!-- @param(phone, amount, account, @description) -->
mpesa = MPESA::stkPush('254700123456', 1000, 'Account 123');

<!-- @param(checkout_request_id) -->
mpesa = MPESA::stkQuery('ws_CO_14092017184227664');

<!-- @param(transaction, party = '', identifier_type = '4', @remarks, @occassion) -->
mpesa = MPESA::getTransactionStatus('ND893KKHX1', null,4);

Example response handler

public function c2bConfirmation(Request $request)
{
    $response = json_decode($request->getContent(), true);
    $mpesa_transaction_id = $response['TransID'];
    $date_time = Carbon::parse($response['TransTime']);
    $amount = $response['TransAmount'];
    $account = strtoupper(preg_replace('/\s+/', '', $response['BillRefNumber']));
    $merchant_transaction_id = $response['ThirdPartyTransID'];
    $phone = $response['MSISDN'];
    $payer = preg_replace('!\s+!', ' ', ucwords(strtolower($response['FirstName'] . ' ' . $response['MiddleName'] . ' ' . $response['LastName'])));
}

All Done

Feel free to report any issues