Структура:
.
├── aws
│ ├── master
│ │ ├── accounts.tf
│ │ ├── dynamodb.tf
│ │ ├── main.tf
│ │ ├── organization.tf
│ │ └── s3.tf
│ └── ou
│ └── dev2
│ └── dev2_foo
│ └── main.tf
├── main.tf
Файл tfstate находится в s3 и имеет блокировку DynamodB. Ваш субсчет загружен как модуль в main.tf
module "aws_dev2_dev2_foo" {
source = "./aws/ou/dev2/dev2_foo"
}
в
aws/ou/dev2/dev2_foo/main.tf
Я пытаюсь принять на этот счет:
provider "aws" {
alias = "assume"
region = "eu-central-1"
profile = "terraform"
assume_role {
role_arn = "arn:aws:iam::${aws_organizations_account.devteam02.id}:role/terrasume"
session_name = "terraforming"
}
}
resource "aws_iam_account_alias" "alias" {
provider = "aws.assume"
account_alias = "dev02_devteam02-foo"
}
Я получаю эту ошибку, если я запускаю terraform:
Управляемый ресурс "aws_organizations_account" "devteam02" не был объявлен в aws_dev2_dev2_foo. В этом сценарии: Как я могу объявить этот управляемый ресурс?
Ресурс был объявлен внутри aws / master / accounts.tf :
resource "aws_organizations_account" "devteam02" {
name = "devteam02"
email = "john@devteam02.loc"
role_name = "terrasume"
parent_id = "${aws_organizations_organizational_unit.dev2_foo.id}"
lifecycle {
ignore_changes = ["role_name"]
}
}