ldvalue

package
v2.5.1 Latest Latest
Warning

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

Go to latest
Published: Jun 30, 2022 License: Apache-2.0 Imports: 8 Imported by: 28

Documentation

Overview

Package ldvalue provides an abstraction of the LaunchDarkly SDK's general value type. LaunchDarkly supports the standard JSON data types of null, boolean, number, string, array, and object (map), for any feature flag variation or custom user attribute. The ldvalue.Value type can contain any of these.

This package also provides the helper types OptionalBool, OptionalInt, and OptionalString, which are safer alternatives to using pointers for optional values.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type ArrayBuilder

type ArrayBuilder interface {
	// Add appends an element to the array builder.
	Add(value Value) ArrayBuilder
	// Build creates a Value containing the previously added array elements. Continuing to modify the
	// same builder by calling Add after that point does not affect the returned array.
	Build() Value
}

ArrayBuilder is a builder created by ArrayBuild(), for creating immutable arrays.

An ArrayBuilder should not be accessed by multiple goroutines at once.

func ArrayBuild

func ArrayBuild() ArrayBuilder

ArrayBuild creates a builder for constructing an immutable array Value.

arrayValue := ldvalue.ArrayBuild().Add(ldvalue.Int(100)).Add(ldvalue.Int(200)).Build()

func ArrayBuildWithCapacity

func ArrayBuildWithCapacity(capacity int) ArrayBuilder

ArrayBuildWithCapacity creates a builder for constructing an immutable array Value.

The capacity parameter is the same as the capacity of a slice, allowing you to preallocate space if you know the number of elements; otherwise you can pass zero.

arrayValue := ldvalue.ArrayBuildWithCapacity(2).Add(ldvalue.Int(100)).Add(ldvalue.Int(200)).Build()

type ObjectBuilder

type ObjectBuilder interface {
	// Set sets a key-value pair in the object builder.
	Set(key string, value Value) ObjectBuilder
	// Build creates a Value containing the previously specified key-value pairs. Continuing to modify
	// the same builder by calling Set after that point does not affect the returned object.
	Build() Value
}

ObjectBuilder is a builder created by ObjectBuild(), for creating immutable JSON objects.

An ObjectBuilder should not be accessed by multiple goroutines at once.

func ObjectBuild

func ObjectBuild() ObjectBuilder

ObjectBuild creates a builder for constructing an immutable JSON object Value.

objValue := ldvalue.ObjectBuild().Set("a", ldvalue.Int(100)).Set("b", ldvalue.Int(200)).Build()

func ObjectBuildWithCapacity

func ObjectBuildWithCapacity(capacity int) ObjectBuilder

ObjectBuildWithCapacity creates a builder for constructing an immutable JSON object Value.

The capacity parameter is the same as the capacity of a map, allowing you to preallocate space if you know the number of elements; otherwise you can pass zero.

objValue := ldvalue.ObjectBuildWithCapacity(2).Set("a", ldvalue.Int(100)).Set("b", ldvalue.Int(200)).Build()

type OptionalBool

type OptionalBool struct {
	// contains filtered or unexported fields
}

OptionalBool represents a bool that may or may not have a value. This is similar to using a bool pointer to distinguish between a false value and nil, but it is safer because it does not expose a pointer to any mutable value.

To create an instance with a bool value, use NewOptionalBool. There is no corresponding method for creating an instance with no value; simply use the empty literal OptionalBool{}.

ob1 := NewOptionalBool(1)
ob2 := NewOptionalBool(false) // this has a value which is false
ob3 := OptionalBool{}         // this does not have a value

This can also be used as a convenient way to construct a bool pointer within an expression. For instance, this example causes myIntPointer to point to the bool value true:

var myBoolPointer *int = NewOptionalBool(true).AsPointer()

This type is used in the Anonymous property of lduser.User, and for other similar fields in the LaunchDarkly Go SDK where a bool value may or may not be defined.

func NewOptionalBool

func NewOptionalBool(value bool) OptionalBool

NewOptionalBool constructs an OptionalBool that has a bool value.

There is no corresponding method for creating an OptionalBool with no value; simply use the empty literal OptionalBool{}.

func NewOptionalBoolFromPointer

func NewOptionalBoolFromPointer(valuePointer *bool) OptionalBool

NewOptionalBoolFromPointer constructs an OptionalBool from a bool pointer. If the pointer is non-nil, then the OptionalBool copies its value; otherwise the OptionalBool has no value.

func (OptionalBool) AsPointer

func (o OptionalBool) AsPointer() *bool

AsPointer returns the OptionalBool's value as a bool pointer if it has a value, or nil otherwise.

The bool value, if any, is copied rather than returning to a pointer to the internal field.

func (OptionalBool) AsValue

func (o OptionalBool) AsValue() Value

AsValue converts the OptionalBool to a Value, which is either Null() or a boolean value.

func (OptionalBool) BoolValue

func (o OptionalBool) BoolValue() bool

BoolValue returns the OptionalBool's value, or false if it has no value.

func (OptionalBool) Get

func (o OptionalBool) Get() (bool, bool)

Get is a combination of BoolValue and IsDefined. If the OptionalBool contains a bool value, it returns that value and true; otherwise it returns false and false.

func (OptionalBool) IsDefined

func (o OptionalBool) IsDefined() bool

IsDefined returns true if the OptionalBool contains a bool value, or false if it has no value.

func (OptionalBool) MarshalJSON

func (o OptionalBool) MarshalJSON() ([]byte, error)

MarshalJSON converts the OptionalBool to its JSON representation.

The output will be either a JSON boolean or null. Note that the "omitempty" tag for a struct field will not cause an empty OptionalBool field to be omitted; it will be output as null. If you want to completely omit a JSON property when there is no value, it must be a bool pointer instead of an OptionalBool; use the AsPointer() method to get a pointer.

func (OptionalBool) MarshalText

func (o OptionalBool) MarshalText() ([]byte, error)

MarshalText implements the encoding.TextMarshaler interface.

func (OptionalBool) OrElse

func (o OptionalBool) OrElse(valueIfEmpty bool) bool

OrElse returns the OptionalBool's value if it has one, or else the specified fallback value.

func (*OptionalBool) ReadFromJSONReader added in v2.2.0

func (o *OptionalBool) ReadFromJSONReader(r *jreader.Reader)

ReadFromJSONReader provides JSON deserialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Unmarshal. See https://github.com/launchdarkly/go-jsonstream for more details.

func (OptionalBool) String

func (o OptionalBool) String() string

String is a debugging convenience method that returns a description of the OptionalBool. This is either "true", "false, or "[none]" if it has no value.

func (*OptionalBool) UnmarshalJSON

func (o *OptionalBool) UnmarshalJSON(data []byte) error

UnmarshalJSON parses an OptionalBool from JSON.

The input must be either a JSON number that is a boolean or null.

func (*OptionalBool) UnmarshalText

func (o *OptionalBool) UnmarshalText(text []byte) error

UnmarshalText implements the encoding.TextUnmarshaler interface.

This allows OptionalBool to be used with packages that can parse text content, such as gcfg.

func (OptionalBool) WriteToJSONBuffer deprecated

func (o OptionalBool) WriteToJSONBuffer(j *jsonstream.JSONBuffer)

WriteToJSONBuffer provides JSON serialization for use with the deprecated jsonstream API.

Deprecated: this method is provided for backward compatibility. The LaunchDarkly SDK no longer uses this API; instead it uses the newer https://github.com/launchdarkly/go-jsonstream.

func (OptionalBool) WriteToJSONWriter added in v2.2.0

func (o OptionalBool) WriteToJSONWriter(w *jwriter.Writer)

WriteToJSONWriter provides JSON serialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Marshal. See https://github.com/launchdarkly/go-jsonstream for more details.

type OptionalInt

type OptionalInt struct {
	// contains filtered or unexported fields
}

OptionalInt represents an int that may or may not have a value. This is similar to using an int pointer to distinguish between a zero value and nil, but it is safer because it does not expose a pointer to any mutable value.

To create an instance with an int value, use NewOptionalInt. There is no corresponding method for creating an instance with no value; simply use the empty literal OptionalInt{}.

oi1 := NewOptionalInt(1)
oi2 := NewOptionalInt(0) // this has a value which is zero
oi3 := OptionalInt{}     // this does not have a value

This can also be used as a convenient way to construct an int pointer within an expression. For instance, this example causes myIntPointer to point to the int value 2:

var myIntPointer *int = NewOptionalInt("x").AsPointer()

This type is used in ldreason.EvaluationDetail.VariationIndex, and for other similar fields in the LaunchDarkly Go SDK where an int value may or may not be defined.

func NewOptionalInt

func NewOptionalInt(value int) OptionalInt

NewOptionalInt constructs an OptionalInt that has an int value.

There is no corresponding method for creating an OptionalInt with no value; simply use the empty literal OptionalInt{}.

func NewOptionalIntFromPointer

func NewOptionalIntFromPointer(valuePointer *int) OptionalInt

NewOptionalIntFromPointer constructs an OptionalInt from an int pointer. If the pointer is non-nil, then the OptionalInt copies its value; otherwise the OptionalInt has no value.

func (OptionalInt) AsPointer

func (o OptionalInt) AsPointer() *int

AsPointer returns the OptionalInt's value as an int pointer if it has a value, or nil otherwise.

The int value, if any, is copied rather than returning to a pointer to the internal field.

func (OptionalInt) AsValue

func (o OptionalInt) AsValue() Value

AsValue converts the OptionalInt to a Value, which is either Null() or a number value.

func (OptionalInt) Get

func (o OptionalInt) Get() (int, bool)

Get is a combination of IntValue and IsDefined. If the OptionalInt contains an int value, it returns that value and true; otherwise it returns zero and false.

func (OptionalInt) IntValue

func (o OptionalInt) IntValue() int

IntValue returns the OptionalInt's value, or zero if it has no value.

func (OptionalInt) IsDefined

func (o OptionalInt) IsDefined() bool

IsDefined returns true if the OptionalInt contains an int value, or false if it has no value.

func (OptionalInt) MarshalJSON

func (o OptionalInt) MarshalJSON() ([]byte, error)

MarshalJSON converts the OptionalInt to its JSON representation.

The output will be either a JSON number or null. Note that the "omitempty" tag for a struct field will not cause an empty OptionalInt field to be omitted; it will be output as null. If you want to completely omit a JSON property when there is no value, it must be an int pointer instead of an OptionalInt; use the AsPointer() method to get a pointer.

func (OptionalInt) MarshalText

func (o OptionalInt) MarshalText() ([]byte, error)

MarshalText implements the encoding.TextMarshaler interface.

func (OptionalInt) OrElse

func (o OptionalInt) OrElse(valueIfEmpty int) int

OrElse returns the OptionalInt's value if it has one, or else the specified fallback value.

func (*OptionalInt) ReadFromJSONReader added in v2.2.0

func (o *OptionalInt) ReadFromJSONReader(r *jreader.Reader)

ReadFromJSONReader provides JSON deserialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Unmarshal. See https://github.com/launchdarkly/go-jsonstream for more details.

func (OptionalInt) String

func (o OptionalInt) String() string

String is a debugging convenience method that returns a description of the OptionalInt. This is either a numeric string, or "[none]" if it has no value.

func (*OptionalInt) UnmarshalJSON

func (o *OptionalInt) UnmarshalJSON(data []byte) error

UnmarshalJSON parses an OptionalInt from JSON.

The input must be either a JSON number that is an integer or null.

func (*OptionalInt) UnmarshalText

func (o *OptionalInt) UnmarshalText(text []byte) error

UnmarshalText implements the encoding.TextUnmarshaler interface.

This allows OptionalInt to be used with packages that can parse text content, such as gcfg.

func (OptionalInt) WriteToJSONBuffer deprecated

