Please refer to this link for the detailed installation of Globe Connect React Native SDK.
If you haven't signed up yet, please follow the instructions found in Getting Started to obtain an App ID
and App Secret
these tokens will be used to validate most of your interaction requests with the Globe APIs.
The authenication process follows the protocols of **OAuth 2.0**. The example code below shows how you can swap your app tokens for an access token.
var auth = GlobeConnect.Authentication(
'[app_id]',
'[app_secret]');
auth.startAuthActivity(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"access_token":"1ixLbltjWkzwqLMXT-8UF-UQeKRma0hOOWFA6o91oXw",
"subscriber_number":"9171234567"
}
Short Message Service (SMS) enables your application or service to send and receive secure, targeted text messages and alerts to your Globe / TM subscribers.
Note: All API calls must include the access_token as one of the Universal Resource Identifier (URI) parameters.
Send an SMS message to one or more mobile terminals:
import GlobeConnect from 'react-native-globeapi';
var sms = GlobeConnect.Sms(
'[short_code]',
'[access_token]'
);
sms
.setClientCorrelator('[client_correlator]')
.setReceiverAddress('[subscriber_number]')
.setMessage('[message]');
sms.sendMessage(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"outboundSMSMessageRequest": {
"address": "tel:+639175595283",
"deliveryInfoList": {
"deliveryInfo": [],
"resourceURL": "https://devapi.globelabs.com.ph/smsmessaging/v1/outbound/8011/requests?access_token=3YM8xurK_IPdhvX4OUWXQljcHTIPgQDdTESLXDIes4g"
},
"senderAddress": "8011",
"outboundSMSTextMessage": {
"message": "Hello World"
},
"receiptRequest": {
"notifyURL": "http://test-sms1.herokuapp.com/callback",
"callbackData": null,
"senderName": null,
"resourceURL": "https://devapi.globelabs.com.ph/smsmessaging/v1/outbound/8011/requests?access_token=3YM8xurK_IPdhvX4OUWXQljcHTIPgQDdTESLXDIes4g"
}
}
}
Send binary data through SMS:
import GlobeConnect from 'react-native-globeapi';
var binary = GlobeConnect.BinarySms(
'[short_code]',
'[access_token]'
);
binary
.setUserDataHeader('[data_header]')
.setDataCodingScheme([coding_scheme])
.setReceiverAddress('[receiver_address]')
.setBinaryMessage('[message]');
binary.sendBinaryMessage(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"outboundBinaryMessageRequest": {
"address": "9171234567",
"deliveryInfoList": {
"deliveryInfo": [],
"resourceURL": "https://devapi.globelabs.com.ph/binarymessaging/v1/outbound/{senderAddress}/requests?access_token={access_token}",
"senderAddress": "21581234",
"userDataHeader": "06050423F423F4",
"dataCodingScheme": 1,
"outboundBinaryMessage": {
"message": "samplebinarymessage"
},
"receiptRequest": {
"notifyURL": "http://example.com/notify",
"callbackData": null,
"senderName": null
},
"resourceURL": "https://devapi.globelabs.com.ph/binarymessaging/v1/outbound/{senderAddress}/requests?access_token={access_token}"
}
}
USSD are basic features built on most smart phones which allows the phone owner to interact with menu item choices.
The following example shows how to send a USSD request.
import GlobeConnect from 'react-native-globeapi';
var ussd = GlobeConnect.Ussd('[access_token]');
ussd
.setSenderAddress('[short_code]')
.setUssdMessage('[message]')
.setAddress('[subscriber_address]')
.setFlash([flash])
.sendUssdRequest(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"outboundUSSDMessageRequest": {
"address": "639954895489",
"deliveryInfoList": {
"deliveryInfo": [],
"resourceURL": "https://devapi.globelabs.com.ph/ussd/v1/outbound/21589996/reply/requests?access_token=access_token"
},
"senderAddress": "21580001",
"outboundUSSDMessage": {
"message": "Simple USSD Message\nOption - 1\nOption - 2"
},
"receiptRequest": {
"ussdNotifyURL": "http://example.com/notify",
"sessionID": "012345678912"
},
"resourceURL": "https://devapi.globelabs.com.ph/ussd/v1/outbound/21589996/reply/requests?access_token=access_token"
}
}
The following example shows how to send a USSD reply.
import GlobeConnect from 'react-native-globeapi';
var ussd = GlobeConnect.Ussd('[access_token]');
ussd
.setSessionId('[session_id]')
.setAddress('[subscriber_address]')
.setSenderAddress('[short_code]')
.setUssdMessage('[message]')
.setFlash([flash])
.replyUssdRequest(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"outboundUSSDMessageRequest": {
"address": "639954895489",
"deliveryInfoList": {
"deliveryInfo": [],
"resourceURL": "https://devapi.globelabs.com.ph/ussd/v1/outbound/21589996/reply/requests?access_token=access_token"
},
"senderAddress": "21580001",
"outboundUSSDMessage": {
"message": "Simple USSD Message\nOption - 1\nOption - 2"
},
"receiptRequest": {
"ussdNotifyURL": "http://example.com/notify",
"sessionID": "012345678912",
"referenceID": "f7b61b82054e4b5e"
},
"resourceURL": "https://devapi.globelabs.com.ph/ussd/v1/outbound/21589996/reply/requests?access_token=access_token"
}
}
Your application can monetize services from customer's phone load by sending a payment request to the customer, in which they can opt to accept.
The following example shows how you can request for a payment from a customer.
import GlobeConnect from 'react-native-globeapi';
var payment = GlobeConnect.Payment('[access_token]');
payment
.setAppId('[app_id]')
.setAppSecret('[app_secret]')
.setAmount([amount])
.setDescription('[description]')
.setEndUserId('[subscriber_number]')
.setReferenceCode('[reference]')
.setTransactionOperationStatus('[status]')
.sendPaymentRequest(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"amountTransaction":
{
"endUserId": "9171234567",
"paymentAmount":
{
"chargingInformation":
{
"amount": "0.00",
"currency": "PHP",
"description": "my application"
},
"totalAmountCharged": "0.00"
},
"referenceCode": "12341000023",
"serverReferenceCode": "528f5369b390e16a62000006",
"resourceURL": null
}
}
The following example shows how you can get the last reference of payment.
import GlobeConnect from 'react-native-globeapi';
var payment = GlobeConnect.Payment('[access_token]');
payment
.setAppId('[app_id]')
.setAppSecret('[app_secret]')
.getLastReferenceCode(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"referenceCode": "12341000005",
"status": "SUCCESS",
"shortcode": "21581234"
}
Amax is an automated promo builder you can use with your app to award customers with certain globe perks.
import GlobeConnect from 'react-native-globeapi';
var amax = GlobeConnect.Amax(
'[app_id]',
'[app_secret]'
);
amax
.setAddress('[subscriber_number]')
.setRewardsToken('[rewards_token]')
.setPromo('[promo]');
amax.sendRewardRequest(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"outboundRewardRequest": {
"transaction_id": 566,
"status": "Please check your AMAX URL for status",
"address": "9065272450",
"promo": "FREE10MB"
}
}
To determine a general area (lat,lng) of your customers you can utilize this feature.
import GlobeConnect from 'react-native-globeapi';
var location = GlobeConnect.Location('[access_token]');
location
.setAddress('[subscriber_number]')
.setRequestedAccuracy([accuracy]);
location.getLocation(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"terminalLocationList": {
"terminalLocation": {
"address": "tel:9171234567",
"currentLocation": {
"accuracy": 100,
"latitude": "14.5609722",
"longitude": "121.0193394",
"map_url": "http://maps.google.com/maps?z=17&t=m&q=loc:14.5609722+121.0193394",
"timestamp": "Fri Jun 06 2014 09:25:15 GMT+0000 (UTC)"
},
"locationRetrievalStatus": "Retrieved"
}
}
}
Subscriber Data Query API interface allows a Web application to query the customer profile of an end user who is the customer of a mobile network operator.
The following example shows how you can get the subscriber balance.
import GlobeConnect from 'react-native-globeapi';
var subscriber = GlobeConnect.Subscriber('[access_token]');
subscriber
.setAddress('[subscriber_number]')
.getSubscriberBalance(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"terminalLocationList":
{
"terminalLocation":
[
{
address: "639171234567",
subBalance: "60200"
}
]
}
}
The following example shows how you can get the subscriber reload amount.
import GlobeConnect from 'react-native-globeapi';
var subscriber = GlobeConnect.Subscriber('[access_token]');
subscriber
.setAddress('[subscriber_address]')
.getSubscriberReloadAmount(function() {
console.log(arguments);
}, function() {
console.log(arguments);
});
{
"terminalLocationList":
{
"terminalLocation":
[
{
address: "639171234567",
reloadAmount: "30000"
}
]
}
}