/terraform-aws-static-site

Terraform module for creating static [web]site in AWS (with S3 & CloudFront)

Primary LanguageHCLMIT LicenseMIT

Terraform module for static site hosting

This module will create S3 bucket as storage for site and connect it with CloudFront for exposing it to public. It also creates TLS certificates for it.

Usage

provider "aws" {
  alias  = "us_east_1"
  region = "us-east-1"
}

module "static-site" {
  source  = "cookielab/static-site/aws"
  version = "~> 2.1"

  providers = {
    aws.us_east_1 = aws.us_east_1
  }

  domains        = ["www.example.com"]
  domain_zone_id = aws_route53_zone.example_com.zone_id
  s3_bucket_name = "example_com_web"
}

Requirements

Name Version
terraform >= 1.1, < 2.0
aws ~> 4.32

Providers

Name Version
aws ~> 4.32

Modules

Name Source Version
certificate terraform-aws-modules/acm/aws 4.3.1
gitlab ./modules/gitlab n/a
s3_bucket terraform-aws-modules/s3-bucket/aws 3.6.0

Resources

Name Type
aws_cloudfront_distribution.this resource
aws_cloudfront_origin_access_identity.this resource
aws_iam_access_key.deploy resource
aws_iam_user.deploy resource
aws_iam_user_policy.deploy resource
aws_route53_record.this resource
aws_iam_policy_document.bucket_policy data source
aws_iam_policy_document.deploy data source

Inputs

Name Description Type Default Required
cloudfront_price_class n/a string "PriceClass_100" no
domain_zone_id The ID of the hosted zone for domain string n/a yes
domains List of domain aliases. You can also specify wildcard eg.: *.example.com list(string) n/a yes
gitlab_environment n/a string "*" no
gitlab_project_id n/a string null no
logs_bucket n/a string null no
s3_bucket_name n/a string n/a yes
tags n/a map(string) {} no

Outputs

Name Description
aws_access_key_id n/a
aws_cloudfront_distribution_id n/a
aws_s3_bucket_name n/a
aws_secret_access_key n/a

Requirements

Name Version
terraform >= 1.5, < 2.0
aws ~> 5.0

Providers

Name Version
aws ~> 5.0

Modules

Name Source Version
certificate terraform-aws-modules/acm/aws 5.0.0
gitlab ./modules/gitlab n/a
s3_bucket terraform-aws-modules/s3-bucket/aws 3.15.1

Resources

Name Type
aws_cloudfront_distribution.this resource
aws_cloudfront_origin_access_identity.this resource
aws_iam_access_key.deploy resource
aws_iam_user.deploy resource
aws_iam_user_policy.deploy resource
aws_route53_record.this resource
aws_cloudfront_cache_policy.managed_caching_disabled data source
aws_cloudfront_origin_request_policy.managed_all_viewer_and_cloudfront_headers data source
aws_iam_policy_document.bucket_policy data source
aws_iam_policy_document.deploy data source
aws_region.current data source

Inputs

Name Description Type Default Required
cloudfront_price_class n/a string "PriceClass_100" no
domain_zone_id The ID of the hosted zone for domain string n/a yes
domains List of domain aliases. You can also specify wildcard eg.: *.example.com list(string) n/a yes
functions n/a
object({
viewer_request = optional(string)
viewer_response = optional(string)
})
{} no
gitlab_environment n/a string "*" no
gitlab_project_id n/a string null no
logs_bucket n/a string null no
logs_bucket_domain_name n/a string null no
override_status_code_403 n/a number 403 no
override_status_code_404 n/a number 200 no
proxy_paths n/a
list(object({
origin_domain = string
path_prefix = string
}))
[] no
s3_bucket_name n/a string n/a yes
tags n/a map(string) {} no

Outputs

Name Description
aws_access_key_id n/a
aws_cloudfront_distribution_id n/a
aws_s3_bucket_arn n/a
aws_s3_bucket_name n/a
aws_s3_bucket_regional_domain_name n/a
aws_secret_access_key n/a