Terraform
Terraform Enterprise v202308-1 (725)
Last required release: v202304-1 (692)
Known Issues
- [Updated August 14, 2024] Runs that rely on dynamic provider credentials and workload identity will fail after a certain number of signing key rotations. This problem is fixed in v202407-1, and you can avoid it by upgrading v202407-1 or above. For details on additional workarounds, including manually trimming keys, refer to our support article.
Deprecations
- Terraform Enterprise no longer supports the following PostgreSQL server versions due to a known defect: 14.0, 14.1, 14.2, and 14.3.
- In Terraform Enterprise v202309-1 the server services will be consolidated into a single container named
terraform-enterprise
. This container runs as a non-root user and contains the logs for all server services. Terraform runs will continue to execute in isolated, short-lived containers but will run as a non-root user. A preview of this change is available now using the optional consolidated_services setting. See consolidated services for more information on this change. - When consolidated services mode is enabled in v202309-1 or higher, logs will now appear in json-lines format, and will be prepended with the name of the service that generated the log message. If you are forwarding logs, you may need to update your log forwarding configuration to accommodate the consolidated log file and the json format change. The legacy architecture will remain available until v202312-1, but will be disabled by default. If you need to revert to the legacy architecture in v202309-1 or higher, set
consolidated_services = false
in your settings.json file. For assistance please contact support. - Docker 19.03 and 20.10 have reached end of life and are no longer supported in Terraform Enterprise.
Features
- Added the ability to specify multiple dynamic provider credentials configurations per provider in a workspace. For more information, see specifying multiple configurations.
- Adds customizable permissions for teams on a project level. Users now have the ability to set various project and workspace permissions at the project level which apply to the project itself and all workspaces contained therein. For more see our documentation on Project Team Access.
Improvements
- Improved the load speed of the policy sets page.
- Credentials generated in AWS when using Vault-backed dynamic credentials for AWS with the iam_user auth type are eventually consistent, meaning they can take 5-10 seconds (or more) to be valid. This was causing unexpected
InvalidClientTokenId
errors to be thrown from the AWS provider for some users. You can now specify a number of seconds to wait after requesting Vault-Backed dynamic credentials for AWS before proceeding with your Terraform run, to ensure your new credentials will be ready to use before attempting to authenticate with them. - The time required for Vault to issue Azure credentials is proportional to the number of Azure roles in the account. You can now specify a number of seconds to wait after requesting Vault-Backed dynamic credentials for Azure before proceeding with your Terraform run, to ensure your new credentials will be ready to use.
- Increased the timeout on the backup and restore API endpoint, which will prevent most timeout issues when running with large data sets.
- Terraform Enterprise has set the rate limit for the workspace runs endpoint (/api/v2/workspaces/.../runs) has been at 30/min.
Bug Fixes
- Policy Set and Run Task names no longer update page headings when editing 'name' fields.
- Fixes a bug that prevented users from updating their organization name when there is only a letter case change.
- Users reported seeing duplicate resources in the workspace overview for some workspaces. For those workspaces impacted, the false copies of resources will be removed.
- Users had reported seeing errors related to
duplicate key value violates unique constraint "index_storage_deletion_requests_on_storage_record"
in their log output. This has been resolved and these messages will no longer appear. - Fixed an issue where users could have accidentally made private provider records with os or arch values like
${os[1]}
. Then when they attempted to delete those records, the registry request would fail, since the request URL would contain invalid characters. - Limited the number of repositories returned by GitHub App VCS connections to 100, to avoid timeouts that prevented the UI from loading properly when creating a workspace/module. Users with more than 100 repositories will need to use the text field to specify the repository name to connect to, if it is not loaded in the list of repos.
- Users can no longer see the option to update a variable in the workspace's variables page if they don't have permission to update variables.
- Organization list now refreshes after modifying an organization's name.
- Email notifications are no longer sent to suspended users or users outside the organization.
Security
- Updated the UI for required permissions for OPA policy set overrides.
- Container updates address reported vulnerabilities (CVEs) in underlying packages and dependencies.