From 1565443b90c5b18b60facae197944e2ba292991a Mon Sep 17 00:00:00 2001 From: Alessandro Yuichi Okimoto Date: Fri, 18 Oct 2024 13:53:17 +0900 Subject: [PATCH] docs: update android variation details (#136) Signed-off-by: Alessandro Yuichi Okimoto --- docs/sdk/client-side/android/index.md | 148 ++++++++++++++++++-------- 1 file changed, 103 insertions(+), 45 deletions(-) diff --git a/docs/sdk/client-side/android/index.md b/docs/sdk/client-side/android/index.md index 184f461..6402ba4 100644 --- a/docs/sdk/client-side/android/index.md +++ b/docs/sdk/client-side/android/index.md @@ -293,6 +293,12 @@ The variation method will return the default value if the feature flag is missin The Bucketeer SDK supports the following variation types. +:::caution Deprecated + +The `jsonVariation` interface is deprecated. Please use the `objectVariation` instead. + +::: + @@ -305,7 +311,103 @@ fun intVariation(featureId: String, defaultValue: Int): Int fun doubleVariation(featureId: String, defaultValue: Double): Double -fun jsonVariation(featureId: String, defaultValue: JSONObject): JSONObject +fun objectVariation(featureId: String, defaultValue: BKTValue): BKTValue +``` + + + + +### Getting evaluation details + +The following methods will return the **evaluation details** for a specific feature flag. If the feature flag is missing in the SDK's cache, the variable `reason` value will be `CLIENT`, which means the default value was returned. + +This is useful if you use another A/B Test solution with Bucketeer and need to know the variation name, reason, and other information. + +:::caution Deprecated + +The `evaluationDetails` interface is deprecated. Please use the following [interfaces](#interface). + +::: + + +#### Interface + + + + +```kotlin showLineNumbers +fun boolVariationDetails( + featureId: String, + defaultValue: Boolean, +): BKTEvaluationDetails + +fun stringVariationDetails( + featureId: String, + defaultValue: String, +): BKTEvaluationDetails + +fun intVariationDetails( + featureId: String, + defaultValue: Int, +): BKTEvaluationDetails + +fun doubleVariationDetails( + featureId: String, + defaultValue: Double, +): BKTEvaluationDetails + +fun objectVariationDetails( + featureId: String, + defaultValue: BKTValue, +): BKTEvaluationDetails +``` + + + + +#### Object + + + + +```kotlin showLineNumbers +data class BKTEvaluationDetails( + val featureId: String, + val featureVersion: Int, + val userId: String, + val variationId: String, + val variationName: String, + val variationValue: T, + val reason: Reason, +) { + enum class Reason { + TARGET, // Evaluated using an Individual targeting + RULE, // Evaluated using a custom Rule targeting + DEFAULT, // Evaluated using the Default Strategy + CLIENT, // The flag is missing in the cache. The default value was returned + OFF_VARIATION, // Evaluated using the Off Variation + PREREQUISITE, // Evaluated using a Prerequiste targeting + + ; + } +} +``` + + + + +#### Usage + + + + +```kotlin showLineNumbers +val showNewFeature = client.boolVariationDetails("YOUR_FEATURE_FLAG_ID", false) +if (showNewFeature.variationValue) { + // The Application code to show the new feature +} else { + // The code to run when the feature is off +} ``` @@ -527,50 +629,6 @@ val user = client.currentUser() -### Getting evaluation details - -This method will return the **evaluation details** for a specific feature flag or will return **null** if the feature flag is missing in the SDK's cache. - -This is useful if you use another A/B Test solution with Bucketeer and need to know the variation name, reason, and other information. - -
- Evaluation details - - - - ```kotlin showLineNumbers - data class BKTEvaluation( - var id: String, - val featureId: String, - val featureVersion: Int, - val userId: String, - val variationId: String, - val variationName: String, - val variationValue: String, - val reason: Reason, - ) - ``` - - - -
- -:::caution - -Do not call this method without calling the [Evaluating user method](#evaluating-user). The Evaluating user method must always be called because it generates analytics events that will be sent to the server. - -::: - - - - -```kotlin showLineNumbers -val evaluationDetails = client.evaluationDetails("YOUR_FEATURE_FLAG_ID") -``` - - - - ### Listening to evaluation updates