2020-05-19 08:18:38 +00:00
|
|
|
using System.Collections.Generic;
|
2023-03-24 11:43:46 +00:00
|
|
|
using System.Linq;
|
2020-05-19 08:18:38 +00:00
|
|
|
using System.Text.Json;
|
|
|
|
using Pulumi;
|
|
|
|
using Aws = Pulumi.Aws;
|
|
|
|
|
2022-07-21 19:04:02 +00:00
|
|
|
return await Deployment.RunAsync(() =>
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2024-02-11 17:02:12 +00:00
|
|
|
// Read the default VPC and public subnets, which we will use.
|
2022-07-21 19:04:02 +00:00
|
|
|
var vpc = Aws.Ec2.GetVpc.Invoke(new()
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
Default = true,
|
|
|
|
});
|
|
|
|
|
|
|
|
var subnets = Aws.Ec2.GetSubnetIds.Invoke(new()
|
|
|
|
{
|
|
|
|
VpcId = vpc.Apply(getVpcResult => getVpcResult.Id),
|
|
|
|
});
|
|
|
|
|
|
|
|
// Create a security group that permits HTTP ingress and unrestricted egress.
|
|
|
|
var webSecurityGroup = new Aws.Ec2.SecurityGroup("webSecurityGroup", new()
|
|
|
|
{
|
|
|
|
VpcId = vpc.Apply(getVpcResult => getVpcResult.Id),
|
|
|
|
Egress = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
new Aws.Ec2.Inputs.SecurityGroupEgressArgs
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
Protocol = "-1",
|
|
|
|
FromPort = 0,
|
|
|
|
ToPort = 0,
|
|
|
|
CidrBlocks = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
"0.0.0.0/0",
|
2020-05-19 08:18:38 +00:00
|
|
|
},
|
|
|
|
},
|
2022-07-21 19:04:02 +00:00
|
|
|
},
|
|
|
|
Ingress = new[]
|
|
|
|
{
|
|
|
|
new Aws.Ec2.Inputs.SecurityGroupIngressArgs
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
Protocol = "tcp",
|
|
|
|
FromPort = 80,
|
|
|
|
ToPort = 80,
|
|
|
|
CidrBlocks = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
"0.0.0.0/0",
|
2020-05-19 08:18:38 +00:00
|
|
|
},
|
|
|
|
},
|
2022-07-21 19:04:02 +00:00
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
// Create an ECS cluster to run a container-based service.
|
|
|
|
var cluster = new Aws.Ecs.Cluster("cluster");
|
|
|
|
|
|
|
|
// Create an IAM role that can be used by our service's task.
|
|
|
|
var taskExecRole = new Aws.Iam.Role("taskExecRole", new()
|
|
|
|
{
|
|
|
|
AssumeRolePolicy = JsonSerializer.Serialize(new Dictionary<string, object?>
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
["Version"] = "2008-10-17",
|
|
|
|
["Statement"] = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
new Dictionary<string, object?>
|
|
|
|
{
|
|
|
|
["Sid"] = "",
|
|
|
|
["Effect"] = "Allow",
|
|
|
|
["Principal"] = new Dictionary<string, object?>
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
["Service"] = "ecs-tasks.amazonaws.com",
|
|
|
|
},
|
|
|
|
["Action"] = "sts:AssumeRole",
|
|
|
|
},
|
2020-05-19 08:18:38 +00:00
|
|
|
},
|
2022-07-21 19:04:02 +00:00
|
|
|
}),
|
|
|
|
});
|
|
|
|
|
|
|
|
var taskExecRolePolicyAttachment = new Aws.Iam.RolePolicyAttachment("taskExecRolePolicyAttachment", new()
|
|
|
|
{
|
|
|
|
Role = taskExecRole.Name,
|
|
|
|
PolicyArn = "arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy",
|
|
|
|
});
|
|
|
|
|
|
|
|
// Create a load balancer to listen for HTTP traffic on port 80.
|
|
|
|
var webLoadBalancer = new Aws.ElasticLoadBalancingV2.LoadBalancer("webLoadBalancer", new()
|
|
|
|
{
|
|
|
|
Subnets = subnets.Apply(getSubnetIdsResult => getSubnetIdsResult.Ids),
|
|
|
|
SecurityGroups = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
webSecurityGroup.Id,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
var webTargetGroup = new Aws.ElasticLoadBalancingV2.TargetGroup("webTargetGroup", new()
|
|
|
|
{
|
|
|
|
Port = 80,
|
|
|
|
Protocol = "HTTP",
|
|
|
|
TargetType = "ip",
|
|
|
|
VpcId = vpc.Apply(getVpcResult => getVpcResult.Id),
|
|
|
|
});
|
|
|
|
|
|
|
|
var webListener = new Aws.ElasticLoadBalancingV2.Listener("webListener", new()
|
|
|
|
{
|
|
|
|
LoadBalancerArn = webLoadBalancer.Arn,
|
|
|
|
Port = 80,
|
|
|
|
DefaultActions = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
new Aws.ElasticLoadBalancingV2.Inputs.ListenerDefaultActionArgs
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
Type = "forward",
|
|
|
|
TargetGroupArn = webTargetGroup.Arn,
|
2020-05-19 08:18:38 +00:00
|
|
|
},
|
2022-07-21 19:04:02 +00:00
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
// Spin up a load balanced service running NGINX
|
|
|
|
var appTask = new Aws.Ecs.TaskDefinition("appTask", new()
|
|
|
|
{
|
|
|
|
Family = "fargate-task-definition",
|
|
|
|
Cpu = "256",
|
|
|
|
Memory = "512",
|
|
|
|
NetworkMode = "awsvpc",
|
|
|
|
RequiresCompatibilities = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
"FARGATE",
|
|
|
|
},
|
|
|
|
ExecutionRoleArn = taskExecRole.Arn,
|
|
|
|
ContainerDefinitions = JsonSerializer.Serialize(new[]
|
|
|
|
{
|
|
|
|
new Dictionary<string, object?>
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
["name"] = "my-app",
|
|
|
|
["image"] = "nginx",
|
|
|
|
["portMappings"] = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
|
|
|
new Dictionary<string, object?>
|
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
["containerPort"] = 80,
|
|
|
|
["hostPort"] = 80,
|
|
|
|
["protocol"] = "tcp",
|
2020-05-19 08:18:38 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-07-21 19:04:02 +00:00
|
|
|
}),
|
|
|
|
});
|
|
|
|
|
|
|
|
var appService = new Aws.Ecs.Service("appService", new()
|
|
|
|
{
|
|
|
|
Cluster = cluster.Arn,
|
|
|
|
DesiredCount = 5,
|
|
|
|
LaunchType = "FARGATE",
|
|
|
|
TaskDefinition = appTask.Arn,
|
|
|
|
NetworkConfiguration = new Aws.Ecs.Inputs.ServiceNetworkConfigurationArgs
|
|
|
|
{
|
|
|
|
AssignPublicIp = true,
|
|
|
|
Subnets = subnets.Apply(getSubnetIdsResult => getSubnetIdsResult.Ids),
|
|
|
|
SecurityGroups = new[]
|
2020-05-19 08:18:38 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
webSecurityGroup.Id,
|
2020-05-19 08:18:38 +00:00
|
|
|
},
|
2022-07-21 19:04:02 +00:00
|
|
|
},
|
|
|
|
LoadBalancers = new[]
|
2020-06-29 23:33:52 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
new Aws.Ecs.Inputs.ServiceLoadBalancerArgs
|
2020-06-29 23:33:52 +00:00
|
|
|
{
|
2022-07-21 19:04:02 +00:00
|
|
|
TargetGroupArn = webTargetGroup.Arn,
|
|
|
|
ContainerName = "my-app",
|
|
|
|
ContainerPort = 80,
|
2020-06-29 23:33:52 +00:00
|
|
|
},
|
2022-07-21 19:04:02 +00:00
|
|
|
},
|
|
|
|
}, new CustomResourceOptions
|
|
|
|
{
|
2024-03-25 15:34:54 +00:00
|
|
|
DependsOn =
|
2022-07-21 19:04:02 +00:00
|
|
|
{
|
2024-04-09 21:11:25 +00:00
|
|
|
webListener,
|
2022-07-21 19:04:02 +00:00
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
return new Dictionary<string, object?>
|
|
|
|
{
|
|
|
|
["url"] = webLoadBalancer.DnsName,
|
|
|
|
};
|
|
|
|
});
|
2020-05-19 08:18:38 +00:00
|
|
|
|