Hey there, OpenTofu community! Over the last few months we've been hard at work to bring new features, such as the state encryption and the removed block, as well as compatibility improvements to you. A few days ago we released the first preview version of these improvements as OpenTofu 1.7.0-alpha1.
We have done everything we could to make sure that the new alpha release doesn't break anything, and we need your help to get this release tested. If you have a non-production setup that you would be willing to test any of the new features on, please give it a try and give us feedback using this form, even if it's just telling us that everything went well.
This blog post will go over how to download the new preview release and detail how each of the new features works.
Do not test this release on a production project! It is not a stable release!
Downloading the alpha release
The alpha release is available exclusively from the GitHub Releases page. Please select the appropriate file for your platform. Here are some quick links:
Platform/Device | Download link |
---|---|
Desktop Windows computer (64-bit) | tofu_1.7.0-alpha1_windows_amd64.zip |
MacOS (Macbook M1 or higher; ARM64) | tofu_1.7.0-alpha1_darwin_arm64.tar.gz |
MacOS (Macbook pre-M1 or lower; AMD64) | tofu_1.7.0-alpha1_darwin_amd64.tar.gz |
Intel/AMD Linux computer or server (AMD64) | tofu_1.7.0-alpha1_linux_amd64.tar.gz |
ARM-based Linux computer or Raspberry Pi 3 or higher (ARM64) | tofu_1.7.0-alpha1_linux_arm64.tar.gz |
For the releases above, please unpack the archive and you should find the tofu
binary inside. You can also use the standalone installer to download the release with signature verification.
State encryption
State encryption is one of the flagship features of this release. We have prepared a full documentation for this feature.
To test this feature, please make a backup of your state file and then add the following configuration:
You can migrate from an encrypted state file to an unencrypted one like this:
If you have access to an AWS account, you can also test the AWS Key-Management Service key provider. (Please note the AWS KMS pricing.)
The OpenTofu core developers would like to thank Stephan Bartels (Interhyp) and Alex Scheel for their extensive work on this feature.
Removed block
The removed block lets you remove a resource from the state file but keep it on the infrastructure. We have prepared a full documentation for this feature. You can test it by creating a resource first:
After applying, you can replace the resource with a removed block:
After the next apply, you will see that the local_file.test resource no longer exists in your state file, but the test.txt
file should still exist on your disk. You can now remove the removed
block safely.
Built-in function changes
This release also contains several new functions and changes to existing functions:
- New function: templatestring
- New function: base64gunzip
- New function: cidrcontains
- New function: urldecode
- New function: issensitive
- nonsensitive no longer returns an error when the applied values are not sensitive.
- templatefile now supports recursion up to a depth of 1024.
CLI changes
There are also several changes to the CLI:
tofu plan
now has a-concise
flag to shorten the plan output.tofu console
now works on Solaris and AIX.- The CLI now supports the XDG directory specification.
- Aliases for
state list
→state ls
,state mv
→state move
,state rm
→state remove
.
Providing feedback
Thank you for taking the time to test this preview release. If you have any feedback, please use this feedback form or chat with us on the OpenTofu Slack.