Skip to content

A plugin for easily integrating Hubtel USSD service into Laravel projects

Notifications You must be signed in to change notification settings

jowusu837/hubtel-ussd-plugin-laravel

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Hubtel USSD plugin for Laravel

Latest Release on GitHub Software License Total Downloads

Based on Hubtel's USSD API

About

This package allows you to integrate Hubtel USSD service directly into your existing Laravel application. This allows users to access your application on USSD like *1234#. Check out this link to know how you can acquire a USSD code from Hubtel.

Installation

Require the jowusu837/hubtel-ussd-plugin-laravel package in your composer.json and update your dependencies:

$ composer require jowusu837/hubtel-ussd-plugin-laravel

If you're using Laravel 5.5, this is all there is to do.

Should you still be on older versions of Laravel, the final steps for you are to add the service provider of the package and alias the package. To do this open your config/app.php file.

Add the HubtelUssd\ServiceProvider to your providers array:

Jowusu837\HubtelUssd\ServiceProvider::class,

Usage

Your application should now have an endpoint for USSD access. You can use the Hubtel USSD Simulator to test your it out by supplying your application url as: http://your-application.com/ussd

Customization

Your application should have the default USSD flow just to show you the the plugin is working. You create your own custom USSD flows by simply creating Activities. You can start by creating a new folder in your app directory called USSD. This is where you will store all your USSD related logic.

A USSD activity is just a simple php class that extends the UssdActivity class. Here's how it looks like:

namespace App\Ussd\Activities;

use App\Ussd\Activities\MenuSelection;
use Jowusu837\HubtelUssd\Lib\UssdActivity;
use Jowusu837\HubtelUssd\Lib\UssdResponse;

class HomeActivity extends UssdActivity
{
    public function run() {
        $this->response->Type = UssdResponse::RELEASE;
        $this->response->Message = 'Ussd is working!';
        return $this;
    }
    
    public function next() {
        return MenuSelection::class;
    }

}

So basically, an activity class such as the one above must implement 2 methods: run() and next(). The run() method is the main entry point for the activity and must always return $this. The next() must just return a reference to the next activity to be executed. You can do this by simply returning a string with the full namespace to the activity class or you can use the ::class approach to have php resolve that for you.

You have access to the current request $this->request, the response to be sent $this->response, and the current USSD session $this->session from within the activity as well. The request and response properties exposes all the properties of a USSD request and response respectively as documented here. The session property however is just an array. Note that the session is implemented on top of your existing Laravel cache. The session allows you to persist state throughout your USSD session. You can store a value in the session like so: $this->session['name'] = 'John Doe', and retrieve it elsewhere like so: $name = $this->session['name'].

Once you have created your activiy files, you need to set your entry point activity in the config file as shown in the next section.

Configuration

The defaults are set in config/hubtel-ussd.php. Copy this file to your own config directory to modify the values. You can publish the config using this command:

$ php artisan vendor:publish --provider="Jowusu837\HubtelUssd\ServiceProvider"
return [
    "home" => \App\Ussd\Activities\HomeActivity::class
];

License

Released under the MIT License, see LICENSE.

About

A plugin for easily integrating Hubtel USSD service into Laravel projects

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages