forked from cloudposse/terraform-aws-amplify-app
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.tf
129 lines (104 loc) · 6.06 KB
/
main.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
locals {
enabled = module.this.enabled
environments = { for k, v in var.environments : k => v if local.enabled }
domains = merge(local.domain_config, { for k, v in var.domains : k => v if local.enabled })
}
# https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/amplify_app
resource "aws_amplify_app" "default" {
count = local.enabled ? 1 : 0
name = module.this.id
description = var.description
repository = var.repository
platform = var.platform
access_token = var.access_token
oauth_token = var.oauth_token
auto_branch_creation_patterns = var.auto_branch_creation_patterns
basic_auth_credentials = var.basic_auth_credentials
build_spec = var.build_spec
enable_auto_branch_creation = var.enable_auto_branch_creation
enable_branch_auto_deletion = var.enable_branch_auto_deletion
enable_basic_auth = var.enable_basic_auth
enable_branch_auto_build = var.enable_branch_auto_build
environment_variables = var.environment_variables
iam_service_role_arn = local.iam_service_role_arn
dynamic "custom_rule" {
for_each = var.custom_rules
content {
condition = lookup(custom_rule.value, "condition", null)
source = custom_rule.value.source
status = lookup(custom_rule.value, "status", null)
target = custom_rule.value.target
}
}
dynamic "auto_branch_creation_config" {
for_each = var.auto_branch_creation_config != null ? [true] : []
content {
basic_auth_credentials = lookup(var.auto_branch_creation_config, "basic_auth_credentials", null)
build_spec = lookup(var.auto_branch_creation_config, "build_spec", null)
enable_auto_build = lookup(var.auto_branch_creation_config, "enable_auto_build", null)
enable_basic_auth = lookup(var.auto_branch_creation_config, "enable_basic_auth", null)
enable_performance_mode = lookup(var.auto_branch_creation_config, "enable_performance_mode", null)
enable_pull_request_preview = lookup(var.auto_branch_creation_config, "enable_pull_request_preview", null)
environment_variables = lookup(var.auto_branch_creation_config, "environment_variables", null)
framework = lookup(var.auto_branch_creation_config, "framework", null)
pull_request_environment_name = lookup(var.auto_branch_creation_config, "pull_request_environment_name", null)
stage = lookup(var.auto_branch_creation_config, "stage", null)
}
}
tags = module.this.tags
}
# https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/amplify_backend_environment
resource "aws_amplify_backend_environment" "default" {
for_each = { for k, v in local.environments : k => v if lookup(v, "backend_enabled", null) != null && lookup(v, "backend_enabled", false) }
app_id = one(aws_amplify_app.default[*].id)
environment_name = lookup(each.value, "environment_name", each.key)
deployment_artifacts = lookup(each.value, "deployment_artifacts", null)
stack_name = lookup(each.value, "stack_name", null)
}
# https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/amplify_branch
resource "aws_amplify_branch" "default" {
for_each = local.environments
app_id = one(aws_amplify_app.default[*].id)
backend_environment_arn = lookup(each.value, "backend_enabled", false) ? aws_amplify_backend_environment.default[each.key].arn : null
basic_auth_credentials = lookup(each.value, "basic_auth_credentials", null)
branch_name = lookup(each.value, "branch_name", each.key)
display_name = lookup(each.value, "display_name", each.key)
description = lookup(each.value, "description", null)
enable_auto_build = lookup(each.value, "enable_auto_build", null)
enable_basic_auth = lookup(each.value, "enable_basic_auth", null)
enable_notification = lookup(each.value, "enable_notification ", null)
enable_performance_mode = lookup(each.value, "enable_performance_mode", null)
enable_pull_request_preview = lookup(each.value, "enable_pull_request_preview", null)
environment_variables = lookup(each.value, "environment_variables", {})
framework = lookup(each.value, "framework", null)
pull_request_environment_name = lookup(each.value, "pull_request_environment_name", null)
stage = lookup(each.value, "stage", null)
ttl = lookup(each.value, "ttl", null)
tags = module.this.tags
}
# https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/amplify_domain_association
resource "aws_amplify_domain_association" "default" {
for_each = local.domains
app_id = one(aws_amplify_app.default[*].id)
domain_name = each.key
enable_auto_sub_domain = lookup(each.value, "enable_auto_sub_domain", null)
wait_for_verification = lookup(each.value, "wait_for_verification", null)
dynamic "sub_domain" {
for_each = lookup(each.value, "sub_domain")
content {
branch_name = aws_amplify_branch.default[sub_domain.value.branch_name].branch_name
prefix = sub_domain.value.prefix
}
}
}
# https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/amplify_webhook
resource "aws_amplify_webhook" "default" {
for_each = { for k, v in local.environments : k => v if lookup(v, "webhook_enabled", false) }
app_id = one(aws_amplify_app.default[*].id)
branch_name = aws_amplify_branch.default[lookup(each.value, "branch_name", each.key)].branch_name
description = format("trigger-%s", aws_amplify_branch.default[lookup(each.value, "branch_name", each.key)].branch_name)
# NOTE: We trigger the webhook via local-exec so as to kick off the first build on creation of Amplify App
provisioner "local-exec" {
command = "curl -X POST -d {} '${aws_amplify_webhook.default[each.key].url}&operation=startbuild' -H 'Content-Type:application/json'"
}
}