This commit adds the definitions of provider protocol 5.6, 5.7, 6.6, and 6.7 to our archive of the historical protocol versions and then adopts 5.7 as the current version of major version 5 and 6.7 as the current version of major version 6. These MPL-licensed schema definitions are from the plugin protocol server implementation in this repository, copyright HashiCorp: https://github.com/hashicorp/terraform-plugin-go The only modifications made are to change the "option go_package" directive to match where the stubs need to be generated for OpenTofu, and to claim copyright for that change and thus make the copyright header consistent with what our pre-commit rules require. The regeneration of the Go API stubs for the two major protocol versions introduces some new fields and messages that OpenTofu does not yet support but will happily ignore. Future work might make some use of these new additions, but that's out of scope of this change that is intended only to synchronize our protocol definition with what new plugin server releases are likely to be linked against. This commit continues the existing precedent of having the stubs for the newly-added interface methods in package grpcwrap being just a panicking stub, which is how they will remain until a future project begins using those methods in a way which requires them to be implemented, since implementing the wrappers would require a deeper understanding of the desired behavior of those methods. It appears that we previously accepted a pull request to correct a typo that originated in the older versions of the upstream protocol definitions, but I have intentionally not forward-ported that here because it seems clearer to keep these definitions as close as possible to their source of truth from upstream, given that our current intention is to follow the protocol as documented and not to change it. Signed-off-by: Martin Atkins <mart@degeneration.co.uk> |
||
---|---|---|
.github | ||
cmd/tofu | ||
docs | ||
internal | ||
rfc | ||
scripts | ||
testing | ||
tools | ||
version | ||
website | ||
.copywrite.hcl | ||
.devcontainer.json | ||
.gitignore | ||
.go-version | ||
.golangci-complexity.yml | ||
.golangci.yml | ||
.goreleaser.yaml | ||
.licensei.toml | ||
.tfdev | ||
CHANGELOG.md | ||
CODE_OF_CONDUCT.md | ||
codecov.yml | ||
CODEOWNERS | ||
CONTRIBUTING.md | ||
CONTRIBUTING.RELEASE.md | ||
Dockerfile | ||
go.mod | ||
go.sum | ||
LICENSE | ||
MAINTAINERS | ||
Makefile | ||
README.md | ||
RELEASE.md | ||
SECURITY.md | ||
tools.go | ||
TSC_SUMMARY.md | ||
WEEKLY_UPDATES.md |
OpenTofu
- Manifesto
- About the OpenTofu fork
- How to install
- Join our Slack community!
- Weekly OpenTofu Status Updates
OpenTofu is an OSS tool for building, changing, and versioning infrastructure safely and efficiently. OpenTofu can manage existing and popular service providers as well as custom in-house solutions.
The key features of OpenTofu 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: OpenTofu has a "planning" step where it generates an execution plan. The execution plan shows what OpenTofu will do when you call apply. This lets you avoid any surprises when OpenTofu manipulates infrastructure.
-
Resource Graph: OpenTofu builds a graph of all your resources, and parallelizes the creation and modification of any non-dependent resources. Because of this, OpenTofu 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 OpenTofu will change and in what order, avoiding many possible human errors.
Getting help and contributing
- Have a question? Post it in GitHub Discussions or on the OpenTofu Slack!
- Want to contribute? Please read the Contribution Guide.
- Want to stay up to date? Read the weekly updates, TSC summary, or join the community meetings on Wednesdays at 14:30 CET / 8:30 AM Eastern / 5:30 AM Western / 19:00 India time on this link: https://meet.google.com/xfm-cgms-has (📅 calendar link)
Tip
For more OpenTofu events, subscribe to the OpenTofu Events Calendar!
Reporting security vulnerabilities
If you've found a vulnerability or a potential vulnerability in OpenTofu please follow Security Policy. We'll send a confirmation email to acknowledge your report, and we'll send an additional email when we've identified the issue positively or negatively.
Reporting possible copyright issues
If you believe you have found any possible copyright or intellectual property issues, please contact liaison@opentofu.org. We'll send a confirmation email to acknowledge your report.
Registry Access
In an effort to comply with applicable sanctions, we block access from specific countries of origin.