func (o OptionalInt) WriteToJSONBuffer(j *jsonstream.JSONBuffer)

WriteToJSONBuffer provides JSON serialization for use with the deprecated jsonstream API.

Deprecated: this method is provided for backward compatibility. The LaunchDarkly SDK no longer uses this API; instead it uses the newer https://github.com/launchdarkly/go-jsonstream.

func (OptionalInt) WriteToJSONWriter added in v2.2.0

func (o OptionalInt) WriteToJSONWriter(w *jwriter.Writer)

WriteToJSONWriter provides JSON serialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Marshal. See https://github.com/launchdarkly/go-jsonstream for more details.

type OptionalString

type OptionalString struct {
	// contains filtered or unexported fields
}

OptionalString represents a string that may or may not have a value. This is similar to using a string pointer to distinguish between an empty string and nil, but it is safer because it does not expose a pointer to any mutable value.

Unlike Value, which can contain a value of any JSON-compatible type, OptionalString either contains a string or nothing. To create an instance with a string value, use NewOptionalString. There is no corresponding method for creating an instance with no value; simply use the empty literal OptionalString{}.

os1 := NewOptionalString("this has a value")
os2 := NewOptionalString("") // this has a value which is an empty string
os2 := OptionalString{} // this does not have a value

This can also be used as a convenient way to construct a string pointer within an expression. For instance, this example causes myStringPointer to point to the string "x":

var myStringPointer *string = NewOptionalString("x").AsPointer()

func NewOptionalString

func NewOptionalString(value string) OptionalString

NewOptionalString constructs an OptionalString that has a string value.

There is no corresponding method for creating an OptionalString with no value; simply use the empty literal OptionalString{}.

func NewOptionalStringFromPointer

func NewOptionalStringFromPointer(valuePointer *string) OptionalString

NewOptionalStringFromPointer constructs an OptionalString from a string pointer. If the pointer is non-nil, then the OptionalString copies its value; otherwise the OptionalString has no value.

func (OptionalString) AsPointer

func (o OptionalString) AsPointer() *string

AsPointer returns the OptionalString's value as a string pointer if it has a value, or nil otherwise.

The string value, if any, is copied rather than returning to a pointer to the internal field.

func (OptionalString) AsValue

func (o OptionalString) AsValue() Value

AsValue converts the OptionalString to a Value, which is either Null() or a string value.

func (OptionalString) Get

func (o OptionalString) Get() (string, bool)

Get is a combination of StringValue and IsDefined. If the OptionalString contains a string value, it returns that value and true; otherwise it returns an empty string and false.

func (OptionalString) IsDefined

func (o OptionalString) IsDefined() bool

IsDefined returns true if the OptionalString contains a string value, or false if it has no value.

func (OptionalString) MarshalJSON

func (o OptionalString) MarshalJSON() ([]byte, error)

MarshalJSON converts the OptionalString to its JSON representation.

The output will be either a JSON string or null. Note that the "omitempty" tag for a struct field will not cause an empty OptionalString field to be omitted; it will be output as null. If you want to completely omit a JSON property when there is no value, it must be a string pointer instead of an OptionalString; use the AsPointer() method to get a pointer.

func (OptionalString) MarshalText

func (o OptionalString) MarshalText() ([]byte, error)

MarshalText implements the encoding.TextMarshaler interface.

Marshaling an empty OptionalString{} will return nil, rather than a zero-length slice.

func (OptionalString) OnlyIfNonEmptyString

func (o OptionalString) OnlyIfNonEmptyString() OptionalString

OnlyIfNonEmptyString returns the same OptionalString unless it contains an empty string (""), in which case it returns an OptionalString that has no value.

func (OptionalString) OrElse

func (o OptionalString) OrElse(valueIfEmpty string) string

OrElse returns the OptionalString's value if it has one, or else the specified fallback value.

func (*OptionalString) ReadFromJSONReader added in v2.2.0

func (o *OptionalString) ReadFromJSONReader(r *jreader.Reader)

ReadFromJSONReader provides JSON deserialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Unmarshal. See https://github.com/launchdarkly/go-jsonstream for more details.

func (OptionalString) String

func (o OptionalString) String() string

String is a debugging convenience method that returns a description of the OptionalString. This is either the same as its string value, "[empty]" if it has a string value that is empty, or "[none]" if it has no value.

Since String() is used by methods like fmt.Printf, if you want to use the actual string value of the OptionalString instead of this special representation, you should call StringValue():

s := OptionalString{}
fmt.Printf("it is '%s'", s) // prints "it is '[none]'"
fmt.Printf("it is '%s'", s.StringValue()) // prints "it is ''"

func (OptionalString) StringValue

func (o OptionalString) StringValue() string

StringValue returns the OptionalString's value, or an empty string if it has no value.

func (*OptionalString) UnmarshalJSON

func (o *OptionalString) UnmarshalJSON(data []byte) error

UnmarshalJSON parses an OptionalString from JSON.

The input must be either a JSON string or null.

func (*OptionalString) UnmarshalText

func (o *OptionalString) UnmarshalText(text []byte) error

UnmarshalText implements the encoding.TextUnmarshaler interface.

This allows OptionalString to be used with packages that can parse text content, such as gcfg.

If the byte slice is nil, rather than zero-length, it will set the target value to an empty OptionalString{}. Otherwise, it will set it to a string value.

func (OptionalString) WriteToJSONBuffer deprecated

func (o OptionalString) WriteToJSONBuffer(j *jsonstream.JSONBuffer)

WriteToJSONBuffer provides JSON serialization for use with the deprecated jsonstream API.

Deprecated: this method is provided for backward compatibility. The LaunchDarkly SDK no longer uses this API; instead it uses the newer https://github.com/launchdarkly/go-jsonstream.

func (OptionalString) WriteToJSONWriter added in v2.2.0

func (o OptionalString) WriteToJSONWriter(w *jwriter.Writer)

WriteToJSONWriter provides JSON serialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Marshal. See https://github.com/launchdarkly/go-jsonstream for more details.

