OptimizelyDecision for the Go SDK
Details the OptimizelyDecision object for the Optimizely Feature Experimentation Go SDK, which is returned from the decide methods in Optimizely Feature Experimentation.
Version
SDK v1.6.0 and higher
Object model
The following shows the object model for the OptimizelyDecision object.
type OptimizelyDecision struct {
	VariationKey string
	Enabled      bool
	Variables    *optimizelyjson.OptimizelyJSON
	RuleKey      string
	FlagKey      string
	UserContext  OptimizelyUserContext
	Reasons      []string
}The following table describes the fields of the OptimizelyDecision object:
| Field | Type | Description | 
|---|---|---|
| enabled | Boolean | Whether the flag is enabled or not. Optimizely never returns nil for this field; it returns false when it fails to make a decision due to an error. | 
| variables | OptimizelyJSON | Key-value pairs of all the flag variables. When there are no variables defined for the flag or SDK cannot get variables, this field returns an empty object. When SDK fails to get variables for a decision, the Reasons field includes the error messages regardless of the Include Reasons option. | 
| variation key | String | When SDK fails to make a decision, this field returns nil and the Reasons field includes the log messages if the Include Reasons option is set. | 
| rule key | String | The key of the flag rule that the user bucketed into for this decision. | 
| flag key | String | The key of the flag for which the decision was made. | 
| user context | OptimizelyUserContext | The user associated with the call to the Decide method. | 
| reasons | Array | An array of relevant error and log messages, in chronological order. Optimizely Feature Experimentation returns messages in this field: 
 See the following section for more information. | 
Reasons
The returned decision object includes error and log messages in the Reasons field.
Error reasons
For the sake of consistency with other decision results, Optimizely Feature Experimentation returns a decision with empty fields instead of throwing errors or exceptions.
Critical errors are always included in the reasons field of the returned decision object regardless of the include reasons option you set on the Decide method.
| Error | Possible reasons | 
|---|---|
| empty   | 
 | 
| empty  | 
 | 
Log reasons
Optimizely Feature Experimentation collects log messages in the reasons field of the returned OptimizelyDecision object in the order in which they are logged.
The following types of log messages are only included in the reasons field if you set the include reasons option on the Decide method:
- Log messages related to bucketing users based on audiences or attributes.
- Log messages related to bucketing users based on traffic percentages.
Examples
For an example of a returned decision object, see Decide methods.
Updated 3 days ago