terraform-cdk-serverless-github-actions-runner-controller 0.0.0 → 0.0.2
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 +3647 -2
- package/API.md +212 -0
- package/lib/__tests__/index-test.js +16 -4
- package/lib/index.d.ts +2 -0
- package/lib/index.js +3 -1
- package/lib/lib/aws.d.ts +4 -0
- package/lib/lib/aws.js +395 -0
- package/lib/lib/azure.js +1 -1
- package/lib/lib/gcp.d.ts +4 -0
- package/lib/lib/gcp.js +251 -0
- package/lib/lib/variables.js +3 -1
- package/lib/tfModules.js +17 -1
- package/main.tf +26 -0
- package/modules/azure-container-apps/README.md +3 -3
- package/modules/azure-container-apps/cdk.tf.json +7 -7
- package/modules/elastic-container-service/README.md +66 -0
- package/modules/elastic-container-service/cdk.tf.json +314 -0
- package/modules/google-cloud-run/README.md +62 -0
- package/modules/google-cloud-run/cdk.tf.json +355 -0
- package/package.json +8 -1
- package/scripts/collect-variables.ts +188 -0
- package/variables.tf +27 -0
package/lib/lib/aws.js
ADDED
@@ -0,0 +1,395 @@
|
|
1
|
+
"use strict";
|
2
|
+
var _a;
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
4
|
+
exports.Aws = void 0;
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
6
|
+
const cloudwatch_log_group_1 = require("@cdktf/provider-aws/lib/cloudwatch-log-group");
|
7
|
+
const data_aws_caller_identity_1 = require("@cdktf/provider-aws/lib/data-aws-caller-identity");
|
8
|
+
const data_aws_region_1 = require("@cdktf/provider-aws/lib/data-aws-region");
|
9
|
+
const data_aws_security_groups_1 = require("@cdktf/provider-aws/lib/data-aws-security-groups");
|
10
|
+
const data_aws_subnets_1 = require("@cdktf/provider-aws/lib/data-aws-subnets");
|
11
|
+
const ecs_cluster_1 = require("@cdktf/provider-aws/lib/ecs-cluster");
|
12
|
+
const ecs_service_1 = require("@cdktf/provider-aws/lib/ecs-service");
|
13
|
+
const ecs_task_definition_1 = require("@cdktf/provider-aws/lib/ecs-task-definition");
|
14
|
+
const iam_policy_1 = require("@cdktf/provider-aws/lib/iam-policy");
|
15
|
+
const iam_role_1 = require("@cdktf/provider-aws/lib/iam-role");
|
16
|
+
const iam_role_policy_attachment_1 = require("@cdktf/provider-aws/lib/iam-role-policy-attachment");
|
17
|
+
const provider_1 = require("@cdktf/provider-aws/lib/provider");
|
18
|
+
const cdktf_1 = require("cdktf");
|
19
|
+
const constructs_1 = require("constructs");
|
20
|
+
const variables_1 = require("./variables");
|
21
|
+
const efs_file_system_1 = require("@cdktf/provider-aws/lib/efs-file-system");
|
22
|
+
const efs_mount_target_1 = require("@cdktf/provider-aws/lib/efs-mount-target");
|
23
|
+
class Aws extends constructs_1.Construct {
|
24
|
+
constructor(scope, id) {
|
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', {});
|
29
|
+
const { pat, githubConfigUrl } = (0, variables_1.commonVariables)(this);
|
30
|
+
const cluster = new ecs_cluster_1.EcsCluster(this, 'Cluster', {
|
31
|
+
name: 'gha-runner-cluster',
|
32
|
+
});
|
33
|
+
const runnerRole = new iam_role_1.IamRole(this, 'RunnerRole', {
|
34
|
+
assumeRolePolicy: cdktf_1.Fn.jsonencode({
|
35
|
+
'Version': '2012-10-17',
|
36
|
+
'Statement': [
|
37
|
+
{
|
38
|
+
'Effect': 'Allow',
|
39
|
+
'Principal': {
|
40
|
+
'Service': 'ecs-tasks.amazonaws.com'
|
41
|
+
},
|
42
|
+
'Action': 'sts:AssumeRole'
|
43
|
+
}
|
44
|
+
]
|
45
|
+
})
|
46
|
+
});
|
47
|
+
const autoscalerRole = new iam_role_1.IamRole(this, 'AutoscalerRole', {
|
48
|
+
assumeRolePolicy: cdktf_1.Fn.jsonencode({
|
49
|
+
'Version': '2012-10-17',
|
50
|
+
'Statement': [
|
51
|
+
{
|
52
|
+
'Effect': 'Allow',
|
53
|
+
'Principal': {
|
54
|
+
'Service': 'ecs-tasks.amazonaws.com'
|
55
|
+
},
|
56
|
+
'Action': 'sts:AssumeRole'
|
57
|
+
}
|
58
|
+
]
|
59
|
+
})
|
60
|
+
});
|
61
|
+
const ecsTaskExecutionRole = new iam_role_1.IamRole(this, 'TaskExecutionRole', {
|
62
|
+
assumeRolePolicy: cdktf_1.Fn.jsonencode({
|
63
|
+
'Version': '2012-10-17',
|
64
|
+
'Statement': [
|
65
|
+
{
|
66
|
+
'Effect': 'Allow',
|
67
|
+
'Principal': {
|
68
|
+
'Service': 'ecs-tasks.amazonaws.com'
|
69
|
+
},
|
70
|
+
'Action': 'sts:AssumeRole'
|
71
|
+
}
|
72
|
+
]
|
73
|
+
}),
|
74
|
+
managedPolicyArns: [
|
75
|
+
'arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy'
|
76
|
+
]
|
77
|
+
});
|
78
|
+
const runnerLogGroup = new cloudwatch_log_group_1.CloudwatchLogGroup(this, 'RunnerLogGroup', {
|
79
|
+
name: '/ecs/GHA',
|
80
|
+
});
|
81
|
+
const autoscalerLogGroup = new cloudwatch_log_group_1.CloudwatchLogGroup(this, 'AutoscalerLogGroup', {
|
82
|
+
name: '/ecs/Autoscaler',
|
83
|
+
});
|
84
|
+
const subnets = new data_aws_subnets_1.DataAwsSubnets(this, 'Subnets', {});
|
85
|
+
const securityGroups = new data_aws_security_groups_1.DataAwsSecurityGroups(this, 'SecurityGroups');
|
86
|
+
// EFS volume to allow sharing data between tasks
|
87
|
+
const efs = new efs_file_system_1.EfsFileSystem(this, 'efs', {
|
88
|
+
throughputMode: 'elastic',
|
89
|
+
tags: {
|
90
|
+
Name: 'work'
|
91
|
+
}
|
92
|
+
});
|
93
|
+
const externalsEfs = new efs_file_system_1.EfsFileSystem(this, 'externalsEfs', {
|
94
|
+
throughputMode: 'elastic',
|
95
|
+
tags: {
|
96
|
+
Name: 'externals'
|
97
|
+
}
|
98
|
+
});
|
99
|
+
// Each subnet in VPC are on different AZs, so creating mountpoint to each
|
100
|
+
const iterator = cdktf_1.TerraformIterator.fromList(subnets.ids);
|
101
|
+
new efs_mount_target_1.EfsMountTarget(this, 'EfsMountTarget', {
|
102
|
+
forEach: iterator,
|
103
|
+
fileSystemId: efs.id,
|
104
|
+
subnetId: iterator.value
|
105
|
+
});
|
106
|
+
new efs_mount_target_1.EfsMountTarget(this, 'ExternalsEfsMountTarget', {
|
107
|
+
forEach: iterator,
|
108
|
+
fileSystemId: externalsEfs.id,
|
109
|
+
subnetId: iterator.value
|
110
|
+
});
|
111
|
+
const runnerVolumeName = 'work';
|
112
|
+
const externalsVolumeName = 'externals';
|
113
|
+
const runnerContainerDefinitions = [
|
114
|
+
{
|
115
|
+
name: 'runner',
|
116
|
+
image: 'ghcr.io/hi-fi/actions-runner:ecs',
|
117
|
+
command: ['/bin/sh', '-c', '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'],
|
118
|
+
essential: true,
|
119
|
+
environment: [
|
120
|
+
{
|
121
|
+
name: 'EFS_ID',
|
122
|
+
value: efs.id
|
123
|
+
},
|
124
|
+
{
|
125
|
+
name: 'EXTERNALS_EFS_ID',
|
126
|
+
value: externalsEfs.id
|
127
|
+
},
|
128
|
+
{
|
129
|
+
name: 'ECS_CLUSTER_NAME',
|
130
|
+
value: cluster.name
|
131
|
+
},
|
132
|
+
{
|
133
|
+
name: 'ACTIONS_RUNNER_POD_NAME',
|
134
|
+
value: 'gha-pod'
|
135
|
+
},
|
136
|
+
{
|
137
|
+
name: 'ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER',
|
138
|
+
value: 'false'
|
139
|
+
},
|
140
|
+
{
|
141
|
+
name: 'ECS_SUBNETS',
|
142
|
+
value: cdktf_1.Fn.join(',', subnets.ids)
|
143
|
+
},
|
144
|
+
{
|
145
|
+
name: 'ECS_SECURITY_GROUPS',
|
146
|
+
value: cdktf_1.Fn.join(',', securityGroups.ids)
|
147
|
+
},
|
148
|
+
{
|
149
|
+
name: 'ECS_TASK_ROLE',
|
150
|
+
value: runnerRole.arn
|
151
|
+
},
|
152
|
+
{
|
153
|
+
name: 'ECS_EXECUTION_ROLE',
|
154
|
+
value: ecsTaskExecutionRole.arn
|
155
|
+
}
|
156
|
+
],
|
157
|
+
mountPoints: [
|
158
|
+
{
|
159
|
+
sourceVolume: runnerVolumeName,
|
160
|
+
containerPath: '/tmp/_work',
|
161
|
+
},
|
162
|
+
{
|
163
|
+
sourceVolume: externalsVolumeName,
|
164
|
+
containerPath: '/tmp/externals',
|
165
|
+
}
|
166
|
+
],
|
167
|
+
logConfiguration: {
|
168
|
+
logDriver: 'awslogs',
|
169
|
+
options: {
|
170
|
+
"awslogs-group": runnerLogGroup.name,
|
171
|
+
"awslogs-region": region.name,
|
172
|
+
"awslogs-stream-prefix": "ecs",
|
173
|
+
}
|
174
|
+
}
|
175
|
+
}
|
176
|
+
];
|
177
|
+
// TODO: Images through caching: https://docs.aws.amazon.com/AmazonECR/latest/userguide/pull-through-cache.html (requires authentication)
|
178
|
+
// 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
|
179
|
+
// TODO: Pass Task role to job task
|
180
|
+
const runnerTaskDefinition = new ecs_task_definition_1.EcsTaskDefinition(this, 'RunnerTaskDefinition', {
|
181
|
+
family: 'GHA',
|
182
|
+
taskRoleArn: runnerRole.arn,
|
183
|
+
executionRoleArn: ecsTaskExecutionRole.arn,
|
184
|
+
containerDefinitions: cdktf_1.Fn.jsonencode(runnerContainerDefinitions),
|
185
|
+
cpu: '1024',
|
186
|
+
memory: '2048',
|
187
|
+
requiresCompatibilities: [
|
188
|
+
'FARGATE'
|
189
|
+
],
|
190
|
+
runtimePlatform: {
|
191
|
+
cpuArchitecture: 'X86_64',
|
192
|
+
operatingSystemFamily: 'LINUX'
|
193
|
+
},
|
194
|
+
networkMode: 'awsvpc',
|
195
|
+
volume: [
|
196
|
+
{
|
197
|
+
name: runnerVolumeName,
|
198
|
+
efsVolumeConfiguration: {
|
199
|
+
fileSystemId: efs.id,
|
200
|
+
},
|
201
|
+
},
|
202
|
+
// This doesn't work with same volume, as volume is initially empty so it can't map to it's "externals" directory
|
203
|
+
{
|
204
|
+
name: externalsVolumeName,
|
205
|
+
efsVolumeConfiguration: {
|
206
|
+
fileSystemId: externalsEfs.id,
|
207
|
+
}
|
208
|
+
}
|
209
|
+
]
|
210
|
+
});
|
211
|
+
const autoscalerTaskDefinition = new ecs_task_definition_1.EcsTaskDefinition(this, 'AutoscalerTaskDefinition', {
|
212
|
+
family: 'Autoscaler',
|
213
|
+
taskRoleArn: autoscalerRole.arn,
|
214
|
+
executionRoleArn: ecsTaskExecutionRole.arn,
|
215
|
+
containerDefinitions: cdktf_1.Fn.jsonencode([
|
216
|
+
{
|
217
|
+
name: 'autoscaler',
|
218
|
+
image: 'ghcr.io/hi-fi/gha-runners-on-managed-env:test',
|
219
|
+
essential: true,
|
220
|
+
environment: [
|
221
|
+
{
|
222
|
+
name: 'PAT',
|
223
|
+
value: pat.value
|
224
|
+
},
|
225
|
+
{
|
226
|
+
name: 'GITHUB_CONFIG_URL',
|
227
|
+
value: githubConfigUrl.value
|
228
|
+
},
|
229
|
+
{
|
230
|
+
name: 'TASK_DEFINITION_ARN',
|
231
|
+
value: runnerTaskDefinition.arn
|
232
|
+
},
|
233
|
+
{
|
234
|
+
name: 'ECS_CLUSTER',
|
235
|
+
value: cluster.arn
|
236
|
+
},
|
237
|
+
{
|
238
|
+
name: 'ECS_SUBNETS',
|
239
|
+
value: cdktf_1.Fn.join(',', subnets.ids)
|
240
|
+
},
|
241
|
+
{
|
242
|
+
name: 'ECS_SECURITY_GROUPS',
|
243
|
+
value: cdktf_1.Fn.join(',', securityGroups.ids)
|
244
|
+
},
|
245
|
+
{
|
246
|
+
name: 'SCALE_SET_NAME',
|
247
|
+
value: 'ecs-runner-set'
|
248
|
+
},
|
249
|
+
],
|
250
|
+
logConfiguration: {
|
251
|
+
logDriver: 'awslogs',
|
252
|
+
options: {
|
253
|
+
"awslogs-group": autoscalerLogGroup.name,
|
254
|
+
"awslogs-region": region.name,
|
255
|
+
"awslogs-stream-prefix": "ecs",
|
256
|
+
}
|
257
|
+
}
|
258
|
+
}
|
259
|
+
]),
|
260
|
+
cpu: '256',
|
261
|
+
memory: '512',
|
262
|
+
requiresCompatibilities: [
|
263
|
+
'FARGATE'
|
264
|
+
],
|
265
|
+
runtimePlatform: {
|
266
|
+
cpuArchitecture: 'X86_64',
|
267
|
+
operatingSystemFamily: 'LINUX'
|
268
|
+
},
|
269
|
+
networkMode: 'awsvpc',
|
270
|
+
});
|
271
|
+
const runnerPolicy = new iam_policy_1.IamPolicy(this, 'RunnerPolicy', {
|
272
|
+
policy: cdktf_1.Fn.jsonencode({
|
273
|
+
'Version': '2012-10-17',
|
274
|
+
'Statement': [
|
275
|
+
{
|
276
|
+
'Sid': 'StartandMonitorTask',
|
277
|
+
'Effect': 'Allow',
|
278
|
+
'Action': [
|
279
|
+
'ecs:RunTask',
|
280
|
+
'ecs:TagResource',
|
281
|
+
'ecs:ListTaskDefinitions',
|
282
|
+
'ecs:ListTasks',
|
283
|
+
'ecs:StopTask',
|
284
|
+
'ecs:RegisterTaskDefinition',
|
285
|
+
'ecs:DescribeTaskDefinition',
|
286
|
+
'ecs:DeregisterTaskDefinition',
|
287
|
+
'ecs:DeleteTaskDefinitions',
|
288
|
+
'ecs:ExecuteCommand',
|
289
|
+
// Needed for waiting
|
290
|
+
'ecs:DescribeTasks',
|
291
|
+
'logs:GetLogEvents',
|
292
|
+
'iam:PassRole',
|
293
|
+
'logs:StartLiveTail',
|
294
|
+
'logs:CreateLogStream',
|
295
|
+
],
|
296
|
+
'Resource': [
|
297
|
+
`arn:aws:ecs:${region.name}:${identity.accountId}:task-definition/gha-pod-workflow:*`,
|
298
|
+
cluster.arn,
|
299
|
+
// Triggerer has to be allowed to pass both task and task execution role
|
300
|
+
ecsTaskExecutionRole.arn,
|
301
|
+
runnerRole.arn,
|
302
|
+
`arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,
|
303
|
+
//TODO: reorder rights so that listing is only one with star
|
304
|
+
'*'
|
305
|
+
]
|
306
|
+
},
|
307
|
+
{
|
308
|
+
'Sid': 'GetVpcInfo',
|
309
|
+
'Effect': 'Allow',
|
310
|
+
'Action': [
|
311
|
+
'ec2:DescribeSubnets',
|
312
|
+
'ec2:DescribeSecurityGroups'
|
313
|
+
],
|
314
|
+
'Resource': '*'
|
315
|
+
},
|
316
|
+
{
|
317
|
+
'Sid': 'ExecCommands',
|
318
|
+
'Effect': 'Allow',
|
319
|
+
'Action': [
|
320
|
+
'ssmmessages:CreateControlChannel',
|
321
|
+
'ssmmessages:CreateDataChannel',
|
322
|
+
'ssmmessages:OpenControlChannel',
|
323
|
+
'ssmmessages:OpenDataChannel'
|
324
|
+
],
|
325
|
+
'Resource': '*'
|
326
|
+
}
|
327
|
+
]
|
328
|
+
})
|
329
|
+
});
|
330
|
+
new iam_role_policy_attachment_1.IamRolePolicyAttachment(this, 'RunnerPolicyAttachment', {
|
331
|
+
policyArn: runnerPolicy.arn,
|
332
|
+
role: runnerRole.name
|
333
|
+
});
|
334
|
+
const autoscalerPolicy = new iam_policy_1.IamPolicy(this, 'AutoscalerPolicy', {
|
335
|
+
policy: cdktf_1.Fn.jsonencode({
|
336
|
+
'Version': '2012-10-17',
|
337
|
+
'Statement': [
|
338
|
+
{
|
339
|
+
'Sid': 'StartandMonitorTask',
|
340
|
+
'Effect': 'Allow',
|
341
|
+
'Action': [
|
342
|
+
'ecs:RunTask',
|
343
|
+
// Needed for waiting
|
344
|
+
'ecs:DescribeTasks',
|
345
|
+
'logs:GetLogEvents',
|
346
|
+
'iam:PassRole',
|
347
|
+
],
|
348
|
+
'Resource': [
|
349
|
+
`${runnerTaskDefinition.arnWithoutRevision}:*`,
|
350
|
+
// Triggerer has to be allowed to pass both task and task execution role
|
351
|
+
ecsTaskExecutionRole.arn,
|
352
|
+
runnerRole.arn,
|
353
|
+
`arn:aws:ecs:${region.name}:${identity.accountId}:task/${cluster.name}/*`,
|
354
|
+
`${runnerLogGroup.arn}:log-stream:*`,
|
355
|
+
]
|
356
|
+
},
|
357
|
+
{
|
358
|
+
'Sid': 'GetVpcInfo',
|
359
|
+
'Effect': 'Allow',
|
360
|
+
'Action': [
|
361
|
+
'ec2:DescribeSubnets',
|
362
|
+
'ec2:DescribeSecurityGroups'
|
363
|
+
],
|
364
|
+
'Resource': '*'
|
365
|
+
}
|
366
|
+
]
|
367
|
+
})
|
368
|
+
});
|
369
|
+
new iam_role_policy_attachment_1.IamRolePolicyAttachment(this, 'AutoscalerPolicyAttachment', {
|
370
|
+
policyArn: autoscalerPolicy.arn,
|
371
|
+
role: autoscalerRole.name
|
372
|
+
});
|
373
|
+
new ecs_service_1.EcsService(this, 'AutoscalerService', {
|
374
|
+
cluster: cluster.arn,
|
375
|
+
name: 'autoscaler-service',
|
376
|
+
desiredCount: 1,
|
377
|
+
launchType: 'FARGATE',
|
378
|
+
taskDefinition: autoscalerTaskDefinition.arnWithoutRevision,
|
379
|
+
networkConfiguration: {
|
380
|
+
assignPublicIp: true,
|
381
|
+
subnets: subnets.ids,
|
382
|
+
securityGroups: securityGroups.ids
|
383
|
+
},
|
384
|
+
lifecycle: {
|
385
|
+
ignoreChanges: [
|
386
|
+
'desired_count'
|
387
|
+
]
|
388
|
+
}
|
389
|
+
});
|
390
|
+
}
|
391
|
+
}
|
392
|
+
exports.Aws = Aws;
|
393
|
+
_a = JSII_RTTI_SYMBOL_1;
|
394
|
+
Aws[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Aws", version: "0.0.2" };
|
395
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws.js","sourceRoot":"","sources":["../../src/lib/aws.ts"],"names":[],"mappings":"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","sourcesContent":["import { 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 { DataAwsSecurityGroups } from '@cdktf/provider-aws/lib/data-aws-security-groups';\nimport { DataAwsSubnets } 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 { EcsTaskDefinition } from '@cdktf/provider-aws/lib/ecs-task-definition';\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, TerraformIterator } from 'cdktf';\nimport { Construct } from 'constructs';\nimport { commonVariables } from './variables';\nimport { EfsFileSystem } from '@cdktf/provider-aws/lib/efs-file-system';\nimport { type ContainerDefinition } from '@aws-sdk/client-ecs'\nimport { EfsMountTarget } from '@cdktf/provider-aws/lib/efs-mount-target';\n\nexport class Aws extends Construct {\n    constructor(scope: Construct, id: string) {\n        super(scope, id);\n\n        new AwsProvider(this, 'aws', {\n\n        });\n\n        const identity = new DataAwsCallerIdentity(this, 'Identity', {});\n\n        const region = new DataAwsRegion(this, 'Region', {})\n\n        const { pat, githubConfigUrl } = commonVariables(this);\n\n        const cluster = new EcsCluster(this, 'Cluster', {\n            name: 'gha-runner-cluster',\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 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 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            managedPolicyArns: [\n                'arn:aws:iam::aws:policy/service-role/AmazonECSTaskExecutionRolePolicy'\n            ]\n        })\n\n        const runnerLogGroup = new CloudwatchLogGroup(this, 'RunnerLogGroup', {\n            name: '/ecs/GHA',\n        });\n\n        const autoscalerLogGroup = new CloudwatchLogGroup(this, 'AutoscalerLogGroup', {\n            name: '/ecs/Autoscaler',\n        });\n\n\n        const subnets = new DataAwsSubnets(this, 'Subnets', {});\n\n        const securityGroups = new DataAwsSecurityGroups(this, 'SecurityGroups');\n\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        const runnerContainerDefinitions: ContainerDefinition[] = [\n            {\n            name: 'runner',\n            image: 'ghcr.io/hi-fi/actions-runner:ecs',\n            command: ['/bin/sh', '-c', '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            essential: true,\n            environment: [\n                {\n                    name: 'EFS_ID',\n                    value: efs.id\n                },\n                {\n                    name: 'EXTERNALS_EFS_ID',\n                    value: externalsEfs.id\n                },\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: 'ACTIONS_RUNNER_REQUIRE_JOB_CONTAINER',\n                    value: 'false'\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                {\n                    sourceVolume: runnerVolumeName,\n                    containerPath: '/tmp/_work',\n                },\n                {\n                    sourceVolume: externalsVolumeName,\n                    containerPath: '/tmp/externals',\n                }\n            ],\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        // 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(this, 'RunnerTaskDefinition', {\n            family: 'GHA',\n            taskRoleArn: runnerRole.arn,\n            executionRoleArn: ecsTaskExecutionRole.arn,\n            containerDefinitions: Fn.jsonencode(runnerContainerDefinitions),\n            cpu: '1024',\n            memory: '2048',\n            requiresCompatibilities: [\n                'FARGATE'\n            ],\n            runtimePlatform: {\n                cpuArchitecture: 'X86_64',\n                operatingSystemFamily: 'LINUX'\n            },\n            networkMode: 'awsvpc',\n            volume: [\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\n        const autoscalerTaskDefinition = new EcsTaskDefinition(this, 'AutoscalerTaskDefinition', {\n            family: 'Autoscaler',\n            taskRoleArn: autoscalerRole.arn,\n            executionRoleArn: ecsTaskExecutionRole.arn,\n            containerDefinitions: Fn.jsonencode([\n                {\n                    name: 'autoscaler',\n                    image: 'ghcr.io/hi-fi/gha-runners-on-managed-env:test',\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: 'TASK_DEFINITION_ARN',\n                            value: runnerTaskDefinition.arn\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            cpu: '256',\n            memory: '512',\n            requiresCompatibilities: [\n                'FARGATE'\n            ],\n            runtimePlatform: {\n                cpuArchitecture: 'X86_64',\n                operatingSystemFamily: 'LINUX'\n            },\n            networkMode: 'awsvpc',\n        })\n\n        const runnerPolicy = new IamPolicy(this, 'RunnerPolicy', {\n            policy: Fn.jsonencode({\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': [\n                            'ec2:DescribeSubnets',\n                            'ec2:DescribeSecurityGroups'\n                        ],\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            )\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': [\n                            'ec2:DescribeSubnets',\n                            'ec2:DescribeSecurityGroups'\n                        ],\n                        'Resource': '*'\n                    }\n                ]\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: [\n                    'desired_count'\n                ]\n            }\n        })\n    }\n}\n"]}
|
package/lib/lib/azure.js
CHANGED
@@ -474,5 +474,5 @@ class Azure extends constructs_1.Construct {
|
|
474
474
|
}
|
475
475
|
exports.Azure = Azure;
|
476
476
|
_a = JSII_RTTI_SYMBOL_1;
|
477
|
-
Azure[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Azure", version: "0.0.
|
477
|
+
Azure[_a] = { fqn: "terraform-cdk-serverless-github-actions-runner-controller.Azure", version: "0.0.2" };
|
478
478
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azure.js","sourceRoot":"","sources":["../../src/lib/azure.ts"],"names":[],"mappings":"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","sourcesContent":["import { AzurermProvider } from \"@cdktf/provider-azurerm/lib/provider\";\nimport { AzapiProvider } from '../.gen/providers/azapi/provider'\nimport { Resource } from '../.gen/providers/azapi/resource'\nimport { DataAzapiResourceAction } from '../.gen/providers/azapi/data-azapi-resource-action'\nimport { Fn, TerraformVariable } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { ContainerRegistry } from \"@cdktf/provider-azurerm/lib/container-registry\";\nimport { UserAssignedIdentity } from \"@cdktf/provider-azurerm/lib/user-assigned-identity\";\nimport { RoleAssignment } from \"@cdktf/provider-azurerm/lib/role-assignment\";\nimport { LogAnalyticsWorkspace } from \"@cdktf/provider-azurerm/lib/log-analytics-workspace\";\nimport { RoleDefinition } from \"@cdktf/provider-azurerm/lib/role-definition\";\nimport { DataAzurermSubscription } from \"@cdktf/provider-azurerm/lib/data-azurerm-subscription\";\nimport { ContainerApp } from \"@cdktf/provider-azurerm/lib/container-app\";\nimport { commonVariables } from \"./variables\";\nimport { ContainerAppEnvironmentStorage } from \"@cdktf/provider-azurerm/lib/container-app-environment-storage\";\nimport { RandomProvider } from \"@cdktf/provider-random/lib/provider\";\nimport { StringResource } from \"@cdktf/provider-random/lib/string-resource\";\n\nexport class Azure extends Construct {\n    constructor(scope: Construct, id: string) {\n        super(scope, id);\n        \n        new AzurermProvider(this, 'azurerm', {\n            features: [\n                {}\n            ]\n        })\n\n        new AzapiProvider(this, 'azapi', {\n        })\n\n        new RandomProvider(this, 'random')\n\n        const sub = new DataAzurermSubscription(this, 'sub', {});\n\n        const { pat, githubConfigUrl } = commonVariables(this);\n\n        const location = new TerraformVariable(this, 'location', {\n            default: 'westeurope',\n            description: 'Location where to provision resources to',\n            type: 'string',\n            sensitive: false,\n            nullable: false\n        }).value;\n\n        const rg = new ResourceGroup(this, 'rg', {\n            location,\n            name: 'gha-runner-rg',\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const random = new StringResource(this, 'randomSuffix', {\n            length: 6,\n            special: false,\n            upper: false,\n        })\n\n        const acr = new ContainerRegistry(this, 'acr', {\n            location,\n            name: `runneracr${random.result}`,\n            resourceGroupName: rg.name,\n            sku: 'Basic',\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        // use caching for images\n        const runnerCache = new Resource(this, 'runnerCache', {\n            type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',\n            parentId: acr.id,\n            name: 'root-runner-cache',\n            body: {\n                properties: {\n                    sourceRepository: 'ghcr.io/hi-fi/root-actions-runner',\n                    targetRepository: 'root-actions-runner'\n                }\n            }\n        })\n\n        const autoscalerCache = new Resource(this, 'autoscalerCache', {\n            type: 'Microsoft.ContainerRegistry/registries/cacheRules@2023-01-01-preview',\n            parentId: acr.id,\n            name: 'autoscaler-cache',\n            body: {\n                properties: {\n                    sourceRepository: 'ghcr.io/hi-fi/gha-runners-on-managed-env',\n                    targetRepository: 'autoscaler'\n                }\n            }\n        })\n\n        const identity = new UserAssignedIdentity(this, 'identity', {\n            location,\n            name: 'aca-acr-access',\n            resourceGroupName: rg.name,\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        new RoleAssignment(this, 'roleAssignment', {\n            principalId: identity.principalId,\n            scope: acr.id,\n            roleDefinitionName: 'AcrPull'\n        });\n\n        const log = new LogAnalyticsWorkspace(this, 'log', {\n            location,\n            name: 'gha-example-logs',\n            resourceGroupName: rg.name,\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        })\n\n        const storageAccount = new Resource(this, 'storageAccount', {\n            type: 'Microsoft.Storage/storageAccounts@2023-01-01',\n            parentId: rg.id,\n            location,\n            name: `ghastorageaccount${random.result}`,\n            body: {\n                properties: {\n                    largeFileSharesState: 'Enabled'\n                },\n                sku: {\n                    name: 'Standard_LRS'\n                },\n                kind: 'StorageV2',\n            },\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            },\n            responseExportValues: [\n\n            ]\n        });\n\n        const storageShare = new Resource(this, 'storageShare', {\n            type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',\n            name: 'ghaexampleshare',\n            parentId: `${storageAccount.id}/fileServices/default`,\n            body: {\n                properties: {\n                    enabledProtocols: 'SMB',\n                }\n            },\n        });\n\n        const externalsShare = new Resource(this, 'externalsShare', {\n            type: 'Microsoft.Storage/storageAccounts/fileServices/shares@2023-01-01',\n            name: 'ghaexternalsshare',\n            parentId: `${storageAccount.id}/fileServices/default`,\n            body: {\n                properties: {\n                    enabledProtocols: 'SMB',\n                }\n            },\n        });\n\n        const environment = new Resource(this, 'acaenv', {\n            type: 'Microsoft.App/managedEnvironments@2024-03-01',\n            parentId: rg.id,\n            location,\n            name: 'gha-runner-environment',\n            body: {\n                properties: {\n                    appLogsConfiguration: {\n                        destination: 'log-analytics',\n                        logAnalyticsConfiguration: {\n                            customerId: log.workspaceId,\n                            sharedKey: log.primarySharedKey,\n                        }\n                    },\n                    infrastructureResourceGroup: 'managed-aca-rg',\n                    workloadProfiles: [\n                        {\n                            name: 'Consumption',\n                            workloadProfileType: 'Consumption'\n                        }\n                    ]\n                }\n            },\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const storageAccessKey = new DataAzapiResourceAction(this, 'storageAccessKeys', {\n            type: 'Microsoft.Storage/storageAccounts@2023-01-01',\n            action: 'listKeys',\n            resourceId: storageAccount.id,\n            responseExportValues: ['*'],\n            dependsOn: [\n                storageAccount\n            ]\n        });\n\n        // see https://github.com/hashicorp/terraform-cdk/issues/1641\n        // For older Azapi way to get key would be this when (default) data output was json. Witn 2.0.0-beta default was changed to HCL\n        // const accessKey = Fn.lookup(Fn.element(Fn.lookup(Fn.jsondecode(storageAccessKey.output as any), 'keys'), 0), 'value')\n\n        const accessKey = Fn.lookup(Fn.element(Fn.element(storageAccessKey.output.lookup('0'), 0), 0), 'value')\n\n        const acaEnvStorage = new ContainerAppEnvironmentStorage(this, 'acaenvstorage', {\n            name: 'gharunnerjobstorage',\n            accessKey,\n            accessMode: 'ReadWrite',\n            accountName: storageAccount.name,\n            containerAppEnvironmentId: environment.id,\n            shareName: storageShare.name,\n            dependsOn: [\n                // Name doesn't create dependsOn requirement, so adding that explicitly\n                storageShare\n            ] \n        });\n\n        const acaExternalStorage = new ContainerAppEnvironmentStorage(this, 'acaexternalstorage', {\n            name: 'gharunnerexternalstorage',\n            accessKey,\n            accessMode: 'ReadWrite',\n            accountName: storageAccount.name,\n            containerAppEnvironmentId: environment.id,\n            shareName: externalsShare.name,\n            dependsOn: [\n                // Name doesn't create dependsOn requirement, so adding that explicitly\n                externalsShare\n            ] \n        });\n\n        const runnerVolumeName = 'work'\n        const externalVolumeName = 'externals'\n\n        /**\n         * @see https://learn.microsoft.com/en-us/azure/templates/microsoft.app/jobs?pivots=deployment-language-terraform\n         */\n        const ghaRunnerJob = new Resource(this, 'ghaRunnerJob', {\n            type: 'Microsoft.App/jobs@2024-02-02-preview',\n            identity: [\n                {\n                    type: 'UserAssigned',\n                    identityIds: [\n                        identity.id\n                    ]\n                }\n            ],\n            name: 'gha-runner-job-01',\n            parentId: rg.id,\n            location,\n            body: {\n                properties: {\n                    configuration: {\n                        manualTriggerConfig: {\n                            parallelism: 1,\n                            replicaCompletionCount: 1,\n                        },\n                        triggerType: 'Manual',\n                        replicaTimeout: 1200,\n                        registries: [\n                            {\n                                identity: identity.id,\n                                server: acr.loginServer\n                            }\n                        ],\n                    },\n                    environmentId: environment.id,\n                    template: {\n                        containers: [\n                            {\n                                resources: {\n                                    cpu: 1,\n                                    memory: '2Gi',\n                                },\n                                // Have to use custom image as we want to run service as root to be able to install packages\n                                image: `${acr.loginServer}/root-actions-runner:latest`,\n                                name: 'main',\n                                command: ['/bin/sh', '-c', 'export EXECID=$(cat /proc/sys/kernel/random/uuid) && mkdir -p /tmp/_work/$EXECID && ln -s /tmp/_work/$EXECID _work && /home/runner/run.sh ; rm -r /tmp/_work/$EXECID'],\n                                volumeMounts: [\n                                    {\n                                        mountPath: '/tmp/_work',\n                                        volumeName: runnerVolumeName,\n                                    },\n                                    {\n                                        mountPath: '/tmp/externals',\n                                        volumeName: externalVolumeName,\n                                    }\n                                ],\n                                env: [\n                                    // https://github.com/microsoft/azure-container-apps/issues/502#issuecomment-1340225438\n                                    {\n                                        name: 'APPSETTING_WEBSITE_SITE_NAME',\n                                        value: 'identity-workaround'\n                                    },\n                                    // https://github.com/microsoft/azure-container-apps/issues/442#issuecomment-1665621031\n                                    {\n                                        name: 'AZURE_CLIENT_ID',\n                                        value: identity.clientId\n                                    },\n                                    {\n                                        name: 'RG_NAME',\n                                        value: rg.name\n                                    },\n                                    {\n                                        name: 'LOG_ID',\n                                        value: log.workspaceId\n                                    },\n                                    {\n                                        name: 'STORAGE_NAME',\n                                        value: acaEnvStorage.name\n                                    },\n                                    {\n                                        name: 'EXTERNAL_STORAGE_NAME',\n                                        value: acaExternalStorage.name\n                                    },\n                                    {\n                                        name: 'SUBSCRIPTION_ID',\n                                        value: sub.subscriptionId\n                                    },\n                                    {\n                                        name: 'ACA_ENVIRONMENT_ID',\n                                        value: environment.id\n                                    }\n                                ],\n                            },\n                        ],\n                        volumes: [\n                            {\n                                name: runnerVolumeName,\n                                storageName: acaEnvStorage.name,\n                                storageType: 'AzureFile',\n                                mountOptions: 'mfsymlinks'\n                            },\n                            {\n                                name: externalVolumeName,\n                                storageName: acaExternalStorage.name,\n                                storageType: 'AzureFile',\n                                mountOptions: 'mfsymlinks'\n                            }\n                        ]\n                    }\n                }\n            },\n            dependsOn: [\n                runnerCache\n            ],\n            lifecycle: {\n                ignoreChanges: [\n                    'tags'\n                ]\n            }\n        });\n\n        const autoscalerApp = new ContainerApp(this, 'autoscalerApp', {\n            containerAppEnvironmentId: environment.id,\n            name: 'autoscaler-app-01',\n            resourceGroupName: rg.name,\n            revisionMode: 'Single',\n            identity: {\n                type: 'SystemAssigned, UserAssigned',\n                identityIds: [\n                    identity.id\n                ]\n            },\n            secret: [\n                {\n                    name: 'pat',\n                    value: pat.value\n                }\n            ],\n            registry: [\n                {\n                    identity: identity.id,\n                    server: acr.loginServer\n                }\n            ],\n            template: {\n                container: [\n                    {\n                        // CPU and Memory can be lower with workload profile\n                        cpu: 0.25,\n                        memory: '0.5Gi',\n                        image: `${acr.loginServer}/autoscaler:test`,\n                        name: 'autoscaler',\n                        env: [\n                            {\n                                name: 'PAT',\n                                secretName: 'pat',\n                            },\n                            {\n                                name: 'GITHUB_CONFIG_URL',\n                                value: githubConfigUrl.value\n                            },\n                            {\n                                name: 'AZURE_TENANT_ID',\n                                value: sub.tenantId,\n                            },\n                            {\n                                name: 'SUBSCRIPTION_ID',\n                                value: sub.subscriptionId\n                            },\n                            {\n                                name: 'RESOURCE_GROUP_NAME',\n                                value: rg.name\n                            },\n                            {\n                                name: 'JOB_NAME',\n                                value: ghaRunnerJob.name\n                            },\n                            {\n                                name: 'SCALE_SET_NAME',\n                                value: 'aca-runner-set'\n                            },\n                        ]\n                    }\n                ]\n            },\n            dependsOn: [\n                autoscalerCache\n            ],\n            lifecycle: {\n                ignoreChanges: [\n                    'tags',\n                    'workload_profile_name'\n                ]\n            }\n        });\n\n        /**\n         * @see https://github.com/microsoft/azure-container-apps/issues/1024\n         */\n        const role = new RoleDefinition(this, 'jobRole', {\n            name: `gha-example-revision-start-role-${random.result}`,\n            scope: sub.id,\n            permissions: [\n                {\n                    actions: [\n                        'microsoft.app/jobs/start/action',\n                        'microsoft.app/jobs/stop/action',\n                        'microsoft.app/jobs/read',\n                        'microsoft.app/jobs/executions/read',\n                    ],\n                }\n            ]\n        })\n\n        const jobCreationRole = new RoleDefinition(this, 'jobCreationRole', {\n            name: `gha-example-revision-create-role-${random.result}`,\n            scope: sub.id,\n            permissions: [\n                {\n                    actions: [\n                        'microsoft.app/jobs/start/action',\n                        'microsoft.app/jobs/stop/action',\n                        'microsoft.app/jobs/read',\n                        'microsoft.app/jobs/write',\n                        'microsoft.app/jobs/executions/read',\n                        'microsoft.app/managedEnvironments/join/action',\n                        'microsoft.app/jobs/delete' // cleanup for jobs\n                    ],\n                }\n            ]\n        })\n\n        // Allow autoscaler to create new revision of app\n        new RoleAssignment(this, 'scaleJobRoleAssignment', {\n            principalId: autoscalerApp.identity.principalId,\n            scope: ghaRunnerJob.id,\n            roleDefinitionId: role.roleDefinitionResourceId\n        })\n\n        // Allow runner to start the job. As each one created new job, have to give to RG level.\n        new RoleAssignment(this, 'actionContainerStartRoleAssignment', {\n            principalId: identity.principalId,\n            scope: rg.id,\n            roleDefinitionId: jobCreationRole.roleDefinitionResourceId\n        })\n\n        new RoleAssignment(this, 'imagePushRoleAssignment', {\n            principalId: identity.principalId,\n            scope: acr.id,\n            roleDefinitionName: 'AcrPush'\n        });\n\n        new RoleAssignment(this, 'jobLogReadAssignment', {\n            principalId: identity.principalId,\n            scope: log.id,\n            roleDefinitionName: 'Log Analytics Reader'\n        })\n    }\n}"]}
|
package/lib/lib/gcp.d.ts
ADDED