norris1z / hubtel-ussd
An unofficial php library for processing Hubtel USSD requests
Installs: 36
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/norris1z/hubtel-ussd
Requires
- php: >=5.6.4
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.10
- phpunit/phpunit: ^6.5
This package is auto-updated.
Last update: 2025-09-29 01:35:25 UTC
README
Based on Hubtel's USSD API
About
This package helps you to build maintainable and scalable USSD applications by breaking down your "long switch" statement USSD application into modules
Getting Started
Check out this link to know how you can acquire a USSD code from Hubtel.
Installing
Install the package from composer
composer require norris1z/hubtel-ussd
Usage
Setup a route to respond to all Hubtel's requests.
Note that Hubtel sends no csrf tokens hence disable csrfprotection for that route.
For Laravel, add the route to the except array in the VerifyCsrfToken middleware.
Hubtel\USSD\Request::class is a class which represents the request from Hubtel. It has methods for all the parameters listed on Hubtel's Documentation Page.
View Source Request.php
Hubtel\USSD\Response::class is a class which represents the response sent to Hubtel. It has methods for all the parameters listed on Hubtel's Documentation Page.
View Source Response.php
RequestTypes::class has two properties, RESPONSE and RELEASE for indicating the type of response in a sequence.
$response = Response::createInstance('Hello Hubtel, i want a response',RequestTypes::RESPONSE); $response = Response::createInstance('Hello Hubtel, end the sequence',RequestTypes::RELEASE);
USSD::class is a class with one static method process which takes two parameters a Request (an instance of Hubtel\USSD\Reqeust) and
an array of sequence (any class that implements the Hubtel\USSD\SequenceInterface);
USSD::process(/** An instance of Hubtel\USSD\Request **/,[ new Sequence1(), new Sequence2(), new Sequence3() ])->toArray();
All seqeunces must have implement the SequenceInterface and hence have a handle method and must return an instance of Hubtel\USSD\Response (Response).
The USSD::process method automagically injects a Request parameter into the handle method of each sequence. This Request is an
instace of Hubtel\USSD\Request which grants access to all properties and methods in the request.
//Sequence1.php use Hubtel\USSD\Request; use Hubtel\USSD\RequestTypes; use Hubtel\USSD\Response; use Hubtel\USSD\SequenceInterface; class Sequence1 implements SequenceInterface { public function handle(Request $request) { return Response::createInstance('Welcome to Freebie Service.\n1. Free Food\n2. Free Drink\n3. Free Airtime',RequestTypes::RESPONSE); } }
Visit Hubtel's USSD Api documentation page for the list of methods on the request and response classes
Examples
Feel free to submit pull-requests for examples with other frameworks 😊
Running the tests
composer test
Authors
- Norris Oduro - Norris1z
License
This project is licensed under the MIT License