-
Notifications
You must be signed in to change notification settings - Fork 32
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(flag-decisions): Add support for sending flag decisions along with decision metadata. #405
Changes from 3 commits
b558918
ca32f1f
9cee565
fdc1afb
95409f0
029cfd5
42d7165
799e65d
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -216,7 +216,7 @@ private Variation activate(@Nullable ProjectConfig projectConfig, | |
return null; | ||
} | ||
|
||
sendImpression(projectConfig, experiment, userId, copiedAttributes, variation); | ||
sendImpression(projectConfig, experiment, userId, copiedAttributes, variation, experiment.getKey(), "experiment"); | ||
|
||
return variation; | ||
} | ||
|
@@ -225,22 +225,26 @@ private void sendImpression(@Nonnull ProjectConfig projectConfig, | |
@Nonnull Experiment experiment, | ||
@Nonnull String userId, | ||
@Nonnull Map<String, ?> filteredAttributes, | ||
@Nonnull Variation variation) { | ||
if (!experiment.isRunning()) { | ||
logger.info("Experiment has \"Launched\" status so not dispatching event during activation."); | ||
return; | ||
} | ||
@Nonnull Variation variation, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I will appreciate if you can add header doc because of no. of args. |
||
@Nonnull String flagKey, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. it should be featureFlagKey or featureKey There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. we are calling it flagKey and flagType in all other sdks. So should I change it in java-sdk? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I like flagKey which we use in Decide-API |
||
@Nonnull String flagType) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It should be featureSource, |
||
|
||
UserEvent userEvent = UserEventFactory.createImpressionEvent( | ||
projectConfig, | ||
experiment, | ||
variation, | ||
userId, | ||
filteredAttributes); | ||
filteredAttributes, | ||
flagKey, | ||
flagType); | ||
|
||
if (userEvent == null) { | ||
return; | ||
} | ||
eventProcessor.process(userEvent); | ||
logger.info("Activating user \"{}\" in experiment \"{}\".", userId, experiment.getKey()); | ||
|
||
if (experiment != null) { | ||
mnoman09 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
logger.info("Activating user \"{}\" in experiment \"{}\".", userId, experiment.getKey()); | ||
} | ||
// Kept For backwards compatibility. | ||
// This notification is deprecated and the new DecisionNotifications | ||
// are sent via their respective method calls. | ||
|
@@ -386,16 +390,22 @@ private Boolean isFeatureEnabled(@Nonnull ProjectConfig projectConfig, | |
FeatureDecision featureDecision = decisionService.getVariationForFeature(featureFlag, userId, copiedAttributes, projectConfig); | ||
Boolean featureEnabled = false; | ||
SourceInfo sourceInfo = new RolloutSourceInfo(); | ||
if (featureDecision.decisionSource != null) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. in which case, decisionSource can be null. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. when experiment and variation is null.
|
||
decisionSource = featureDecision.decisionSource; | ||
} | ||
sendImpression( | ||
projectConfig, | ||
featureDecision.experiment, | ||
userId, | ||
copiedAttributes, | ||
featureDecision.variation, | ||
featureKey, | ||
decisionSource.toString()); | ||
|
||
if (featureDecision.variation != null) { | ||
// This information is only necessary for feature tests. | ||
// For rollouts experiments and variations are an implementation detail only. | ||
if (featureDecision.decisionSource.equals(FeatureDecision.DecisionSource.FEATURE_TEST)) { | ||
sendImpression( | ||
projectConfig, | ||
featureDecision.experiment, | ||
userId, | ||
copiedAttributes, | ||
featureDecision.variation); | ||
decisionSource = featureDecision.decisionSource; | ||
sourceInfo = new FeatureTestSourceInfo(featureDecision.experiment.getKey(), featureDecision.variation.getKey()); | ||
} else { | ||
logger.info("The user \"{}\" is not included in an experiment for feature \"{}\".", | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
/** | ||
* | ||
* Copyright 2016-2019, Optimizely and contributors | ||
* Copyright 2016-2020, Optimizely and contributors | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
|
@@ -16,9 +16,11 @@ | |
*/ | ||
package com.optimizely.ab.event.internal; | ||
|
||
import com.optimizely.ab.bucketing.FeatureDecision; | ||
import com.optimizely.ab.config.Experiment; | ||
import com.optimizely.ab.config.ProjectConfig; | ||
import com.optimizely.ab.config.Variation; | ||
import com.optimizely.ab.event.internal.payload.DecisionMetadata; | ||
import com.optimizely.ab.internal.EventTagUtils; | ||
import org.slf4j.Logger; | ||
import org.slf4j.LoggerFactory; | ||
|
@@ -33,21 +35,51 @@ public static ImpressionEvent createImpressionEvent(@Nonnull ProjectConfig proje | |
@Nonnull Experiment activatedExperiment, | ||
@Nonnull Variation variation, | ||
@Nonnull String userId, | ||
@Nonnull Map<String, ?> attributes) { | ||
@Nonnull Map<String, ?> attributes, | ||
@Nonnull String flagKey, | ||
@Nonnull String flagType) { | ||
|
||
if ((FeatureDecision.DecisionSource.ROLLOUT.toString().equals(flagType) || variation == null) && !projectConfig.getSendFlagDecisions()) | ||
{ | ||
return null; | ||
} | ||
|
||
String variationKey = null; | ||
String variationID = null; | ||
if (variation != null) { | ||
variationKey = variation.getKey(); | ||
variationID = variation.getId(); | ||
} | ||
|
||
String layerID = null; | ||
String experimentId = null; | ||
String experimentKey = null; | ||
if (activatedExperiment != null) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This check for experiment shouldn't be required since it is already checked by the caller? |
||
layerID = activatedExperiment.getLayerId(); | ||
experimentId = activatedExperiment.getId(); | ||
experimentKey = activatedExperiment.getKey(); | ||
} | ||
|
||
UserContext userContext = new UserContext.Builder() | ||
.withUserId(userId) | ||
.withAttributes(attributes) | ||
.withProjectConfig(projectConfig) | ||
.build(); | ||
|
||
DecisionMetadata metadata = new DecisionMetadata.Builder() | ||
.setFlagKey(flagKey) | ||
.setFlagType(flagType) | ||
.setVariationKey(variationKey) | ||
.build(); | ||
|
||
return new ImpressionEvent.Builder() | ||
.withUserContext(userContext) | ||
.withLayerId(activatedExperiment.getLayerId()) | ||
.withExperimentId(activatedExperiment.getId()) | ||
.withExperimentKey(activatedExperiment.getKey()) | ||
.withVariationId(variation.getId()) | ||
.withVariationKey(variation.getKey()) | ||
.withLayerId(layerID) | ||
.withExperimentId(experimentId) | ||
.withExperimentKey(experimentKey) | ||
.withVariationId(variationID) | ||
.withVariationKey(variationKey) | ||
.withMetadata(metadata) | ||
.build(); | ||
} | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
please make
experiment
const orenum