-
Notifications
You must be signed in to change notification settings - Fork 708
/
Copy pathstorage_accounts.tf
51 lines (44 loc) · 2.97 KB
/
storage_accounts.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
module "storage_accounts" {
source = "./modules/storage_account"
for_each = var.storage_accounts
base_tags = try(local.global_settings.inherit_tags, false) ? try(local.combined_objects_resource_groups[try(each.value.resource_group.lz_key, local.client_config.landingzone_key)][try(each.value.resource_group.key, each.value.resource_group_key)].tags, {}) : {}
client_config = local.client_config
diagnostic_profiles = try(each.value.diagnostic_profiles, {})
diagnostics = local.combined_diagnostics
global_settings = local.global_settings
location = can(local.global_settings.regions[each.value.region]) ? local.global_settings.regions[each.value.region] : local.combined_objects_resource_groups[try(each.value.resource_group.lz_key, local.client_config.landingzone_key)][try(each.value.resource_group.key, each.value.resource_group_key)].location
managed_identities = local.combined_objects_managed_identities
private_dns = local.combined_objects_private_dns
private_endpoints = try(each.value.private_endpoints, {})
recovery_vaults = local.combined_objects_recovery_vaults
resource_group_name = can(each.value.resource_group.name) || can(each.value.resource_group_name) ? try(each.value.resource_group.name, each.value.resource_group_name) : local.combined_objects_resource_groups[try(each.value.resource_group.lz_key, local.client_config.landingzone_key)][try(each.value.resource_group_key, each.value.resource_group.key)].name
resource_groups = try(each.value.private_endpoints, {}) == {} ? null : local.resource_groups
storage_account = each.value
vnets = local.combined_objects_networking
}
output "storage_accounts" {
value = module.storage_accounts
sensitive = true
}
resource "azurerm_storage_account_customer_managed_key" "cmk" {
depends_on = [module.keyvault_access_policies]
for_each = {
for key, value in var.storage_accounts : key => value
if can(value.customer_managed_key)
}
storage_account_id = module.storage_accounts[each.key].id
key_vault_id = local.combined_objects_keyvaults[try(each.value.customer_managed_key.lz_key, local.client_config.landingzone_key)][each.value.customer_managed_key.keyvault_key].id
key_name = can(each.value.customer_managed_key.key_name) ? each.value.customer_managed_key.key_name : local.combined_objects_keyvault_keys[try(each.value.customer_managed_key.lz_key, local.client_config.landingzone_key)][each.value.customer_managed_key.keyvault_key_key].name
key_version = try(each.value.customer_managed_key.key_version, null)
}
module "encryption_scopes" {
source = "./modules/storage_account/encryption_scope"
for_each = {
for key, value in var.storage_accounts : key => value
if can(value.encryption_scopes)
}
client_config = local.client_config
settings = each.value
storage_account_id = module.storage_accounts[each.key].id
keyvault_keys = local.combined_objects_keyvault_keys
}