Newer
Older

Nuwan Rajika Kumarasiri
committed
data "template_file" "container" {
template = file("./templates/container-definitions.tpl")

Nuwan Rajika Kumarasiri
committed
vars = {
container_name = var.container_name
image_name = var.image_name
app_port1 = var.container_app_port[0]
app_port2 = var.container_app_port[1]
app_port3 = var.container_app_port[2]
informatica_username = var.informatica_username
informatica_password = var.informatica_password
volume1 = var.secure_agnet_container_volumes[0]
volume2 = var.secure_agnet_container_volumes[1]
volume3 = var.secure_agnet_container_volumes[2]
volume4 = var.secure_agnet_container_volumes[3]
secure_agent_efs_volume = var.secure_agent_efs_volume

Nuwan Rajika Kumarasiri
committed
}
}
data "aws_iam_role" "ecs-task-execution" {
name = "ecsTaskExecutionRole"
}
resource "aws_ecs_task_definition" "task" {

Nuwan Rajika Kumarasiri
committed
family = var.ecs_task_name
execution_role_arn = data.aws_iam_role.ecs-task-execution.arn
network_mode = var.container_network_mode
requires_compatibilities = [

Nuwan Rajika Kumarasiri
committed
container_definitions = data.template_file.container.rendered
volume {
name = var.secure_agent_efs_volume
host_path = ""
docker_volume_configuration {
autoprovision = true
scope = "shared"
driver_opts = {
"type" = "nfs"
"device" = "${aws_efs_file_system.secure-agent-fs.dns_name}:/"
"o" = "addr=${aws_efs_file_system.secure-agent-fs.dns_name},nfsvers=4.1,rsize=1048576,wsize=1048576,hard,timeo=600,retrans=2,nosuid"
}
}
}
tags = var.ecs_task_tags

Nuwan Rajika Kumarasiri
committed
}
resource "aws_ecs_service" "service" {

Nuwan Rajika Kumarasiri
committed
name = var.ecs_service_name
cluster = aws_ecs_cluster.cluster.id

Nuwan Rajika Kumarasiri
committed
task_definition = aws_ecs_task_definition.task.arn

Nuwan Rajika Kumarasiri
committed
desired_count = 1
# secure agent configs and logs are persisted into an EFS volume.
launch_type = "EC2"

Nuwan Rajika Kumarasiri
committed
network_configuration {

Nuwan Rajika Kumarasiri
committed
security_groups = [
data.aws_security_group.sec-group.id]
subnets = data.aws_subnet_ids.subnets.ids

Nuwan Rajika Kumarasiri
committed
assign_public_ip = false
}
}
resource "aws_ecs_cluster" "cluster" {
name = var.ecs_cluster_name
tags = var.ecs_cluster_tags
}