internal

package
v0.20.7 Latest Latest
Warning

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

Go to latest
Published: Jan 3, 2025 License: Apache-2.0 Imports: 23 Imported by: 0

Documentation

Index

Constants

View Source
const ApiServerEnvVarKey = "CHALK_API_SERVER"
View Source
const ClientIdEnvVarKey = "CHALK_CLIENT_ID"
View Source
const ClientSecretEnvVarKey = "CHALK_CLIENT_SECRET"
View Source
const EnvironmentEnvVarKey = "CHALK_ACTIVE_ENVIRONMENT"

Variables

View Source
var ChalkTag = "chalk"
View Source
var NameTag = "name"
View Source
var NowTimeFormat = "2006-01-02T15:04:05.000000-07:00"
View Source
var SkipUnmarshalFqnRoots = map[string]bool{
	"__chalk__": true,
}
View Source
var WindowsTag = "windows"

Functions

func ChalkMarshal added in v0.3.13

func ChalkMarshal(attrs map[string]any) ([]byte, error)

ChalkMarshal converts a map to a byte array. Follows the byte-packing format as described in the Chalk Python repo's `byte_transmit.serialize()` function.

func ChalkUnmarshal added in v0.3.6

func ChalkUnmarshal(body []byte) (map[string]any, error)

func ChalkpySnakeCase added in v0.8.2

func ChalkpySnakeCase(s string) string

ChalkpySnakeCase aims to be in parity with our Python implementation of snake_case. We are supposed to use this in all places over LegacySnakeCase, but that's a breaking change because our CLI generates the `name` struct tag if and only if the snake case generated using LegacySnakeCase does not match the actual feature name. If we switch to using ChalkpySnakeCase, that would make new codegen code incompatible with old chalk-go versions. In short, we want to keep using LegacySnakeCase in chalk-go to snake-case field names, and ChalkpySnakeCase to snake-case struct names.

func ColumnMapToRecord added in v0.7.0

func ColumnMapToRecord(inputs map[string]any) (arrow.Record, error)

ColumnMapToRecord converts a map of column names to slices of values to an Arrow Record.

func ConvertBytesToTable added in v0.3.7

func ConvertBytesToTable(byteArr []byte) (result arrow.Table, err error)

func CreateOnlineQueryBulkBody added in v0.3.6

func CreateOnlineQueryBulkBody(inputs map[string]any, header FeatherRequestHeader) ([]byte, error)

func CreateUploadFeaturesBody added in v0.3.13

func CreateUploadFeaturesBody(inputs map[string]any) ([]byte, error)

func ExpandTilde added in v0.3.3

func ExpandTilde(path string) (string, error)

func ExtractFeaturesFromTable added in v0.7.0

func ExtractFeaturesFromTable(
	table arrow.Table,
	timeAsString bool,
) ([]map[string]any, error)

func FileExists

func FileExists(path string) bool

func FormatBucketDuration

func FormatBucketDuration(duration int) string

FormatBucketDuration takes an integer number of seconds and returns a string representation that satisfies these conditions:

  • the largest possible unit of time (e.g. "10m" instead of "600s")
  • a single unit of time (e.g. "601s" instead of "10m1s")

func GenerateGetEnumFunction

func GenerateGetEnumFunction[K comparable](valueToEnum map[string]K, enumName string) func(string) (*K, error)

func GetBucketFromFqn added in v0.16.0

func GetBucketFromFqn(fqn string) (string, error)

func GetHeaderFromSerializedOnlineQueryBulkBody added in v0.5.1

func GetHeaderFromSerializedOnlineQueryBulkBody(body []byte) (map[string]any, error)

func GetReflectValue added in v0.3.6

func GetReflectValue(value any, typ reflect.Type, nsMemo NamespaceMemo) (*reflect.Value, error)

GetReflectValue returns a reflect.Value of the given type from the given non-reflect value.

func GetValueFromArrowArray added in v0.7.0

func GetValueFromArrowArray(a arrow.Array, idx int, timeAsString bool) (any, error)

func GetWindowBucketsFromStructTag added in v0.16.0

func GetWindowBucketsFromStructTag(field reflect.StructField) ([]string, error)

func GetWindowBucketsSecondsFromStructTag added in v0.16.0

func GetWindowBucketsSecondsFromStructTag(field reflect.StructField) ([]int, error)

func HasDontOmitTag added in v0.16.0

func HasDontOmitTag(field reflect.StructField) bool

func InputsToArrowBytes added in v0.13.0

func InputsToArrowBytes(inputs map[string]any) ([]byte, error)

InputsToArrowBytes converts map of FQNs to slice of values to an Arrow Record, serialized.

func Int64ToInt added in v0.18.27

func Int64ToInt(value int64) (int, error)

func IsDataclass added in v0.3.6

func IsDataclass(field reflect.Value) bool

func IsFeaturesClass added in v0.18.29

func IsFeaturesClass(typ reflect.Type) bool

func IsStruct added in v0.16.0

func IsStruct(typ reflect.Type) bool

func IsTypeDataclass added in v0.11.0

func IsTypeDataclass(typ reflect.Type) bool

func KindMismatchError added in v0.8.4

func KindMismatchError(expected reflect.Kind, actual reflect.Kind) error

func LegacySnakeCase added in v0.20.3

func LegacySnakeCase(s string) string

LegacySnakeCase is how we turn our struct field names into feature names. We really should be using ChalkpySnakeCase, but we can't change it now because it would break existing codegen customers. Using this in our CLI to convert struct field names to snake case is still correct because if it does not correctly match the feature name, it generates the `name` struct tag. If we switch to using ChalkpySnakeCase, that would make new codegen code incompatible with old chalk-go versions. In short, we want to keep using LegacySnakeCase in chalk-go to snake-case field names, and ChalkpySnakeCase to snake-case struct names.

func ParseBucketDuration

func ParseBucketDuration(durationStr string) (int, error)

ParseBucketDuration parses a bucket duration string and returns the duration in seconds. The input string must be of the form "Nunit" where N is a positive integer and unit is one of "s", "m", "h", "d", or "w".

func PreprocessIfStruct added in v0.19.0

func PreprocessIfStruct(values any) (any, error)

func ReflectPtr added in v0.8.4

func ReflectPtr(value reflect.Value) reflect.Value

func ResolveFeatureName added in v0.11.0

func ResolveFeatureName(field reflect.StructField) (string, error)

func SetMapEntryValue added in v0.16.0

func SetMapEntryValue(mapValue reflect.Value, key string, value any, nsMemo NamespaceMemo) error

SetMapEntryValue exists as a separate special setter function because while all other fields are settable and can be passed into GetReflectValue to be set, map field values are not settable, and the entire map has to be passed instead.

func SingleInputsToBulkInputs added in v0.19.0

func SingleInputsToBulkInputs(singleInputs map[string]any) (map[string]any, error)

func StringOrNil

func StringOrNil(value string) *string

Types

type BufferWriteSeeker added in v0.3.7

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

func (*BufferWriteSeeker) Bytes added in v0.3.7

func (b *BufferWriteSeeker) Bytes() []byte

func (*BufferWriteSeeker) Seek added in v0.3.7

func (b *BufferWriteSeeker) Seek(offset int64, whence int) (int64, error)

func (*BufferWriteSeeker) Write added in v0.3.7

func (b *BufferWriteSeeker) Write(p []byte) (n int, err error)

type ChunkResult added in v0.18.27

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

type FeatherRequestHeader added in v0.4.7

type FeatherRequestHeader struct {
	Outputs          []string            `json:"outputs"`
	BranchId         *string             `json:"branch_id"`
	Explain          bool                `json:"explain"`
	Context          *OnlineQueryContext `json:"context"`
	Staleness        map[string]string   `json:"staleness"`
	Now              []string            `json:"now,omitempty"`
	IncludeMeta      bool                `json:"include_meta"`
	CorrelationId    *string             `json:"correlation_id"`
	QueryName        *string             `json:"query_name"`
	QueryNameVersion *string             `json:"query_name_version"`
	QueryContext     *map[string]any     `json:"query_context"`
	Meta             map[string]string   `json:"meta"`
	StorePlanStages  bool                `json:"store_plan_stages"`
}

type FeatureEncodingOptions added in v0.17.0

type FeatureEncodingOptions struct {
	EncodeStructsAsObjects bool `json:"encode_structs_as_objects"`
}

type NamespaceMemo added in v0.18.26

type NamespaceMemo map[string]*NamespaceMemoItem

type NamespaceMemoItem added in v0.18.26

type NamespaceMemoItem struct {
	// Root and non-root FQN as keys
	ResolvedFieldNameToIndices map[string][]int
	// Non-root FQN as keys only
	StructFieldsSet map[string]bool
}

func NewNamespaceMemoItem added in v0.18.26

func NewNamespaceMemoItem() *NamespaceMemoItem

type Numbers added in v0.3.6

type Numbers interface {
	int | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | float32 | float64
}

type OfflineQueryInputSerialized added in v0.14.2

type OfflineQueryInputSerialized struct {
	Columns []string `json:"columns"`
	Values  [][]any  `json:"values"`
}

type OfflineQueryRequestSerialized added in v0.14.2

type OfflineQueryRequestSerialized struct {
	Input                OfflineQueryInputSerialized `json:"input"`
	Output               []string                    `json:"output"`
	RequiredOutput       []string                    `json:"required_output"`
	DatasetName          *string                     `json:"dataset_name"`
	Branch               *string                     `json:"branch"`
	MaxSamples           *int                        `json:"max_samples"`
	DestinationFormat    string                      `json:"destination_format"`
	JobId                *string                     `json:"job_id"`
	MaxCacheAge          *int                        `json:"max_cache_age_secs"`
	ObservedAtLowerBound *time.Time                  `json:"observed_at_lower_bound"`
	ObservedAtUpperBound *time.Time                  `json:"observed_at_upper_bound"`
	QueryContext         *map[string]any             `json:"query_context"`
	Tags                 []string                    `json:"tags"`
}

type OnlineQueryContext added in v0.14.2

type OnlineQueryContext struct {
	Environment          *string  `json:"environment"`
	Tags                 []string `json:"tags"`
	RequiredResolverTags []string `json:"required_resolver_tags"`
}

type OnlineQueryRequestSerialized added in v0.14.2

type OnlineQueryRequestSerialized struct {
	Inputs           map[string]any         `json:"inputs"`
	Outputs          []string               `json:"outputs"`
	Context          OnlineQueryContext     `json:"context"`
	Staleness        map[string]string      `json:"staleness"`
	IncludeMeta      bool                   `json:"include_meta"`
	IncludeMetrics   bool                   `json:"include_metrics"`
	DeploymentId     *string                `json:"deployment_id"`
	QueryName        *string                `json:"query_name"`
	CorrelationId    *string                `json:"correlation_id"`
	QueryContext     *map[string]any        `json:"query_context"`
	Meta             map[string]string      `json:"meta"`
	QueryNameVersion *string                `json:"query_name_version"`
	Now              *string                `json:"now"`
	Explain          bool                   `json:"explain"`
	StorePlanStages  bool                   `json:"store_plan_stages"`
	EncodingOptions  FeatureEncodingOptions `json:"encoding_options"`
}

Directories

Path Synopsis
tests

Jump to

Keyboard shortcuts

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