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/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, 'aws', {});
27
- const identity = new data_aws_caller_identity_1.DataAwsCallerIdentity(this, 'Identity', {});
28
- const region = new data_aws_region_1.DataAwsRegion(this, 'Region', {});
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, 'Cluster', {
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, 'Subnets', {
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, 'SecurityGroups', {
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, 'AutoscalerRole', {
39
+ const autoscalerRole = new iam_role_1.IamRole(this, "AutoscalerRole", {
40
40
  assumeRolePolicy: cdktf_1.Fn.jsonencode({
41
- Version: '2012-10-17',
41
+ Version: "2012-10-17",
42
42
  Statement: [
43
43
  {
44
- Effect: 'Allow',
44
+ Effect: "Allow",
45
45
  Principal: {
46
- Service: 'ecs-tasks.amazonaws.com',
46
+ Service: "ecs-tasks.amazonaws.com",
47
47
  },
48
- Action: 'sts:AssumeRole',
48
+ Action: "sts:AssumeRole",
49
49
  },
50
50
  ],
51
51
  }),
52
52
  });
53
- const runnerRole = new iam_role_1.IamRole(this, 'RunnerRole', {
53
+ const runnerRole = new iam_role_1.IamRole(this, "RunnerRole", {
54
54
  assumeRolePolicy: cdktf_1.Fn.jsonencode({
55
- Version: '2012-10-17',
55
+ Version: "2012-10-17",
56
56
  Statement: [
57
57
  {
58
- Effect: 'Allow',
58
+ Effect: "Allow",
59
59
  Principal: {
60
- Service: 'ecs-tasks.amazonaws.com',
60
+ Service: "ecs-tasks.amazonaws.com",
61
61
  },
62
- Action: 'sts:AssumeRole',
62
+ Action: "sts:AssumeRole",
63
63
  },
64
64
  ],
65
65
  }),
66
66
  });
67
- const ecsTaskExecutionRole = new iam_role_1.IamRole(this, 'TaskExecutionRole', {
67
+ const ecsTaskExecutionRole = new iam_role_1.IamRole(this, "TaskExecutionRole", {
68
68
  assumeRolePolicy: cdktf_1.Fn.jsonencode({
69
- Version: '2012-10-17',
69
+ Version: "2012-10-17",
70
70
  Statement: [
71
71
  {
72
- Effect: 'Allow',
72
+ Effect: "Allow",
73
73
  Principal: {
74
- Service: 'ecs-tasks.amazonaws.com',
74
+ Service: "ecs-tasks.amazonaws.com",
75
75
  },
76
- Action: 'sts:AssumeRole',
76
+ Action: "sts:AssumeRole",
77
77
  },
78
78
  ],
79
79
  }),
80
80
  });
81
- new iam_role_policy_attachment_1.IamRolePolicyAttachment(this, 'TeskExecutionRoleAttachment', {
82
- policyArn: 'arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy',
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, 'RunnerLogGroup', {
86
- name: '/ecs/GHA',
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, 'AutoscalerLogGroup', {
89
- name: '/ecs/Autoscaler',
88
+ const autoscalerLogGroup = new cloudwatch_log_group_1.CloudwatchLogGroup(this, "AutoscalerLogGroup", {
89
+ name: "/ecs/Autoscaler",
90
90
  });
91
91
  const autoscalerContainerDefinition = {
92
- name: 'autoscaler',
92
+ name: "autoscaler",
93
93
  image: autoscalerImage.stringValue,
94
94
  essential: true,
95
95
  environment: [
96
96
  {
97
- name: 'PAT',
97
+ name: "PAT",
98
98
  value: pat.value,
99
99
  },
100
100
  {
101
- name: 'GITHUB_CONFIG_URL',
101
+ name: "GITHUB_CONFIG_URL",
102
102
  value: githubConfigUrl.value,
103
103
  },
104
104
  {
105
- name: 'ECS_CLUSTER',
105
+ name: "ECS_CLUSTER",
106
106
  value: cluster.arn,
107
107
  },
108
108
  {
109
- name: 'ECS_SUBNETS',
110
- value: cdktf_1.Fn.join(',', subnets.ids),
109
+ name: "ECS_SUBNETS",
110
+ value: cdktf_1.Fn.join(",", subnets.ids),
111
111
  },
112
112
  {
113
- name: 'ECS_SECURITY_GROUPS',
114
- value: cdktf_1.Fn.join(',', securityGroups.ids),
113
+ name: "ECS_SECURITY_GROUPS",
114
+ value: cdktf_1.Fn.join(",", securityGroups.ids),
115
115
  },
116
116
  {
117
- name: 'SCALE_SET_NAME',
118
- value: 'ecs-runner-set',
117
+ name: "SCALE_SET_NAME",
118
+ value: "ecs-runner-set",
119
119
  },
120
120
  ],
121
121
  logConfiguration: {
122
- logDriver: 'awslogs',
122
+ logDriver: "awslogs",
123
123
  options: {
124
- 'awslogs-group': autoscalerLogGroup.name,
125
- 'awslogs-region': region.name,
126
- 'awslogs-stream-prefix': 'ecs',
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: 'runner',
133
- image: 'ghcr.io/actions/actions-runner:2.323.0',
132
+ name: "runner",
133
+ image: "ghcr.io/actions/actions-runner:2.323.0",
134
134
  essential: true,
135
- entryPoint: ['/home/runner/run.sh'],
135
+ entryPoint: ["/home/runner/run.sh"],
136
136
  environment: [
137
137
  {
138
- name: 'ECS_CLUSTER_NAME',
138
+ name: "ECS_CLUSTER_NAME",
139
139
  value: cluster.name,
140
140
  },
141
141
  {
142
- name: 'ACTIONS_RUNNER_POD_NAME',
143
- value: 'gha-pod',
142
+ name: "ACTIONS_RUNNER_POD_NAME",
143
+ value: "gha-pod",
144
144
  },
145
145
  {
146
- name: 'ECS_SUBNETS',
147
- value: cdktf_1.Fn.join(',', subnets.ids),
146
+ name: "ECS_SUBNETS",
147
+ value: cdktf_1.Fn.join(",", subnets.ids),
148
148
  },
149
149
  {
150
- name: 'ECS_SECURITY_GROUPS',
151
- value: cdktf_1.Fn.join(',', securityGroups.ids),
150
+ name: "ECS_SECURITY_GROUPS",
151
+ value: cdktf_1.Fn.join(",", securityGroups.ids),
152
152
  },
153
153
  {
154
- name: 'ECS_TASK_ROLE',
154
+ name: "ECS_TASK_ROLE",
155
155
  value: runnerRole.arn,
156
156
  },
157
157
  {
158
- name: 'ECS_EXECUTION_ROLE',
158
+ name: "ECS_EXECUTION_ROLE",
159
159
  value: ecsTaskExecutionRole.arn,
160
160
  },
161
161
  ],
162
162
  mountPoints: [],
163
163
  logConfiguration: {
164
- logDriver: 'awslogs',
164
+ logDriver: "awslogs",
165
165
  options: {
166
- 'awslogs-group': runnerLogGroup.name,
167
- 'awslogs-region': region.name,
168
- 'awslogs-stream-prefix': 'ecs',
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, 'efs', {
175
- throughputMode: 'elastic',
174
+ const efs = new efs_file_system_1.EfsFileSystem(this, "efs", {
175
+ throughputMode: "elastic",
176
176
  tags: {
177
- Name: 'work',
177
+ Name: "work",
178
178
  },
179
179
  });
180
- const externalsEfs = new efs_file_system_1.EfsFileSystem(this, 'externalsEfs', {
181
- throughputMode: 'elastic',
180
+ const externalsEfs = new efs_file_system_1.EfsFileSystem(this, "externalsEfs", {
181
+ throughputMode: "elastic",
182
182
  tags: {
183
- Name: 'externals',
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, 'EfsMountTarget', {
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, 'ExternalsEfsMountTarget', {
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 = 'work';
199
- const externalsVolumeName = 'externals';
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: '/tmp/_work',
215
+ containerPath: "/tmp/_work",
216
216
  }, {
217
217
  sourceVolume: externalsVolumeName,
218
- containerPath: '/tmp/externals',
218
+ containerPath: "/tmp/externals",
219
219
  });
220
220
  runnerContainerDefinition.environment?.push({
221
- name: 'EFS_ID',
221
+ name: "EFS_ID",
222
222
  value: efs.id,
223
223
  }, {
224
- name: 'EXTERNALS_EFS_ID',
224
+ name: "EXTERNALS_EFS_ID",
225
225
  value: externalsEfs.id,
226
226
  }, {
227
- name: 'ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER',
228
- value: 'false',
227
+ name: "ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER",
228
+ value: "false",
229
229
  });
230
230
  runnerContainerDefinition.command = [
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',
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 = 'ghcr.io/hi-fi/actions-runner:ecs';
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, 'RunnerTaskDefinition', {
241
- family: 'GHA',
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: '1024',
246
- memory: '2048',
247
- requiresCompatibilities: ['FARGATE'],
245
+ cpu: "1024",
246
+ memory: "2048",
247
+ requiresCompatibilities: ["FARGATE"],
248
248
  runtimePlatform: {
249
- cpuArchitecture: 'X86_64',
250
- operatingSystemFamily: 'LINUX',
249
+ cpuArchitecture: "X86_64",
250
+ operatingSystemFamily: "LINUX",
251
251
  },
252
- networkMode: 'awsvpc',
252
+ networkMode: "awsvpc",
253
253
  volume: runnerVolume,
254
254
  });
255
255
  autoscalerContainerDefinition.environment?.push({
256
- name: 'TASK_DEFINITION_ARN',
256
+ name: "TASK_DEFINITION_ARN",
257
257
  value: runnerTaskDefinition.arn,
258
258
  });
259
- const autoscalerTaskDefinition = new ecs_task_definition_1.EcsTaskDefinition(this, 'AutoscalerTaskDefinition', {
260
- family: 'Autoscaler',
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: '256',
265
- memory: '512',
266
- requiresCompatibilities: ['FARGATE'],
264
+ cpu: "256",
265
+ memory: "512",
266
+ requiresCompatibilities: ["FARGATE"],
267
267
  runtimePlatform: {
268
- cpuArchitecture: 'X86_64',
269
- operatingSystemFamily: 'LINUX',
268
+ cpuArchitecture: "X86_64",
269
+ operatingSystemFamily: "LINUX",
270
270
  },
271
- networkMode: 'awsvpc',
271
+ networkMode: "awsvpc",
272
272
  });
273
273
  const runnerPolicyDefinition = {
274
- Version: '2012-10-17',
274
+ Version: "2012-10-17",
275
275
  Statement: [
276
276
  {
277
- Sid: 'StartandMonitorTask',
278
- Effect: 'Allow',
277
+ Sid: "StartandMonitorTask",
278
+ Effect: "Allow",
279
279
  Action: [
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',
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
- 'ecs:DescribeTasks',
292
- 'logs:GetLogEvents',
293
- 'iam:PassRole',
294
- 'logs:StartLiveTail',
295
- 'logs:CreateLogStream',
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: 'GetVpcInfo',
310
- Effect: 'Allow',
311
- Action: ['ec2:DescribeSubnets', 'ec2:DescribeSecurityGroups'],
312
- Resource: '*',
309
+ Sid: "GetVpcInfo",
310
+ Effect: "Allow",
311
+ Action: ["ec2:DescribeSubnets", "ec2:DescribeSecurityGroups"],
312
+ Resource: "*",
313
313
  },
314
314
  {
315
- Sid: 'ExecCommands',
316
- Effect: 'Allow',
315
+ Sid: "ExecCommands",
316
+ Effect: "Allow",
317
317
  Action: [
318
- 'ssmmessages:CreateControlChannel',
319
- 'ssmmessages:CreateDataChannel',
320
- 'ssmmessages:OpenControlChannel',
321
- 'ssmmessages:OpenDataChannel',
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, 'RunnerPolicy', {
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, 'RunnerPolicyAttachment', {
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, 'AutoscalerPolicy', {
334
+ const autoscalerPolicy = new iam_policy_1.IamPolicy(this, "AutoscalerPolicy", {
335
335
  policy: cdktf_1.Fn.jsonencode({
336
- Version: '2012-10-17',
336
+ Version: "2012-10-17",
337
337
  Statement: [
338
338
  {
339
- Sid: 'StartandMonitorTask',
340
- Effect: 'Allow',
339
+ Sid: "StartandMonitorTask",
340
+ Effect: "Allow",
341
341
  Action: [
342
- 'ecs:RunTask',
342
+ "ecs:RunTask",
343
343
  // Needed for waiting
344
- 'ecs:DescribeTasks',
345
- 'logs:GetLogEvents',
346
- 'iam:PassRole',
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: 'GetVpcInfo',
359
- Effect: 'Allow',
360
- Action: ['ec2:DescribeSubnets', 'ec2:DescribeSecurityGroups'],
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, 'AutoscalerPolicyAttachment', {
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, 'AutoscalerService', {
370
+ new ecs_service_1.EcsService(this, "AutoscalerService", {
371
371
  cluster: cluster.arn,
372
- name: 'autoscaler-service',
372
+ name: "autoscaler-service",
373
373
  desiredCount: 1,
374
- launchType: 'FARGATE',
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: ['desired_count'],
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.7" };
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"]}