AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 79561136
Accepted
TheDemonLord
TheDemonLord
Asked: 2025-04-08 11:48:08 +0800 CST2025-04-08 11:48:08 +0800 CST 2025-04-08 11:48:08 +0800 CST

使用嵌套对象进行扁平化的 Terraform

  • 772

这是我的情况,我正在尝试将旧的 Azure Frontdoor 实例部署到新版本的 AFD 并通过 Terraform 执行此操作。

以下是我的本地防火墙策略的摘录:

firewall_policy = {
    policy = {
      name     = "policy"
      sku_name = "AzureSKU"
      mode     = "prevention"
      managed_rules_list = [
        {
          type    = "Microsoft_DefaultRuleSet"
          version = "1.1"
          action  = "Block"
          exclusion = [
            {
              match_variable = "QueryStringArgNames"
              operator       = "Contains"
              selector       = "string1"
            },
            {
              match_variable = "RequestBodyPostArgNames"
              operator       = "StartsWith"
              selector       = "string2"
            },
            {
              match_variable = "RequestCookieNames"
              operator       = "EqualsAny"
              selector       = "string3"
            },
            {
              match_variable = "RequestBodyPostArgNames"
              operator       = "Contains"
              selector       = "string4"
            }
          ]
          override = [
            {
              rule_group_name = "RFI"
              rule = [
                {
                  rule_id = "931130"
                  action  = "Block"
                  exclusion = [
                    {
                      match_variable = "RequestBodyPostArgNames"
                      operator       = "Equals"
                      selector       = "string1"
                    },
                    {
                      match_variable = "QueryStringArgNames"
                      operator       = "Contains"
                      selector       = "string2"
                    },
                    {
                      match_variable = "QueryStringArgNames"
                      operator       = "Contains"
                      selector       = "string3"
                    },
                    {
                      match_variable = "QueryStringArgNames"
                      operator       = "Contains"
                      selector       = "string4"
                    }
                  ]
                }
              ]
            },
            {
              rule_group_name = "PHP"
              rule = [
                {
                  rule_id = "933100"
                  enabled = false
                  action  = "Block"
                },
                {
                  rule_id = "933110"
                  enabled = false
                  action  = "Block"
                },
                {
                  rule_id = "933120"
                  enabled = false
                  action  = "Block"
                }
              ]
            }
          ]
        }
      ]
    }

}

如您所见,有很多嵌套对象。

在我的 main.tf 文件中,我调用以下内容:

    module "Azure_FW_Policy_module" {
  for_each                                        = local.firewall_policy
  source                                          = "./frontdoorFirewallPolicy"
  cdn_frontdoor_firewall_policy_name              = each.value.name
  resource_group_name                             = var.resource_group_name
  sku_name                                        = each.value.sku_name
  mode                                            = each.value.mode
  managed_rules_list                              = each.value.managed_rules_list
  managed_rules_exclusion_list                    = each.value.managed_rules_list.exclusion
  managed_rules_overide_list                      = each.value.managed_rules_list.override
  managed_rules_overide_rule_list                 = each.value.managed_rules_list.override.rule
  managed_rules_overide_rule_exclusion_list       = each.value.managed_rules_list.override.rule.exclusion
  managed_rules_overide_rule_group_exclusion_list = each.value.managed_rules_list.override.exclusion
  custom_rules_list                               = each.value.custom_rules_list
  tags                                            = var.tags
}

模块本身有一堆动态块,以适应各种配置,如下所示:

    resource "azurerm_cdn_frontdoor_firewall_policy" "cdn_frontdoor_firewall_policy" {
  name                              = var.cdn_frontdoor_firewall_policy_name
  resource_group_name               = var.resource_group_name
  sku_name                          = var.sku_name
  enabled                           = var.enabled
  mode                              = var.mode
  custom_block_response_status_code = var.custom_block_response_status_code
  custom_block_response_body        = var.custom_block_response_body
  request_body_check_enabled        = var.request_body_check_enabled
  tags                              = var.tags
  dynamic "managed_rule" {
    for_each = toset(var.managed_rules_list)
    content {
      type    = managed_rule.value["type"]
      version = managed_rule.value["version"]
      action  = managed_rule.value["action"]
      dynamic "exclusion" {
        for_each = toset(var.managed_rules_exclusion_list)
        content {
          match_variable = exclusion.value["match_variable"]
          operator       = exclusion.value["operator"]
          selector       = exclusion.value["selector"]
        }
      }
      dynamic "override" {
        for_each = toset(var.managed_rules_overide_list)
        content {
          rule_group_name = override.value["rule_group_name"]
          dynamic "rule" {
            for_each = toset(var.managed_rules_overide_rule_list)
            content {
              rule_id = rule.value["rule_id"]
              action  = rule.value["action"]
              dynamic "exclusion" {
                for_each = toset(var.managed_rules_overide_rule_exclusion_list)
                content {
                  match_variable = exclusion.value["match_variable"]
                  operator       = exclusion.value["operator"]
                  selector       = exclusion.value["selector"]
                }
              }
            }
          }
          dynamic "exclusion" {
            for_each = toset(var.managed_rules_overide_rule_group_exclusion_list)
            content {
              match_variable = exclusion.value["match_variable"]
              operator       = exclusion.value["operator"]
              selector       = exclusion.value["selector"]
            }
          }
        }
      }
    }
  }
  dynamic "custom_rule" {
    for_each = toset(var.custom_rules_list)
    content {
      name                           = custom_rule.value["name"]
      enabled                        = custom_rule.value["enabled"]
      priority                       = custom_rule.value["priority"]
      type                           = custom_rule.value["type"]
      action                         = custom_rule.value["action"]
      rate_limit_duration_in_minutes = custom_rule.value["rate_limit_duration_in_minutes"]
      rate_limit_threshold           = custom_rule.value["rate_limit_threshold"]
      match_condition {
        match_variable     = custom_rule.value["match_variable"]
        operator           = custom_rule.value["operator"]
        negation_condition = custom_rule.value["negation_condition"]
        match_values       = custom_rule.value["match_values"]
      }
    }
  }
}

