Terraform:如何读取地图清单?

Ric*_*ess 5 terraform

请参阅以下示例:

data "aws_kms_secrets" "api_key" {
  count = "${length(keys(var.keys))}"

  secret {
    name    = "secret_name"
    payload = "${element(values(var.keys), count.index)}"
  }
}

resource "aws_api_gateway_api_key" "access_key" {
  count = "${length(keys(var.keys))}"

  name  = "${var.environment}-${element(keys(var.keys), count.index)}"
  value = "${lookup(element(data.aws_kms_secrets.api_key.*.plaintext, count.index), "secret_name")}"
}
Run Code Online (Sandbox Code Playgroud)

从数据资源中查找纯文本值似乎是不可能的。

value = "${lookup(element(data.aws_kms_secrets.api_key.*.plaintext, count.index), "secret_name")}"

结果是 lookup: argument 1 should be type map, got type string in:

我已经尝试了多种组合elementlookup*和字典的语法没有什么作品。

我的var.keys样子是:

keys = {
  key-name-one = "sssss"
  key-name-two = "sss"
}
Run Code Online (Sandbox Code Playgroud)

Ric*_*ess 7

这里的技巧是使用字典语法来替换元素调用,它在映射列表中表现得更好。

value = "${lookup(data.aws_kms_secrets.api_key.*.plaintext[count.index], "secret_name")}"
Run Code Online (Sandbox Code Playgroud)

这样做的诱惑力data.aws_kms_secrets.api_key[count.index].plaintext是无效的 HCL