bsmsapp/terraform/organization/datasources.tf

69 lines
1.7 KiB
HCL

# ---------------------------------------------------------------------------
# Main resources
# ---------------------------------------------------------------------------
data "aws_region" "current" {
provider = aws.aws
}
data "aws_caller_identity" "current" {
provider = aws.aws
}
data "template_file" "userdata" {
template = file("${path.module}/html/index.html")
vars = {
ENDPOINT = "${module.apigw.endpoint}"
}
}
data "aws_iam_policy_document" "dynamodb" {
statement {
effect = "Allow"
actions = [
"dynamodb:PutItem",
"dynamodb:Scan",
"dynamodb:GetItem",
"dynamodb:UpdateItem",
"dynamodb:DeleteItem"
]
principals {
type = "AWS"
identifiers = ["*"]
}
resources = ["arn:aws:dynamodb:${data.aws_region.current.name}:${data.aws_caller_identity.current.account_id}:table/${module.dynamodb.name}"]
}
}
data "aws_iam_policy_document" "sns" {
statement {
effect = "Allow"
actions = [
"sns:Publish",
"sns:Subscribe",
"sns:CreateTopic",
"sns:GetTopicAttributes",
"sns:SetTopicAttributes",
]
principals {
type = "AWS"
identifiers = ["*"]
}
resources = ["arn:aws:sns:${data.aws_region.current.name}:${data.aws_caller_identity.current.account_id}:${module.sns.name}"]
}
}
data "aws_iam_policy_document" "stepfunctions" {
statement {
effect = "Allow"
actions = [
"states:StartExecution",
]
principals {
type = "AWS"
identifiers = ["*"]
}
resources = ["arn:aws:states:${data.aws_region.current.name}:${data.aws_caller_identity.current.account_id}:stateMachine:${module.stepfunctions.name}"]
}
}