VOTO Java SDK is a wrapper around the VOTO API to make it very easy to use. The goal of this SDK is to ease VOTO API integration into both Android and Java applications.
It comes with three independent modules:
- Synchronous module; Access the API synchronously
- Asynchronous module; Access the API asynchronously
- RxJava module; Access the API using RxJava
Note: These are not official libraries from the VOTO team.
###Setup Add gradle dependency:
Add jcenter repostory:
repositories {
    jcenter()
}Synchronous module:
dependencies {
    compile 'com.addhen:voto-sdk-sync:0.3.0'
}Asynchronous module:
dependencies {
    compile 'com.addhen:voto-sdk-async:0.3.0'
}RxJava module:
dependencies {
    compile 'com.addhen:voto-sdk-rxjava:0.3.0'
}- Synchronous:
SyncVotoApiClient syncVotoApilient = new SyncVotoApiClient.Builder(<api_key>)
	.withLogLevel(HttpLoggingInterceptor.Level.BODY)
	.build();- Asynchronous:
AsyncVotoApiClient asyncVotoClient = new AsyncVotoApiClient.Builder(<api_key>)
	.withLogLevel(HttpLoggingInterceptor.Level.BODY)
	.build();- RxJava:
RxJavaVotoApiClient rxVotoClient = new RxJavaVotoApiClient.Builder(<api_key>)
	.withLogLevel(HttpLoggingInterceptor.Level.BODY)
	.build();- Synchronous:
SyncVotoApiClient syncVotoApiClient = new SyncVotoApiClient.Builder("api_key")
	.withLogLevel(HttpLoggingInterceptor.Level.BODY)
	.build();
	
ListSubscribersResponse listSubscribersResponse = null;
try {
    listSubscribersResponse = syncVotoApiClient.listSubscribers(10);
} catch (IOException e) {
    e.printStackTrace();
}
System.out.println(listSubscribersResponse);- Asynchronous:
AsyncVotoApiClient asyncVotoApiClient = new AsyncVotoApiClient.Builder("api_key")
	.withLogLevel(HttpLoggingInterceptor.Level.BODY)
	.build();
	
asyncVotoApiClient.listSubscribers(10, new Callback<ListSubscribersResponse>() {
	@Override
    public void onResponse(Call<ListSubscribersResponse> call, Response<ListSubscribersResponse> response) {
    ListSubscribersResponse listSubscribersResponse = response.body();
    	System.out.println(listSubscribersResponse);
    }
    @Override
    public void onFailure(Call<ListSubscribersResponse> call, Throwable t) {
    	t.printStackTrace();
    }
});- RxJava:
RxJavaVotoApiClient rxJavaVotoApiClient = new RxJavaVotoApiClient.Builder("api_key")
	.withLogLevel(HttpLoggingInterceptor.Level.BODY)
	.build();
	
rxJavaVotoApiClient.listSubscribers(10).subscribe(new Action1<ListSubscribersResponse>() {
	@Override
	public void call(ListSubscribersResponse listSubscribersResponse) {
    	System.out.println(listSubscribersResponse);
  	}
});Make sure you've your VOTO API key set in the local.properties file located in the root directory
of the project. The property name should be votoApiKey. If you don't set this, a dummy API key will be used.
After setting the voto api key, issue ./gradlew run. This should run the sample app and output the results in the console.
Copyright 2016 Henry Addo Open Source Project
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
   http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
