Documentation ¶
Overview ¶
The config package is responsible for loading and validating the configuration.
Index ¶
- Variables
- func Funcs() map[string]ast.Function
- func IsEmptyDir(root string) (bool, error)
- func IsIgnoredFile(name string) bool
- func ProviderConfigName(t string, pcs []*ProviderConfig) string
- func ResourceProviderFullName(resourceType, explicitProvider string) string
- type AtlasConfig
- type Backend
- type Config
- func Append(c1, c2 *Config) (*Config, error)
- func LoadBytes(path string, contents []byte) (*Config, error)
- func LoadDir(root string) (*Config, error)
- func LoadFile(path string) (*Config, error)
- func LoadFs(fs afero.Fs) (*Config, error)
- func LoadJSON(raw json.RawMessage) (*Config, error)
- func Merge(c1, c2 *Config) (*Config, error)
- type CountValueType
- type CountVariable
- type ErrNoConfigsFound
- type InterpolatedVariable
- type Local
- type LocalVariable
- type Module
- type ModuleVariable
- type Output
- type PathValueType
- type PathVariable
- type ProviderConfig
- type ProviderVersionConstraint
- type ProviderVersionConstraints
- type Provisioner
- type ProvisionerOnFailure
- type ProvisionerWhen
- type RawConfig
- func (r *RawConfig) Config() map[string]interface{}
- func (r *RawConfig) Copy() *RawConfig
- func (r *RawConfig) GobDecode(b []byte) error
- func (r *RawConfig) GobEncode() ([]byte, error)
- func (r *RawConfig) Interpolate(vs map[string]ast.Variable) error
- func (r *RawConfig) Merge(other *RawConfig) *RawConfig
- func (r *RawConfig) RawMap() map[string]interface{}
- func (r *RawConfig) UnknownKeys() []string
- func (r *RawConfig) Value() interface{}
- type Resource
- type ResourceLifecycle
- type ResourceMode
- type ResourceVariable
- type SelfVariable
- type SimpleVariable
- type Terraform
- type TerraformVariable
- type UserVariable
- type Variable
- type VariableType
Constants ¶
This section is empty.
Variables ¶
var NameRegexp = regexp.MustCompile(`(?i)\A[A-Z0-9_][A-Z0-9\-\_]*\z`)
NameRegexp is the regular expression that all names (modules, providers, resources, etc.) must follow.
var ReservedDataSourceFields = []string{
"connection",
"count",
"depends_on",
"lifecycle",
"provider",
"provisioner",
}
var ReservedProviderFields = []string{
"alias",
"version",
}
var ReservedResourceFields = []string{
"connection",
"count",
"depends_on",
"id",
"lifecycle",
"provider",
"provisioner",
}
Functions ¶
func IsEmptyDir ¶
IsEmptyDir returns true if the directory given has no Terraform configuration files.
func IsIgnoredFile ¶
IsIgnoredFile returns true or false depending on whether the provided file name is a file that should be ignored.
func ProviderConfigName ¶
func ProviderConfigName(t string, pcs []*ProviderConfig) string
ProviderConfigName returns the name of the provider configuration in the given mapping that maps to the proper provider configuration for this resource.
func ResourceProviderFullName ¶
ResourceProviderFullName returns the full (dependable) name of the provider for a hypothetical resource with the given resource type and explicit provider string. If the explicit provider string is empty then the provider name is inferred from the resource type name.
Types ¶
type AtlasConfig ¶
AtlasConfig is the configuration for building in HashiCorp's Atlas.
type Backend ¶
type Backend struct { Type string RawConfig *RawConfig // Hash is a unique hash code representing the original configuration // of the backend. This won't be recomputed unless Rehash is called. Hash uint64 }
Backend is the configuration for the "backend" to use with Terraform. A backend is responsible for all major behavior of Terraform's core. The abstraction layer above the core (the "backend") allows for behavior such as remote operation.
type Config ¶
type Config struct { Fs afero.Fs // Dir is the path to the directory where this configuration was // loaded from. If it is blank, this configuration wasn't loaded from // any meaningful directory. Dir string Terraform *Terraform Atlas *AtlasConfig Modules []*Module ProviderConfigs []*ProviderConfig Resources []*Resource Variables []*Variable Locals []*Local Outputs []*Output // contains filtered or unexported fields }
Config is the configuration that comes from loading a collection of Terraform templates.
func Append ¶
Append appends one configuration to another.
Append assumes that both configurations will not have conflicting variables, resources, etc. If they do, the problems will be caught in the validation phase.
It is possible that c1, c2 on their own are not valid. For example, a resource in c2 may reference a variable in c1. But together, they would be valid.
func LoadBytes ¶
LoadBytes loads the Terraform configuration from a given byte array.
This string can be any format that Terraform recognizes, and import any other format that Terraform recognizes.
func LoadDir ¶
LoadDir loads all the Terraform configuration files in a single directory and appends them together.
Special files known as "override files" can also be present, which are merged into the loaded configuration. That is, the non-override files are loaded first to create the configuration. Then, the overrides are merged into the configuration to create the final configuration.
Files are loaded in lexical order.
func LoadFile ¶
LoadFile loads the Terraform configuration from a given file.
This file can be any format that Terraform recognizes, and import any other format that Terraform recognizes.
func LoadFs ¶
LoadDir loads all the Terraform configuration files from the root of the given virtual filesystem and appends them together.
Special files known as "override files" can also be present, which are merged into the loaded configuration. That is, the non-override files are loaded first to create the configuration. Then, the overrides are merged into the configuration to create the final configuration.
Files are loaded in lexical order.
func LoadJSON ¶
func LoadJSON(raw json.RawMessage) (*Config, error)
LoadJSON loads a single Terraform configuration from a given JSON document.
The document must be a complete Terraform configuration. This function will NOT try to load any additional modules so only the given document is loaded.
func Merge ¶
Merge merges two configurations into a single configuration.
Merge allows for the two configurations to have duplicate resources, because the resources will be merged. This differs from a single Config which must only have unique resources.
func (*Config) InterpolatedVariables ¶
func (c *Config) InterpolatedVariables() map[string][]InterpolatedVariable
InterpolatedVariables is a helper that returns a mapping of all the interpolated variables within the configuration. This is used to verify references are valid in the Validate step.
func (*Config) ProviderConfigsByFullName ¶
func (c *Config) ProviderConfigsByFullName() map[string]*ProviderConfig
ProviderConfigsByFullName returns a map from provider full names (as returned by ProviderConfig.FullName()) to the corresponding provider configs.
This function returns no new information than what's already in c.ProviderConfigs, but returns it in a more convenient shape. If there is more than one provider config with the same full name then the result is undefined, but that is guaranteed not to happen for any config that has passed validation.
func (*Config) RequiredProviders ¶
func (c *Config) RequiredProviders() ProviderVersionConstraints
RequiredProviders returns the ProviderVersionConstraints for this module.
This includes both providers that are explicitly requested by provider blocks and those that are used implicitly by instantiating one of their resource types. In the latter case, the returned semver Range will accept any version of the provider.
func (*Config) TestString ¶
TestString is a Stringer-like function that outputs a string that can be used to easily compare multiple Config structures in unit tests.
This function has no practical use outside of unit tests and debugging.
type CountValueType ¶
type CountValueType byte
CountValueType is the type of the count variable that is referenced.
const ( CountValueInvalid CountValueType = iota CountValueIndex )
type CountVariable ¶
type CountVariable struct { Type CountValueType // contains filtered or unexported fields }
CountVariable is a variable for referencing information about the count.
func NewCountVariable ¶
func NewCountVariable(key string) (*CountVariable, error)
func (*CountVariable) FullKey ¶
func (c *CountVariable) FullKey() string
type ErrNoConfigsFound ¶
type ErrNoConfigsFound struct {
Dir string
}
ErrNoConfigsFound is the error returned by LoadDir if no Terraform configuration files were found in the given directory.
func (ErrNoConfigsFound) Error ¶
func (e ErrNoConfigsFound) Error() string
type InterpolatedVariable ¶
type InterpolatedVariable interface {
FullKey() string
}
An InterpolatedVariable is a variable reference within an interpolation.
Implementations of this interface represents various sources where variables can come from: user variables, resources, etc.
func DetectVariables ¶
func DetectVariables(root ast.Node) ([]InterpolatedVariable, error)
DetectVariables takes an AST root and returns all the interpolated variables that are detected in the AST tree.
func NewInterpolatedVariable ¶
func NewInterpolatedVariable(v string) (InterpolatedVariable, error)
type LocalVariable ¶
type LocalVariable struct {
Name string
}
A LocalVariable is a variable that references a local value defined within the current module, via a "locals" block. This looks like "${local.foo}".
func NewLocalVariable ¶
func NewLocalVariable(key string) (*LocalVariable, error)
func (*LocalVariable) FullKey ¶
func (v *LocalVariable) FullKey() string
func (*LocalVariable) GoString ¶
func (v *LocalVariable) GoString() string
type Module ¶
type Module struct { Name string Source string Version string Providers map[string]string RawConfig *RawConfig }
Module is a module used within a configuration.
This does not represent a module itself, this represents a module call-site within an existing configuration.
type ModuleVariable ¶
A ModuleVariable is a variable that is referencing the output of a module, such as "${module.foo.bar}"
func NewModuleVariable ¶
func NewModuleVariable(key string) (*ModuleVariable, error)
func (*ModuleVariable) FullKey ¶
func (v *ModuleVariable) FullKey() string
func (*ModuleVariable) GoString ¶
func (v *ModuleVariable) GoString() string
type Output ¶
type Output struct { Name string DependsOn []string Description string Sensitive bool RawConfig *RawConfig }
Output is an output defined within the configuration. An output is resulting data that is highlighted by Terraform when finished. An output marked Sensitive will be output in a masked form following application, but will still be available in state.
type PathValueType ¶
type PathValueType byte
const ( PathValueInvalid PathValueType = iota PathValueCwd PathValueModule PathValueRoot )
type PathVariable ¶
type PathVariable struct { Type PathValueType // contains filtered or unexported fields }
A PathVariable is a variable that references path information about the module.
func NewPathVariable ¶
func NewPathVariable(key string) (*PathVariable, error)
func (*PathVariable) FullKey ¶
func (v *PathVariable) FullKey() string
type ProviderConfig ¶
ProviderConfig is the configuration for a resource provider.
For example, Terraform needs to set the AWS access keys for the AWS resource provider.
func (*ProviderConfig) FullName ¶
func (c *ProviderConfig) FullName() string
func (*ProviderConfig) GoString ¶
func (c *ProviderConfig) GoString() string
type ProviderVersionConstraint ¶
ProviderVersionConstraint presents a constraint for a particular provider, identified by its full name.
type ProviderVersionConstraints ¶
type ProviderVersionConstraints map[string]ProviderVersionConstraint
ProviderVersionConstraints is a map from provider full name to its associated ProviderVersionConstraint, as produced by Config.RequiredProviders.
func (ProviderVersionConstraints) RequiredRanges ¶
func (cons ProviderVersionConstraints) RequiredRanges() map[string]semver.Range
RequiredRanges returns a semver.Range for each distinct provider type in the constraint map. If the same provider type appears more than once (e.g. because aliases are in use) then their respective constraints are combined such that they must *all* apply.
The result of this method can be passed to the PluginMetaSet.ConstrainVersions method within the plugin/discovery package in order to filter down the available plugins to those which satisfy the given constraints.
This function will panic if any of the constraints within cannot be parsed as semver ranges. This is guaranteed to never happen for a constraint set that was built from a configuration that passed validation.
type Provisioner ¶
type Provisioner struct { Type string RawConfig *RawConfig ConnInfo *RawConfig When ProvisionerWhen OnFailure ProvisionerOnFailure }
Provisioner is a configured provisioner step on a resource.
func (*Provisioner) Copy ¶
func (p *Provisioner) Copy() *Provisioner
Copy returns a copy of this Provisioner
type ProvisionerOnFailure ¶
type ProvisionerOnFailure int
ProvisionerOnFailure is an enum for valid values for on_failure options for provisioners.
const ( ProvisionerOnFailureInvalid ProvisionerOnFailure = iota ProvisionerOnFailureContinue ProvisionerOnFailureFail )
func (ProvisionerOnFailure) String ¶
func (v ProvisionerOnFailure) String() string
type ProvisionerWhen ¶
type ProvisionerWhen int
ProvisionerWhen is an enum for valid values for when to run provisioners.
const ( ProvisionerWhenInvalid ProvisionerWhen = iota ProvisionerWhenCreate ProvisionerWhenDestroy )
func (ProvisionerWhen) String ¶
func (v ProvisionerWhen) String() string
type RawConfig ¶
type RawConfig struct { Key string Raw map[string]interface{} Interpolations []ast.Node Variables map[string]InterpolatedVariable // contains filtered or unexported fields }
RawConfig is a structure that holds a piece of configuration where the overall structure is unknown since it will be used to configure a plugin or some other similar external component.
RawConfigs can be interpolated with variables that come from other resources, user variables, etc.
RawConfig supports a query-like interface to request information from deep within the structure.
func NewRawConfig ¶
NewRawConfig creates a new RawConfig structure and populates the publicly readable struct fields.
func TestRawConfig ¶
TestRawConfig is used to create a RawConfig for testing.
func (*RawConfig) Config ¶
Config returns the entire configuration with the variables interpolated from any call to Interpolate.
If any interpolated variables are unknown (value set to UnknownVariableValue), the first non-container (map, slice, etc.) element will be removed from the config. The keys of unknown variables can be found using the UnknownKeys function.
By pruning out unknown keys from the configuration, the raw structure will always successfully decode into its ultimate structure using something like mapstructure.
func (*RawConfig) GobEncode ¶
GobEncode is a custom Gob encoder to use so that we only include the raw configuration. Interpolated variables and such are lost and the tree of interpolated variables is recomputed on decode, since it is referentially transparent.
func (*RawConfig) Interpolate ¶
Interpolate uses the given mapping of variable values and uses those as the values to replace any variables in this raw configuration.
Any prior calls to Interpolate are replaced with this one.
If a variable key is missing, this will panic.
func (*RawConfig) Merge ¶
Merge merges another RawConfig into this one (overriding any conflicting values in this config) and returns a new config. The original config is not modified.
func (*RawConfig) UnknownKeys ¶
UnknownKeys returns the keys of the configuration that are unknown because they had interpolated variables that must be computed.
type Resource ¶
type Resource struct { Mode ResourceMode // which operations the resource supports Name string Type string RawCount *RawConfig RawConfig *RawConfig Provisioners []*Provisioner Provider string DependsOn []string Lifecycle ResourceLifecycle }
A resource represents a single Terraform resource in the configuration. A Terraform resource is something that supports some or all of the usual "create, read, update, delete" operations, depending on the given Mode.
func (*Resource) Copy ¶
Copy returns a copy of this Resource. Helpful for avoiding shared config pointers across multiple pieces of the graph that need to do interpolation.
func (*Resource) ProviderFullName ¶
ProviderFullName returns the full name of the provider for this resource, which may either be specified explicitly using the "provider" meta-argument or implied by the prefix on the resource type name.
type ResourceLifecycle ¶
type ResourceLifecycle struct { CreateBeforeDestroy bool `mapstructure:"create_before_destroy"` PreventDestroy bool `mapstructure:"prevent_destroy"` IgnoreChanges []string `mapstructure:"ignore_changes"` }
ResourceLifecycle is used to store the lifecycle tuning parameters to allow customized behavior
func (*ResourceLifecycle) Copy ¶
func (r *ResourceLifecycle) Copy() *ResourceLifecycle
Copy returns a copy of this ResourceLifecycle
type ResourceMode ¶
type ResourceMode int
const ( ManagedResourceMode ResourceMode = iota DataResourceMode )
func (ResourceMode) String ¶
func (i ResourceMode) String() string
func (ResourceMode) Taintable ¶
func (m ResourceMode) Taintable() bool
type ResourceVariable ¶
type ResourceVariable struct { Mode ResourceMode Type string // Resource type, i.e. "aws_instance" Name string // Resource name Field string // Resource field Multi bool // True if multi-variable: aws_instance.foo.*.id Index int // Index for multi-variable: aws_instance.foo.1.id == 1 // contains filtered or unexported fields }
A ResourceVariable is a variable that is referencing the field of a resource, such as "${aws_instance.foo.ami}"
func NewResourceVariable ¶
func NewResourceVariable(key string) (*ResourceVariable, error)
func (*ResourceVariable) FullKey ¶
func (v *ResourceVariable) FullKey() string
func (*ResourceVariable) ResourceId ¶
func (v *ResourceVariable) ResourceId() string
type SelfVariable ¶
type SelfVariable struct { Field string // contains filtered or unexported fields }
SelfVariable is a variable that is referencing the same resource it is running on: "${self.address}"
func NewSelfVariable ¶
func NewSelfVariable(key string) (*SelfVariable, error)
func (*SelfVariable) FullKey ¶
func (v *SelfVariable) FullKey() string
func (*SelfVariable) GoString ¶
func (v *SelfVariable) GoString() string
type SimpleVariable ¶
type SimpleVariable struct {
Key string
}
SimpleVariable is an unprefixed variable, which can show up when users have strings they are passing down to resources that use interpolation internally. The template_file resource is an example of this.
func NewSimpleVariable ¶
func NewSimpleVariable(key string) (*SimpleVariable, error)
func (*SimpleVariable) FullKey ¶
func (v *SimpleVariable) FullKey() string
func (*SimpleVariable) GoString ¶
func (v *SimpleVariable) GoString() string
type Terraform ¶
type Terraform struct { RequiredVersion string `hcl:"required_version"` // Required Terraform version (constraint) Backend *Backend // See Backend struct docs }
Terraform is the Terraform meta-configuration that can be present in configuration files for configuring Terraform itself.
type TerraformVariable ¶
type TerraformVariable struct { Field string // contains filtered or unexported fields }
TerraformVariable is a "terraform."-prefixed variable used to access metadata about the Terraform run.
func NewTerraformVariable ¶
func NewTerraformVariable(key string) (*TerraformVariable, error)
func (*TerraformVariable) FullKey ¶
func (v *TerraformVariable) FullKey() string
func (*TerraformVariable) GoString ¶
func (v *TerraformVariable) GoString() string
type UserVariable ¶
A UserVariable is a variable that is referencing a user variable that is inputted from outside the configuration. This looks like "${var.foo}"
func NewUserVariable ¶
func NewUserVariable(key string) (*UserVariable, error)
func (*UserVariable) FullKey ¶
func (v *UserVariable) FullKey() string
func (*UserVariable) GoString ¶
func (v *UserVariable) GoString() string
type Variable ¶
type Variable struct { Name string DeclaredType string `mapstructure:"type"` Default interface{} Description string }
Variable is a module argument defined within the configuration.
type VariableType ¶
type VariableType byte
VariableType is the type of value a variable is holding, and returned by the Type() function on variables.
const ( VariableTypeUnknown VariableType = iota VariableTypeString VariableTypeList VariableTypeMap )
func (VariableType) Printable ¶
func (v VariableType) Printable() string