This section explains how to prepare your development environment to start working with the Bluevia Java SDK. First check out the system requirements that your computer must meet, and then follow the installation steps. Once you have finished you will be able to develop your first Java application using the functionality provided by Bluevia APIs.
The Bluevia library for Java is prepared and has been tested to develop applications under Java 1.6.
Supported Operating Systems
- Windows XP (32-bit) or Vista (32- or 64-bit) or Windows 7
- Mac OS X 10.5.8 or later (x86 only)
- Linux (tested on Linux Ubuntu Hardy Heron)
The first step to start developing applications is setting up your environment.
Developing environment
- Eclipse 3.4 or greater
- Maven 2
- Maven plugin for Eclipse
It is not strictly necessary to use Eclipse and Maven as your development environment, but it is recommended to manage dependencies in your projects.
Depending on whether or not you are using Maven, you will have to add library dependencies to the project classpath or just edit your pom.xml to enable Maven to manage them:
You have to include the library in your Eclipse project and configure the dependencies:
- Download Bluevia Library and save it in your hard disk: Bluevia Java SDK
- Create your Project in Eclipse: select File > New > Java Project.
- Include the Bluevia SDK Library into the Java build path:
- As JAR file:
- Select Project > Properties.
- In Java Build Path section, click on Libraries tab.
- Click on Add External JARs and select the path where you put the BlueVia Library JAR (The SDK Jar file is included in "target" folder)).
- As source code:
- Select Project > Properties.
- In Java Build Path section, click on Source tab.
- Click on Link Source and select the path where you put the Bluevia SDK source folder in /src/main/java as linked folder location
- As JAR file:
Finally, include the JAR dependencies of Bluevia SDK in Libraries tab clicking on Add External JARs (The JAR files are included in "target/dependency" folder).
-
Download Bluevia Library and save it in your hard disk: Bluevia Java SDK
-
Create your Project in Eclipse: select File > New > Maven Project
-
Install the Bluevia Library on your Maven Local Repository:
- Right click on Maven Dependencies in your maven project and select "install or deploy an artifact to a Maven Repository
- Select the SDK Bluevia Library Jar file (included in "target" folder of Bluevia Official Library Java) as artifact file and also select POM file (also included in Bluevia Library)
- Complete the fields for group Id (bluevia), artifact Id (sdk), version (1.6) and packaging (jar) and press Finish. The sdk java library is now installed on your local maven repository with the name and version mentioned.
-
Edit the pom.xml file adding the following lines to include the Bluevia library dependencies:
<dependencies> .............. <dependency> <groupId>bluevia</groupId> <artifactId>sdk</artifactId> <version>1.6</version> </dependency> .............. </dependencies>
You can find a set of complete sample apps on this repository:
- /samples/sample : Gets advertising
- /samples/sample : Gets user and user equipement information
- /samples/sample : Gets the location of a user
- /samples/sample : Sends MMS and a Check Delivery Status (MMS MT). Receive MMS (MMS MO)
- /samples/sample : Demostrates OAuth process negotiation
- /samples/sample : Performs a Payment
- /samples/sample : Sends SMS and a Check Delivery Status (SMS MT). Receive SMS (SMS MO)
Please find below also some quick snippets on how to use the library.
Most of the APIs need have passed a complete OAuth process once before starting to use them because they will act on behalf a customer (OAuth 3-leggded mode); others, like receiving messages ones, don't need that process (OAuth 2-legged mode). The advertising API, could be used both as 3-legged and as 2-legged.
You can get your own application keys for you app at BlueVia.
BlueVia APIs authentication is based on OAuth 1.0 To get the users authorization for using BlueVia API's on their behalf, you shall do as follows. By using your API key, you have to create a request token that is required to start the OAuth process. For example:
// Create the client (you have to choose the mode and include the Consumer credentials)
BVOauth oauthClient = new BVOauth(Mode.LIVE, "consumer_key", "consumer_secret");
// Retrieve the request token
RequestToken requestToken = oauthClient.getRequestToken();
There are two alternatives to request the user authorisation:
To get user authorization using the oauth_token from your request token you have to take the user to BlueVia. The obtained request token contains the verification url to access to the BlueVia portal. Depending on the mode used, it will be available for final users (LIVE) or developers (TEST and SANDBOX). The application should enable the user (customer) to visit the url in any way, where he will have to introduce its credentials (user and password) to authorise the application to connect BlueVia APIs behalf him. Once permission has been granted, the user will obtain a PIN code necessary to exchange the request token for the access token.
Once the user confirms the authorization, you have to ask the user to enter the oauth_verifier in your app. Note that your users will need to copy and paste the oauth_verifier manually, so be clear when you request it to be sure they do not get confused.
Bluevia supports a variation of OAuth process where the user is not using the browser to authorize the application. Instead he will receive an SMS containing he PIN code (oauth_verifier). To use this SMS handshake, getRequestToken request must pass the user's MSISDN (phone number) in callback parameter. After the user had received the PIN code, the application should allow him to enter it and request the access token.
// Retrieve the request token
RequestToken requestToken = oauthClient.getRequestTokenSmsHandshake("34609090909");
With the obtained PIN code (oauth_verifier), you can now get the accessToken from the user as follows:
//Obtain the access token
OAuthToken accessToken = oauthClient.getAccessToken(oauth_verifier, token, secret);
Both token and token_secret must be saved in your application because OAuth process will require it later.
Payment API enables your application to make payments behalf the user to let him buy products or pay for services, and request the status of a previous payment. Bluevia Payment API uses an extension of OAuth protocol to guarantee secure payment operations. For each payment the user makes he must complete the OAuth process to identify itself and get a valid acess token. These tokens will be valid for 48 hours and then will be dismissed. First, you have to retrieve a request token to be authorised by the user. In this case you have to use the PaymentRequestToken object, which includes the digital good pricing besides the usual request tokens params:
BVPayment paymentClient = new BVPayment(Mode.LIVE, "consumer_key", "consumer_secret");
RequestToken requestToken = paymentClient.getPaymentRequestToken(100, "GBP", "bluevia", "service_id");
Then, take the user to BlueVia Connect to authorise the application as usual. Once you have obtained the oauth_verifier, you can now get the accessToken as follows:
OAuthToken accessToken = paymentClient.getAccessToken(verifier, token, secret); /* Get verifier from GUI */
You can also use a callback url to redirect the response with verifier from bluevia to a service on your calback url: BVPayment paymentClient = new BVPayment(Mode.LIVE, "consumer_key", "consumer_secret"); RequestToken requestToken = paymentClient.getPaymentRequestToken(100, "GBP", "bluevia", "service_id", "https://www.example.com/");
SMS API allows your app to send messages on behalf of the users, this means that their mobile number will be the text sender and they will pay for them.
BVMtSms smsClient = new BVMtSms(Mode.LIVE, "consumer_key", "consumer_secret", "access_token", "access_token_secret");
// Send the message.
String smsId = smsClient.send("600010101", "This is the text to be sent using Bluevia API");
Your application can send the same SMS to several users including multiple elements:
String[] addresses = {"600010101", "600010102", "600010103"}
String smsId = smsClient.send(addresses, "This is the text to be sent using Bluevia API");
Take into account that the recipients numbers are required to included the international country calling code.
After sending an SMS you may need to know if it has been delivered. You can poll to check the delivery status.This alternative is used typically for mobile applications without a backend server. You need to keep the deliveryStatusId to ask about the delivery status of that SMS as follows:
ArrayList<DeliveryInfo> statusObj = smsClient.getDeliveryStatus(smsId);
for (DeliveryInfo singleStatus : statusObj) {
Status status = singleStatus.getStatus();
log.info("Message status: " + status);
}
It is possible to receive status notifications by providing BlueVia with an URI where notifications must be sent. This URI is provided during the SMS sending, including the optional parameters endpoint and correlator:
// Subscribe notifications
String correlator= smsClient.startNotification(phoneNumber, endpoint, criteria);
//Unsubscribe from notification
smsClient.stopNotification(correlator);
MMS API enables your application to send an MMS on behalf of the user, check the delivery status of a sent MMS and Receive an MMS on your application.
BVMtMms mmsClient = new BVMtMms(Mode.LIVE, "consumer_key", "consumer_secret", "access_token", "access_token_secret");
Several attachments could be attached to the MMS message. The class that represent multipart attachment is Attachment, which specifies the path of the attachment and its Content-type:
// The attachment is a file located at the sdcard.
ArrayList<Attachment> attachments = new ArrayList<Attachment>();
attachments.add(new Attachment("/sdcard/image.gif", ContentType.IMAGE_GIF));
// Send the message.
String mmsId = mmsClient.send("600010101", "This is a MMS" "This is the text of the MMS to be sent using Bluevia API", attachments);
Your application can send the same MMS to several users including multiple elements, by invoking many times the addAddress method:
mms.addAddress(new UserId(Type.PHONE_NUMBER,"600010102"));
Take into account that the recipients numbers are required to included the international country calling code.
After sending an MMS you may need to know if it has been delivered. You can poll polling to check the delivery status. This alternative is used typically for mobile applications without a backend server. You need to keep the deliveryStatusId to ask about the delivery status of that MMS as follows:
ArrayList<DeliveryInfo> statusObj = mmsClient.getDeliveryStatus(mmsId);
for (DeliveryInfo singleStatus : statusObj) {
Status status = singleStatus.getStatus();
log.info("Message status: " + status);
}
It is possible to receive status notifications by providing BlueVia with an URI where notifications must be sent. This URI is provided during the SMS sending, including the optional parameters endpoint and correlator:
// Subscribe notifications
String correlator= mmsClient.startNotification(phoneNumber, endpoint, criteria);
//Unsubscribe from notification
mmsClient.stopNotification(correlator);
You can can retrieve the SMS sent to your app using OAuth-2-legged auhtorisation so no user access token is required.
BVMoSms smsMoClient = new BVMoSms(Mode.LIVE, "consumer_key", "consumer_secret");
Your application can receive SMS from users sent to BlueVia shortcodes including your application keyword. You have to take into account that you will need to remember the SMS keyword you defined when you requested you API key.
You can grab messages sent from users to you app as follows:
String registrationId = "553456"
ArrayList<SmsMessage> list = smsMoClient.getAllMessages(registrationId);
for (SmsMessage mms : list){
log.info("Received sms: " + sms.getMessage());
}
Note that this is just an example and you should implement a more efficient polling strategy.
You can can retrieve the MMS sent to your app using OAuth-2-legged auhtorisation so no user access token is required.
BVMoMms mmsClient = new BVMoMms(Mode.LIVE, "consumer_key", "consumer_secret");
Your application can receive MMS from users sent to BlueVia shortcodes including your application keyword. You have to take into account that you will need to remember the MMS keyword you defined when you requested you API key.
You can grab messages sent from users to you app as follows. The ReceivedMmsInfo object contains the information of the sent MMS, but the attachments. In order to retreive attached documents in the MMS you have to use the getMessage function, which needs the messageIdentifier available in the ReceivedMmsInfo object. The returned ReceivedMms object contains the info of the Mms itself and a list of MimeContent objects with the content of the attachments:
String registrationId = "546780"
ArrayList<MmsMessageInfo> list = mmsMoClient.getAllMessages(registrationId, false);
for (MmsMessageInfo info : list){
MmsMessage message = mmsMoClient.getMessage(registrationId, info.getMessageId());
for (MimeContent attachment : message.getAttachments()){
// You can save on do any stuff with the attachments
}
}
Note that this is just an example and you should implement a more efficient polling strategy
User Context API enables your application to get information about the user's customer profile in order to know more about your users to targetize better your product.
BVDirectory directoryClient = new BVDirectory(
Mode.LIVE, "consumer_key", "consumer_secret", "access_token", "access_token_secret");
Profile profile = directoryClient.getProfile();
AccessInfo accessInfo = directoryClient.getAccessInfo();
PersonalInfo personalInfo = directoryClient.getPersonalInfo();
TerminalInfo terminalInfo = directoryClient.getTerminalInfo();
If you want to configure a filter on the information relevant for your application you can do it for any of the requests above:
TerminalInfo.Fields[] fields = {Fields.BRAND, Fields.MODEL, Fields.MMS, Fields.WAP, Fields.SCREEN_RESOLUTION};
TerminalInfo terminalInfo = directoryClient.getTerminalInfo(fields);
Location API enables your application to retrieve the geographical coordinates of user. These geographical coordinates are expressed through a latitude, longitude, altitude and accuracy.
The acceptableAccuracy (optional) parameter expresses the range in meters that the application considers useful. If the location cannot be determined within this range, then the application would prefer not to receive the information. Once the server responds the user have to retrieve the location information from the returned LocationDataType instance. The LocationDataType includes the status of the client request and the LocationInfoType member which contains the location information.
int acceptableAccuracy = 500;
BVLocation locationClient = new BVLocation(Mode.LIVE, "consumer_key", "consumer_secret", "access_token", "access_token_secret");
LocationInfo info = locationClient.getLocation(acceptableAccuracy);
Adverstising API enables your application to retrieve advertisements.
You can invoke this API using a 3-leddged client (ouath process passed) or a 2-legged client. This is selected in the client instantiating. Once configured your client is ready to get advertisements. When retrieving a simple advertisement you can specify a set of request parameters such as banner size, protection policy, etc. Mandatory parameters are adSpace, that is the identifier you obtained when you registered your application within the Bluevia portal; and protectionPolicy. The adRequetsId is an optional parameter (if it is not supplied, the SDK will generate one). For a more detailed description please see the API Reference.
BVAdvertising adClient = new BVAdvertising(Mode.LIVE, "consumer_key", "consumer_secret");
SimpleResponse response = adClient.getAdvertising2l("12921", "UK", null, String adRequestId, Type.IMAGE, null, ProtectionPolicyType.SAFE, null);
ArrayList<CreativeElement> ad = response.getAdvertisingList();
Take into account that the Protection Policy sets the rules for adult advertising, please be careful.
- ProtectionPolicyType.LOW : Low, moderately explicit content (I am youth; you can show me moderately explicit content).
- ProtectionPolicyType.SAFE : Safe, not rated content (I am a kid, please, show me only safe content).
- ProtectionPolicyType.HIGH : High, explicit content (I am an adult; I am over 18 so you can show me any content including very explicit content).