This Secret Manager module allows you to easily create any needed secrets in Secret Manager. This module loops through a list of variable names and creates a secret and randomly generated password for each item. Coalfire has tested this module with Terraform version 1.5.0 and the Hashicorp Google provider versions 4.70 - 5.0.
FedRAMP Compliance: Moderate
module "ad-secrets" {
source = "github.com/Coalfire-CF/terraform-gcp-secret-manager"
project_id = "your-project-id"
region = "us-central1-a"
secrets = [
{
id = "db1-password",
},
{
id = "db2-password",
}
]
kms_key_name = "kms-key-name"
length = 15
special = true
override_special = "_%@!"
min_lower = 1
min_upper = 1
min_numeric = 1
min_special = 1
}
No requirements.
Name | Version |
---|---|
n/a | |
random | n/a |
No modules.
Name | Type |
---|---|
google_secret_manager_secret.secrets | resource |
google_secret_manager_secret_version.secret_versions | resource |
random_password.password | resource |
Name | Description | Type | Default | Required |
---|---|---|---|---|
kms_key_name | Specifies the key of the CMEK to be used to encrypt the secret values in the versions stored in this secret. | string |
n/a | yes |
length | The length of the password to be generated | number |
15 |
no |
min_lower | Minimum number of lower case characters | number |
1 |
no |
min_numeric | Minimum number of numeric characters | number |
1 |
no |
min_special | Minimum number of special characters | number |
1 |
no |
min_upper | Minimum number of upper case characters | number |
1 |
no |
override_special | Provide your own list of special characters | string |
"_%@!" |
no |
project_id | The project ID to manage the Secret Manager resources | string |
n/a | yes |
region | The GCP region to create resources in. | string |
n/a | yes |
secrets | The list of the secrets | list(object({ |
[] |
no |
special | Include special characters in random password string | bool |
true |
no |
Name | Description |
---|---|
names | List of secret names |
secrets | List of secrets |
secrets_versions | List of secret versions |