Я создал более раннюю публикацию, чтобы решить проблему создания нескольких блоков s3 без попыток дублирования кода.Это сработало хорошо!
Terraform - создание нескольких сегментов
aws_iam_policy выглядит так:
resource "aws_iam_policy" "user_policy" {
count = "${length(var.s3_bucket_name)}"
name = "UserPolicy"
policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"s3:PutObject",
"s3:GetObject",
"s3:DeleteObject",
"s3:ListBucket",
"s3:GetLifecycleConfiguration",
"s3:PutLifecycleConfiguration",
"s3:PutObjectTagging",
"s3:GetObjectTagging",
"s3:DeleteObjectTagging"
],
"Resource": [
"arn:aws:s3:::${var.s3_bucket_name[count.index]}",
"arn:aws:s3:::${var.s3_bucket_name[count.index]}/*"
]
}
]
}
EOF
}
Вот как я прикрепляю политику:
resource "aws_iam_user_policy_attachment" "user_policy_attach" {
user = "${aws_iam_user.user.name}"
policy_arn = "${aws_iam_policy.user_policy.arn}"
}
К сожалению, при подключении политики пользователя IAM возникает ошибка, поскольку она должна выполнять итерации по индексу:
Resource 'aws_iam_policy.user_policy' not found for variable 'aws_iam_policy.user_policy.arn'