terraform-cdk-serverless-github-actions-runner-controller 0.0.7 → 0.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +19 -2
- package/biome.jsonc +25 -52
- package/lib/index.d.ts +3 -3
- package/lib/index.js +1 -1
- package/lib/lib/aws.d.ts +4 -4
- package/lib/lib/aws.js +145 -145
- package/lib/lib/azure.d.ts +1 -1
- package/lib/lib/azure.js +132 -132
- package/lib/lib/gcp.d.ts +1 -1
- package/lib/lib/gcp.js +82 -82
- package/lib/lib/variables.d.ts +2 -2
- package/lib/lib/variables.js +11 -11
- package/lib/tfModules.js +17 -17
- package/modules/azure-container-apps/README.md +17 -17
- package/modules/azure-container-apps/cdk.tf.json +1 -1
- package/modules/google-cloud-run/README.md +16 -16
- package/modules/google-cloud-run/cdk.tf.json +1 -1
- package/package.json +11 -9
- package/renovate.json5 +2 -2
package/lib/lib/aws.js
CHANGED
|
@@ -23,180 +23,180 @@ const variables_1 = require("./variables");
|
|
|
23
23
|
class Aws extends constructs_1.Construct {
|
|
24
24
|
constructor(scope, id, props) {
|
|
25
25
|
super(scope, id);
|
|
26
|
-
new provider_1.AwsProvider(this,
|
|
27
|
-
const identity = new data_aws_caller_identity_1.DataAwsCallerIdentity(this,
|
|
28
|
-
const region = new data_aws_region_1.DataAwsRegion(this,
|
|
26
|
+
new provider_1.AwsProvider(this, "aws", {});
|
|
27
|
+
const identity = new data_aws_caller_identity_1.DataAwsCallerIdentity(this, "Identity", {});
|
|
28
|
+
const region = new data_aws_region_1.DataAwsRegion(this, "Region", {});
|
|
29
29
|
const { pat, githubConfigUrl, autoscalerImage } = (0, variables_1.commonVariables)(this);
|
|
30
|
-
const cluster = new ecs_cluster_1.EcsCluster(this,
|
|
30
|
+
const cluster = new ecs_cluster_1.EcsCluster(this, "Cluster", {
|
|
31
31
|
name: props.clusterName,
|
|
32
32
|
});
|
|
33
|
-
const subnets = new data_aws_subnets_1.DataAwsSubnets(this,
|
|
33
|
+
const subnets = new data_aws_subnets_1.DataAwsSubnets(this, "Subnets", {
|
|
34
34
|
filter: props.subnetFilters,
|
|
35
35
|
});
|
|
36
|
-
const securityGroups = new data_aws_security_groups_1.DataAwsSecurityGroups(this,
|
|
36
|
+
const securityGroups = new data_aws_security_groups_1.DataAwsSecurityGroups(this, "SecurityGroups", {
|
|
37
37
|
filter: props.securityGroupFilters,
|
|
38
38
|
});
|
|
39
|
-
const autoscalerRole = new iam_role_1.IamRole(this,
|
|
39
|
+
const autoscalerRole = new iam_role_1.IamRole(this, "AutoscalerRole", {
|
|
40
40
|
assumeRolePolicy: cdktf_1.Fn.jsonencode({
|
|
41
|
-
Version:
|
|
41
|
+
Version: "2012-10-17",
|
|
42
42
|
Statement: [
|
|
43
43
|
{
|
|
44
|
-
Effect:
|
|
44
|
+
Effect: "Allow",
|
|
45
45
|
Principal: {
|
|
46
|
-
Service:
|
|
46
|
+
Service: "ecs-tasks.amazonaws.com",
|
|
47
47
|
},
|
|
48
|
-
Action:
|
|
48
|
+
Action: "sts:AssumeRole",
|
|
49
49
|
},
|
|
50
50
|
],
|
|
51
51
|
}),
|
|
52
52
|
});
|
|
53
|
-
const runnerRole = new iam_role_1.IamRole(this,
|
|
53
|
+
const runnerRole = new iam_role_1.IamRole(this, "RunnerRole", {
|
|
54
54
|
assumeRolePolicy: cdktf_1.Fn.jsonencode({
|
|
55
|
-
Version:
|
|
55
|
+
Version: "2012-10-17",
|
|
56
56
|
Statement: [
|
|
57
57
|
{
|
|
58
|
-
Effect:
|
|
58
|
+
Effect: "Allow",
|
|
59
59
|
Principal: {
|
|
60
|
-
Service:
|
|
60
|
+
Service: "ecs-tasks.amazonaws.com",
|
|
61
61
|
},
|
|
62
|
-
Action:
|
|
62
|
+
Action: "sts:AssumeRole",
|
|
63
63
|
},
|
|
64
64
|
],
|
|
65
65
|
}),
|
|
66
66
|
});
|
|
67
|
-
const ecsTaskExecutionRole = new iam_role_1.IamRole(this,
|
|
67
|
+
const ecsTaskExecutionRole = new iam_role_1.IamRole(this, "TaskExecutionRole", {
|
|
68
68
|
assumeRolePolicy: cdktf_1.Fn.jsonencode({
|
|
69
|
-
Version:
|
|
69
|
+
Version: "2012-10-17",
|
|
70
70
|
Statement: [
|
|
71
71
|
{
|
|
72
|
-
Effect:
|
|
72
|
+
Effect: "Allow",
|
|
73
73
|
Principal: {
|
|
74
|
-
Service:
|
|
74
|
+
Service: "ecs-tasks.amazonaws.com",
|
|
75
75
|
},
|
|
76
|
-
Action:
|
|
76
|
+
Action: "sts:AssumeRole",
|
|
77
77
|
},
|
|
78
78
|
],
|
|
79
79
|
}),
|
|
80
80
|
});
|
|
81
|
-
new iam_role_policy_attachment_1.IamRolePolicyAttachment(this,
|
|
82
|
-
policyArn:
|
|
81
|
+
new iam_role_policy_attachment_1.IamRolePolicyAttachment(this, "TeskExecutionRoleAttachment", {
|
|
82
|
+
policyArn: "arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy",
|
|
83
83
|
role: ecsTaskExecutionRole.name,
|
|
84
84
|
});
|
|
85
|
-
const runnerLogGroup = new cloudwatch_log_group_1.CloudwatchLogGroup(this,
|
|
86
|
-
name:
|
|
85
|
+
const runnerLogGroup = new cloudwatch_log_group_1.CloudwatchLogGroup(this, "RunnerLogGroup", {
|
|
86
|
+
name: "/ecs/GHA",
|
|
87
87
|
});
|
|
88
|
-
const autoscalerLogGroup = new cloudwatch_log_group_1.CloudwatchLogGroup(this,
|
|
89
|
-
name:
|
|
88
|
+
const autoscalerLogGroup = new cloudwatch_log_group_1.CloudwatchLogGroup(this, "AutoscalerLogGroup", {
|
|
89
|
+
name: "/ecs/Autoscaler",
|
|
90
90
|
});
|
|
91
91
|
const autoscalerContainerDefinition = {
|
|
92
|
-
name:
|
|
92
|
+
name: "autoscaler",
|
|
93
93
|
image: autoscalerImage.stringValue,
|
|
94
94
|
essential: true,
|
|
95
95
|
environment: [
|
|
96
96
|
{
|
|
97
|
-
name:
|
|
97
|
+
name: "PAT",
|
|
98
98
|
value: pat.value,
|
|
99
99
|
},
|
|
100
100
|
{
|
|
101
|
-
name:
|
|
101
|
+
name: "GITHUB_CONFIG_URL",
|
|
102
102
|
value: githubConfigUrl.value,
|
|
103
103
|
},
|
|
104
104
|
{
|
|
105
|
-
name:
|
|
105
|
+
name: "ECS_CLUSTER",
|
|
106
106
|
value: cluster.arn,
|
|
107
107
|
},
|
|
108
108
|
{
|
|
109
|
-
name:
|
|
110
|
-
value: cdktf_1.Fn.join(
|
|
109
|
+
name: "ECS_SUBNETS",
|
|
110
|
+
value: cdktf_1.Fn.join(",", subnets.ids),
|
|
111
111
|
},
|
|
112
112
|
{
|
|
113
|
-
name:
|
|
114
|
-
value: cdktf_1.Fn.join(
|
|
113
|
+
name: "ECS_SECURITY_GROUPS",
|
|
114
|
+
value: cdktf_1.Fn.join(",", securityGroups.ids),
|
|
115
115
|
},
|
|
116
116
|
{
|
|
117
|
-
name:
|
|
118
|
-
value:
|
|
117
|
+
name: "SCALE_SET_NAME",
|
|
118
|
+
value: "ecs-runner-set",
|
|
119
119
|
},
|
|
120
120
|
],
|
|
121
121
|
logConfiguration: {
|
|
122
|
-
logDriver:
|
|
122
|
+
logDriver: "awslogs",
|
|
123
123
|
options: {
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
124
|
+
"awslogs-group": autoscalerLogGroup.name,
|
|
125
|
+
"awslogs-region": region.name,
|
|
126
|
+
"awslogs-stream-prefix": "ecs",
|
|
127
127
|
},
|
|
128
128
|
},
|
|
129
129
|
};
|
|
130
130
|
const runnerVolume = [];
|
|
131
131
|
const runnerContainerDefinition = {
|
|
132
|
-
name:
|
|
133
|
-
image:
|
|
132
|
+
name: "runner",
|
|
133
|
+
image: "ghcr.io/actions/actions-runner:2.323.0",
|
|
134
134
|
essential: true,
|
|
135
|
-
entryPoint: [
|
|
135
|
+
entryPoint: ["/home/runner/run.sh"],
|
|
136
136
|
environment: [
|
|
137
137
|
{
|
|
138
|
-
name:
|
|
138
|
+
name: "ECS_CLUSTER_NAME",
|
|
139
139
|
value: cluster.name,
|
|
140
140
|
},
|
|
141
141
|
{
|
|
142
|
-
name:
|
|
143
|
-
value:
|
|
142
|
+
name: "ACTIONS_RUNNER_POD_NAME",
|
|
143
|
+
value: "gha-pod",
|
|
144
144
|
},
|
|
145
145
|
{
|
|
146
|
-
name:
|
|
147
|
-
value: cdktf_1.Fn.join(
|
|
146
|
+
name: "ECS_SUBNETS",
|
|
147
|
+
value: cdktf_1.Fn.join(",", subnets.ids),
|
|
148
148
|
},
|
|
149
149
|
{
|
|
150
|
-
name:
|
|
151
|
-
value: cdktf_1.Fn.join(
|
|
150
|
+
name: "ECS_SECURITY_GROUPS",
|
|
151
|
+
value: cdktf_1.Fn.join(",", securityGroups.ids),
|
|
152
152
|
},
|
|
153
153
|
{
|
|
154
|
-
name:
|
|
154
|
+
name: "ECS_TASK_ROLE",
|
|
155
155
|
value: runnerRole.arn,
|
|
156
156
|
},
|
|
157
157
|
{
|
|
158
|
-
name:
|
|
158
|
+
name: "ECS_EXECUTION_ROLE",
|
|
159
159
|
value: ecsTaskExecutionRole.arn,
|
|
160
160
|
},
|
|
161
161
|
],
|
|
162
162
|
mountPoints: [],
|
|
163
163
|
logConfiguration: {
|
|
164
|
-
logDriver:
|
|
164
|
+
logDriver: "awslogs",
|
|
165
165
|
options: {
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
166
|
+
"awslogs-group": runnerLogGroup.name,
|
|
167
|
+
"awslogs-region": region.name,
|
|
168
|
+
"awslogs-stream-prefix": "ecs",
|
|
169
169
|
},
|
|
170
170
|
},
|
|
171
171
|
};
|
|
172
172
|
if (props.containerSupport) {
|
|
173
173
|
// EFS volume to allow sharing data between tasks
|
|
174
|
-
const efs = new efs_file_system_1.EfsFileSystem(this,
|
|
175
|
-
throughputMode:
|
|
174
|
+
const efs = new efs_file_system_1.EfsFileSystem(this, "efs", {
|
|
175
|
+
throughputMode: "elastic",
|
|
176
176
|
tags: {
|
|
177
|
-
Name:
|
|
177
|
+
Name: "work",
|
|
178
178
|
},
|
|
179
179
|
});
|
|
180
|
-
const externalsEfs = new efs_file_system_1.EfsFileSystem(this,
|
|
181
|
-
throughputMode:
|
|
180
|
+
const externalsEfs = new efs_file_system_1.EfsFileSystem(this, "externalsEfs", {
|
|
181
|
+
throughputMode: "elastic",
|
|
182
182
|
tags: {
|
|
183
|
-
Name:
|
|
183
|
+
Name: "externals",
|
|
184
184
|
},
|
|
185
185
|
});
|
|
186
186
|
// Each subnet in VPC are on different AZs, so creating mountpoint to each
|
|
187
187
|
const iterator = cdktf_1.TerraformIterator.fromList(subnets.ids);
|
|
188
|
-
new efs_mount_target_1.EfsMountTarget(this,
|
|
188
|
+
new efs_mount_target_1.EfsMountTarget(this, "EfsMountTarget", {
|
|
189
189
|
forEach: iterator,
|
|
190
190
|
fileSystemId: efs.id,
|
|
191
191
|
subnetId: iterator.value,
|
|
192
192
|
});
|
|
193
|
-
new efs_mount_target_1.EfsMountTarget(this,
|
|
193
|
+
new efs_mount_target_1.EfsMountTarget(this, "ExternalsEfsMountTarget", {
|
|
194
194
|
forEach: iterator,
|
|
195
195
|
fileSystemId: externalsEfs.id,
|
|
196
196
|
subnetId: iterator.value,
|
|
197
197
|
});
|
|
198
|
-
const runnerVolumeName =
|
|
199
|
-
const externalsVolumeName =
|
|
198
|
+
const runnerVolumeName = "work";
|
|
199
|
+
const externalsVolumeName = "externals";
|
|
200
200
|
runnerVolume.push({
|
|
201
201
|
name: runnerVolumeName,
|
|
202
202
|
efsVolumeConfiguration: {
|
|
@@ -212,87 +212,87 @@ class Aws extends constructs_1.Construct {
|
|
|
212
212
|
});
|
|
213
213
|
runnerContainerDefinition.mountPoints?.push({
|
|
214
214
|
sourceVolume: runnerVolumeName,
|
|
215
|
-
containerPath:
|
|
215
|
+
containerPath: "/tmp/_work",
|
|
216
216
|
}, {
|
|
217
217
|
sourceVolume: externalsVolumeName,
|
|
218
|
-
containerPath:
|
|
218
|
+
containerPath: "/tmp/externals",
|
|
219
219
|
});
|
|
220
220
|
runnerContainerDefinition.environment?.push({
|
|
221
|
-
name:
|
|
221
|
+
name: "EFS_ID",
|
|
222
222
|
value: efs.id,
|
|
223
223
|
}, {
|
|
224
|
-
name:
|
|
224
|
+
name: "EXTERNALS_EFS_ID",
|
|
225
225
|
value: externalsEfs.id,
|
|
226
226
|
}, {
|
|
227
|
-
name:
|
|
228
|
-
value:
|
|
227
|
+
name: "ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER",
|
|
228
|
+
value: "false",
|
|
229
229
|
});
|
|
230
230
|
runnerContainerDefinition.command = [
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
231
|
+
"/bin/sh",
|
|
232
|
+
"-c",
|
|
233
|
+
"export EXECID=$(cat /proc/sys/kernel/random/uuid) && sudo mkdir -p /tmp/_work/$EXECID && sudo chown runner:runner /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && sudo chown runner:runner /tmp/externals && /home/runner/run.sh ; sudo rm -r /tmp/_work/$EXECID",
|
|
234
234
|
];
|
|
235
|
-
runnerContainerDefinition.image =
|
|
235
|
+
runnerContainerDefinition.image = "ghcr.io/hi-fi/actions-runner:ecs";
|
|
236
236
|
}
|
|
237
237
|
// TODO: Images through caching: https://docs.aws.amazon.com/AmazonECR/latest/userguide/pull-through-cache.html (requires authentication)
|
|
238
238
|
// TODO: Pass Execution role to job task: https://www.ernestchiang.com/en/posts/2021/using-amazon-ecs-exec/#1-grant-permissions-ecs-task-iam-role
|
|
239
239
|
// TODO: Pass Task role to job task
|
|
240
|
-
const runnerTaskDefinition = new ecs_task_definition_1.EcsTaskDefinition(this,
|
|
241
|
-
family:
|
|
240
|
+
const runnerTaskDefinition = new ecs_task_definition_1.EcsTaskDefinition(this, "RunnerTaskDefinition", {
|
|
241
|
+
family: "GHA",
|
|
242
242
|
taskRoleArn: runnerRole.arn,
|
|
243
243
|
executionRoleArn: ecsTaskExecutionRole.arn,
|
|
244
244
|
containerDefinitions: cdktf_1.Fn.jsonencode([runnerContainerDefinition]),
|
|
245
|
-
cpu:
|
|
246
|
-
memory:
|
|
247
|
-
requiresCompatibilities: [
|
|
245
|
+
cpu: "1024",
|
|
246
|
+
memory: "2048",
|
|
247
|
+
requiresCompatibilities: ["FARGATE"],
|
|
248
248
|
runtimePlatform: {
|
|
249
|
-
cpuArchitecture:
|
|
250
|
-
operatingSystemFamily:
|
|
249
|
+
cpuArchitecture: "X86_64",
|
|
250
|
+
operatingSystemFamily: "LINUX",
|
|
251
251
|
},
|
|
252
|
-
networkMode:
|
|
252
|
+
networkMode: "awsvpc",
|
|
253
253
|
volume: runnerVolume,
|
|
254
254
|
});
|
|
255
255
|
autoscalerContainerDefinition.environment?.push({
|
|
256
|
-
name:
|
|
256
|
+
name: "TASK_DEFINITION_ARN",
|
|
257
257
|
value: runnerTaskDefinition.arn,
|
|
258
258
|
});
|
|
259
|
-
const autoscalerTaskDefinition = new ecs_task_definition_1.EcsTaskDefinition(this,
|
|
260
|
-
family:
|
|
259
|
+
const autoscalerTaskDefinition = new ecs_task_definition_1.EcsTaskDefinition(this, "AutoscalerTaskDefinition", {
|
|
260
|
+
family: "Autoscaler",
|
|
261
261
|
taskRoleArn: autoscalerRole.arn,
|
|
262
262
|
executionRoleArn: ecsTaskExecutionRole.arn,
|
|
263
263
|
containerDefinitions: cdktf_1.Fn.jsonencode([autoscalerContainerDefinition]),
|
|
264
|
-
cpu:
|
|
265
|
-
memory:
|
|
266
|
-
requiresCompatibilities: [
|
|
264
|
+
cpu: "256",
|
|
265
|
+
memory: "512",
|
|
266
|
+
requiresCompatibilities: ["FARGATE"],
|
|
267
267
|
runtimePlatform: {
|
|
268
|
-
cpuArchitecture:
|
|
269
|
-
operatingSystemFamily:
|
|
268
|
+
cpuArchitecture: "X86_64",
|
|
269
|
+
operatingSystemFamily: "LINUX",
|
|
270
270
|
},
|
|
271
|
-
networkMode:
|
|
271
|
+
networkMode: "awsvpc",
|
|
272
272
|
});
|
|
273
273
|
const runnerPolicyDefinition = {
|
|
274
|
-
Version:
|
|
274
|
+
Version: "2012-10-17",
|
|
275
275
|
Statement: [
|
|
276
276
|
{
|
|
277
|
-
Sid:
|
|
278
|
-
Effect:
|
|
277
|
+
Sid: "StartandMonitorTask",
|
|
278
|
+
Effect: "Allow",
|
|
279
279
|
Action: [
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
280
|
+
"ecs:RunTask",
|
|
281
|
+
"ecs:TagResource",
|
|
282
|
+
"ecs:ListTaskDefinitions",
|
|
283
|
+
"ecs:ListTasks",
|
|
284
|
+
"ecs:StopTask",
|
|
285
|
+
"ecs:RegisterTaskDefinition",
|
|
286
|
+
"ecs:DescribeTaskDefinition",
|
|
287
|
+
"ecs:DeregisterTaskDefinition",
|
|
288
|
+
"ecs:DeleteTaskDefinitions",
|
|
289
|
+
"ecs:ExecuteCommand",
|
|
290
290
|
// Needed for waiting
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
291
|
+
"ecs:DescribeTasks",
|
|
292
|
+
"logs:GetLogEvents",
|
|
293
|
+
"iam:PassRole",
|
|
294
|
+
"logs:StartLiveTail",
|
|
295
|
+
"logs:CreateLogStream",
|
|
296
296
|
],
|
|
297
297
|
Resource: [
|
|
298
298
|
`arn:aws:ecs:${region.name}:${identity.accountId}:task-definition/gha-pod-workflow:*`,
|
|
@@ -302,48 +302,48 @@ class Aws extends constructs_1.Construct {
|
|
|
302
302
|
runnerRole.arn,
|
|
303
303
|
`arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,
|
|
304
304
|
//TODO: reorder rights so that listing is only one with star
|
|
305
|
-
|
|
305
|
+
"*",
|
|
306
306
|
],
|
|
307
307
|
},
|
|
308
308
|
{
|
|
309
|
-
Sid:
|
|
310
|
-
Effect:
|
|
311
|
-
Action: [
|
|
312
|
-
Resource:
|
|
309
|
+
Sid: "GetVpcInfo",
|
|
310
|
+
Effect: "Allow",
|
|
311
|
+
Action: ["ec2:DescribeSubnets", "ec2:DescribeSecurityGroups"],
|
|
312
|
+
Resource: "*",
|
|
313
313
|
},
|
|
314
314
|
{
|
|
315
|
-
Sid:
|
|
316
|
-
Effect:
|
|
315
|
+
Sid: "ExecCommands",
|
|
316
|
+
Effect: "Allow",
|
|
317
317
|
Action: [
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
318
|
+
"ssmmessages:CreateControlChannel",
|
|
319
|
+
"ssmmessages:CreateDataChannel",
|
|
320
|
+
"ssmmessages:OpenControlChannel",
|
|
321
|
+
"ssmmessages:OpenDataChannel",
|
|
322
322
|
],
|
|
323
|
-
Resource:
|
|
323
|
+
Resource: "*",
|
|
324
324
|
},
|
|
325
325
|
],
|
|
326
326
|
};
|
|
327
|
-
const runnerPolicy = new iam_policy_1.IamPolicy(this,
|
|
327
|
+
const runnerPolicy = new iam_policy_1.IamPolicy(this, "RunnerPolicy", {
|
|
328
328
|
policy: cdktf_1.Fn.jsonencode(runnerPolicyDefinition),
|
|
329
329
|
});
|
|
330
|
-
new iam_role_policy_attachment_1.IamRolePolicyAttachment(this,
|
|
330
|
+
new iam_role_policy_attachment_1.IamRolePolicyAttachment(this, "RunnerPolicyAttachment", {
|
|
331
331
|
policyArn: runnerPolicy.arn,
|
|
332
332
|
role: runnerRole.name,
|
|
333
333
|
});
|
|
334
|
-
const autoscalerPolicy = new iam_policy_1.IamPolicy(this,
|
|
334
|
+
const autoscalerPolicy = new iam_policy_1.IamPolicy(this, "AutoscalerPolicy", {
|
|
335
335
|
policy: cdktf_1.Fn.jsonencode({
|
|
336
|
-
Version:
|
|
336
|
+
Version: "2012-10-17",
|
|
337
337
|
Statement: [
|
|
338
338
|
{
|
|
339
|
-
Sid:
|
|
340
|
-
Effect:
|
|
339
|
+
Sid: "StartandMonitorTask",
|
|
340
|
+
Effect: "Allow",
|
|
341
341
|
Action: [
|
|
342
|
-
|
|
342
|
+
"ecs:RunTask",
|
|
343
343
|
// Needed for waiting
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
344
|
+
"ecs:DescribeTasks",
|
|
345
|
+
"logs:GetLogEvents",
|
|
346
|
+
"iam:PassRole",
|
|
347
347
|
],
|
|
348
348
|
Resource: [
|
|
349
349
|
`${runnerTaskDefinition.arnWithoutRevision}:*`,
|
|
@@ -355,23 +355,23 @@ class Aws extends constructs_1.Construct {
|
|
|
355
355
|
],
|
|
356
356
|
},
|
|
357
357
|
{
|
|
358
|
-
Sid:
|
|
359
|
-
Effect:
|
|
360
|
-
Action: [
|
|
361
|
-
Resource:
|
|
358
|
+
Sid: "GetVpcInfo",
|
|
359
|
+
Effect: "Allow",
|
|
360
|
+
Action: ["ec2:DescribeSubnets", "ec2:DescribeSecurityGroups"],
|
|
361
|
+
Resource: "*",
|
|
362
362
|
},
|
|
363
363
|
],
|
|
364
364
|
}),
|
|
365
365
|
});
|
|
366
|
-
new iam_role_policy_attachment_1.IamRolePolicyAttachment(this,
|
|
366
|
+
new iam_role_policy_attachment_1.IamRolePolicyAttachment(this, "AutoscalerPolicyAttachment", {
|
|
367
367
|
policyArn: autoscalerPolicy.arn,
|
|
368
368
|
role: autoscalerRole.name,
|
|
369
369
|
});
|
|
370
|
-
new ecs_service_1.EcsService(this,
|
|
370
|
+
new ecs_service_1.EcsService(this, "AutoscalerService", {
|
|
371
371
|
cluster: cluster.arn,
|
|
372
|
-
name:
|
|
372
|
+
name: "autoscaler-service",
|
|
373
373
|
desiredCount: 1,
|
|
374
|
-
launchType:
|
|
374
|
+
launchType: "FARGATE",
|
|
375
375
|
taskDefinition: autoscalerTaskDefinition.arnWithoutRevision,
|
|
376
376
|
networkConfiguration: {
|
|
377
377
|
assignPublicIp: true,
|
|
@@ -379,12 +379,12 @@ class Aws extends constructs_1.Construct {
|
|
|
379
379
|
securityGroups: securityGroups.ids,
|
|
380
380
|
},
|
|
381
381
|
lifecycle: {
|
|
382
|
-
ignoreChanges: [
|
|
382
|
+
ignoreChanges: ["desired_count"],
|
|
383
383
|
},
|
|
384
384
|
});
|
|
385
385
|
}
|
|
386
386
|
}
|
|
387
387
|
exports.Aws = Aws;
|
|
388
388
|
_a = JSII_RTTI_SYMBOL_1;
|
|
389
|
-
Aws[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Aws", version: "0.0.
|
|
390
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws.js","sourceRoot":"","sources":["../../src/lib/aws.ts"],"names":[],"mappings":"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","sourcesContent":["import { type ContainerDefinition } from '@aws-sdk/client-ecs'\nimport { CloudwatchLogGroup } from '@cdktf/provider-aws/lib/cloudwatch-log-group'\nimport { DataAwsCallerIdentity } from '@cdktf/provider-aws/lib/data-aws-caller-identity'\nimport { DataAwsRegion } from '@cdktf/provider-aws/lib/data-aws-region'\nimport {\n  DataAwsSecurityGroups,\n  DataAwsSecurityGroupsFilter,\n} from '@cdktf/provider-aws/lib/data-aws-security-groups'\nimport {\n  DataAwsSubnets,\n  DataAwsSubnetsFilter,\n} from '@cdktf/provider-aws/lib/data-aws-subnets'\nimport { EcsCluster } from '@cdktf/provider-aws/lib/ecs-cluster'\nimport { EcsService } from '@cdktf/provider-aws/lib/ecs-service'\nimport {\n  EcsTaskDefinition,\n  EcsTaskDefinitionVolume,\n} from '@cdktf/provider-aws/lib/ecs-task-definition'\nimport { EfsFileSystem } from '@cdktf/provider-aws/lib/efs-file-system'\nimport { EfsMountTarget } from '@cdktf/provider-aws/lib/efs-mount-target'\nimport { IamPolicy } from '@cdktf/provider-aws/lib/iam-policy'\nimport { IamRole } from '@cdktf/provider-aws/lib/iam-role'\nimport { IamRolePolicyAttachment } from '@cdktf/provider-aws/lib/iam-role-policy-attachment'\nimport { AwsProvider } from '@cdktf/provider-aws/lib/provider'\nimport { Fn, IResolvable, TerraformIterator } from 'cdktf'\nimport { Construct } from 'constructs'\nimport { commonVariables } from './variables'\n\nexport interface AwsProps {\n  // Name of the ECS cluster to create and use.\n  readonly clusterName: string\n  // Utilize runner-container-hooks to allow support for service and build container as well as container actions and steps.\n  readonly containerSupport: boolean\n  /**\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DescribeSubnets.html\n   */\n  readonly subnetFilters?: DataAwsSubnetsFilter[] | IResolvable\n  /**\n   * @see https://docs.aws.amazon.com/cli/latest/reference/ec2/describe-security-groups.html\n   */\n  readonly securityGroupFilters?: DataAwsSecurityGroupsFilter[] | IResolvable\n}\n\nexport class Aws extends Construct {\n  constructor(scope: Construct, id: string, props: AwsProps) {\n    super(scope, id)\n\n    new AwsProvider(this, 'aws', {})\n\n    const identity = new DataAwsCallerIdentity(this, 'Identity', {})\n\n    const region = new DataAwsRegion(this, 'Region', {})\n\n    const { pat, githubConfigUrl, autoscalerImage } = commonVariables(this)\n\n    const cluster = new EcsCluster(this, 'Cluster', {\n      name: props.clusterName,\n    })\n\n    const subnets = new DataAwsSubnets(this, 'Subnets', {\n      filter: props.subnetFilters,\n    })\n\n    const securityGroups = new DataAwsSecurityGroups(this, 'SecurityGroups', {\n      filter: props.securityGroupFilters,\n    })\n\n    const autoscalerRole = new IamRole(this, 'AutoscalerRole', {\n      assumeRolePolicy: Fn.jsonencode({\n        Version: '2012-10-17',\n        Statement: [\n          {\n            Effect: 'Allow',\n            Principal: {\n              Service: 'ecs-tasks.amazonaws.com',\n            },\n            Action: 'sts:AssumeRole',\n          },\n        ],\n      }),\n    })\n\n    const runnerRole = new IamRole(this, 'RunnerRole', {\n      assumeRolePolicy: Fn.jsonencode({\n        Version: '2012-10-17',\n        Statement: [\n          {\n            Effect: 'Allow',\n            Principal: {\n              Service: 'ecs-tasks.amazonaws.com',\n            },\n            Action: 'sts:AssumeRole',\n          },\n        ],\n      }),\n    })\n\n    const ecsTaskExecutionRole = new IamRole(this, 'TaskExecutionRole', {\n      assumeRolePolicy: Fn.jsonencode({\n        Version: '2012-10-17',\n        Statement: [\n          {\n            Effect: 'Allow',\n            Principal: {\n              Service: 'ecs-tasks.amazonaws.com',\n            },\n            Action: 'sts:AssumeRole',\n          },\n        ],\n      }),\n    })\n\n    new IamRolePolicyAttachment(this, 'TeskExecutionRoleAttachment', {\n      policyArn:\n        'arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy',\n      role: ecsTaskExecutionRole.name,\n    })\n\n    const runnerLogGroup = new CloudwatchLogGroup(this, 'RunnerLogGroup', {\n      name: '/ecs/GHA',\n    })\n\n    const autoscalerLogGroup = new CloudwatchLogGroup(\n      this,\n      'AutoscalerLogGroup',\n      {\n        name: '/ecs/Autoscaler',\n      },\n    )\n\n    const autoscalerContainerDefinition: ContainerDefinition = {\n      name: 'autoscaler',\n      image: autoscalerImage.stringValue,\n      essential: true,\n      environment: [\n        {\n          name: 'PAT',\n          value: pat.value,\n        },\n        {\n          name: 'GITHUB_CONFIG_URL',\n          value: githubConfigUrl.value,\n        },\n        {\n          name: 'ECS_CLUSTER',\n          value: cluster.arn,\n        },\n        {\n          name: 'ECS_SUBNETS',\n          value: Fn.join(',', subnets.ids),\n        },\n        {\n          name: 'ECS_SECURITY_GROUPS',\n          value: Fn.join(',', securityGroups.ids),\n        },\n        {\n          name: 'SCALE_SET_NAME',\n          value: 'ecs-runner-set',\n        },\n      ],\n      logConfiguration: {\n        logDriver: 'awslogs',\n        options: {\n          'awslogs-group': autoscalerLogGroup.name,\n          'awslogs-region': region.name,\n          'awslogs-stream-prefix': 'ecs',\n        },\n      },\n    }\n\n    const runnerVolume: EcsTaskDefinitionVolume[] = []\n\n    const runnerContainerDefinition: ContainerDefinition = {\n      name: 'runner',\n      image: 'ghcr.io/actions/actions-runner:2.323.0',\n      essential: true,\n      entryPoint: ['/home/runner/run.sh'],\n      environment: [\n        {\n          name: 'ECS_CLUSTER_NAME',\n          value: cluster.name,\n        },\n        {\n          name: 'ACTIONS_RUNNER_POD_NAME',\n          value: 'gha-pod',\n        },\n        {\n          name: 'ECS_SUBNETS',\n          value: Fn.join(',', subnets.ids),\n        },\n        {\n          name: 'ECS_SECURITY_GROUPS',\n          value: Fn.join(',', securityGroups.ids),\n        },\n        {\n          name: 'ECS_TASK_ROLE',\n          value: runnerRole.arn,\n        },\n        {\n          name: 'ECS_EXECUTION_ROLE',\n          value: ecsTaskExecutionRole.arn,\n        },\n      ],\n      mountPoints: [],\n      logConfiguration: {\n        logDriver: 'awslogs',\n        options: {\n          'awslogs-group': runnerLogGroup.name,\n          'awslogs-region': region.name,\n          'awslogs-stream-prefix': 'ecs',\n        },\n      },\n    }\n\n    if (props.containerSupport) {\n      // EFS volume to allow sharing data between tasks\n      const efs = new EfsFileSystem(this, 'efs', {\n        throughputMode: 'elastic',\n        tags: {\n          Name: 'work',\n        },\n      })\n\n      const externalsEfs = new EfsFileSystem(this, 'externalsEfs', {\n        throughputMode: 'elastic',\n        tags: {\n          Name: 'externals',\n        },\n      })\n\n      // Each subnet in VPC are on different AZs, so creating mountpoint to each\n      const iterator = TerraformIterator.fromList(subnets.ids)\n\n      new EfsMountTarget(this, 'EfsMountTarget', {\n        forEach: iterator,\n        fileSystemId: efs.id,\n        subnetId: iterator.value,\n      })\n\n      new EfsMountTarget(this, 'ExternalsEfsMountTarget', {\n        forEach: iterator,\n        fileSystemId: externalsEfs.id,\n        subnetId: iterator.value,\n      })\n\n      const runnerVolumeName = 'work'\n      const externalsVolumeName = 'externals'\n\n      runnerVolume.push(\n        {\n          name: runnerVolumeName,\n          efsVolumeConfiguration: {\n            fileSystemId: efs.id,\n          },\n        },\n        // This doesn't work with same volume, as volume is initially empty so it can't map to it's \"externals\" directory\n        {\n          name: externalsVolumeName,\n          efsVolumeConfiguration: {\n            fileSystemId: externalsEfs.id,\n          },\n        },\n      )\n\n      runnerContainerDefinition.mountPoints?.push(\n        {\n          sourceVolume: runnerVolumeName,\n          containerPath: '/tmp/_work',\n        },\n        {\n          sourceVolume: externalsVolumeName,\n          containerPath: '/tmp/externals',\n        },\n      )\n\n      runnerContainerDefinition.environment?.push(\n        {\n          name: 'EFS_ID',\n          value: efs.id,\n        },\n        {\n          name: 'EXTERNALS_EFS_ID',\n          value: externalsEfs.id,\n        },\n        {\n          name: 'ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER',\n          value: 'false',\n        },\n      )\n\n      runnerContainerDefinition.command = [\n        '/bin/sh',\n        '-c',\n        'export EXECID=$(cat /proc/sys/kernel/random/uuid) && sudo mkdir -p /tmp/_work/$EXECID && sudo chown runner:runner /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && sudo chown runner:runner /tmp/externals && /home/runner/run.sh ; sudo rm -r /tmp/_work/$EXECID',\n      ]\n      runnerContainerDefinition.image = 'ghcr.io/hi-fi/actions-runner:ecs'\n    }\n\n    // TODO: Images through caching: https://docs.aws.amazon.com/AmazonECR/latest/userguide/pull-through-cache.html (requires authentication)\n    // TODO: Pass Execution role to job task: https://www.ernestchiang.com/en/posts/2021/using-amazon-ecs-exec/#1-grant-permissions-ecs-task-iam-role\n    // TODO: Pass Task role to job task\n    const runnerTaskDefinition = new EcsTaskDefinition(\n      this,\n      'RunnerTaskDefinition',\n      {\n        family: 'GHA',\n        taskRoleArn: runnerRole.arn,\n        executionRoleArn: ecsTaskExecutionRole.arn,\n        containerDefinitions: Fn.jsonencode([runnerContainerDefinition]),\n        cpu: '1024',\n        memory: '2048',\n        requiresCompatibilities: ['FARGATE'],\n        runtimePlatform: {\n          cpuArchitecture: 'X86_64',\n          operatingSystemFamily: 'LINUX',\n        },\n        networkMode: 'awsvpc',\n        volume: runnerVolume,\n      },\n    )\n\n    autoscalerContainerDefinition.environment?.push({\n      name: 'TASK_DEFINITION_ARN',\n      value: runnerTaskDefinition.arn,\n    })\n\n    const autoscalerTaskDefinition = new EcsTaskDefinition(\n      this,\n      'AutoscalerTaskDefinition',\n      {\n        family: 'Autoscaler',\n        taskRoleArn: autoscalerRole.arn,\n        executionRoleArn: ecsTaskExecutionRole.arn,\n        containerDefinitions: Fn.jsonencode([autoscalerContainerDefinition]),\n        cpu: '256',\n        memory: '512',\n        requiresCompatibilities: ['FARGATE'],\n        runtimePlatform: {\n          cpuArchitecture: 'X86_64',\n          operatingSystemFamily: 'LINUX',\n        },\n        networkMode: 'awsvpc',\n      },\n    )\n\n    const runnerPolicyDefinition = {\n      Version: '2012-10-17',\n      Statement: [\n        {\n          Sid: 'StartandMonitorTask',\n          Effect: 'Allow',\n          Action: [\n            'ecs:RunTask',\n            'ecs:TagResource',\n            'ecs:ListTaskDefinitions',\n            'ecs:ListTasks',\n            'ecs:StopTask',\n            'ecs:RegisterTaskDefinition',\n            'ecs:DescribeTaskDefinition',\n            'ecs:DeregisterTaskDefinition',\n            'ecs:DeleteTaskDefinitions',\n            'ecs:ExecuteCommand',\n            // Needed for waiting\n            'ecs:DescribeTasks',\n            'logs:GetLogEvents',\n            'iam:PassRole',\n            'logs:StartLiveTail',\n            'logs:CreateLogStream',\n          ],\n          Resource: [\n            `arn:aws:ecs:${region.name}:${identity.accountId}:task-definition/gha-pod-workflow:*`,\n            cluster.arn,\n            // Triggerer has to be allowed to pass both task and task execution role\n            ecsTaskExecutionRole.arn,\n            runnerRole.arn,\n            `arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,\n            //TODO: reorder rights so that listing is only one with star\n            '*',\n          ],\n        },\n        {\n          Sid: 'GetVpcInfo',\n          Effect: 'Allow',\n          Action: ['ec2:DescribeSubnets', 'ec2:DescribeSecurityGroups'],\n          Resource: '*',\n        },\n        {\n          Sid: 'ExecCommands',\n          Effect: 'Allow',\n          Action: [\n            'ssmmessages:CreateControlChannel',\n            'ssmmessages:CreateDataChannel',\n            'ssmmessages:OpenControlChannel',\n            'ssmmessages:OpenDataChannel',\n          ],\n          Resource: '*',\n        },\n      ],\n    }\n\n    const runnerPolicy = new IamPolicy(this, 'RunnerPolicy', {\n      policy: Fn.jsonencode(runnerPolicyDefinition),\n    })\n\n    new IamRolePolicyAttachment(this, 'RunnerPolicyAttachment', {\n      policyArn: runnerPolicy.arn,\n      role: runnerRole.name,\n    })\n\n    const autoscalerPolicy = new IamPolicy(this, 'AutoscalerPolicy', {\n      policy: Fn.jsonencode({\n        Version: '2012-10-17',\n        Statement: [\n          {\n            Sid: 'StartandMonitorTask',\n            Effect: 'Allow',\n            Action: [\n              'ecs:RunTask',\n              // Needed for waiting\n              'ecs:DescribeTasks',\n              'logs:GetLogEvents',\n              'iam:PassRole',\n            ],\n            Resource: [\n              `${runnerTaskDefinition.arnWithoutRevision}:*`,\n              // Triggerer has to be allowed to pass both task and task execution role\n              ecsTaskExecutionRole.arn,\n              runnerRole.arn,\n              `arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,\n              `${runnerLogGroup.arn}:log-stream:*`,\n            ],\n          },\n          {\n            Sid: 'GetVpcInfo',\n            Effect: 'Allow',\n            Action: ['ec2:DescribeSubnets', 'ec2:DescribeSecurityGroups'],\n            Resource: '*',\n          },\n        ],\n      }),\n    })\n    new IamRolePolicyAttachment(this, 'AutoscalerPolicyAttachment', {\n      policyArn: autoscalerPolicy.arn,\n      role: autoscalerRole.name,\n    })\n\n    new EcsService(this, 'AutoscalerService', {\n      cluster: cluster.arn,\n      name: 'autoscaler-service',\n      desiredCount: 1,\n      launchType: 'FARGATE',\n      taskDefinition: autoscalerTaskDefinition.arnWithoutRevision,\n      networkConfiguration: {\n        assignPublicIp: true,\n        subnets: subnets.ids,\n        securityGroups: securityGroups.ids,\n      },\n      lifecycle: {\n        ignoreChanges: ['desired_count'],\n      },\n    })\n  }\n}\n"]}
|
|
389
|
+
Aws[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Aws", version: "0.0.8" };
|
|
390
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws.js","sourceRoot":"","sources":["../../src/lib/aws.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ContainerDefinition } from \"@aws-sdk/client-ecs\";\nimport { CloudwatchLogGroup } from \"@cdktf/provider-aws/lib/cloudwatch-log-group\";\nimport { DataAwsCallerIdentity } from \"@cdktf/provider-aws/lib/data-aws-caller-identity\";\nimport { DataAwsRegion } from \"@cdktf/provider-aws/lib/data-aws-region\";\nimport {\n\tDataAwsSecurityGroups,\n\ttype DataAwsSecurityGroupsFilter,\n} from \"@cdktf/provider-aws/lib/data-aws-security-groups\";\nimport {\n\tDataAwsSubnets,\n\ttype DataAwsSubnetsFilter,\n} from \"@cdktf/provider-aws/lib/data-aws-subnets\";\nimport { EcsCluster } from \"@cdktf/provider-aws/lib/ecs-cluster\";\nimport { EcsService } from \"@cdktf/provider-aws/lib/ecs-service\";\nimport {\n\tEcsTaskDefinition,\n\ttype EcsTaskDefinitionVolume,\n} from \"@cdktf/provider-aws/lib/ecs-task-definition\";\nimport { EfsFileSystem } from \"@cdktf/provider-aws/lib/efs-file-system\";\nimport { EfsMountTarget } from \"@cdktf/provider-aws/lib/efs-mount-target\";\nimport { IamPolicy } from \"@cdktf/provider-aws/lib/iam-policy\";\nimport { IamRole } from \"@cdktf/provider-aws/lib/iam-role\";\nimport { IamRolePolicyAttachment } from \"@cdktf/provider-aws/lib/iam-role-policy-attachment\";\nimport { AwsProvider } from \"@cdktf/provider-aws/lib/provider\";\nimport { Fn, type IResolvable, TerraformIterator } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { commonVariables } from \"./variables\";\n\nexport interface AwsProps {\n\t// Name of the ECS cluster to create and use.\n\treadonly clusterName: string;\n\t// Utilize runner-container-hooks to allow support for service and build container as well as container actions and steps.\n\treadonly containerSupport: boolean;\n\t/**\n\t * @see https://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DescribeSubnets.html\n\t */\n\treadonly subnetFilters?: DataAwsSubnetsFilter[] | IResolvable;\n\t/**\n\t * @see https://docs.aws.amazon.com/cli/latest/reference/ec2/describe-security-groups.html\n\t */\n\treadonly securityGroupFilters?: DataAwsSecurityGroupsFilter[] | IResolvable;\n}\n\nexport class Aws extends Construct {\n\tconstructor(scope: Construct, id: string, props: AwsProps) {\n\t\tsuper(scope, id);\n\n\t\tnew AwsProvider(this, \"aws\", {});\n\n\t\tconst identity = new DataAwsCallerIdentity(this, \"Identity\", {});\n\n\t\tconst region = new DataAwsRegion(this, \"Region\", {});\n\n\t\tconst { pat, githubConfigUrl, autoscalerImage } = commonVariables(this);\n\n\t\tconst cluster = new EcsCluster(this, \"Cluster\", {\n\t\t\tname: props.clusterName,\n\t\t});\n\n\t\tconst subnets = new DataAwsSubnets(this, \"Subnets\", {\n\t\t\tfilter: props.subnetFilters,\n\t\t});\n\n\t\tconst securityGroups = new DataAwsSecurityGroups(this, \"SecurityGroups\", {\n\t\t\tfilter: props.securityGroupFilters,\n\t\t});\n\n\t\tconst autoscalerRole = new IamRole(this, \"AutoscalerRole\", {\n\t\t\tassumeRolePolicy: Fn.jsonencode({\n\t\t\t\tVersion: \"2012-10-17\",\n\t\t\t\tStatement: [\n\t\t\t\t\t{\n\t\t\t\t\t\tEffect: \"Allow\",\n\t\t\t\t\t\tPrincipal: {\n\t\t\t\t\t\t\tService: \"ecs-tasks.amazonaws.com\",\n\t\t\t\t\t\t},\n\t\t\t\t\t\tAction: \"sts:AssumeRole\",\n\t\t\t\t\t},\n\t\t\t\t],\n\t\t\t}),\n\t\t});\n\n\t\tconst runnerRole = new IamRole(this, \"RunnerRole\", {\n\t\t\tassumeRolePolicy: Fn.jsonencode({\n\t\t\t\tVersion: \"2012-10-17\",\n\t\t\t\tStatement: [\n\t\t\t\t\t{\n\t\t\t\t\t\tEffect: \"Allow\",\n\t\t\t\t\t\tPrincipal: {\n\t\t\t\t\t\t\tService: \"ecs-tasks.amazonaws.com\",\n\t\t\t\t\t\t},\n\t\t\t\t\t\tAction: \"sts:AssumeRole\",\n\t\t\t\t\t},\n\t\t\t\t],\n\t\t\t}),\n\t\t});\n\n\t\tconst ecsTaskExecutionRole = new IamRole(this, \"TaskExecutionRole\", {\n\t\t\tassumeRolePolicy: Fn.jsonencode({\n\t\t\t\tVersion: \"2012-10-17\",\n\t\t\t\tStatement: [\n\t\t\t\t\t{\n\t\t\t\t\t\tEffect: \"Allow\",\n\t\t\t\t\t\tPrincipal: {\n\t\t\t\t\t\t\tService: \"ecs-tasks.amazonaws.com\",\n\t\t\t\t\t\t},\n\t\t\t\t\t\tAction: \"sts:AssumeRole\",\n\t\t\t\t\t},\n\t\t\t\t],\n\t\t\t}),\n\t\t});\n\n\t\tnew IamRolePolicyAttachment(this, \"TeskExecutionRoleAttachment\", {\n\t\t\tpolicyArn:\n\t\t\t\t\"arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy\",\n\t\t\trole: ecsTaskExecutionRole.name,\n\t\t});\n\n\t\tconst runnerLogGroup = new CloudwatchLogGroup(this, \"RunnerLogGroup\", {\n\t\t\tname: \"/ecs/GHA\",\n\t\t});\n\n\t\tconst autoscalerLogGroup = new CloudwatchLogGroup(\n\t\t\tthis,\n\t\t\t\"AutoscalerLogGroup\",\n\t\t\t{\n\t\t\t\tname: \"/ecs/Autoscaler\",\n\t\t\t},\n\t\t);\n\n\t\tconst autoscalerContainerDefinition: ContainerDefinition = {\n\t\t\tname: \"autoscaler\",\n\t\t\timage: autoscalerImage.stringValue,\n\t\t\tessential: true,\n\t\t\tenvironment: [\n\t\t\t\t{\n\t\t\t\t\tname: \"PAT\",\n\t\t\t\t\tvalue: pat.value,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"GITHUB_CONFIG_URL\",\n\t\t\t\t\tvalue: githubConfigUrl.value,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ECS_CLUSTER\",\n\t\t\t\t\tvalue: cluster.arn,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ECS_SUBNETS\",\n\t\t\t\t\tvalue: Fn.join(\",\", subnets.ids),\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ECS_SECURITY_GROUPS\",\n\t\t\t\t\tvalue: Fn.join(\",\", securityGroups.ids),\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"SCALE_SET_NAME\",\n\t\t\t\t\tvalue: \"ecs-runner-set\",\n\t\t\t\t},\n\t\t\t],\n\t\t\tlogConfiguration: {\n\t\t\t\tlogDriver: \"awslogs\",\n\t\t\t\toptions: {\n\t\t\t\t\t\"awslogs-group\": autoscalerLogGroup.name,\n\t\t\t\t\t\"awslogs-region\": region.name,\n\t\t\t\t\t\"awslogs-stream-prefix\": \"ecs\",\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\n\t\tconst runnerVolume: EcsTaskDefinitionVolume[] = [];\n\n\t\tconst runnerContainerDefinition: ContainerDefinition = {\n\t\t\tname: \"runner\",\n\t\t\timage: \"ghcr.io/actions/actions-runner:2.323.0\",\n\t\t\tessential: true,\n\t\t\tentryPoint: [\"/home/runner/run.sh\"],\n\t\t\tenvironment: [\n\t\t\t\t{\n\t\t\t\t\tname: \"ECS_CLUSTER_NAME\",\n\t\t\t\t\tvalue: cluster.name,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ACTIONS_RUNNER_POD_NAME\",\n\t\t\t\t\tvalue: \"gha-pod\",\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ECS_SUBNETS\",\n\t\t\t\t\tvalue: Fn.join(\",\", subnets.ids),\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ECS_SECURITY_GROUPS\",\n\t\t\t\t\tvalue: Fn.join(\",\", securityGroups.ids),\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ECS_TASK_ROLE\",\n\t\t\t\t\tvalue: runnerRole.arn,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ECS_EXECUTION_ROLE\",\n\t\t\t\t\tvalue: ecsTaskExecutionRole.arn,\n\t\t\t\t},\n\t\t\t],\n\t\t\tmountPoints: [],\n\t\t\tlogConfiguration: {\n\t\t\t\tlogDriver: \"awslogs\",\n\t\t\t\toptions: {\n\t\t\t\t\t\"awslogs-group\": runnerLogGroup.name,\n\t\t\t\t\t\"awslogs-region\": region.name,\n\t\t\t\t\t\"awslogs-stream-prefix\": \"ecs\",\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\n\t\tif (props.containerSupport) {\n\t\t\t// EFS volume to allow sharing data between tasks\n\t\t\tconst efs = new EfsFileSystem(this, \"efs\", {\n\t\t\t\tthroughputMode: \"elastic\",\n\t\t\t\ttags: {\n\t\t\t\t\tName: \"work\",\n\t\t\t\t},\n\t\t\t});\n\n\t\t\tconst externalsEfs = new EfsFileSystem(this, \"externalsEfs\", {\n\t\t\t\tthroughputMode: \"elastic\",\n\t\t\t\ttags: {\n\t\t\t\t\tName: \"externals\",\n\t\t\t\t},\n\t\t\t});\n\n\t\t\t// Each subnet in VPC are on different AZs, so creating mountpoint to each\n\t\t\tconst iterator = TerraformIterator.fromList(subnets.ids);\n\n\t\t\tnew EfsMountTarget(this, \"EfsMountTarget\", {\n\t\t\t\tforEach: iterator,\n\t\t\t\tfileSystemId: efs.id,\n\t\t\t\tsubnetId: iterator.value,\n\t\t\t});\n\n\t\t\tnew EfsMountTarget(this, \"ExternalsEfsMountTarget\", {\n\t\t\t\tforEach: iterator,\n\t\t\t\tfileSystemId: externalsEfs.id,\n\t\t\t\tsubnetId: iterator.value,\n\t\t\t});\n\n\t\t\tconst runnerVolumeName = \"work\";\n\t\t\tconst externalsVolumeName = \"externals\";\n\n\t\t\trunnerVolume.push(\n\t\t\t\t{\n\t\t\t\t\tname: runnerVolumeName,\n\t\t\t\t\tefsVolumeConfiguration: {\n\t\t\t\t\t\tfileSystemId: efs.id,\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t\t// This doesn't work with same volume, as volume is initially empty so it can't map to it's \"externals\" directory\n\t\t\t\t{\n\t\t\t\t\tname: externalsVolumeName,\n\t\t\t\t\tefsVolumeConfiguration: {\n\t\t\t\t\t\tfileSystemId: externalsEfs.id,\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t);\n\n\t\t\trunnerContainerDefinition.mountPoints?.push(\n\t\t\t\t{\n\t\t\t\t\tsourceVolume: runnerVolumeName,\n\t\t\t\t\tcontainerPath: \"/tmp/_work\",\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tsourceVolume: externalsVolumeName,\n\t\t\t\t\tcontainerPath: \"/tmp/externals\",\n\t\t\t\t},\n\t\t\t);\n\n\t\t\trunnerContainerDefinition.environment?.push(\n\t\t\t\t{\n\t\t\t\t\tname: \"EFS_ID\",\n\t\t\t\t\tvalue: efs.id,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"EXTERNALS_EFS_ID\",\n\t\t\t\t\tvalue: externalsEfs.id,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: \"ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER\",\n\t\t\t\t\tvalue: \"false\",\n\t\t\t\t},\n\t\t\t);\n\n\t\t\trunnerContainerDefinition.command = [\n\t\t\t\t\"/bin/sh\",\n\t\t\t\t\"-c\",\n\t\t\t\t\"export EXECID=$(cat /proc/sys/kernel/random/uuid) && sudo mkdir -p /tmp/_work/$EXECID && sudo chown runner:runner /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && sudo chown runner:runner /tmp/externals && /home/runner/run.sh ; sudo rm -r /tmp/_work/$EXECID\",\n\t\t\t];\n\t\t\trunnerContainerDefinition.image = \"ghcr.io/hi-fi/actions-runner:ecs\";\n\t\t}\n\n\t\t// TODO: Images through caching: https://docs.aws.amazon.com/AmazonECR/latest/userguide/pull-through-cache.html (requires authentication)\n\t\t// TODO: Pass Execution role to job task: https://www.ernestchiang.com/en/posts/2021/using-amazon-ecs-exec/#1-grant-permissions-ecs-task-iam-role\n\t\t// TODO: Pass Task role to job task\n\t\tconst runnerTaskDefinition = new EcsTaskDefinition(\n\t\t\tthis,\n\t\t\t\"RunnerTaskDefinition\",\n\t\t\t{\n\t\t\t\tfamily: \"GHA\",\n\t\t\t\ttaskRoleArn: runnerRole.arn,\n\t\t\t\texecutionRoleArn: ecsTaskExecutionRole.arn,\n\t\t\t\tcontainerDefinitions: Fn.jsonencode([runnerContainerDefinition]),\n\t\t\t\tcpu: \"1024\",\n\t\t\t\tmemory: \"2048\",\n\t\t\t\trequiresCompatibilities: [\"FARGATE\"],\n\t\t\t\truntimePlatform: {\n\t\t\t\t\tcpuArchitecture: \"X86_64\",\n\t\t\t\t\toperatingSystemFamily: \"LINUX\",\n\t\t\t\t},\n\t\t\t\tnetworkMode: \"awsvpc\",\n\t\t\t\tvolume: runnerVolume,\n\t\t\t},\n\t\t);\n\n\t\tautoscalerContainerDefinition.environment?.push({\n\t\t\tname: \"TASK_DEFINITION_ARN\",\n\t\t\tvalue: runnerTaskDefinition.arn,\n\t\t});\n\n\t\tconst autoscalerTaskDefinition = new EcsTaskDefinition(\n\t\t\tthis,\n\t\t\t\"AutoscalerTaskDefinition\",\n\t\t\t{\n\t\t\t\tfamily: \"Autoscaler\",\n\t\t\t\ttaskRoleArn: autoscalerRole.arn,\n\t\t\t\texecutionRoleArn: ecsTaskExecutionRole.arn,\n\t\t\t\tcontainerDefinitions: Fn.jsonencode([autoscalerContainerDefinition]),\n\t\t\t\tcpu: \"256\",\n\t\t\t\tmemory: \"512\",\n\t\t\t\trequiresCompatibilities: [\"FARGATE\"],\n\t\t\t\truntimePlatform: {\n\t\t\t\t\tcpuArchitecture: \"X86_64\",\n\t\t\t\t\toperatingSystemFamily: \"LINUX\",\n\t\t\t\t},\n\t\t\t\tnetworkMode: \"awsvpc\",\n\t\t\t},\n\t\t);\n\n\t\tconst runnerPolicyDefinition = {\n\t\t\tVersion: \"2012-10-17\",\n\t\t\tStatement: [\n\t\t\t\t{\n\t\t\t\t\tSid: \"StartandMonitorTask\",\n\t\t\t\t\tEffect: \"Allow\",\n\t\t\t\t\tAction: [\n\t\t\t\t\t\t\"ecs:RunTask\",\n\t\t\t\t\t\t\"ecs:TagResource\",\n\t\t\t\t\t\t\"ecs:ListTaskDefinitions\",\n\t\t\t\t\t\t\"ecs:ListTasks\",\n\t\t\t\t\t\t\"ecs:StopTask\",\n\t\t\t\t\t\t\"ecs:RegisterTaskDefinition\",\n\t\t\t\t\t\t\"ecs:DescribeTaskDefinition\",\n\t\t\t\t\t\t\"ecs:DeregisterTaskDefinition\",\n\t\t\t\t\t\t\"ecs:DeleteTaskDefinitions\",\n\t\t\t\t\t\t\"ecs:ExecuteCommand\",\n\t\t\t\t\t\t// Needed for waiting\n\t\t\t\t\t\t\"ecs:DescribeTasks\",\n\t\t\t\t\t\t\"logs:GetLogEvents\",\n\t\t\t\t\t\t\"iam:PassRole\",\n\t\t\t\t\t\t\"logs:StartLiveTail\",\n\t\t\t\t\t\t\"logs:CreateLogStream\",\n\t\t\t\t\t],\n\t\t\t\t\tResource: [\n\t\t\t\t\t\t`arn:aws:ecs:${region.name}:${identity.accountId}:task-definition/gha-pod-workflow:*`,\n\t\t\t\t\t\tcluster.arn,\n\t\t\t\t\t\t// Triggerer has to be allowed to pass both task and task execution role\n\t\t\t\t\t\tecsTaskExecutionRole.arn,\n\t\t\t\t\t\trunnerRole.arn,\n\t\t\t\t\t\t`arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,\n\t\t\t\t\t\t//TODO: reorder rights so that listing is only one with star\n\t\t\t\t\t\t\"*\",\n\t\t\t\t\t],\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tSid: \"GetVpcInfo\",\n\t\t\t\t\tEffect: \"Allow\",\n\t\t\t\t\tAction: [\"ec2:DescribeSubnets\", \"ec2:DescribeSecurityGroups\"],\n\t\t\t\t\tResource: \"*\",\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tSid: \"ExecCommands\",\n\t\t\t\t\tEffect: \"Allow\",\n\t\t\t\t\tAction: [\n\t\t\t\t\t\t\"ssmmessages:CreateControlChannel\",\n\t\t\t\t\t\t\"ssmmessages:CreateDataChannel\",\n\t\t\t\t\t\t\"ssmmessages:OpenControlChannel\",\n\t\t\t\t\t\t\"ssmmessages:OpenDataChannel\",\n\t\t\t\t\t],\n\t\t\t\t\tResource: \"*\",\n\t\t\t\t},\n\t\t\t],\n\t\t};\n\n\t\tconst runnerPolicy = new IamPolicy(this, \"RunnerPolicy\", {\n\t\t\tpolicy: Fn.jsonencode(runnerPolicyDefinition),\n\t\t});\n\n\t\tnew IamRolePolicyAttachment(this, \"RunnerPolicyAttachment\", {\n\t\t\tpolicyArn: runnerPolicy.arn,\n\t\t\trole: runnerRole.name,\n\t\t});\n\n\t\tconst autoscalerPolicy = new IamPolicy(this, \"AutoscalerPolicy\", {\n\t\t\tpolicy: Fn.jsonencode({\n\t\t\t\tVersion: \"2012-10-17\",\n\t\t\t\tStatement: [\n\t\t\t\t\t{\n\t\t\t\t\t\tSid: \"StartandMonitorTask\",\n\t\t\t\t\t\tEffect: \"Allow\",\n\t\t\t\t\t\tAction: [\n\t\t\t\t\t\t\t\"ecs:RunTask\",\n\t\t\t\t\t\t\t// Needed for waiting\n\t\t\t\t\t\t\t\"ecs:DescribeTasks\",\n\t\t\t\t\t\t\t\"logs:GetLogEvents\",\n\t\t\t\t\t\t\t\"iam:PassRole\",\n\t\t\t\t\t\t],\n\t\t\t\t\t\tResource: [\n\t\t\t\t\t\t\t`${runnerTaskDefinition.arnWithoutRevision}:*`,\n\t\t\t\t\t\t\t// Triggerer has to be allowed to pass both task and task execution role\n\t\t\t\t\t\t\tecsTaskExecutionRole.arn,\n\t\t\t\t\t\t\trunnerRole.arn,\n\t\t\t\t\t\t\t`arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,\n\t\t\t\t\t\t\t`${runnerLogGroup.arn}:log-stream:*`,\n\t\t\t\t\t\t],\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tSid: \"GetVpcInfo\",\n\t\t\t\t\t\tEffect: \"Allow\",\n\t\t\t\t\t\tAction: [\"ec2:DescribeSubnets\", \"ec2:DescribeSecurityGroups\"],\n\t\t\t\t\t\tResource: \"*\",\n\t\t\t\t\t},\n\t\t\t\t],\n\t\t\t}),\n\t\t});\n\t\tnew IamRolePolicyAttachment(this, \"AutoscalerPolicyAttachment\", {\n\t\t\tpolicyArn: autoscalerPolicy.arn,\n\t\t\trole: autoscalerRole.name,\n\t\t});\n\n\t\tnew EcsService(this, \"AutoscalerService\", {\n\t\t\tcluster: cluster.arn,\n\t\t\tname: \"autoscaler-service\",\n\t\t\tdesiredCount: 1,\n\t\t\tlaunchType: \"FARGATE\",\n\t\t\ttaskDefinition: autoscalerTaskDefinition.arnWithoutRevision,\n\t\t\tnetworkConfiguration: {\n\t\t\t\tassignPublicIp: true,\n\t\t\t\tsubnets: subnets.ids,\n\t\t\t\tsecurityGroups: securityGroups.ids,\n\t\t\t},\n\t\t\tlifecycle: {\n\t\t\t\tignoreChanges: [\"desired_count\"],\n\t\t\t},\n\t\t});\n\t}\n}\n"]}
|