type Value

type Value struct {
	// contains filtered or unexported fields
}

Value represents any of the data types supported by JSON, all of which can be used for a LaunchDarkly feature flag variation or a custom user attribute.

You cannot compare Value instances with the == operator, because the struct may contain a slice. Value has an Equal method for this purpose; reflect.DeepEqual will also work.

Value instances are immutable when used by code outside of this package.

func ArrayOf

func ArrayOf(items ...Value) Value

ArrayOf creates an array Value from a list of Values.

This requires a slice copy to ensure immutability; otherwise, an existing slice could be passed using the spread operator, and then modified. However, since Value is itself immutable, it does not need to deep-copy each item.

func Bool

func Bool(value bool) Value

Bool creates a boolean Value.

func CopyArbitraryValue

func CopyArbitraryValue(valueAsInterface interface{}) Value

CopyArbitraryValue creates a Value from an arbitrary interface{} value of any type.

If the value is nil, a boolean, an integer, a floating-point number, or a string, it becomes the corresponding JSON primitive value type. If it is a slice of values ([]interface{} or []Value), it is deep-copied to an array value. If it is a map of strings to values (map[string]interface{} or map[string]Value), it is deep-copied to an object value.

If it is a pointer to any of the above types, then it is dereferenced and treated the same as above, unless the pointer is nil, in which case it becomes Null().

For all other types, the value is marshaled to JSON and then converted to the corresponding Value type (unless marshalling returns an error, in which case it becomes Null()). This is somewhat inefficient since it involves parsing the marshaled JSON.

func CopyObject

func CopyObject(m map[string]Value) Value

CopyObject creates a Value by copying an existing map[string]Value.

If you want to copy a map[string]interface{} instead, use CopyArbitraryValue.

func Float64

func Float64(value float64) Value

Float64 creates a numeric Value from a float64.

func Int

func Int(value int) Value

Int creates a numeric Value from an integer.

Note that all numbers are represented internally as the same type (float64), so Int(2) is exactly equal to Float64(2).

func Null

func Null() Value

Null creates a null Value.

func Parse

func Parse(jsonData []byte) Value

Parse returns a Value parsed from a JSON string, or Null if it cannot be parsed.

This is simply a shortcut for calling json.Unmarshal and disregarding errors. It is meant for use in test scenarios where malformed data is not a concern.

func Raw

func Raw(value json.RawMessage) Value

Raw creates an unparsed JSON Value.

This constructor will store the json.RawMessage value as-is without syntax validation, and will set the type of the Value to ldvalue.RawType. That means, for instance, that ldvalue.Raw(json.RawMessage("true")) is not logically equivalent to ldvalue.Bool(true), even though they will produce the same result if they are re-encoded to JSON.

That also means that if you pass malformed data that is not valid JSON, you will get malformed data if it is re-encoded to JSON. It is the caller's responsibility to make sure the json.RawMessage really is valid JSON. However, since it is easy to mistakenly write json.RawMessage(nil) (a zero-length value) when what is really meant is a JSON null value, the ldvalue.Value JSON encoder will detect any use of json.RawMessage(nil) or json.RawMessage("") and transparently convert it to "null" when it is being encoded to JSON.

func String

func String(value string) Value

String creates a string Value.

func (Value) AsArbitraryValue

func (v Value) AsArbitraryValue() interface{}

AsArbitraryValue returns the value in its simplest Go representation, typed as interface{}.

This is nil for a null value; for primitive types, it is bool, float64, or string (all numbers are represented as float64 because that is Go's default when parsing from JSON).

Arrays and objects are represented as []interface{} and map[string]interface{}. They are deep-copied, which preserves immutability of the Value but may be an expensive operation. To examine array and object values without copying the whole data structure, use getter methods: Count, Keys, GetByIndex, TryGetByIndex, GetByKey, TryGetByKey.

func (Value) AsOptionalString

func (v Value) AsOptionalString() OptionalString

AsOptionalString converts the value to the OptionalString type, which contains either a string value or nothing if the original value was not a string.

func (Value) AsPointer

func (v Value) AsPointer() *Value

AsPointer returns either a pointer to a copy of this Value, or nil if it is a null value.

This may be desirable if you are serializing a struct that contains a Value, and you want that field to be completely omitted if the Value is null; since the "omitempty" tag only works for pointers, you can declare the field as a *Value like so:

type MyJsonStruct struct {
    AnOptionalField *Value `json:"anOptionalField,omitempty"`
}
s := MyJsonStruct{AnOptionalField: someValue.AsPointer()}

func (Value) AsRaw

func (v Value) AsRaw() json.RawMessage

AsRaw returns the value as a json.RawMessage.

If the value was originally created from a RawMessage, it returns the same value. For all other values, it converts the value to its JSON representation and returns that representation.

Note that the ldvalue.Raw(json.RawMessage) constructor does not do any syntax validation, so if you create a Value from a malformed string such as ldvalue.Raw(json.RawMessage("{{{")), you will get back the same string from AsRaw().

func (Value) AsValueArray added in v2.1.0

func (v Value) AsValueArray() ValueArray

AsValueArray converts the Value to the immutable ValueArray type if it is a JSON array. Otherwise it returns a ValueArray in an uninitialized (nil) state. This is an efficient operation that does not allocate a new slice.

func (Value) AsValueMap added in v2.1.0

func (v Value) AsValueMap() ValueMap

AsValueMap converts the Value to the immutable ValueMap type if it is a JSON object. Otherwise it returns a ValueMap in an uninitialized (nil) state. This is an efficient operation that does not allocate a new map.

func (Value) BoolValue

func (v Value) BoolValue() bool

BoolValue returns the Value as a boolean.

If the Value is not a boolean, it returns false.

func (Value) Count

func (v Value) Count() int

Count returns the number of elements in an array or JSON object.

For values of any other type, it returns zero.

func (Value) Enumerate

func (v Value) Enumerate(fn func(index int, key string, value Value) bool)

Enumerate calls a function for each value within a Value.

If the input value is Null(), the function is not called.

If the input value is an array, fn is called for each element, with the element's index in the first parameter, "" in the second, and the element value in the third.

If the input value is an object, fn is called for each key-value pair, with 0 in the first parameter, the key in the second, and the value in the third.

For any other value type, fn is called once for that value.

The return value of fn is true to continue enumerating, false to stop.

func (Value) Equal

func (v Value) Equal(other Value) bool

Equal tests whether this Value is equal to another, in both type and value.

For arrays and objects, this is a deep equality test. This method behaves the same as reflect.DeepEqual, but is slightly more efficient.

func (Value) Float64Value

func (v Value) Float64Value() float64

Float64Value returns the value as a float64.

If the Value is not numeric, it returns zero.

func (Value) GetByIndex

func (v Value) GetByIndex(index int) Value

GetByIndex gets an element of an array by index.

If the value is not an array, or if the index is out of range, it returns Null().

func (Value) GetByKey

func (v Value) GetByKey(name string) Value

GetByKey gets a value from a JSON object by key.

If the value is not an object, or if the key is not found, it returns Null().

func (Value) IntValue

func (v Value) IntValue() int

IntValue returns the value as an int.

If the Value is not numeric, it returns zero. If the value is a number but not an integer, it is rounded toward zero (truncated).

func (Value) IsBool

func (v Value) IsBool() bool

IsBool returns true if the Value is a boolean.

func (Value) IsDefined added in v2.1.0

func (v Value) IsDefined() bool

IsDefined returns true if the Value is anything other than null.

This is exactly equivalent to !v.IsNull(), but is provided as a separate method for consistency with other types that have an IsDefined() method.

func (Value) IsInt

func (v Value) IsInt() bool

IsInt returns true if the Value is an integer.

JSON does not have separate types for integer and floating-point values; they are both just numbers. IsInt returns true if and only if the actual numeric value has no fractional component, so Int(2).IsInt() and Float64(2.0).IsInt() are both true.

func (Value) IsNull

func (v Value) IsNull() bool

IsNull returns true if the Value is a null.

func (Value) IsNumber

func (v Value) IsNumber() bool

IsNumber returns true if the Value is numeric.

func (Value) IsString

func (v Value) IsString() bool

IsString returns true if the Value is a string.

func (Value) JSONString

func (v Value) JSONString() string

JSONString returns the JSON representation of the value.

func (Value) Keys

func (v Value) Keys() []string

Keys returns the keys of a JSON object as a slice.

The method copies the keys. If the value is not an object, it returns an empty slice.

func (Value) MarshalJSON

func (v Value) MarshalJSON() ([]byte, error)

MarshalJSON converts the Value to its JSON representation.

Note that the "omitempty" tag for a struct field will not cause an empty Value field to be omitted; it will be output as null. If you want to completely omit a JSON property when there is no value, it must be a pointer; use AsPointer().

func (*Value) ReadFromJSONReader added in v2.2.0

func (v *Value) ReadFromJSONReader(r *jreader.Reader)

ReadFromJSONReader provides JSON deserialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Unmarshal. See the jsonstream package for more details.

func (Value) String

func (v Value) String() string

String converts the value to a string representation, equivalent to JSONString().

This is different from StringValue, which returns the actual string for a string value or an empty string for anything else. For instance, Int(2).StringValue() returns "2" and String("x").StringValue() returns "\"x\"", whereas Int(2).AsString() returns "" and String("x").AsString() returns "x".

This method is provided because it is common to use the Stringer interface as a quick way to summarize the contents of a value. The simplest way to do so in this case is to use the JSON representation.

func (Value) StringValue

func (v Value) StringValue() string

StringValue returns the value as a string.

If the value is not a string, it returns an empty string.

This is different from String(), which returns a concise string representation of any value type.

func (Value) Transform

func (v Value) Transform(fn func(index int, key string, value Value) (Value, bool)) Value

Transform applies a transformation function to a Value, returning a new Value.

The behavior is as follows:

If the input value is Null(), the return value is always Null() and the function is not called.

If the input value is an array, fn is called for each element, with the element's index in the first parameter, "" in the second, and the element value in the third. The return values of fn can be either a transformed value and true, or any value and false to remove the element.

ldvalue.ArrayOf(ldvalue.Int(1), ldvalue.Int(2), ldvalue.Int(3)).Build().
    Transform(func(index int, key string, value Value) (Value, bool) {
        if value.IntValue() == 2 {
            return ldvalue.Null(), false
        }
        return ldvalue.Int(value.IntValue() * 10), true
    })
// returns [10, 30]

If the input value is an object, fn is called for each key-value pair, with 0 in the first parameter, the key in the second, and the value in the third. Again, fn can choose to either transform or drop the value.

ldvalue.ObjectBuild().Set("a", ldvalue.Int(1)).Set("b", ldvalue.Int(2)).Set("c", ldvalue.Int(3)).Build().
    Transform(func(index int, key string, value Value) (Value, bool) {
        if key == "b" {
            return ldvalue.Null(), false
        }
        return ldvalue.Int(value.IntValue() * 10), true
    })
// returns {"a": 10, "c": 30}

For any other value type, fn is called once for that value; if it provides a transformed value and true, the transformed value is returned, otherwise Null().

ldvalue.Int(2).Transform(func(index int, key string, value Value) (Value, bool) {
    return ldvalue.Int(value.IntValue() * 10), true
})
// returns numeric value of 20

For array and object values, if the function does not modify or drop any values, the exact same instance is returned without allocating a new slice or map.

func (Value) TryGetByIndex

func (v Value) TryGetByIndex(index int) (Value, bool)

TryGetByIndex gets an element of an array by index, with a second return value of true if successful.

If the value is not an array, or if the index is out of range, it returns (Null(), false).

func (Value) TryGetByKey

func (v Value) TryGetByKey(name string) (Value, bool)

TryGetByKey gets a value from a JSON object by key, with a second return value of true if successful.

If the value is not an object, or if the key is not found, it returns (Null(), false).

func (Value) Type

func (v Value) Type() ValueType

Type returns the ValueType of the Value.

func (*Value) UnmarshalJSON

func (v *Value) UnmarshalJSON(data []byte) error

UnmarshalJSON parses a Value from JSON.

func (Value) WriteToJSONBuffer deprecated

func (v Value) WriteToJSONBuffer(j *jsonstream.JSONBuffer)

WriteToJSONBuffer provides JSON serialization for use with the deprecated jsonstream API.

Deprecated: this method is provided for backward compatibility. The LaunchDarkly SDK no longer uses this API; instead it uses the newer https://github.com/launchdarkly/go-jsonstream.

func (Value) WriteToJSONWriter added in v2.2.0

func (v Value) WriteToJSONWriter(w *jwriter.Writer)

WriteToJSONWriter provides JSON serialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Marshal. See https://github.com/launchdarkly/go-jsonstream for more details.

type ValueArray added in v2.1.0

type ValueArray struct {
	// contains filtered or unexported fields
}

ValueArray is an immutable array of Value values.

This is used internally to hold the contents of a JSON array in a Value. You can also use it separately in any context where you know that the data must be array-like, rather than any of the other types that a Value can be.

The wrapped slice is not directly accessible, so it cannot be modified. You can obtain a copy of it with AsSlice() if necessary.

Like a Go slice, there is a distinction between an array in a nil state-- which is the zero value of ValueArray{}-- and a non-nil aray that is empty. The former is represented in JSON as a null; the latter is an empty JSON array [].

func CopyArbitraryValueArray added in v2.1.0

func CopyArbitraryValueArray(data []interface{}) ValueArray

CopyArbitraryValueArray copies an existing ordinary map of interface{} values to a ValueArray. The behavior for each value is the same as CopyArbitraryValue.

If the parameter is nil, an uninitialized ValueArray{} is returned instead of a zero-length map.

func CopyValueArray added in v2.1.0

func CopyValueArray(data []Value) ValueArray

CopyValueArray copies an existing ordinary map to a ValueArray.

If the parameter is nil, an uninitialized ValueArray{} is returned instead of a zero-length array.

func ValueArrayOf added in v2.1.0

func ValueArrayOf(items ...Value) ValueArray

ValueArrayOf creates a ValueArray from a list of Values.

This requires a slice copy to ensure immutability; otherwise, an existing slice could be passed using the spread operator, and then modified. However, since Value is itself immutable, it does not need to deep-copy each item.

func (ValueArray) AsArbitraryValueSlice added in v2.1.0

func (a ValueArray) AsArbitraryValueSlice() []interface{}

AsArbitraryValueSlice returns a copy of the wrapped data as a simple Go slice whose values are of type interface{}. The behavior for each value is the same as Value.AsArbitraryValue().

For an uninitialized ValueArray{}, this returns nil.

func (ValueArray) AsSlice added in v2.1.0

func (a ValueArray) AsSlice() []Value

AsSlice returns a copy of the wrapped data as a simple Go slice whose values are of type Value.

For an uninitialized ValueArray{}, this returns nil.

func (ValueArray) AsValue added in v2.1.0

func (a ValueArray) AsValue() Value

AsValue converts the ValueArray to a Value which is either Null() or an array. This does not cause any new allocations.

func (ValueArray) Count added in v2.1.0

func (a ValueArray) Count() int

Count returns the number of elements in the array. For an uninitialized ValueArray{}, this is zero.

func (ValueArray) Enumerate added in v2.1.0

func (a ValueArray) Enumerate(fn func(index int, value Value) bool)

Enumerate calls a function for each value within a ValueArray, passing the index with each.

The return value of fn is true to continue enumerating, false to stop.

func (ValueArray) Equal added in v2.1.0

func (a ValueArray) Equal(other ValueArray) bool

Equal returns true if the two arrays are deeply equal. Nil and zero-length arrays are not considered equal to each other.

func (ValueArray) Get added in v2.1.0

func (a ValueArray) Get(index int) Value

Get gets a value from the array by index.

If the index is out of range, it returns Null().

func (ValueArray) IsDefined added in v2.1.0

func (a ValueArray) IsDefined() bool

IsDefined returns true if the array is non-nil.

func (ValueArray) JSONString added in v2.1.0

func (a ValueArray) JSONString() string

JSONString returns the JSON representation of the map.

func (ValueArray) MarshalJSON added in v2.1.0

func (a ValueArray) MarshalJSON() ([]byte, error)

MarshalJSON converts the ValueArray to its JSON representation.

Like a Go slice, a ValueArray in an uninitialized/nil state produces a JSON null rather than an empty [].

func (*ValueArray) ReadFromJSONReader added in v2.2.0

func (a *ValueArray) ReadFromJSONReader(r *jreader.Reader)

ReadFromJSONReader provides JSON deserialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Unmarshal. See the jsonstream package for more details.

func (ValueArray) String added in v2.1.0

func (a ValueArray) String() string

String converts the value to a string representation, equivalent to JSONString().

This method is provided because it is common to use the Stringer interface as a quick way to summarize the contents of a value. The simplest way to do so in this case is to use the JSON representation.

func (ValueArray) Transform added in v2.1.0

func (a ValueArray) Transform(fn func(index int, value Value) (Value, bool)) ValueArray

Transform applies a transformation function to a ValueArray, returning a new ValueArray.

The behavior is as follows:

If the input value is nil or zero-length, the result is identical and the function is not called.

Otherwise, fn is called for each value. It should return a transformed value and true, or else return false for the second return value if the property should be dropped.

func (ValueArray) TryGet added in v2.1.0

func (a ValueArray) TryGet(index int) (Value, bool)

TryGet gets a value from the map by index, with a second return value of true if successful.

If the index is out of range, it returns (Null(), false).

func (*ValueArray) UnmarshalJSON added in v2.1.0

func (a *ValueArray) UnmarshalJSON(data []byte) error

UnmarshalJSON parses a ValueArray from JSON.

func (ValueArray) WriteToJSONBuffer deprecated added in v2.1.0

func (a ValueArray) WriteToJSONBuffer(j *jsonstream.JSONBuffer)

WriteToJSONBuffer provides JSON serialization for use with the deprecated jsonstream API.

Deprecated: this method is provided for backward compatibility. The LaunchDarkly SDK no longer uses this API; instead it uses the newer https://github.com/launchdarkly/go-jsonstream.

Like a Go slice, a ValueArray in an uninitialized/nil state produces a JSON null rather than an empty [].

func (ValueArray) WriteToJSONWriter added in v2.2.0

func (a ValueArray) WriteToJSONWriter(w *jwriter.Writer)

WriteToJSONWriter provides JSON serialization for use with the jsonstream API.

The JSON output format is identical to what is produced by json.Marshal, but this implementation is more efficient when building output with jsonstream. See the jsonstream package for more details.

Like a Go slice, a ValueArray in an uninitialized/nil state produces a JSON null rather than an empty [].

type ValueArrayBuilder added in v2.1.0

type ValueArrayBuilder interface {
	// Add appends an element to the array builder.
	Add(value Value) ValueArrayBuilder
	// AddAllFromArray appends all elements from an existing ValueArray.
	AddAllFromValueArray(ValueArray) ValueArrayBuilder
	// Build creates a Value containing the previously added array elements. Continuing to modify the
	// same builder by calling Add after that point does not affect the returned array.
	Build() ValueArray
}

ValueArrayBuilder is a builder created by ValueArrayBuild(), for creating immutable JSON arrays.

A ValueArrayBuilder should not be accessed by multiple goroutines at once.

func ValueArrayBuild added in v2.1.0

func ValueArrayBuild() ValueArrayBuilder

ValueArrayBuild creates a builder for constructing an immutable ValueArray.

ValueArray := ldvalue.ValueArrayBuild().Add(ldvalue.Int(100)).Add(ldvalue.Int(200)).Build()

func ValueArrayBuildFromArray added in v2.1.0

func ValueArrayBuildFromArray(a ValueArray) ValueArrayBuilder

ValueArrayBuildFromArray creates a builder for constructing an immutable ValueArray, initializing it from an existing ValueArray.

The builder has copy-on-write behavior, so if you make no changes before calling Build(), the original array is used as-is.

func ValueArrayBuildWithCapacity added in v2.1.0

func ValueArrayBuildWithCapacity(capacity int) ValueArrayBuilder

ValueArrayBuildWithCapacity creates a builder for constructing an immutable ValueArray.

The capacity parameter is the same as the capacity of a slice, allowing you to preallocate space if you know the number of elements; otherwise you can pass zero.

arrayValue := ldvalue.ValueArrayBuildWithCapacity(2).Add(ldvalue.Int(100)).Add(ldvalue.Int(200)).Build()

type ValueMap added in v2.1.0

type ValueMap struct {
	// contains filtered or unexported fields
}

ValueMap is an immutable map of string keys to Value values.

This is used internally to hold the properties of a JSON object in a Value. You can also use it separately in any context where you know that the data must be map-like, rather than any of the other types that a Value can be.

The wrapped map is not directly accessible, so it cannot be modified. You can obtain a copy of it with AsMap() if necessary.

Like a Go map, there is a distinction between a map in a nil state-- which is the zero value of ValueMap{}-- and a non-nil map that is empty. The former is represented in JSON as a null; the latter is an empty JSON object {}.

func CopyArbitraryValueMap added in v2.1.0

func CopyArbitraryValueMap(data map[string]interface{}) ValueMap

CopyArbitraryValueMap copies an existing ordinary map of interface{} values to a ValueMap. The behavior for each value is the same as CopyArbitraryValue.

If the parameter is nil, an uninitialized ValueMap{} is returned instead of a zero-length map.

func CopyValueMap added in v2.1.0

func CopyValueMap(data map[string]Value) ValueMap

CopyValueMap copies an existing ordinary map to a ValueMap.

If the parameter is nil, an uninitialized ValueMap{} is returned instead of a zero-length map.

func (ValueMap) AsArbitraryValueMap added in v2.1.0

func (m ValueMap) AsArbitraryValueMap() map[string]interface{}

AsArbitraryValueMap returns a copy of the wrapped data as a simple Go map whose values are of type interface{}. The behavior for each value is the same as Value.AsArbitraryValue().

For an uninitialized ValueMap{}, this returns nil.

func (ValueMap) AsMap added in v2.1.0

func (m ValueMap) AsMap() map[string]Value

AsMap returns a copy of the wrapped data as a simple Go map whose values are of type Value.

For an uninitialized ValueMap{}, this returns nil.

func (ValueMap) AsValue added in v2.1.0

func (m ValueMap) AsValue() Value

AsValue converts the ValueMap to a Value which is either Null() or an object. This does not cause any new allocations.

func (ValueMap) Count added in v2.1.0

func (m ValueMap) Count() int

Count returns the number of keys in the map. For an uninitialized ValueMap{}, this is zero.

func (ValueMap) Enumerate added in v2.1.0

func (m ValueMap) Enumerate(fn func(key string, value Value) bool)

Enumerate calls a function for each key-value pair within a ValueMap. The ordering is undefined since map iteration in Go is non-deterministic.

The return value of fn is true to continue enumerating, false to stop.

func (ValueMap) Equal added in v2.1.0

func (m ValueMap) Equal(other ValueMap) bool

Equal returns true if the two maps are deeply equal. Nil and zero-length maps are not considered equal to each other.

func (ValueMap) Get added in v2.1.0

func (m ValueMap) Get(key string) Value

Get gets a value from the map by key.

If the key is not found, it returns Null().

func (ValueMap) IsDefined added in v2.1.0

func (m ValueMap) IsDefined() bool

IsDefined returns true if the map is non-nil.

func (ValueMap) JSONString added in v2.1.0

func (m ValueMap) JSONString() string

JSONString returns the JSON representation of the map.

func (ValueMap) Keys added in v2.1.0

func (m ValueMap) Keys() []string

Keys returns the keys of a the map as a slice.

The method copies the keys. For an uninitialized ValueMap{}, it returns nil.

func (ValueMap) MarshalJSON added in v2.1.0

func (m ValueMap) MarshalJSON() ([]byte, error)

MarshalJSON converts the ValueMap to its JSON representation.

Like a Go map, a ValueMap in an uninitialized/nil state produces a JSON null rather than an empty {}.

func (*ValueMap) ReadFromJSONReader added in v2.2.0

func (m *ValueMap) ReadFromJSONReader(r *jreader.Reader)

ReadFromJSONReader provides JSON deserialization for use with the jsonstream API.

This implementation is used by the SDK in cases where it is more efficient than JSON.Unmarshal. See the jsonstream package for more details.

func (ValueMap) String added in v2.1.0

func (m ValueMap) String() string

String converts the value to a map representation, equivalent to JSONString().

This method is provided because it is common to use the Stringer interface as a quick way to summarize the contents of a value. The simplest way to do so in this case is to use the JSON representation.

func (ValueMap) Transform added in v2.1.0

func (m ValueMap) Transform(fn func(key string, value Value) (string, Value, bool)) ValueMap

Transform applies a transformation function to a ValueMap, returning a new ValueMap.

The behavior is as follows:

If the input value is nil or zero-length, the result is identical and the function is not called.

Otherwise, fn is called for each key-value pair. It should return a transformed key-value pair and true, or else return false for the third return value if the property should be dropped.

func (ValueMap) TryGet added in v2.1.0

func (m ValueMap) TryGet(key string) (Value, bool)

TryGet gets a value from the map by key, with a second return value of true if successful.

If the key is not found, it returns (Null(), false).

func (*ValueMap) UnmarshalJSON added in v2.1.0

func (m *ValueMap) UnmarshalJSON(data []byte) error

UnmarshalJSON parses a ValueMap from JSON.

func (ValueMap) WriteToJSONBuffer deprecated added in v2.1.0

func (m ValueMap) WriteToJSONBuffer(j *jsonstream.JSONBuffer)

WriteToJSONBuffer provides JSON serialization for use with the deprecated jsonstream API.

Deprecated: this method is provided for backward compatibility. The LaunchDarkly SDK no longer uses this API; instead it uses the newer https://github.com/launchdarkly/go-jsonstream.

Like a Go map, a ValueMap in an uninitialized/nil state produces a JSON null rather than an empty {}.

func (ValueMap) WriteToJSONWriter added in v2.2.0

func (m ValueMap) WriteToJSONWriter(w *jwriter.Writer)

WriteToJSONWriter provides JSON serialization for use with the jsonstream API.

The JSON output format is identical to what is produced by json.Marshal, but this implementation is more efficient when building output with JSONBuffer. See the jsonstream package for more details.

Like a Go map, a ValueMap in an uninitialized/nil state produces a JSON null rather than an empty {}.

type ValueMapBuilder added in v2.1.0

type ValueMapBuilder interface {
	// Set sets a key-value pair in the map builder.
	Set(key string, value Value) ValueMapBuilder
	// SetAllFromValueMap copies all key-value pairs from an existing ValueMap.
	SetAllFromValueMap(ValueMap) ValueMapBuilder
	// Remove unsets a key if it was set.
	Remove(key string) ValueMapBuilder
	// Build creates a ValueMap containing the previously specified key-value pairs. Continuing to
	// modify the same builder by calling Set after that point does not affect the returned ValueMap.
	Build() ValueMap
}

ValueMapBuilder is a builder created by ValueMapBuild(), for creating immutable JSON objects.

A ValueMapBuilder should not be accessed by multiple goroutines at once.

func ValueMapBuild added in v2.1.0

func ValueMapBuild() ValueMapBuilder

ValueMapBuild creates a builder for constructing an immutable ValueMap.

valueMap := ldvalue.ValueMapBuild().Set("a", ldvalue.Int(100)).Set("b", ldvalue.Int(200)).Build()

func ValueMapBuildFromMap added in v2.1.0

func ValueMapBuildFromMap(m ValueMap) ValueMapBuilder

ValueMapBuildFromMap creates a builder for constructing an immutable ValueMap, initializing it from an existing ValueMap.

The builder has copy-on-write behavior, so if you make no changes before calling Build(), the original map is used as-is.

func ValueMapBuildWithCapacity added in v2.1.0

func ValueMapBuildWithCapacity(capacity int) ValueMapBuilder

ValueMapBuildWithCapacity creates a builder for constructing an immutable ValueMap.

The capacity parameter is the same as the capacity of a map, allowing you to preallocate space if you know the number of elements; otherwise you can pass zero.

objValue := ldvalue.ObjectBuildWithCapacity(2).Set("a", ldvalue.Int(100)).Set("b", ldvalue.Int(200)).Build()

type ValueType

type ValueType int

ValueType indicates which JSON type is contained in a Value.

const (
	// NullType describes a null value. Note that the zero value of ValueType is NullType, so the
	// zero of Value is a null value.
	NullType ValueType = iota
	// BoolType describes a boolean value.
	BoolType ValueType = iota
	// NumberType describes a numeric value. JSON does not have separate types for int and float, but
	// you can convert to either.
	NumberType ValueType = iota
	// StringType describes a string value.
	StringType ValueType = iota
	// ArrayType describes an array value.
	ArrayType ValueType = iota
	// ObjectType describes an object (a.k.a. map).
	ObjectType ValueType = iota
	// RawType describes a json.RawMessage value. This value will not be parsed or interpreted as
	// any other data type, and can be accessed only by calling AsRaw().
	RawType ValueType = iota
)

func (ValueType) String

func (t ValueType) String() string

String returns the name of the value type.

Jump to

Keyboard shortcuts

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