This chapter gives a general idea about how to configure the ESPF (External system provisioning framework) to capture changes in customer / account configuration in PortaBilling® and then send provisioning events to the external system via the HTTP protocol.
To receive requests from PortaBilling® and process them and update an external system, service providers develop a web application that uses a programming language they prefer. They can run it on any of their web servers.
Enabling the ESPF handlers and provisioning event types requires a deep knowledge of ESPF architecture. Therefore, please contact the PortaOne® support team to configure the ESPF for you.
In this document we demonstrate how to configure the ESPF to provision events to a custom web application. Let’s say that you operate as an MVNO and you now have an HSS of your own. You wish to provision your subscriber details there when a mobile user is added to or modified in PortaBilling®.
For example, provisioning events are sent when an administrator changes a phone number / SIM card or product for a user, when the user depleted their available funds or topped up their balance, or when an administrator temporarily blocks a user (e.g. for non-payment).
The EventSender handler provisions events to custom web applications. To provision any of the supported external systems, it is necessary to choose an essential handler (e.g. Yate HSS) and configure this handler instead of the EventSender.
Print the following page and use it during system setup to check off the operations as you complete them according to the instructions in this chapter. Please be sure to perform all of the operations in the order designated (all of the boxes should be checked), otherwise the service will not work.
Enable provisioning on the Configuration server
Configure a handler on the Configuration server
Enable notifications upon failure (optional)
Enable the handler
Enable provisioning event types
Subscribe the handler for the provisioning event types
Test the system
To enable provisioning to external systems, create a new ESPF instance as follows:
1. On the Configuration server web interface, go to the Configurations tab.
2. Clone the current configuration.
3. In the node tree select Auxiliaries → ESPF and click Create instance.
4. Select the server and service IP for the instance.
5. Click Save.
6. Leave it as is and move on to the next step.
To provision data to your external web application, configure the EventSender handler.
1. In the node tree, select ESPF.
2. Select the environment (e.g. Global).
3. Move to Groups and select EventSender.
4. Fill in the following information:
· AsyncMode – Leave the default Yes value to send requests asynchronously (a handler sends a request as soon as it is processed, without waiting for a reply from a server) or change to No to send requests synchronously (one by one once a server reply is received).
· AuthHeader – This is the name for the header that holds authentication details (e.g. authentication key / user / credentials / type / key ID) based on the authentication method. Leave the default Authorization.
· AuthMethod – Select the method used to authenticate HTTP requests:
o Basic – authenticate with user ID and password;
o Custom – authenticate custom type and credentials;
o Signature – authenticate by key and key ID.
· BasicAuth_Key –Specify the user password for the Basic method only.
· BasicAuth_User – Specify the user ID for the Basic method only.
· CustomAuth_Credentials – Specify the credentials for the Custom method only.
· CustomAuth_Type – Specify the type for the Custom method only.
· MaxWaitTime – This defines how long the handler waits for a response from a server in asynchronous mode. The time starts once the last request from an iteration was sent (60 seconds by default.)
· RequestTimeout – The number of seconds that the handler waits for the response from the server once a request is sent (5 by default.)
· SignatureAuth.KeyId – The string that the server can use to look up the component required to validate a signature.
· SignatureAuth.Key – The key associated with the key ID that is used to create a signature.
· TokenBurstiness – This value defines the maximum number of requests that can be sent per second in asynchronous mode (100 by default).
· TokenRate – This value defines the average number of requests that are sent per second in asynchronous mode (10 by default).
· URL – The IP address or host name of the server to which requests are sent (e.g. or ). Be aware that the ESPF sends requests to external systems in the order they are added here.
It may happen that the web application becomes unreachable due to network connectivity issues and therefore, that provisioning fails. To be informed about unsuccessful provisioning, configure the ESPF to notify you via email.
1. From Groups, select Provisioning.
2. Fill in the fields:
· AlertRecepient – Type in your email address to receive notifications.
· send_options – Specify the options passed to the command-line sendmail utility. This utility is used to send notifications about provisioning errors (if there are any).
3. Click Save.
When you are done, click Verify to view the changes and then click Check/Apply to apply the configuration.
To activate the ESPF components the evctl.pl script is used. To run the script, please connect to the PortaBilling® web server via SHH and run the commands named below:
Some changes in customer or product configuration in PortaBilling® influence account configuration. For example, when a customer reaches their credit limit or depletes their available funds, their credit accounts no longer have access to services until the customer refills their balance.
If you must provision changes that are caused by changes in customer / product and / or service configuration for an account, please also run this command to enable the necessary handlers: ProductToAccountsDispatcher, CustomerToAccountsDispatcher, ServiceAttributeDispatcher.
In our example, it is necessary to provision account changes once a customer configuration changes. So these two commands must be run:
/home/provisioning-framework/utils/evctl.pl handler enable EventSender
/home/provisioning-framework/utils/evctl.pl handler enable CustomerToAccountsDispatcher
To meet the requirements in our example, the following event types must be enabled:
o Account/ServicePassword / Changed
To activate an event type, run the following command:
/home/provisioning-framework/utils/evctl.pl type enable Account/SIMCardAssignment
Repeat this command for each event type to activate it. Change the event type name to the requisite one.
When subscribed for an event type, once a handler receives notifications upon event creation it processes them. To subscribe a handler for an event type, run this command:
/home/provisioning-framework/utils/evctl.pl handler sub EventSender Account/SIMCardAssignment
Repeat this command to subscribe a handler for other event types as well.
Alternatively, you can use the following command to subscribe the handler for all event types available for this handler:
/home/provisioning-framework/utils/evctl.pl handler sub EventSender all
Be aware that CustomerToAccountsDispatcher must also be subscribed for customer event types.
To make sure that a handler is now subscribed for a requisite event type, you execute the following command:
· “.” shows that the event handler can subscribe for an event;
· “+” shows that the event handler is already subscribed for an event.
Create a new mobile account via the administrator web interface and see whether the request has been sent.
1. On your customer’s panel, click Accounts.
2. On the Create an account panel, specify the account’s details:
· ID –Type in the user’s mobile number.
· Account role – Select Mobile.
· IMSI – Click on the IMSI icon and select one of the available SIM cards from the SIM Card Inventory dialog box.
· Product – Select the LTE Product here.
· Activation date – The date from which the account is usable.
· Type – Select Credit for your postpaid Internet users.
· Balance control – Select Subordinate from the list.
3. Click Save to create an account.
4. Check the log.
When an account has been added, you can view this event in the log file:
or see the provisioning status in the database (Account_Provisioning_Statuses table).