New Terraform Tutorial: Sensitive Input Variables
A new tutorial on HashiCorp Learn shows how to protect sensitive data with Terraform.
HashiCorp Terraform configuration often includes sensitive inputs, such as passwords, API tokens, or Personally Identifiable Information (PII). Terraform provides several features to help avoid accidentally exposing sensitive data.
Learn to Protect Sensitive Inputs
Follow our new tutorial on HashiCorp Learn, Protect Sensitive Input Variables. In this tutorial, you will provision a web application using Terraform, and use the `sensitive` variable flag to set sensitive values. You will also learn about ways to manage sensitive values in your Terraform state.
Use the “sensitive” Flag
New in Terraform 0.14, input variables now support the `sensitive` flag. Terraform will redact the values of sensitive variables in console and log output, to reduce the risk of accidentally disclosing these values.
data:image/s3,"s3://crabby-images/d7cb4/d7cb46fe008be7b3ff04dba5668f57d2218ae29a" alt="Code block defining variable "db_password""
When you apply this configuration, Terraform redacts the sensitive value from its console output.
data:image/s3,"s3://crabby-images/0a3cb/0a3cb386ed08a5e9f9e15508a1302215e52270fe" alt="Code block running `terraform apply`. Output shows warnining that attribute value will be marked as sensitive and will not display in UI output."
This feature helps prevent accidental disclosure of sensitive values, but is not sufficient to fully secure your Terraform configuration.
Secure Terraform State
Even when a variable is marked sensitive, Terraform still needs to store the value in its state file, so that it can correctly apply configuration changes.
data:image/s3,"s3://crabby-images/2432b/2432b84063004f167033a1dad913ddc091855a95" alt="Code block running `grep "password" terraform.tfstate`"
In this tutorial, you will learn about several methods that Terraform and other HashiCorp products provide to secure your state file.
Sign up for the latest HashiCorp news
More blog posts like this one
data:image/s3,"s3://crabby-images/c0ac4/c0ac485b3ae3153495cc01ec80e8b7b4101f1cc2" alt="Terraform provides more flexible controls with project-owned variable sets"
Terraform provides more flexible controls with project-owned variable sets
Project-owned variable sets simplify management, reduce dependencies, and allow for more flexible control over access and usage.
data:image/s3,"s3://crabby-images/c0ac4/c0ac485b3ae3153495cc01ec80e8b7b4101f1cc2" alt="A smoother HCP Terraform workspace experience"
A smoother HCP Terraform workspace experience
Learn how to automate HCP Terraform workspace setup and onboarding with the TFE provider, a custom module, and good requirements gathering.
data:image/s3,"s3://crabby-images/7f125/7f125768d167c83edc36366f0b649e065becad32" alt="ServiceNow Terraform plugin updates: No-code execution mode, key-value tags, and enhanced security"
ServiceNow Terraform plugin updates: No-code execution mode, key-value tags, and enhanced security
The ServiceNow plugins for Terraform are being updated with new enhancements that implement no-code execution mode, key-value tags, and increased encryption security enhancements.