tumainimosha / laravel-tigopesa-push
Laravel package for Tigopesa (TZ) USSD Push integration
Installs: 1 274
Dependents: 0
Suggesters: 0
Security: 0
Stars: 13
Watchers: 3
Forks: 5
Open Issues: 0
Requires
- php: >=7.1.3
- ext-json: *
- guzzlehttp/guzzle: ~7.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.13
- fzaninotto/faker: ^1.9@dev
- illuminate/support: ^5.8@dev
- mockery/mockery: ^1.0@dev
- orchestra/database: ^3.8@dev
- orchestra/testbench: ^3.8@dev
- phpunit/phpunit: ^7.4@dev
README
Install
composer require tumainimosha/laravel-tigopesa-push
Publish Configuration File
Publish config file to customize the default package config.
php artisan vendor:publish --provider="Tumainimosha\TigopesaPush\TigopesaPushServiceProvider" --tag="config"
Run migration
php artisan migrate
Configuration
Authentication
Configure your api parameters in .env
file as follows. Substitute example values below with those provided to you at time of integration.
TZ_TIGOPESA_PUSH_USERNAME=<your-username> TZ_TIGOPESA_PUSH_PASSWORD=<your-password> TZ_TIGOPESA_PUSH_BILLER_MSISDN=<your-biller-msisdn> # Should start with country code 255 followed by 9 digits. eg: 25565000111 TZ_TIGOPESA_PUSH_GET_TOKEN_URL=<your-get-token-url> TZ_TIGOPESA_PUSH_BILL_PAY_URL=<your-biller-pay-url>
Other configuration can be found in the config file published by this package. The options are well commented :)
Usage
Quick start
use Tumainimosha\TigopesaPush\TigopesaPush; $customerMsisdn = '255652111222'; $amount = 1000; $txnId = uniqid(); $tigopesaPushService = TigopesaPush::instance(); $response = $tigopesaPushService->postRequest($customerMsisdn, $amount, $txnId); /** @var bool $success */ $success = $response['ResponseStatus'];
Handling callback
Out of the box, this package stores transactions in table tigopesa_push_transactions
, and updates their status on receiving callback.
However, you may need to do further actions on your app after receiving callback, by listening to event TigopesaCallbackReceivedHandler::class
fired at callback.
You need to implement your own event listener to listen for this event and do any additional steps after receiving callback.
The event has public attribute $transaction
which contains the transaction parameters including status
// EventServiceProvider.php protected $listen = [ ... \Tumainimosha\TigopesaPush\Events\TigopesaCallbackReceived::class => [ \App\Listeners\TigopesaCallbackReceivedHandler::class, ], ]; // TigopesaCallbackReceivedHandler.php public function handle(TigopesaCallbackReceived $event) { $transaction = $event->transaction; // do your custom logic here }
Customize config values at runtime
The service offers fluent setters to change config values at runtime if your use case requires.
Such a use case could be when you have multiple accounts on the same project, and you fetch your config values from DB.
$tigopesaPushService = TigopesaPush::instance(); $tigopesaPushService->setUsername($account->username) ->setPassword($account->password) ->setBillerMsisdn($account->business_number) ->setTokenUrl(config('tigopesa-push.token_url')) ->setBillPayUrl(config('tigopesa-push.bill_pay_url'));
Testing
Run the tests with:
vendor/bin/phpunit
Contributing
Please see CONTRIBUTING for details.
** Help needed with improving documentation and unit testing. Pull Requests are welcome.
Security
If you discover any security-related issues, please email instead of using the issue tracker.
License
The MIT License (MIT). Please see License File for more information.