2017-07-26 01:34:56 +00:00
|
|
|
package userfunc
|
|
|
|
|
|
|
|
import (
|
2019-09-09 23:08:19 +00:00
|
|
|
"github.com/hashicorp/hcl/v2"
|
2017-07-26 01:34:56 +00:00
|
|
|
"github.com/zclconf/go-cty/cty/function"
|
|
|
|
)
|
|
|
|
|
|
|
|
// A ContextFunc is a callback used to produce the base EvalContext for
|
|
|
|
// running a particular set of functions.
|
|
|
|
//
|
|
|
|
// This is a function rather than an EvalContext directly to allow functions
|
|
|
|
// to be decoded before their context is complete. This will be true, for
|
|
|
|
// example, for applications that wish to allow functions to refer to themselves.
|
|
|
|
//
|
|
|
|
// The simplest use of a ContextFunc is to give user functions access to the
|
|
|
|
// same global variables and functions available elsewhere in an application's
|
|
|
|
// configuration language, but more complex applications may use different
|
|
|
|
// contexts to support lexical scoping depending on where in a configuration
|
|
|
|
// structure a function declaration is found, etc.
|
2017-09-11 23:40:37 +00:00
|
|
|
type ContextFunc func() *hcl.EvalContext
|
2017-07-26 01:34:56 +00:00
|
|
|
|
|
|
|
// DecodeUserFunctions looks for blocks of the given type in the given body
|
|
|
|
// and, for each one found, interprets it as a custom function definition.
|
|
|
|
//
|
|
|
|
// On success, the result is a mapping of function names to implementations,
|
|
|
|
// along with a new body that represents the remaining content of the given
|
|
|
|
// body which can be used for further processing.
|
|
|
|
//
|
|
|
|
// The result expression of each function is parsed during decoding but not
|
|
|
|
// evaluated until the function is called.
|
|
|
|
//
|
|
|
|
// If the given ContextFunc is non-nil, it will be called to obtain the
|
|
|
|
// context in which the function result expressions will be evaluated. If nil,
|
|
|
|
// or if it returns nil, the result expression will have access only to
|
|
|
|
// variables named after the declared parameters. A non-nil context turns
|
|
|
|
// the returned functions into closures, bound to the given context.
|
|
|
|
//
|
|
|
|
// If the returned diagnostics set has errors then the function map and
|
|
|
|
// remain body may be nil or incomplete.
|
2017-09-11 23:40:37 +00:00
|
|
|
func DecodeUserFunctions(body hcl.Body, blockType string, context ContextFunc) (funcs map[string]function.Function, remain hcl.Body, diags hcl.Diagnostics) {
|
2017-07-26 01:34:56 +00:00
|
|
|
return decodeUserFunctions(body, blockType, context)
|
|
|
|
}
|