Giter Site home page Giter Site logo

mpesa's Introduction

M-PESA API Package

Build Status Latest Stable Version Latest Unstable Version License

This is a PHP package for the Safaricom's M-Pesa REST API dubbed DARAJA API.

If you are looking for a laravel implementation do check the following repo Laravel Implementation

Installation

This project supports both composer dependency management tool and can also be used without composer

Using Composer

  1. Run the following command
composer require kabangi/mpesa

Without composer

  1. Download the source code as zipped

  2. Follow the following directions

<?php
require "{PATHTOTHISLIBFOLDER}/src/autoload.php";

use Kabangi\Mpesa\Init as Mpesa;
  1. Check the following example for usage https://github.com/Kabangi/mpesa/blob/master/example/mpesa.php

Configuration

The library comes with a structured config file based on the API that you intend to use.

To add the necessary configurations:-

  1. Open the folder installation.

  2. Look for a file named config/mpesa.php

  3. Edit the necessary keys that reflects the product you are using.

Usage

<?php
require "../src/autoload.php";

use Kabangi\Mpesa\Init as Mpesa;

// You can also pass your own config here.
// Check the folder ./config/mpesa.php for reference

$mpesa = new Mpesa();
try {

    $response = $mpesa->STKPush([
        'amount' => 10,
        'transactionDesc' => '',
        'phoneNumber' => '',
    ]);
    
    $response = $mpesa->B2C([
        'amount' => 10,
        'accountReference' => '12',
        'callBackURL' => 'https://example.com/v1/payments/C2B/confirmation',
        'queueTimeOutURL' => 'https://example.com/v1/payments/C2B/confirmation',
        'resultURL' => 'https://example.com/v1/payments/C2B/confirmation',
        'Remarks' => 'Test'
    ]);


    // $mpesa->STKStatus([]);
    
    // $mpesa->C2BRegister([]);
    
    // $mpesa->STKPush([]);
    
    // $mpesa->C2BSimulate([]);
    
    // $mpesa->B2C([])
    
    // $mpesa->B2B([]);
    
    // $mpesa->accountBalance([])
    
    // $mpesa->reversal([]);
    
    // $mpesa->transactionStatus([]);
    
    // $mpesa->reversal([]);
}catch(\Exception $e){
    $response = json_decode($e->getMessage());
}

header('Content-Type: application/json');
echo json_encode($response);

Support

Need support using this package:- Send a quick message here

https://t.me/kabangi

API's Supported

The library implements all the exposed endpoints by Safaricom as listed below:-

    What it is?

The Lipa na M-Pesa Online Payment endpoint(STK push) allows you to request payment from your users/clients. With this endpoint all the user is required to do is input their M-PESA pin to a prompt to send a payment to you.

    How to implement it?

Read docs here.

    What it is?

When you request payment from your users/clients via Lipa na M-Pesa Online endpoint above you might want to know the status of that request. This endpoint facilitates that. It allows you to query the status of any STK push on demand.

    How to implement it?

Read docs here.

3. C2B

    What it is?

This endpoint enables developers to receive real time notifications when a client makes a payments to a merchant's Till number or Paybill number. It assumes the payment are made via the SIM card toolkit and as a developer you need to know when that payment hits the merchants till/paybill number for reconciliation and accounting purposes.

    How to implement it?

Read docs here.

4. B2C

    What it is?

This endpoints enables merchants to pay their customers from they paybill account. Some of the use cases are but not limited to paying salaries, paying promotions to customers etc.

    How to implement it?

Read docs here.

5. B2B

    What it is?

This endpoint allows merchants to transfer funds from business to business accounts.

    How to implement it?

Read docs here.

    What it is?

This endpoint enables developers to initiate status check of a B2B, B2C and C2B transactions. It really comes in handy where one party in a transactions fails/claims not to have received an acknowledgment for a transaction.

    How to implement it?

Read docs here.

    What it is?

This endpoint enables merchants to reverse a B2B, B2C or C2B transaction. It allows automation of reversal of erronous payment to a merchant's paybill/till number or payments to goods never delivered.

    How to implement it?

Read docs here.

    What it is?

This endpoint enables merchants to query their Till/Paybill numbers account balance on demand.

    How to implement it?

Read docs here.

Inspiration

This package was inspired by the work from smodav work on the following project:- https://github.com/SmoDav/mpesa

Contributors

Gratitudes goes to the following Ninjas for their help during my integration process and the things I had to learn along the way fom them or their code:-


Julius Kabangi

License

The M-Pesa Package is open-sourced software licensed under the MIT license.

mpesa's People

Contributors

hkimani avatar kabangi avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

mpesa's Issues

Warning: curl_setopt(): supplied resource is not a valid cURL handle resource in /Users/lily/mpesa/vendor/kabangi/mpesa/src/Mpesa/Engine/CurlRequest.php on line 15

This is the test code:
`<?php
require "vendor/autoload.php";

use Kabangi\Mpesa\Native\Mpesa;

$mpesa = new Mpesa();

$response = $mpesa->STKPush([
'amount' => 10,
'PartyA' => '254713963186',
'PhoneNumber' => '254713963186',
'CallBackURL' => 'https://example.com/v1/payments/C2B/confirmation',
'AccountReference' => 'test',
'TransactionDesc' => 'Test'
]);
header('Content-Type: application/json');
echo json_encode($response);`

This is the whole error page:

`

( ! ) Warning: curl_setopt(): supplied resource is not a valid cURL handle resource in /Users/lily/mpesa/vendor/kabangi/mpesa/src/Mpesa/Engine/CurlRequest.php on line 15

1 | 0.0178 | 400832 | {main}( ) | .../test.php:0
2 | 0.1002 | 1134120 | Kabangi\Mpesa\Native\Mpesa->STKPush( ) | .../test.php:9
3 | 0.1079 | 1195984 | Kabangi\Mpesa\LipaNaMpesaOnline\STKPush->submit( ) | .../MpesaTrait.php:18
4 | 0.1154 | 1199848 | Kabangi\Mpesa\Engine\Core->makePostRequest( ) | .../STKPush.php:75
5 | 0.9990 | 1199792 | Kabangi\Mpesa\Engine\Core->request( ) | .../Core.php:151
6 | 1.0114 | 1227976 | Kabangi\Mpesa\Engine\CurlRequest->setOption( ) | .../Core.php:164
7 | 1.0114 | 1227976 | curl_setopt ( ) | .../CurlRequest.php:15

`

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.