terraform

package
v0.29.0 Latest Latest
Warning

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

Go to latest
Published: Aug 28, 2024 License: Apache-2.0 Imports: 23 Imported by: 0

Documentation

Overview

Copyright 2017 HootSuite Media Inc.

Licensed under the Apache License, Version 2.0 (the License); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an AS IS BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. Modified hereafter by contributors to runatlantis/atlantis.

Package terraform handles the actual running of terraform commands.

Index

Constants

This section is empty.

Variables

View Source
var LogStreamingValidCmds = [...]string{"init", "plan", "apply"}

Functions

func MustConstraint

func MustConstraint(v string) version.Constraints

MustConstraint will parse one or more constraints from the given constraint string. The string must be a comma-separated list of constraints. It panics if there is an error.

Types

type Client

type Client interface {
	// RunCommandWithVersion executes terraform with args in path. If v is nil,
	// it will use the default Terraform version. workspace is the Terraform
	// workspace which should be set as an environment variable.
	RunCommandWithVersion(ctx command.ProjectContext, path string, args []string, envs map[string]string, v *version.Version, workspace string) (string, error)

	// EnsureVersion makes sure that terraform version `v` is available to use
	EnsureVersion(log logging.SimpleLogging, v *version.Version) error

	// DetectVersion Extracts required_version from Terraform configuration in the specified project directory. Returns nil if unable to determine the version.
	DetectVersion(log logging.SimpleLogging, projectDirectory string) *version.Version
}

type DefaultClient

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

func NewClient

func NewClient(
	log logging.SimpleLogging,
	binDir string,
	cacheDir string,
	tfeToken string,
	tfeHostname string,
	defaultVersionStr string,
	defaultVersionFlagName string,
	tfDownloadURL string,
	tfDownloader Downloader,
	tfDownloadAllowed bool,
	usePluginCache bool,
	projectCmdOutputHandler jobs.ProjectCommandOutputHandler,
) (*DefaultClient, error)

NewClient constructs a terraform client. tfeToken is an optional terraform enterprise token. defaultVersionStr is an optional default terraform version to use unless a specific version is set. defaultVersionFlagName is the name of the flag that sets the default terraform version. tfDownloader is used to download terraform versions. Will asynchronously download the required version if it doesn't exist already.

func NewClientWithDefaultVersion

func NewClientWithDefaultVersion(
	log logging.SimpleLogging,
	binDir string,
	cacheDir string,
	tfeToken string,
	tfeHostname string,
	defaultVersionStr string,
	defaultVersionFlagName string,
	tfDownloadURL string,
	tfDownloader Downloader,
	tfDownloadAllowed bool,
	usePluginCache bool,
	fetchAsync bool,
	projectCmdOutputHandler jobs.ProjectCommandOutputHandler,
) (*DefaultClient, error)

NewClientWithDefaultVersion creates a new terraform client and pre-fetches the default version

func NewTestClient

func NewTestClient(
	log logging.SimpleLogging,
	binDir string,
	cacheDir string,
	tfeToken string,
	tfeHostname string,
	defaultVersionStr string,
	defaultVersionFlagName string,
	tfDownloadURL string,
	tfDownloader Downloader,
	tfDownloadAllowed bool,
	usePluginCache bool,
	projectCmdOutputHandler jobs.ProjectCommandOutputHandler,
) (*DefaultClient, error)

func (*DefaultClient) DefaultVersion

func (c *DefaultClient) DefaultVersion() *version.Version

Version returns the default version of Terraform we use if no other version is defined.

func (*DefaultClient) DetectVersion added in v0.22.0

func (c *DefaultClient) DetectVersion(log logging.SimpleLogging, projectDirectory string) *version.Version

DetectVersion extracts required_version from Terraform configuration in the specified project directory. Returns nil if unable to determine the version. It will also try to evaluate non-exact matches by passing the Constraints to the hc-install Releases API, which will return a list of available versions. It will then select the highest version that satisfies the constraint.

func (*DefaultClient) EnsureVersion

func (c *DefaultClient) EnsureVersion(log logging.SimpleLogging, v *version.Version) error

See Client.EnsureVersion.

func (*DefaultClient) ExtractExactRegex added in v0.28.2

func (c *DefaultClient) ExtractExactRegex(log logging.SimpleLogging, version string) []string

ExtractExactRegex attempts to extract an exact version number from the provided string as a fallback. The function expects the version string to be in one of the following formats: "= x.y.z", "=x.y.z", or "x.y.z" where x, y, and z are integers. If the version string matches one of these formats, the function returns a slice containing the exact version number. If the version string does not match any of these formats, the function logs a debug message and returns nil.

func (*DefaultClient) RunCommandAsync

func (c *DefaultClient) RunCommandAsync(ctx command.ProjectContext, path string, args []string, customEnvVars map[string]string, v *version.Version, workspace string) (chan<- string, <-chan models.Line)

RunCommandAsync runs terraform with args. It immediately returns an input and output channel. Callers can use the output channel to get the realtime output from the command. Callers can use the input channel to pass stdin input to the command. If any error is passed on the out channel, there will be no further output (so callers are free to exit).

func (*DefaultClient) RunCommandWithVersion

func (c *DefaultClient) RunCommandWithVersion(ctx command.ProjectContext, path string, args []string, customEnvVars map[string]string, v *version.Version, workspace string) (string, error)

See Client.RunCommandWithVersion.

func (*DefaultClient) TerraformBinDir

func (c *DefaultClient) TerraformBinDir() string

TerraformBinDir returns the directory where we download Terraform binaries.

type DefaultDownloader

type DefaultDownloader struct{}

func (*DefaultDownloader) GetAny

func (d *DefaultDownloader) GetAny(dst, src string) error

See go-getter.GetAny.

func (*DefaultDownloader) Install added in v0.28.2

func (d *DefaultDownloader) Install(dir string, downloadURL string, v *version.Version) (string, error)

type Downloader

type Downloader interface {
	Install(dir string, downloadURL string, v *version.Version) (string, error)
	GetAny(dst, src string) error
}

Downloader is for downloading terraform versions.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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