我的问题是,当我运行这个时 - 我收到以下错误:

“each.value.managed_rules_list 是一个包含 1 个元素的元组,此值没有任何属性。”

根据我的阅读,我认为这是因为我需要在 Terraform 中的 firewall_policy 元素上使用 flatten 命令才能将其传递给模块:

就像这里

然而 - 尽管阅读了上述内容,我仍不确定我需要如何调用 flatten 来解释所有嵌套对象,然后如何将它们传递给我的模块,因为我以前没有使用过它。

  • 1 1 个回答
  • 44 Views

1 个回答

  • Voted
  1. Best Answer
    Vinay B
    2025-04-08T17:59:23+08:002025-04-08T17:59:23+08:00

    Terraform 在配置 forntdoor 防火墙策略时使用带有嵌套对象的扁平化。

    在您的 中main.tf,您尝试获取类似 的属性each.value.managed_rules_list.exclusion,这假设managed_rules_list是一个映射。但是,由于managed_rules_list被定义为列表,Terraform 将其视为元组,因此在未指定索引的情况下直接访问属性是无效的。

    要解决此问题,您应该确保正确获取列表元素。这可以使用 Terraform 的flatten功能来完成。该功能可以通过将嵌套列表转换为单个平面列表来帮助管理深度嵌套的结构,从而使其更易于迭代。

    演示配置:

    主文件:

    locals {
      firewall_policy = {
        name     = "afdwafvkpolicy"
        sku_name = "Premium_AzureFrontDoor"
        mode     = "Prevention"
        managed_rules = [
          {
            type    = "Microsoft_DefaultRuleSet"
            version = "1.1"
            action  = "Block"
            exclusions = [
              {
                match_variable = "QueryStringArgNames"
                operator       = "Contains"
                selector       = "string1"
              },
              {
                match_variable = "RequestBodyPostArgNames"
                operator       = "StartsWith"
                selector       = "string2"
              }
            ]
            overrides = [
              {
                rule_group_name = "RFI"
                rules = [
                  {
                    rule_id = "931130"
                    action  = "Block"
                    exclusions = [
                      {
                        match_variable = "QueryStringArgNames"
                        operator       = "Contains"
                        selector       = "string3"
                      }
                    ]
                  }
                ]
              },
              {
                rule_group_name = "PHP"
                rules = [
                  {
                    rule_id = "933100"
                    action  = "Block"
                    enabled = false
                  },
                  {
                    rule_id = "933110"
                    action  = "Block"
                    enabled = false
                  }
                ]
              }
            ]
          }
        ]
        custom_rules = []
      }
    }
    
    module "afd_waf" {
      source                 = "./frontdoorFirewallPolicy"
      firewall_policy_config = local.firewall_policy
      resource_group_name    = var.resource_group_name
    }
    

    frontdoorFirewallPolicy/main.tf

    resource "azurerm_cdn_frontdoor_firewall_policy" "waf" {
      name                = var.firewall_policy_config.name
      resource_group_name = var.resource_group_name
      sku_name            = var.firewall_policy_config.sku_name
      mode                = var.firewall_policy_config.mode
    
    
      dynamic "managed_rule" {
        for_each = var.firewall_policy_config.managed_rules
        content {
          type    = managed_rule.value.type
          version = managed_rule.value.version
          action  = managed_rule.value.action
    
          dynamic "exclusion" {
            for_each = lookup(managed_rule.value, "exclusions", [])
            content {
              match_variable = exclusion.value.match_variable
              operator       = exclusion.value.operator
              selector       = exclusion.value.selector
            }
          }
    
          dynamic "override" {
            for_each = lookup(managed_rule.value, "overrides", [])
            content {
              rule_group_name = override.value.rule_group_name
    
              dynamic "rule" {
                for_each = lookup(override.value, "rules", [])
                content {
                  rule_id = rule.value.rule_id
                  action  = rule.value.action
                  enabled = lookup(rule.value, "enabled", true)
    
                  dynamic "exclusion" {
                    for_each = lookup(rule.value, "exclusions", [])
                    content {
                      match_variable = exclusion.value.match_variable
                      operator       = exclusion.value.operator
                      selector       = exclusion.value.selector
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
    

    部署:

    在此处输入图片描述

    在此处输入图片描述

    参考:

    https://learn.microsoft.com/en-us/azure/frontdoor/create-front-door-terraform

    https://library.tf/modules/T-Systems-MMS/cdn/azurerm/latest

    https://developer.hashicorp.com/terraform/language/functions/flatten

    • 1

相关问题

  • 将复制活动的序列号添加到 Blob

  • Packer 动态源重复工件

  • 选择每组连续 1 的行

  • 图形 API 调用列表 subscribedSkus 状态权限不足,但已授予权限

  • 根据列值创建单独的 DF 的函数

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve