layout | permalink |
---|---|
page |
/actions |
Hover’s SDK uses actions you create to navigate menus on user devices. Typically each action represents a path through USSD menus. Once you create an action you can call it from your application code by passing its action_id
to the Hover SDK.
Actions can be updated anytime from within your Hover dashboard so that you do not have to update your whole app when a USSD service changes. To create actions # to your Hover account then go to the actions tab and click on + New Action
.
- Name of your choice, for example "Send Money".
- Description optional, for your internal use on the dashboard. Anything to help your team know what the action is for.
- Mobile networks/SIM cards that can run the service.
- Type: USSD, SIM Toolkit, USSD push, or variable longstring. See below.
- Root code, the shortcode used to start the session.
- The menu steps. See below.
See our blog post for more on converting USSD menus into actions.
Log into your Hover account and choose “New Action” from the dashboard. Give the action a memorable name. We recommend using the operator name and the type of action for easy reference (eg Tigo Send Money). Then choose the country and mobile operator your action will work with. If you’d like to support the same function across multiple networks, you will need to create a unique action for each operator (eg Tigo Check Balance, MTN Check Balance) if the USSD root code and steps are different.
Choose the type of menu that you are integrating. There are four types:
-
A standard USSD menu that is started by dialing a shortcode and then entering choices in the menus
-
A SIM Toolkit (STK) based menu. Primarily for Safaricom MPESA in Kenya, but there are others. When using this option the root code is not used.
-
A session that is not started by dialing a shortcode or launching the STK but is instead started by an API call. Most commonly used to enter a PIN to confirm, but there can be as many steps as needed, just like a regular USSD action.
-
A USSD session that does not have menus for some choices that need to be made. For example, an airtime top-up using a scratch card might be done by dialing *123*voucherCode# where voucherCode is the number from the scratch card. This is not recommended for general use since many networks prevent longstrings from working.
In root code enter the string a user would dial to initiate the session. These usually look like *123# or *123*01#. Finally enter the steps for your action.
{% include step_types.html %}
For actions that include a 'pin' step, Hover's SDK displays this pin entry screen at the start of the session. The PIN is encrypted and temporarily stored, then inserted into the USSD session at the appropriate time and then deleted. The pin never leaves the user's device. The background color and text color are <a href="/docs/customization">customizable</a>.
Sometimes simple actions like balance checks and account information requests have only a root code and no steps. In this case enter the root code and leave the steps blank.
Later you can add parsers to your action to make information such as confirmation details and USSD session status accessible to your application code.
Since a USSD action will only run on a specific SIM card, Hover's SDK provides a number of methods to help you find out which actions you can run on a user's device, even for dual SIM devices.
You must get the READ_PHONE_STATE
permission and call Hover.initialize()
before using any of Hover's helper methods. You should check if the permission has been granted before calling the method: if permission is not granted the method will throw an exception.
If you want to know if you can run a particular action on the user's SIM(s) you can call Hover.isActionSimPresent(actionId, context);
. If you want to get a list of all your actions that will run on any of a user's present SIM cards you can call Hover.getAllValidActions(context);
which will return a list of actions. There are also helpers for getting all the SIM cards present and for presenting a SIM choice interface to the user.