OpenTofu lets you declaratively manage your cloud infrastructure.
Go to file
2023-09-07 19:52:18 +03:00
.github Pull Request Template validation (#326) 2023-09-07 15:24:35 +03:00
docs Fix link in architecture.md (#271) 2023-09-05 18:06:26 +02:00
internal internal/depsfile: deprecate io/ioutil (#338) 2023-09-07 19:52:18 +03:00
scripts Release workflow (#173) 2023-08-29 11:00:24 +02:00
testing Marshal plan#relevant_attributes in deterministic order (#327) 2023-09-07 13:36:16 +02:00
tools Remove traces of terraform-bundle (#145) 2023-08-23 14:44:45 +02:00
version cleanup after 1.6.0-alpha20230802 release (#33623) 2023-08-02 13:50:11 +02:00
website Added eslint + remark-lint to our documentation pages (#249) 2023-09-06 17:16:54 +01:00
.copywrite.hcl Configure copywrite to ignore more generated code 2023-04-26 16:47:54 -04:00
.gitignore chore: ignore /opentf binary (#289) 2023-09-06 02:08:33 -04:00
.go-version build with Go 1.20.7 (#33645) 2023-08-08 14:35:07 +01:00
.goreleaser.yaml Release workflow (#173) 2023-08-29 11:00:24 +02:00
.tfdev Rename root module name. (#4) 2023-08-17 14:45:11 +02:00
BUILDING.md Fixes broken links in md docs and bug template (#328) 2023-09-07 13:32:52 +02:00
CHANGELOG.md Require hostname for cloud/remote backends and login/logout (#291) 2023-09-06 12:54:39 +02:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md (#176) 2023-08-25 11:58:58 +02:00
codecov.yml [COMPLIANCE] Add Copyright and License Headers 2023-05-02 15:33:06 +00:00
CODEOWNERS Adjust CODEOWNERS to not have any code owners right now 2023-08-21 10:54:47 +03:00
commands.go Rename occurrences in root folder to to OpenTF (#172) 2023-08-25 11:16:55 +02:00
CONTRIBUTING.md Fixes broken links in md docs and bug template (#328) 2023-09-07 13:32:52 +02:00
copyright_headers.go build: Generate copyright headers automatically 2023-05-30 08:21:40 -07:00
Dockerfile Release workflow (#173) 2023-08-29 11:00:24 +02:00
experiments.go Renaming of Terraform to OpenTF 2023-08-22 15:45:05 +03:00
go.mod Remove checkpoint code - less is more (#151) 2023-08-23 16:42:50 +02:00
go.sum Remove checkpoint code - less is more (#151) 2023-08-23 16:42:50 +02:00
help.go Rename occurrences in root folder to to OpenTF (#172) 2023-08-25 11:16:55 +02:00
LICENSE [COMPLIANCE] Update MPL 2.0 LICENSE 2022-10-12 17:36:01 +00:00
main_test.go Rename occurrences in root folder to to OpenTF (#172) 2023-08-25 11:16:55 +02:00
main.go rename func 2023-08-27 17:38:54 +03:00
Makefile Renaming of Terraform to OpenTF 2023-08-22 15:45:05 +03:00
MIGRATION_GUIDE.md Create MIGRATION_GUIDE.md (#23) 2023-08-18 20:00:56 +02:00
plugins.go Rename root module name. (#4) 2023-08-17 14:45:11 +02:00
provider_source.go Rename occurrences in root folder to to OpenTF (#172) 2023-08-25 11:16:55 +02:00
README.md Remove duplicate in readme (#331) 2023-09-07 15:54:28 +02:00
signal_unix.go [COMPLIANCE] Add Copyright and License Headers 2023-05-02 15:33:06 +00:00
signal_windows.go [COMPLIANCE] Add Copyright and License Headers 2023-05-02 15:33:06 +00:00
telemetry.go Rename occurrences in root folder to to OpenTF (#172) 2023-08-25 11:16:55 +02:00
tools.go [COMPLIANCE] Add Copyright and License Headers 2023-05-02 15:33:06 +00:00
version.go Rename root module name. (#4) 2023-08-17 14:45:11 +02:00
working_dir.go Rename root module name. (#4) 2023-08-17 14:45:11 +02:00

OpenTF

OpenTF

Important Note: This repository is currently a work in progress while we're preparing it for the first alpha release and fine-tuning the community contribution process. Please read the announcement post for important context and the contributing docs for instructions on how to contribute. Additionally, please be mindful that building this repository in its current state and running it might put you in violation of the Terraform Registry ToS, if that's where you fetch your providers or modules from.

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

The key features of OpenTF 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: OpenTF has a "planning" step where it generates an execution plan. The execution plan shows what OpenTF will do when you call apply. This lets you avoid any surprises when OpenTF manipulates infrastructure.

  • Resource Graph: OpenTF builds a graph of all your resources, and parallelizes the creation and modification of any non-dependent resources. Because of this, OpenTF 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 OpenTF will change and in what order, avoiding many possible human errors.

Developing OpenTF

This repository contains OpenTF Core, which includes the command line interface and the main graph engine.

License

Mozilla Public License v2.0