codeonweekends / mpesa-php-sdk
(Unofficial) PHP SDK for the MPesa payment gateway by Vodacom Mozambique
Installs: 264
Dependents: 0
Suggesters: 0
Security: 0
Stars: 9
Watchers: 3
Forks: 2
Open Issues: 2
Type:package
Requires
- php: ^7.2 || ^8.0
- ext-json: *
- ext-openssl: *
- guzzlehttp/guzzle: ~6.0
- illuminate/support: *
- phpseclib/phpseclib: ^2.0
Requires (Dev)
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2025-03-20 01:12:09 UTC
README
composer require codeonweekends/mpesa-php-sdk
Usage
The easiest way to use the API is by calling Codeonweekends\Mpesa\Mpesa
and accessing
the available transaction methods.
- Create an instance of
Codeonweekends\Mpesa\Mpesa
- Get the api context using the
getApiContext()
method - Set the public key and the api key on the context using
setPublicKey(YOUR_PUBLIC_KEY)
andsetApiKey(YOUR_API_KEY)
respectively
Example:
$mpesa = new Codeonweekends\Mpesa\Mpesa(); $context = $mpesa->getApiContext(); $context->setPublicKey(YOUR_PUBLIC_KEY); $context->setApiKey(YOUR_API_KEY);
Create a C2B Transaction
$c2b = $mpesa->c2b($thirdPartyReference, $amount, $customerMSISDN, $serviceProviderCode, $transactionReference);
View a Transaction Status
$status = $mpesa->transactionStatus($queryReference, $serviceProviderCode, $securityCredential, $initiatorIdentifier);
Transaction Reversal
$reversal = $mpesa->transactionReversal($amount, $serviceProviderCode, $transactionID, $securityCredential, $initiatorIdentifier);
Running Test Suite
- Open the file
phpunit.xml
and fill the<env/>
values with appropriate information - Run
vendor/bin/phpunit
e.g.
<env name="MPESA_PUBLIC_KEY" value="Your Public Key Here" /> <env name="MPESA_API_KEY" value="Your API Key Here" /> <env name="MPESA_SERVICE_PROVIDER_CODE" value="The Service Provider Code Here" /> <env name="MPESA_CUSTOMER_MSISDN" value="Customer MSISDN here" /> <env name="MPESA_SECURITY_CREDENTIAL" value="Security Credential" /> <env name="MPESA_INITIATOR_IDENTIFIER" value="Initiator Identifier" />
Further Improvements
- Documentation
- Laravel support