flag

package
v1.0.0-rc.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 6, 2023 License: MIT Imports: 8 Imported by: 0

Documentation

Index

Constants

View Source
const (
	PercentageMultiplier = float64(1000)
	MaxPercentage        = uint32(100 * PercentageMultiplier)
)
View Source
const VariationSDKDefault string = "SdkDefault"

Variables

This section is empty.

Functions

func MergeSetOfRules added in v1.0.0

func MergeSetOfRules(initialRules []Rule, updates []Rule) *[]Rule

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 (True / False / Default )
	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
}

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 Indicates that the feature flag is targeting
	// 100% of the targeting audience,
	// e.g. 100% rollout percentage
	ReasonTargetingMatch ResolutionReason = "TARGETING_MATCH"

	// ReasonSplit Indicates that the feature flag is targeting
	// a subset of the targeting audience,
	// e.g. less than 100% rollout percentage
	ReasonSplit ResolutionReason = "SPLIT"

	// ReasonDisabled Indicates that the feature flag is disabled
	ReasonDisabled ResolutionReason = "DISABLED"

	// ReasonDefault Indicates that the feature flag evaluated to the default value
	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"
)

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

func (r *Rule) Evaluate(user ffuser.User, hashID uint32, isDefault bool,
) (string, error)

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) GetName added in v1.0.0

func (r *Rule) GetName() string

func (*Rule) GetPercentages added in v1.0.0

func (r *Rule) GetPercentages() map[string]float64

func (*Rule) GetProgressiveRollout added in v1.0.0

func (r *Rule) GetProgressiveRollout() ProgressiveRollout

func (*Rule) GetQuery added in v1.0.0

func (r *Rule) GetQuery() string

func (*Rule) GetVariationResult added in v1.0.0

func (r *Rule) GetVariationResult() string

func (*Rule) IsDisable added in v1.0.0

func (r *Rule) IsDisable() bool

func (*Rule) IsValid added in v1.0.0

func (r *Rule) IsValid(defaultRule bool) error

IsValid is checking if the rule is valid

func (*Rule) MergeRules added in v1.0.0

func (r *Rule) MergeRules(updatedRule Rule)

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.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL