Harness CF Android SDK
Overview
Harness is a feature management platform that helps teams to build better software and to test features quicker.
Setup
Add following snippet to root project's build.gradle
file:
buildscript {
repositories {
mavenCentral()
}
In app module's build.gradle
file add dependency for Harness's SDK
implementation 'io.harness:ff-android-client-sdk:1.0.3'
After this step, the SDK elements, primarily CfClient
should be accessible in main application.
Initialization
CfClient
is base class that provides all features of SDK. This is singleton and it is acessed with CfClient.getInstance()
.
val sdkConfiguration = CfConfiguration.builder()
.baseUrl("BASE_API_URL")
.pollingInterval(60) // Time in seconds
.enableStream(true)
.streamUrl("STREAM_URL")
.build()
val target = Target().identifier("target")
CfClient.getInstance().initialize(context, "YOUR_API_KEY", sdkConfiguration, target)
{ info, result ->
if (result.isSuccess) {
// Congratulations your SDK has been initialized with success!
// After this callback is executed, You are ready to use the SDK!
}
}
target
represents a desired target for which we want features to be evaluated.
"YOUR_API_KEY"
is a authentication key, needed for access to Harness services.
Your Harness SDK is now initialized. Congratulations!!!
Public API Methods
The Public API exposes a few methods that you can utilize:
-
public void initialize(Context context, String clientId, CfConfiguration configuration, CloudCache cloudCache, AuthCallback authCallback)
-
public boolean boolVariation(String evaluationId, boolean defaultValue)
-
public String stringVariation(String evaluationId, String defaultValue)
-
public double numberVariation(String evaluationId, double defaultValue)
-
public JSONObject jsonVariation(String evaluationId, JSONObject defaultValue)
-
public void registerEventsListener(EventsListener listener)
-
public void unregisterEventsListener(EventsListener observer)
-
public void destroy()
Fetch evaluation's value
It is possible to fetch a value for a given evaluation. Evaluation is performed based on different type. In case there is no evaluation with provided id, the default value is returned.
Use appropriate method to fetch the desired Evaluation of a certain type.
boolVariation(String evaluationId, boolean defaultValue)
//get boolean evaluation
val evaluation: Boolean = CfClient.getInstance().boolVariation("demo_evaluation", false)
numberVariation(String evaluationId, double defaultValue)
//get number evaluation
val numberEvaluation: Double = CfClient.getInstance().numberVariation("demo_number_evaluation", 0)
stringVariation(String evaluationId, String defaultValue)
//get String evaluation
val stringEvaluation: String = CfClient.getInstance().stringVariation("demo_string_evaluation", "demo_value")
Register for events
This method provides a way to register a listener for different events that might be triggered by SDK, indicating specific change in SDK itself.
private final EventsListener eventsListener = statusEvent -> {
if (statusEvent.getEventType() == EVALUATION_CHANGE) {
Evaluation evaluation = statusEvent.extractPayload();
}
}
val success = CfClient.getInstance().registerEventsListener(eventsListener)
Unregister from events
val success = CfClient.getInstance().unregisterEventsListener(eventsListener)
Triggered event will have one of the following types:
public enum EVENT_TYPE {
SSE_START,
SSE_END,
EVALUATION_CHANGE,
EVALUATION_RELOAD
}
Following table provides summary on possible event types and corresponding responses.
EVENT_TYPE | Response |
---|---|
SSE_START | - |
SSE_END | - |
EVALUATION_CHANGE | Evaluation |
EVALUATION_RELOAD | List<Evaluation> |
To avoid unexpected behaviour, when listener is not needed anymore, a caller should call
CfClient.getInstance().unregisterEventsListener(eventsListener)
. This way the sdk will remove desired listener from internal list.
Using feature flags metrics
Metrics API endpoint can be changed like this:
val remoteConfiguration = CfConfiguration.builder()
.enableStream(true)
.pollingInterval(60)
.enableAnalytics(true)
.eventUrl(METRICS_API_EVENTS_URL)
.build()
Otherwise, the default metrics endpoint URL will be used.
Shutting down the SDK
To avoid potential memory leak, when SDK is no longer needed (when the app is closed, for example), a caller should call this method
CfClient.getInstance().destroy()
Cloning the SDK repository
In order to clone SDK repository properly perform cloning like in the following example:
git clone --recurse-submodules git@github.com:drone/ff-android-client-sdk.git
Using SDK in unit tests
To be able to use the SDK in unit tests it is required to set SDKs logging to the console output:
CfLog.testModeOn()
testModeOn
will turn on the use of the system output logging strategy.
On the other hand, to turn on the usage of the Android log class use:
CfLog.runtimeModeOn()
Standard Android logging is the default logging strategy so turning on runtime mode is not required.