我有一个需要 CloudFront + s3 的应用程序。我想创建一个 CloudFront 模块并使其可用于其他应用程序。
我的问题是我有一个应用程序需要两个 Origin(s3_origin_config 和一个 custom_origin_config),而其他应用程序只需要 s3_origin_config。
问题是:我怎样才能拥有一个模块来处理需要两个 Origin 和另一个只需要一个 Origin 的应用程序。
下面是我的代码示例:
resource "aws_cloudfront_distribution" "s3_distribution" {
origin {
domain_name = "${var.domain_name}"
origin_id = "${var.app_name}-${var.environment}"
origin_path = "/${var.environment}/${var.setup}/public"
s3_origin_config {
origin_access_identity = ${aws_cloudfront_origin_access_identity.origin_access_identity.cloudfront_access_identity_path}"
}
}
#HERE, I would like something like if $second_origin, then:
#I know there is no if in terraform, just to have an example ;)
origin {
domain_name = "${var.second_origin_domain_name}"
origin_id = "Custom-${var.second_origin_domain_name}"
custom_origin_config {
http_port = "80"
https_port = "443"
origin_protocol_policy = "https-only"
origin_ssl_protocols = ["TLSv1", "TLSv1.1", "TLSv1.2"]
}
custom_header {
name = "${var.second_origin_header_name}"
value = "${var.second_origin_header_key}"
}
}...
谢谢!