tf-aws-demo/prod/main.tf

84 lines
1.9 KiB
Terraform
Raw Normal View History

2022-08-24 14:14:42 +02:00
provider "aws" {
profile = "default"
region = var.REGION
}
# Create VPC with NAT Gateway and route tables
module "vpc" {
2022-08-25 15:00:54 +02:00
source = "terraform-aws-modules/vpc/aws"
2022-08-24 14:14:42 +02:00
version = "3.14.2"
name = "${var.PROJECT_NAME}-vpc"
2022-08-24 14:14:42 +02:00
cidr = var.DEMO_VPC_CIDR
azs = var.DEMO_VPC_AVAILABILITY_ZONES
2022-08-26 14:17:46 +02:00
private_subnets = var.DEMO_VPC_PRIVATE_SUBNETS_CIDRS
public_subnets = var.DEMO_VPC_PUBLIC_SUBNETS_CIDRS
2022-08-24 14:14:42 +02:00
2022-08-25 15:00:54 +02:00
enable_nat_gateway = true
single_nat_gateway = true
2022-08-24 14:14:42 +02:00
one_nat_gateway_per_az = false
tags = {
Terraform = "true"
}
}
# Get VPC data
module "vpc_data" {
2022-08-25 15:00:54 +02:00
source = "../modules/vpc_data"
depends_on = [module.vpc]
2022-08-24 14:14:42 +02:00
VPC_NAME = "${var.PROJECT_NAME}-vpc"
2022-08-24 14:14:42 +02:00
BASTION_HOST_AZ = var.DEMO_BASTION_HOST_AZ
}
# Get AMI data
module "ami_data" {
source = "../modules/ami_data"
}
2022-08-24 14:14:42 +02:00
# Create bastion host
module "bastion_host" {
source = "../modules/bastion_host"
PROJECT_NAME = var.PROJECT_NAME
2022-08-25 15:00:54 +02:00
VPC_ID = module.vpc_data.vpc.id
SUBNET_ID = module.vpc_data.bastion_host_subnet.id
EC2_AMI = module.ami_data.amazon_linux.id
EC2_TYPE = var.DEMO_BASTION_HOST_TYPE
EC2_KEY_NAME = var.DEMO_BASTION_HOST_KEY_NAME
2022-08-25 15:00:54 +02:00
}
2022-08-26 14:17:46 +02:00
# Create ALB
module "alb" {
source = "../modules/alb"
PROJECT_NAME = var.PROJECT_NAME
2022-08-26 14:17:46 +02:00
VPC_ID = module.vpc_data.vpc.id
2022-08-26 14:17:46 +02:00
ALB_SUBNETS_IDS = module.vpc_data.public_subnets.ids
}
2022-08-25 15:00:54 +02:00
# Create demo app
module "app" {
source = "../modules/app"
PROJECT_NAME = var.PROJECT_NAME
2022-08-25 15:00:54 +02:00
VPC_ID = module.vpc_data.vpc.id
VPC_SUBNETS_IDS = module.vpc_data.private_subnets.ids
EC2_AMI = module.ami_data.amazon_linux.id
2022-08-25 15:00:54 +02:00
EC2_TYPE = var.DEMO_APP_EC2_TYPE
EC2_KEY_NAME = var.DEMO_APP_EC2_KEY_NAME
ASG_MIN_SIZE = var.DEMO_APP_ASG_MIN_SIZE
ASG_MAX_SIZE = var.DEMO_APP_ASG_MAX_SIZE
2022-08-26 14:17:46 +02:00
ALB_TARGET_GROUP_ARNS = [module.alb.alb_tg.arn]
2022-08-25 15:00:54 +02:00
}