generated from cloudposse/terraform-example-module
-
-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathsecurity_groups_common.tf
49 lines (39 loc) · 1.89 KB
/
security_groups_common.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
module "security_groups_common_label" {
for_each = local.security_groups_common_policies
source = "cloudposse/label/null"
version = "0.25.0"
attributes = [each.key]
context = module.this.context
}
resource "aws_fms_policy" "security_groups_common" {
for_each = local.security_groups_common_policies
name = module.security_groups_common_label[each.key].id
delete_all_policy_resources = lookup(each.value, "delete_all_policy_resources", true)
exclude_resource_tags = lookup(each.value, "exclude_resource_tags", false)
remediation_enabled = lookup(each.value, "remediation_enabled", false)
resource_type_list = lookup(each.value, "resource_type_list", null)
resource_type = lookup(each.value, "resource_type", null)
resource_tags = lookup(each.value, "resource_tags", null)
dynamic "include_map" {
for_each = lookup(each.value, "include_account_ids", [])
content {
account = include_map.value
}
}
dynamic "exclude_map" {
for_each = lookup(each.value, "exclude_account_ids", [])
content {
account = exclude_map.value
}
}
security_service_policy_data {
type = "SECURITY_GROUPS_COMMON"
managed_service_data = jsonencode({
type = "SECURITY_GROUPS_COMMON"
revertManualSecurityGroupChanges = lookup(each.value.policy_data, "revert_manual_security_group_changes", false)
exclusiveResourceSecurityGroupManagement = lookup(each.value.policy_data, "exclusive_resource_security_group_management", false)
applyToAllEC2InstanceENIs = lookup(each.value.policy_data, "apply_to_all_ec2_instance_enis", false)
securityGroups = lookup(each.value.policy_data, "security_groups", null) != null ? [for sg in each.value.policy_data.security_groups : { id = sg }] : []
})
}
}