# --------------------------------------------------------------------------- # 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" ] 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}"] } }