Documentation ¶
Index ¶
- Constants
- func MergeSetOfRules(initialRules []Rule, updates []Rule) *[]Rule
- type ErrorCode
- type EvaluationContext
- type ExperimentationRollout
- type Flag
- type InternalFlag
- func (f *InternalFlag) GetDefaultRule() *Rule
- func (f *InternalFlag) GetRuleIndexByName(name string) *int
- func (f *InternalFlag) GetRules() []Rule
- func (f *InternalFlag) GetVariationValue(name string) interface{}
- func (f *InternalFlag) GetVariations() map[string]*interface{}
- func (f *InternalFlag) GetVersion() string
- func (f *InternalFlag) IsDisable() bool
- func (f *InternalFlag) IsTrackEvents() bool
- func (f *InternalFlag) IsValid() error
- func (f *InternalFlag) Value(flagName string, user ffuser.User, evaluationCtx EvaluationContext) (interface{}, ResolutionDetails)
- type ProgressiveRollout
- type ProgressiveRolloutStep
- type ResolutionDetails
- type ResolutionReason
- type Rollout
- type Rule
- func (r *Rule) Evaluate(user ffuser.User, hashID uint32, isDefault bool) (string, error)
- func (r *Rule) GetName() string
- func (r *Rule) GetPercentages() map[string]float64
- func (r *Rule) GetProgressiveRollout() ProgressiveRollout
- func (r *Rule) GetQuery() string
- func (r *Rule) GetVariationResult() string
- func (r *Rule) IsDisable() bool
- func (r *Rule) IsDynamic() bool
- func (r *Rule) IsValid(defaultRule bool) error
- func (r *Rule) MergeRules(updatedRule Rule)
- type ScheduledStep
Constants ¶
const ( PercentageMultiplier = float64(1000) MaxPercentage = uint32(100 * PercentageMultiplier) )
const VariationSDKDefault string = "SdkDefault"
Variables ¶
This section is empty.
Functions ¶
func MergeSetOfRules ¶ added in v1.0.0
MergeSetOfRules is taking a collection of rules and merge it with the updates from a schedule steps. If you want to edit a rule this rule should have a name already to be able to target the updates to the right place.
Types ¶
type ErrorCode ¶ added in v0.27.0
type ErrorCode = string
ErrorCode is an enum following the open-feature specs about error code.
const ( // Proposed in the open-feature specs ErrorCodeProviderNotReady ErrorCode = "PROVIDER_NOT_READY" ErrorCodeFlagNotFound ErrorCode = "FLAG_NOT_FOUND" ErrorCodeParseError ErrorCode = "PARSE_ERROR" ErrorCodeTypeMismatch ErrorCode = "TYPE_MISMATCH" ErrorCodeGeneral ErrorCode = "GENERAL" // ErrorFlagConfiguration is returned when we were not able to use the flag because of a misconfiguration ErrorFlagConfiguration ErrorCode = "FLAG_CONFIG" )
type EvaluationContext ¶ added in v0.27.0
type EvaluationContext struct { // Environment is the name of your current env // this value will be added to the custom information of your user and, // it will allow to create rules based on this environment, Environment string // DefaultSdkValue is the default value of the SDK when calling the variation. DefaultSdkValue interface{} }
type ExperimentationRollout ¶ added in v1.0.0
type ExperimentationRollout struct { // Start is the starting time of the experimentation Start *time.Time `json:"start,omitempty" yaml:"start,omitempty" toml:"start,omitempty"` // End is the ending time of the experimentation End *time.Time `json:"end,omitempty" yaml:"end,omitempty" toml:"end,omitempty"` }
type Flag ¶
type Flag interface { // Value is returning the Value associate to the flag Value(flagName string, user ffuser.User, evaluationCtx EvaluationContext) (interface{}, ResolutionDetails) // GetVersion is the getter for the field Version // Default: 0.0 GetVersion() string // IsTrackEvents is the getter of the field TrackEvents // Default: true IsTrackEvents() bool // IsDisable is the getter for the field Disable // Default: false IsDisable() bool // GetVariationValue return the value of variation from his name GetVariationValue(name string) interface{} }
type InternalFlag ¶ added in v1.0.0
type InternalFlag struct { // Variations are all the variations available for this flag. You can have as many variation as needed. Variations *map[string]*interface{} `json:"variations,omitempty" yaml:"variations,omitempty" toml:"variations,omitempty"` // nolint:lll // Rules is the list of Rule for this flag. // This an optional field. Rules *[]Rule `json:"targeting,omitempty" yaml:"targeting,omitempty" toml:"targeting,omitempty"` // DefaultRule is the originalRule applied after checking that any other rules // matched the user. DefaultRule *Rule `json:"defaultRule,omitempty" yaml:"defaultRule,omitempty" toml:"defaultRule,omitempty"` // Experimentation is your struct to configure an experimentation, it will allow you to configure a start date and // an end date for your flag. // When the experimentation is not running, the flag will serve the default value. Experimentation *ExperimentationRollout `json:"experimentation,omitempty" yaml:"experimentation,omitempty" toml:"experimentation,omitempty"` // nolint: lll // Scheduled is your struct to configure an update on some fields of your flag over time. // You can add several steps that updates the flag, this is typically used if you want to gradually add more user // in your flag. Scheduled *[]ScheduledStep `json:"scheduledRollout,omitempty" yaml:"scheduledRollout,omitempty" toml:"scheduledRollout,omitempty"` // nolint: lll // TrackEvents is false if you don't want to export the data in your data exporter. // Default value is true TrackEvents *bool `json:"trackEvents,omitempty" yaml:"trackEvents,omitempty" toml:"trackEvents,omitempty"` // Disable is true if the flag is disabled. Disable *bool `json:"disable,omitempty" yaml:"disable,omitempty" toml:"disable,omitempty"` // Version (optional) This field contains the version of the flag. // The version is manually managed when you configure your flags, and it is used to display the information // in the notifications and data collection. Version *string `json:"version,omitempty" yaml:"version,omitempty" toml:"version,omitempty"` }
InternalFlag is the internal representation of a flag when using go-feature-flag. All the flags in your configuration files can have different format but will be converted into an InternalFlag to be used in the library.
func (*InternalFlag) GetDefaultRule ¶ added in v1.0.0
func (f *InternalFlag) GetDefaultRule() *Rule
GetDefaultRule is the getter of the field DefaultRule
func (*InternalFlag) GetRuleIndexByName ¶ added in v1.0.0
func (f *InternalFlag) GetRuleIndexByName(name string) *int
func (*InternalFlag) GetRules ¶ added in v1.0.0
func (f *InternalFlag) GetRules() []Rule
func (*InternalFlag) GetVariationValue ¶ added in v1.0.0
func (f *InternalFlag) GetVariationValue(name string) interface{}
GetVariationValue return the value of variation from his name
func (*InternalFlag) GetVariations ¶ added in v1.0.0
func (f *InternalFlag) GetVariations() map[string]*interface{}
GetVariations is the getter of the field Variations
func (*InternalFlag) GetVersion ¶ added in v1.0.0
func (f *InternalFlag) GetVersion() string
GetVersion is the getter for the field Version
func (*InternalFlag) IsDisable ¶ added in v1.0.0
func (f *InternalFlag) IsDisable() bool
IsDisable is the getter for the field Disable
func (*InternalFlag) IsTrackEvents ¶ added in v1.0.0
func (f *InternalFlag) IsTrackEvents() bool
IsTrackEvents is the getter of the field TrackEvents
func (*InternalFlag) IsValid ¶ added in v1.0.0
func (f *InternalFlag) IsValid() error
IsValid is checking if the current flag is valid.
func (*InternalFlag) Value ¶ added in v1.0.0
func (f *InternalFlag) Value( flagName string, user ffuser.User, evaluationCtx EvaluationContext, ) (interface{}, ResolutionDetails)
Value is returning the Value associate to the flag
type ProgressiveRollout ¶ added in v1.0.0
type ProgressiveRollout struct { // Initial contains a description of the initial state of the rollout. Initial *ProgressiveRolloutStep `json:"initial,omitempty" yaml:"initial,omitempty" toml:"initial,omitempty"` // End contains what describes the end status of the rollout. End *ProgressiveRolloutStep `json:"end,omitempty" yaml:"end,omitempty" toml:"end,omitempty"` }
ProgressiveRollout represents how to progressively roll out a originalRule.
type ProgressiveRolloutStep ¶ added in v1.0.0
type ProgressiveRolloutStep struct { // Variation - name of the variation for this step Variation *string `json:"variation,omitempty" yaml:"variation,omitempty" toml:"variation,omitempty"` // Percentage is the percentage (initial or end) for the progressive rollout Percentage *float64 `json:"percentage,omitempty" yaml:"percentage,omitempty" toml:"percentage,omitempty"` // Date is the time it starts or ends. Date *time.Time `json:"date,omitempty" yaml:"date,omitempty" toml:"date,omitempty"` }
ProgressiveRolloutStep define a progressive rollout step (initial and end)
type ResolutionDetails ¶ added in v0.27.0
type ResolutionDetails struct { // Variant indicates the name of the variant used when evaluating the flag Variant string // Reason indicates the reason of the decision Reason ResolutionReason // ErrorCode indicates the error code for this evaluation ErrorCode ErrorCode // RuleIndex indicates which rules applied RuleIndex *int // RuleName (optional) is the name of the associated rule if we have one RuleName *string // Cacheable is set to true if an SDK/provider can cache the value locally. Cacheable bool }
ResolutionDetails is the object used to manipulate the data internally, it allows to retrieve the details of your evaluation.
type ResolutionReason ¶ added in v0.27.0
type ResolutionReason = string
ResolutionReason is an enum following the open-feature specs about resolution reasons.
const ( // ReasonTargetingMatch The resolved value was the result of a dynamic evaluation, // such as a rule or specific user-targeting. // ex: serve variation A if username is Thomas ReasonTargetingMatch ResolutionReason = "TARGETING_MATCH" // ReasonTargetingMatchSplit The resolved value was the result of a dynamic evaluation, // that is serving a percentage. // ex: serve variation A to 10% of users with the username Thomas ReasonTargetingMatchSplit ResolutionReason = "TARGETING_MATCH_SPLIT" // ReasonSplit The resolved value was the result of pseudorandom assignment. // ex: serve variation A to 10% of all the users. ReasonSplit ResolutionReason = "SPLIT" // ReasonDisabled Indicates that the feature flag is disabled ReasonDisabled ResolutionReason = "DISABLED" // ReasonDefault The resolved value was the result of the flag being disabled in the management system. ReasonDefault ResolutionReason = "DEFAULT" // ReasonStatic Indicates that the feature flag evaluated to a // static value, for example, the default value for the flag // // Note: Typically means that no dynamic evaluation has been // executed for the feature flag ReasonStatic ResolutionReason = "STATIC" // ReasonUnknown Indicates an unknown issue occurred during evaluation ReasonUnknown ResolutionReason = "UNKNOWN" // ReasonError Indicates that an error occurred during evaluation // Note: The `errorCode`-field contains the details of this error ReasonError ResolutionReason = "ERROR" // ReasonOffline Indicates that GO Feature Flag is currently evaluating in offline mode. ReasonOffline ResolutionReason = "OFFLINE" )
type Rollout ¶ added in v1.0.0
type Rollout struct { // Experimentation is your struct to configure an experimentation, it will allow you to configure a start date and // an end date for your flag. // When the experimentation is not running, the flag will serve the default value. Experimentation *ExperimentationRollout `json:"experimentation,omitempty" yaml:"experimentation,omitempty" toml:"experimentation,omitempty"` // nolint: lll // Scheduled is your struct to configure an update on some fields of your flag over time. // You can add several steps that updates the flag, this is typically used if you want to gradually add more user // in your flag. Scheduled *[]ScheduledStep `json:"scheduled,omitempty" yaml:"scheduled,omitempty" toml:"scheduled,omitempty"` }
type Rule ¶ added in v1.0.0
type Rule struct { // Name is the name of the originalRule, this field is mandatory if you want // to update the originalRule during scheduled rollout Name *string `json:"name,omitempty" yaml:"name,omitempty" toml:"name,omitempty"` // Query represents an antlr query in the nikunjy/rules format Query *string `json:"query,omitempty" yaml:"query,omitempty" toml:"query,omitempty"` // VariationResult represents the variation name to use if the originalRule apply for the user. // In case we have a percentage field in the config VariationResult is ignored VariationResult *string `json:"variation,omitempty" yaml:"variation,omitempty" toml:"variation,omitempty"` // nolint: lll // Percentages represents the percentage we should give to each variation. // example: variationA = 10%, variationB = 80%, variationC = 10% Percentages *map[string]float64 `json:"percentage,omitempty" yaml:"percentage,omitempty" toml:"percentage,omitempty"` // nolint: lll // ProgressiveRollout is your struct to configure a progressive rollout deployment of your flag. // It will allow you to ramp up the percentage of your flag over time. // You can decide at which percentage you starts with and at what percentage you ends with in your release ramp. // Before the start date we will serve the initial percentage and, after we will serve the end percentage. ProgressiveRollout *ProgressiveRollout `json:"progressiveRollout,omitempty" yaml:"progressiveRollout,omitempty" toml:"progressiveRollout,omitempty"` // nolint: lll // Disable indicates that this rule is disabled. Disable *bool `json:"disable,omitempty" yaml:"disable,omitempty" toml:"disable,omitempty"` }
Rule represents a originalRule applied by the flag.
func (*Rule) Evaluate ¶ added in v1.0.0
Evaluate is checking if the originalRule apply to for the user. If yes it returns the variation you should use for this originalRule.
func (*Rule) GetPercentages ¶ added in v1.0.0
func (*Rule) GetProgressiveRollout ¶ added in v1.0.0
func (r *Rule) GetProgressiveRollout() ProgressiveRollout
func (*Rule) GetVariationResult ¶ added in v1.0.0
func (*Rule) IsDynamic ¶ added in v1.3.0
IsDynamic is a function that allows to know if the rule has a dynamic result or not.
func (*Rule) MergeRules ¶ added in v1.0.0
MergeRules is merging 2 rules. It is used when we have to update a originalRule in a scheduled rollout.
type ScheduledStep ¶ added in v1.0.0
type ScheduledStep struct { InternalFlag `yaml:",inline"` Date *time.Time `json:"date,omitempty" yaml:"date,omitempty" toml:"date,omitempty"` }
ScheduledStep is one change of the flag.