Terraform enables you to safely and predictably create, change, and improve infrastructure. It is a source-available tool that codifies APIs into declarative configuration files that can be shared amongst team members, treated as code, edited, reviewed, and versioned.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Go to file
Martin Atkins bf396b5f1b
command/views: main View type aware if it's running in automation
5 years ago
.circleci remove codedov 5 years ago
.github update to match new default branch name (#27909) 5 years ago
addrs Improve ModuleInstance String() performance (#28246) 5 years ago
backend command/views: Remove baseState argument from plan-rendering views 5 years ago
builtin additional null checks in provisioners 5 years ago
command command/views: main View type aware if it's running in automation 5 years ago
communicator Grammar nit: "setup" as a verb should be spelled "set up" 5 years ago
configs don't build a config if it didn't load properly 5 years ago
dag tiny optimisations of dag.Set 5 years ago
docs update destroying doc to show show more CBD detail 5 years ago
e2e command/cliconfig: Allow development overrides for providers 5 years ago
experiments Conclude provider sensitivity experiment 5 years ago
httpclient
instances instances: staticcheck 5 years ago
internal update getproviders tests for new key 5 years ago
lang functions: Improve marks support for lookup 5 years ago
moduledeps
plans plans/planfile: Read state snapshots as part of reading a plan 5 years ago
plugin use WholeContainingBody instead of Sourceless 5 years ago
plugin6 providers.Interface: rename ValidateDataSourceConfig to ValidateDataResourceConfig (#27874) 5 years ago
providers providers.Interface: rename ValidateDataSourceConfig to ValidateDataResourceConfig (#27874) 5 years ago
provisioners
registry registry: staticcheck 5 years ago
repl lang/funcs: add (console-only) TypeFunction (#28501) 5 years ago
scripts Remove revision from version command 5 years ago
states fix ResourceInstanceObject.DeepCopy 5 years ago
terraform core: Update working state for resource instances in refresh-only mode 5 years ago
tfdiags add addresses to diagnostics 5 years ago
tools terraform-bundle: return an error if "versions" argument is omitted (#28158) 5 years ago
version Cleanup after v0.15.0-alpha20210210 release 5 years ago
website website: Explicit example of for_each chaining between resources 5 years ago
.gitignore ignoring the vendor folder 5 years ago
.go-version build: Use Go 1.16.2 5 years ago
.hashibot.hcl Restore issue migrator 5 years ago
.tfdev Remove revision from version command 5 years ago
BUGPROCESS.md Update BUGPROCESS.md 5 years ago
CHANGELOG.md Update CHANGELOG.md 5 years ago
CODEOWNERS
Dockerfile switch to hashicorp docker mirror 5 years ago
LICENSE
Makefile Remove website-test task from Makefile 5 years ago
README.md update to match new default branch name (#27909) 5 years ago
checkpoint.go
codecov.yml update to match new default branch name (#27909) 5 years ago
commands.go command/views: main View type aware if it's running in automation 5 years ago
go.mod go get github.com/zclconf/go-cty@v1.8.3 5 years ago
go.sum go get github.com/zclconf/go-cty@v1.8.3 5 years ago
help.go Update links to CLI docs in code comments, messages, and readme 5 years ago
main.go don't error when processing autocomplete commands 5 years ago
main_test.go don't error when processing autocomplete commands 5 years ago
plugins.go
provider_source.go Correct the spelling of heirarchy/hierarchy throughout 5 years ago
signal_unix.go
signal_windows.go
version.go Remove revision from version command 5 years ago

README.md

Terraform

Terraform

Terraform is a tool for building, changing, and versioning infrastructure safely and efficiently. Terraform can manage existing and popular service providers as well as custom in-house solutions.

The key features of Terraform are:

  • Infrastructure as Code: Infrastructure is described using a high-level configuration syntax. This allows a blueprint of your datacenter to be versioned and treated as you would any other code. Additionally, infrastructure can be shared and re-used.

  • Execution Plans: Terraform has a "planning" step where it generates an execution plan. The execution plan shows what Terraform will do when you call apply. This lets you avoid any surprises when Terraform manipulates infrastructure.

  • Resource Graph: Terraform builds a graph of all your resources, and parallelizes the creation and modification of any non-dependent resources. Because of this, Terraform builds infrastructure as efficiently as possible, and operators get insight into dependencies in their infrastructure.

  • Change Automation: Complex changesets can be applied to your infrastructure with minimal human interaction. With the previously mentioned execution plan and resource graph, you know exactly what Terraform will change and in what order, avoiding many possible human errors.

For more information, see the introduction section of the Terraform website.

Getting Started & Documentation

Documentation is available on the Terraform website:

If you're new to Terraform and want to get started creating infrastructure, please check out our Getting Started guides on HashiCorp's learning platform. There are also additional guides to continue your learning.

Show off your Terraform knowledge by passing a certification exam. Visit the certification page for information about exams and find study materials on HashiCorp's learning platform.

Developing Terraform

This repository contains only Terraform core, which includes the command line interface and the main graph engine. Providers are implemented as plugins, and Terraform can automatically download providers that are published on the Terraform Registry. HashiCorp develops some providers, and others are developed by other organizations. For more information, see Extending Terraform.

To learn more about compiling Terraform and contributing suggested changes, please refer to the contributing guide.

To learn more about how we handle bug reports, please read the bug triage guide.

License

Mozilla Public License v2.0