Tom Archer 6ac4eb3abf
User Story 60501: 101-key-vault-key (#203)
* New sample (converted from Bicep via OpenAI)
2023-04-05 10:55:02 +08:00

66 lines
1.7 KiB
HCL

resource "random_pet" "rg_name" {
prefix = var.resource_group_name_prefix
}
resource "azurerm_resource_group" "rg" {
name = random_pet.rg_name.id
location = var.resource_group_location
}
data "azurerm_client_config" "current" {}
resource "random_string" "azurerm_key_vault_name" {
length = 13
lower = true
numeric = false
special = false
upper = false
}
locals {
current_user_id = coalesce(var.msi_id, data.azurerm_client_config.current.object_id)
}
resource "azurerm_key_vault" "vault" {
name = coalesce(var.vault_name, "vault-${random_string.azurerm_key_vault_name.result}")
location = azurerm_resource_group.rg.location
resource_group_name = azurerm_resource_group.rg.name
tenant_id = data.azurerm_client_config.current.tenant_id
sku_name = var.sku_name
soft_delete_retention_days = 7
access_policy {
tenant_id = data.azurerm_client_config.current.tenant_id
object_id = local.current_user_id
key_permissions = var.key_permissions
secret_permissions = var.secret_permissions
}
}
resource "random_string" "azurerm_key_vault_key_name" {
length = 13
lower = true
numeric = false
special = false
upper = false
}
resource "azurerm_key_vault_key" "key" {
name = coalesce(var.key_name, "key-${random_string.azurerm_key_vault_key_name.result}")
key_vault_id = azurerm_key_vault.vault.id
key_type = var.key_type
key_size = var.key_size
key_opts = var.key_ops
rotation_policy {
automatic {
time_before_expiry = "P30D"
}
expire_after = "P90D"
notify_before_expiry = "P29D"
}
}