All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ph.com.globe.connect.Ussd Maven / Gradle / Ivy

/*
 * The MIT License
 *
 * Copyright 2016 charleszamora.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package ph.com.globe.connect;

import java.net.URISyntaxException;
import java.util.Map;
import java.util.HashMap;

import org.apache.http.client.utils.URIBuilder;

/**
 * USSD Class.
 *
 * @author Charles Zamora [email protected]
 */
public class Ussd extends Context {
    /* USSD Send url */
    private final String USSD_SEND_NI_URL = "https://devapi.globelabs.com.ph/ussd/v1/outbound/%s/send/requests";

    /* USSD Reply url */
    private final String USSD_REPLY_MT_URL = "https://devapi.globelabs.com.ph/ussd/v1/outbound/%s/reply/requests";

    /* Sender address (Short Code) */
    protected String senderAddress = null;

    /* API Access token */
    protected String accessToken = null;

    /* USSD Message */
    protected String ussdMessage = null;

    /* Subscriber address */
    protected String address = null;

    /* Final message flag */
    protected boolean flash = false;

    /* USSD Session id */
    protected String sessionId = null;

    /**
     * Create Ussd class without parameters.
     */
    public Ussd() {
    }

    /**
     * Create Ussd class with accessToken parameter.
     *
     * @param accessToken access token
     */
    public Ussd(String accessToken) {
        // set access token
        this.accessToken = accessToken;
    }

    /**
     * Create Ussd class with senderAddress and
     * accessToken parameter.
     *
     * @param senderAddress subscriber address
     * @param accessToken access token
     */
    public Ussd(String senderAddress, String accessToken) {
        // set sender address
        this.senderAddress = senderAddress;
        // set access token
        this.accessToken = accessToken;
    }

    /**
     * Sets sender address (Short Code)
     *
     * @param  senderAddress subscriber address
     * @return this
     */
    public Ussd setSenderAddress(String senderAddress) {
        // set sender address
        this.senderAddress = senderAddress;

        return this;
    }

    /**
     * Sets access token.
     *
     * @param  accessToken access token
     * @return this
     */
    public Ussd setAccessToken(String accessToken) {
        // set access token
        this.accessToken = accessToken;

        return this;
    }

    /**
     * Set ussd message.
     *
     * @param  ussdMessage ussd message
     * @return this
     */
    public Ussd setUssdMessage(String ussdMessage) {
        // set ussd message
        this.ussdMessage = ussdMessage;

        return this;
    }

    /**
     * Set subscriber address.
     *
     * @param  address subscriber address
     * @return this
     */
    public Ussd setAddress(String address) {
        // set subscriber address
        this.address = address;

        return this;
    }

    /**
     * Set flash.
     *
     * @param  flash final message flag
     * @return this
     */
    public Ussd setFlash(boolean flash) {
        // set flash
        this.flash = flash;

        return this;
    }

    /**
     * Set session id.
     *
     * @param  sessionId session id
     * @return this
     */
    public Ussd setSessionId(String sessionId) {
        // set session id
        this.sessionId = sessionId;

        return this;
    }

    /**
     * Send USSD Request.
     *
     * @param  senderAddress sender address
     * @param  ussdMessage ussd message
     * @param  address subscriber address
     * @param  flash final message flag
     * @param  asyncHandler async handler instance
     * @throws ApiException api exception
     * @throws HttpRequestException http request exception
     * @throws HttpResponseException http response exception
     */
    public void sendUssdRequest(
        String senderAddress,
        String ussdMessage,
        String address,
        boolean flash,
        AsyncHandler asyncHandler)
        throws ApiException, HttpRequestException, HttpResponseException {

        // build url
        String url = this.buildUrl(this.USSD_SEND_NI_URL);

        // set base data
        Map data = new HashMap<>();

        // set outbound ussd message request
        Map oumr = new HashMap<>();

        // set message data
        Map msg = new HashMap<>();

        // set sender address
        oumr.put("senderAddress", senderAddress);
        // set address
        oumr.put("address", address);
        // set flash
        oumr.put("flash", flash);

        // set message
        msg.put("message", ussdMessage);

        // set message
        oumr.put("outboundUSSDMessage", new org.json.JSONObject(msg));

        // set on base data
        data.put("outboundUSSDMessageRequest", new org.json.JSONObject(oumr));

        // send request
        new HttpRequest()
        // set url
        .setUrl(url)
        // set data
        .setData(data)
        // set async handler
        .setAsyncHandler(asyncHandler)
        // execute async post
        .execute("post");
    }

    /**
     * Send USSD Request.
     *
     * @param  asyncHandler async handler instance
     * @throws ApiException api exception
     * @throws HttpRequestException http request exception
     * @throws HttpResponseException http response exception
     */
    public void sendUssdRequest(AsyncHandler asyncHandler)
        throws ApiException, HttpRequestException, HttpResponseException {

         // call send ussd request
         this.sendUssdRequest(
            this.senderAddress,
            this.ussdMessage,
            this.address,
            this.flash,
            asyncHandler);
    }

    /**
     * Reply USSD Request.
     *
     * @param  sessionId session id
     * @param  senderAddress sender address
     * @param  address subscriber address
     * @param  flash final message flag
     * @param  asyncHandler async handler instance
     * @throws ApiException api exception
     * @throws HttpRequestException http request exception
     * @throws HttpResponseException http response exception
     */
    public void replyUssdRequest(
        String sessionId,
        String senderAddress,
        String address,
        boolean flash,
        AsyncHandler asyncHandler)
        throws ApiException, HttpRequestException, HttpResponseException {

        // build url
        String url = this.buildUrl(this.USSD_REPLY_MT_URL);

        // set base data
        Map data = new HashMap<>();

        // set outbound ussd message request
        Map oumr = new HashMap<>();

        // set message data
        Map msg = new HashMap<>();

        // set sender address
        oumr.put("senderAddress", senderAddress);
        // set address
        oumr.put("address", address);
        // set session id
        oumr.put("sessionID", sessionId);
        // set flash
        oumr.put("flash", flash);

        // set message
        msg.put("message", ussdMessage);

        // set message
        oumr.put("outboundUSSDMessage", new org.json.JSONObject(msg));

        // set on base data
        data.put("outboundUSSDMessageRequest", new org.json.JSONObject(oumr));

        // send request
        new HttpRequest()
        // set url
        .setUrl(url)
        // set data
        .setData(data)
        // set async handler
        .setAsyncHandler(asyncHandler)
        // execute async post
        .execute("post");
    }

    /**
     * Reply USSD Request.
     *
     * @param  asyncHandler async handler instance
     * @throws ApiException api exception
     * @throws HttpRequestException http request exception
     * @throws HttpResponseException http response exception
     */
    public void replyUssdRequest(AsyncHandler asyncHandler)
        throws ApiException, HttpRequestException, HttpResponseException {

        // call reply ussd request
        this.replyUssdRequest(
            this.sessionId,
            this.senderAddress,
            this.address,
            this.flash,
            asyncHandler);
    }

    /**
     * Build request url.
     *
     * @param  url target url
     * @return String
     * @throws ApiException api exception
     */
    protected String buildUrl(String url) throws ApiException {
        // try parsing url
        try {
            // build url
            url = String.format(url, this.senderAddress);
            // initialize url builder
            URIBuilder builder = new URIBuilder(url);

            // set access token parameter
            builder.setParameter("access_token", this.accessToken);

            // build the url
            url = builder.build().toString();

            return url;
        } catch(URISyntaxException e) {
            // throw exception
            throw new ApiException(e.getMessage());
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy