Documentation ¶
Index ¶
- func AddInputVariables(ctx *hcl.EvalContext, vs Values)
- func DecodeVariableBlocks(content *hcl.BodyContent) (map[string]*Variable, hcl.Diagnostics)
- func LoadAutoFiles(wd string) ([]*pb.Variable, hcl.Diagnostics)
- func LoadEnvValues(vars map[string]*Variable) ([]*pb.Variable, hcl.Diagnostics)
- func LoadVariableValues(vars map[string]string, files []string) ([]*pb.Variable, hcl.Diagnostics)
- type HclVariable
- type Value
- type Values
- type Variable
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AddInputVariables ¶
func AddInputVariables(ctx *hcl.EvalContext, vs Values)
AddInputVariables adds the InputValues to the provided hcl context
func DecodeVariableBlocks ¶
DecodeVariableBlocks uses the hclConfig schema to iterate over all variable blocks, validating names and types and checking for duplicates. It returns the final map of Variables to store for later reference.
func LoadAutoFiles ¶
LoadAutoFiles loads any *.auto.wpvars(.json) files in the source repo
func LoadEnvValues ¶ added in v0.6.0
LoadEnvValues loads the variable values from environment variables specified via the `env` field on the `variable` stanza.
func LoadVariableValues ¶
LoadVariableValues collects values set via the CLI (-var, -varfile) and local env vars (WP_VAR_*) and translates those values to pb.Variables. These pb.Variables can then be set on the job for eventual parsing on the runner, after the runner has decoded the variables defined in the waypoint.hcl. All values are set as protobuf strings, with the expectation that later evaluation will convert them to their defined types.
Types ¶
type HclVariable ¶
type HclVariable struct { Name string `hcl:",label"` Default cty.Value `hcl:"default,optional"` Type hcl.Expression `hcl:"type,optional"` Description string `hcl:"description,optional"` Env []string `hcl:"env,optional"` }
HclVariable is used when decoding the waypoint.hcl config. Because we use hclsimple for this decode, we need the `Type` to be evaluated as an hcl expression. When we parse the config, we need `Type` to be evaluated as cty.Type, so this struct is only used for the basic decoding of the file to verify HCL syntax.
type Value ¶
type Value struct { Value cty.Value Source string Expr hcl.Expression // The location of the variable value if the value was provided from a file Range hcl.Range }
Value contain the value of the variable along with associated metada, including the source it was set from: cli, file, env, vcs, server/ui
type Values ¶
Values are used to store values collected from various sources. Values are added to the map in precedence order, and then used to create the final map of cty.Values for config hcl context evaluation.
func EvaluateVariables ¶
func EvaluateVariables( pbvars []*pb.Variable, vs map[string]*Variable, log hclog.Logger, ) (Values, hcl.Diagnostics)
EvaluateVariables evaluates the provided variable values and validates their types per the type declared in the waypoint.hcl for that variable name. The order in which values are evaluated corresponds to their precedence, with higher precedence values overwriting lower precedence values. The supplied map of *Variable should be all defined variables (currently comes from decoding all variable blocks within the waypoint.hcl), and is used to validate types and that all variables have at least one assigned value.
type Variable ¶
type Variable struct { Name string // The default value in the variable definition Default *Value // A list of environment variables that will be sourced to satisfy // the value of this variable. Env []string // Cty Type of the variable. If the default value or a collected value is // not of this type nor can be converted to this type an error diagnostic // will show up. This allows us to assume that values are valid. // // When a default value - and no type - is passed into the variable // declaration, the type of the default variable will be used. Type cty.Type // Description of the variable Description string // The location of the variable definition block in the waypoint.hcl Range hcl.Range }
Variable stores a parsed variable definition from the waypoint.hcl