@cloudsnorkel/cdk-github-runners 0.14.20 → 0.14.21
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 +27 -27
- package/README.md +1 -0
- package/assets/delete-failed-runner.lambda/index.js +3248 -11227
- package/assets/idle-runner-repear.lambda/index.js +3224 -11221
- package/assets/image-builders/aws-image-builder/delete-resources.lambda/index.js +12 -2
- package/assets/image-builders/aws-image-builder/filter-failed-builds.lambda/index.js +4 -1
- package/assets/image-builders/build-image.lambda/index.js +21 -4
- package/assets/providers/ami-root-device.lambda/index.js +45 -10
- package/assets/providers/update-lambda.lambda/index.js +6 -1
- package/assets/setup.lambda/index.js +1762 -4645
- package/assets/status.lambda/index.js +2412 -10615
- package/assets/token-retriever.lambda/index.js +3228 -11221
- package/assets/webhook-handler.lambda/index.js +3264 -11236
- package/assets/webhook-redelivery.lambda/index.js +3220 -11221
- package/lib/access.js +1 -1
- package/lib/delete-failed-runner.lambda.js +22 -4
- package/lib/idle-runner-repear.lambda.js +1 -1
- package/lib/image-builders/api.js +1 -1
- package/lib/image-builders/aws-image-builder/base-image.js +2 -2
- package/lib/image-builders/aws-image-builder/builder.js +3 -3
- package/lib/image-builders/aws-image-builder/delete-resources.lambda.js +6 -2
- package/lib/image-builders/aws-image-builder/deprecated/ami.js +1 -1
- package/lib/image-builders/aws-image-builder/deprecated/container.js +1 -1
- package/lib/image-builders/aws-image-builder/deprecated/linux-components.js +1 -1
- package/lib/image-builders/aws-image-builder/deprecated/windows-components.js +1 -1
- package/lib/image-builders/aws-image-builder/filter-failed-builds.lambda.js +5 -2
- package/lib/image-builders/build-image.lambda.js +15 -4
- package/lib/image-builders/codebuild-deprecated.js +1 -1
- package/lib/image-builders/components.d.ts +12 -1
- package/lib/image-builders/components.js +48 -10
- package/lib/image-builders/static.js +1 -1
- package/lib/lambda-github.d.ts +14 -7
- package/lib/lambda-github.js +34 -8
- package/lib/lambda-helpers.js +8 -2
- package/lib/providers/ami-root-device.lambda.js +39 -10
- package/lib/providers/codebuild.js +2 -2
- package/lib/providers/common.js +3 -3
- package/lib/providers/composite.js +1 -1
- package/lib/providers/ec2.js +2 -2
- package/lib/providers/ecs.js +1 -1
- package/lib/providers/fargate.js +2 -2
- package/lib/providers/lambda.js +2 -2
- package/lib/providers/update-lambda.lambda.js +7 -2
- package/lib/runner.js +1 -1
- package/lib/secrets.js +1 -1
- package/lib/setup.lambda.js +7 -4
- package/lib/status.lambda.js +17 -8
- package/lib/token-retriever.lambda.js +8 -2
- package/lib/webhook-handler.lambda.js +39 -12
- package/lib/webhook-redelivery.lambda.js +1 -1
- package/package.json +5 -5
package/lib/lambda-helpers.js
CHANGED
|
@@ -36,7 +36,13 @@ async function customResourceRespond(event, responseStatus, reason, physicalReso
|
|
|
36
36
|
NoEcho: false,
|
|
37
37
|
Data: data,
|
|
38
38
|
});
|
|
39
|
-
console.log(
|
|
39
|
+
console.log({
|
|
40
|
+
notice: 'Responding to CloudFormation custom resource',
|
|
41
|
+
status: responseStatus,
|
|
42
|
+
reason,
|
|
43
|
+
physicalResourceId,
|
|
44
|
+
responseBody,
|
|
45
|
+
});
|
|
40
46
|
// eslint-disable-next-line @typescript-eslint/no-require-imports
|
|
41
47
|
const parsedUrl = require('url').parse(event.ResponseURL);
|
|
42
48
|
const requestOptions = {
|
|
@@ -61,4 +67,4 @@ async function customResourceRespond(event, responseStatus, reason, physicalReso
|
|
|
61
67
|
}
|
|
62
68
|
});
|
|
63
69
|
}
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFtYmRhLWhlbHBlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvbGFtYmRhLWhlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFnQkEsd0NBWUM7QUFFRCxnREFFQztBQUVELDhDQU1DO0FBRUQsc0RBNENDO0FBdEZELDRFQUFtSDtBQWNuSCxNQUFNLEVBQUUsR0FBRyxJQUFJLDZDQUFvQixFQUFFLENBQUM7QUFFL0IsS0FBSyxVQUFVLGNBQWMsQ0FBQyxHQUF1QjtJQUMxRCxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDVCxNQUFNLElBQUksS0FBSyxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELE1BQU0sTUFBTSxHQUFHLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLDhDQUFxQixDQUFDLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUUzRSxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3pCLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLEdBQUcsRUFBRSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELE9BQU8sTUFBTSxDQUFDLFlBQVksQ0FBQztBQUM3QixDQUFDO0FBRU0sS0FBSyxVQUFVLGtCQUFrQixDQUFDLEdBQXVCO0lBQzlELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0FBQy9DLENBQUM7QUFFTSxLQUFLLFVBQVUsaUJBQWlCLENBQUMsR0FBdUIsRUFBRSxLQUFhO0lBQzVFLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNULE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksNENBQW1CLENBQUMsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDakYsQ0FBQztBQUVNLEtBQUssVUFBVSxxQkFBcUIsQ0FBQyxLQUFrRCxFQUFFLGNBQXNCLEVBQ3BILE1BQWMsRUFBRSxrQkFBMEIsRUFBRSxJQUFTO0lBQ3JELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDbEMsTUFBTSxFQUFFLGNBQWM7UUFDdEIsTUFBTSxFQUFFLE1BQU07UUFDZCxrQkFBa0IsRUFBRSxrQkFBa0I7UUFDdEMsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPO1FBQ3RCLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztRQUMxQixpQkFBaUIsRUFBRSxLQUFLLENBQUMsaUJBQWlCO1FBQzFDLE1BQU0sRUFBRSxLQUFLO1FBQ2IsSUFBSSxFQUFFLElBQUk7S0FDWCxDQUFDLENBQUM7SUFFSCxPQUFPLENBQUMsR0FBRyxDQUFDO1FBQ1YsTUFBTSxFQUFFLDhDQUE4QztRQUN0RCxNQUFNLEVBQUUsY0FBYztRQUN0QixNQUFNO1FBQ04sa0JBQWtCO1FBQ2xCLFlBQVk7S0FDYixDQUFDLENBQUM7SUFFSCxpRUFBaUU7SUFDakUsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDMUQsTUFBTSxjQUFjLEdBQUc7UUFDckIsUUFBUSxFQUFFLFNBQVMsQ0FBQyxRQUFRO1FBQzVCLElBQUksRUFBRSxTQUFTLENBQUMsSUFBSTtRQUNwQixNQUFNLEVBQUUsS0FBSztRQUNiLE9BQU8sRUFBRTtZQUNQLGNBQWMsRUFBRSxFQUFFO1lBQ2xCLGdCQUFnQixFQUFFLFlBQVksQ0FBQyxNQUFNO1NBQ3RDO0tBQ0YsQ0FBQztJQUVGLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7UUFDckMsSUFBSSxDQUFDO1lBQ0gsaUVBQWlFO1lBQ2pFLE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQ2xFLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1lBQzVCLE9BQU8sQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDNUIsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLENBQUM7UUFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ1gsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ1osQ0FBQztJQUNILENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdldFNlY3JldFZhbHVlQ29tbWFuZCwgU2VjcmV0c01hbmFnZXJDbGllbnQsIFVwZGF0ZVNlY3JldENvbW1hbmQgfSBmcm9tICdAYXdzLXNkay9jbGllbnQtc2VjcmV0cy1tYW5hZ2VyJztcblxuZXhwb3J0IGludGVyZmFjZSBTdGVwRnVuY3Rpb25MYW1iZGFJbnB1dCB7XG4gIHJlYWRvbmx5IG93bmVyOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHJlcG86IHN0cmluZztcbiAgcmVhZG9ubHkgcnVubmVyTmFtZTogc3RyaW5nO1xuICByZWFkb25seSBpbnN0YWxsYXRpb25JZD86IG51bWJlcjtcbiAgcmVhZG9ubHkgbGFiZWxzOiBzdHJpbmdbXTtcbiAgcmVhZG9ubHkgZXJyb3I/OiB7XG4gICAgcmVhZG9ubHkgRXJyb3I6IHN0cmluZztcbiAgICByZWFkb25seSBDYXVzZTogc3RyaW5nO1xuICB9O1xufVxuXG5jb25zdCBzbSA9IG5ldyBTZWNyZXRzTWFuYWdlckNsaWVudCgpO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0U2VjcmV0VmFsdWUoYXJuOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgaWYgKCFhcm4pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01pc3Npbmcgc2VjcmV0IEFSTicpO1xuICB9XG5cbiAgY29uc3Qgc2VjcmV0ID0gYXdhaXQgc20uc2VuZChuZXcgR2V0U2VjcmV0VmFsdWVDb21tYW5kKHsgU2VjcmV0SWQ6IGFybiB9KSk7XG5cbiAgaWYgKCFzZWNyZXQuU2VjcmV0U3RyaW5nKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBObyBTZWNyZXRTdHJpbmcgaW4gJHthcm59YCk7XG4gIH1cblxuICByZXR1cm4gc2VjcmV0LlNlY3JldFN0cmluZztcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldFNlY3JldEpzb25WYWx1ZShhcm46IHN0cmluZyB8IHVuZGVmaW5lZCkge1xuICByZXR1cm4gSlNPTi5wYXJzZShhd2FpdCBnZXRTZWNyZXRWYWx1ZShhcm4pKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHVwZGF0ZVNlY3JldFZhbHVlKGFybjogc3RyaW5nIHwgdW5kZWZpbmVkLCB2YWx1ZTogc3RyaW5nKSB7XG4gIGlmICghYXJuKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIHNlY3JldCBBUk4nKTtcbiAgfVxuXG4gIGF3YWl0IHNtLnNlbmQobmV3IFVwZGF0ZVNlY3JldENvbW1hbmQoeyBTZWNyZXRJZDogYXJuLCBTZWNyZXRTdHJpbmc6IHZhbHVlIH0pKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGN1c3RvbVJlc291cmNlUmVzcG9uZChldmVudDogQVdTTGFtYmRhLkNsb3VkRm9ybWF0aW9uQ3VzdG9tUmVzb3VyY2VFdmVudCwgcmVzcG9uc2VTdGF0dXM6IHN0cmluZyxcbiAgcmVhc29uOiBzdHJpbmcsIHBoeXNpY2FsUmVzb3VyY2VJZDogc3RyaW5nLCBkYXRhOiBhbnkpIHtcbiAgY29uc3QgcmVzcG9uc2VCb2R5ID0gSlNPTi5zdHJpbmdpZnkoe1xuICAgIFN0YXR1czogcmVzcG9uc2VTdGF0dXMsXG4gICAgUmVhc29uOiByZWFzb24sXG4gICAgUGh5c2ljYWxSZXNvdXJjZUlkOiBwaHlzaWNhbFJlc291cmNlSWQsXG4gICAgU3RhY2tJZDogZXZlbnQuU3RhY2tJZCxcbiAgICBSZXF1ZXN0SWQ6IGV2ZW50LlJlcXVlc3RJZCxcbiAgICBMb2dpY2FsUmVzb3VyY2VJZDogZXZlbnQuTG9naWNhbFJlc291cmNlSWQsXG4gICAgTm9FY2hvOiBmYWxzZSxcbiAgICBEYXRhOiBkYXRhLFxuICB9KTtcblxuICBjb25zb2xlLmxvZyh7XG4gICAgbm90aWNlOiAnUmVzcG9uZGluZyB0byBDbG91ZEZvcm1hdGlvbiBjdXN0b20gcmVzb3VyY2UnLFxuICAgIHN0YXR1czogcmVzcG9uc2VTdGF0dXMsXG4gICAgcmVhc29uLFxuICAgIHBoeXNpY2FsUmVzb3VyY2VJZCxcbiAgICByZXNwb25zZUJvZHksXG4gIH0pO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tcmVxdWlyZS1pbXBvcnRzXG4gIGNvbnN0IHBhcnNlZFVybCA9IHJlcXVpcmUoJ3VybCcpLnBhcnNlKGV2ZW50LlJlc3BvbnNlVVJMKTtcbiAgY29uc3QgcmVxdWVzdE9wdGlvbnMgPSB7XG4gICAgaG9zdG5hbWU6IHBhcnNlZFVybC5ob3N0bmFtZSxcbiAgICBwYXRoOiBwYXJzZWRVcmwucGF0aCxcbiAgICBtZXRob2Q6ICdQVVQnLFxuICAgIGhlYWRlcnM6IHtcbiAgICAgICdjb250ZW50LXR5cGUnOiAnJyxcbiAgICAgICdjb250ZW50LWxlbmd0aCc6IHJlc3BvbnNlQm9keS5sZW5ndGgsXG4gICAgfSxcbiAgfTtcblxuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHRyeSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXJlcXVpcmUtaW1wb3J0c1xuICAgICAgY29uc3QgcmVxdWVzdCA9IHJlcXVpcmUoJ2h0dHBzJykucmVxdWVzdChyZXF1ZXN0T3B0aW9ucywgcmVzb2x2ZSk7XG4gICAgICByZXF1ZXN0Lm9uKCdlcnJvcicsIHJlamVjdCk7XG4gICAgICByZXF1ZXN0LndyaXRlKHJlc3BvbnNlQm9keSk7XG4gICAgICByZXF1ZXN0LmVuZCgpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHJlamVjdChlKTtcbiAgICB9XG4gIH0pO1xufVxuIl19
|
|
@@ -19,25 +19,39 @@ async function handleAmi(event, ami) {
|
|
|
19
19
|
await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `${ami} has no root device`, 'ERROR', {});
|
|
20
20
|
return;
|
|
21
21
|
}
|
|
22
|
-
console.log(
|
|
22
|
+
console.log({
|
|
23
|
+
notice: 'Resolved AMI root device',
|
|
24
|
+
ami,
|
|
25
|
+
rootDevice,
|
|
26
|
+
});
|
|
23
27
|
await (0, lambda_helpers_1.customResourceRespond)(event, 'SUCCESS', 'OK', rootDevice, {});
|
|
24
28
|
return;
|
|
25
29
|
}
|
|
26
30
|
async function handler(event, context) {
|
|
27
31
|
try {
|
|
28
|
-
console.log({
|
|
32
|
+
console.log({
|
|
33
|
+
notice: 'CloudFormation custom resource request',
|
|
34
|
+
...event,
|
|
35
|
+
ResponseURL: '...',
|
|
36
|
+
});
|
|
29
37
|
const ami = event.ResourceProperties.Ami;
|
|
30
38
|
switch (event.RequestType) {
|
|
31
39
|
case 'Create':
|
|
32
40
|
case 'Update':
|
|
33
41
|
if (ami.startsWith('ami-')) {
|
|
34
|
-
console.log(
|
|
42
|
+
console.log({
|
|
43
|
+
notice: 'Checking AMI',
|
|
44
|
+
ami,
|
|
45
|
+
});
|
|
35
46
|
await handleAmi(event, ami);
|
|
36
47
|
break;
|
|
37
48
|
}
|
|
38
49
|
if (ami.startsWith('resolve:ssm:')) {
|
|
39
50
|
const ssmParam = ami.substring('resolve:ssm:'.length);
|
|
40
|
-
console.log(
|
|
51
|
+
console.log({
|
|
52
|
+
notice: 'Checking SSM',
|
|
53
|
+
ssmParam,
|
|
54
|
+
});
|
|
41
55
|
const ssmValue = (await ssm.send(new client_ssm_1.GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;
|
|
42
56
|
if (!ssmValue) {
|
|
43
57
|
await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `${ami} has no value`, 'ERROR', {});
|
|
@@ -48,7 +62,10 @@ async function handler(event, context) {
|
|
|
48
62
|
}
|
|
49
63
|
if (ami.startsWith('ssm:')) {
|
|
50
64
|
const ssmParam = ami.substring('ssm:'.length);
|
|
51
|
-
console.log(
|
|
65
|
+
console.log({
|
|
66
|
+
notice: 'Checking SSM',
|
|
67
|
+
ssmParam,
|
|
68
|
+
});
|
|
52
69
|
const ssmValue = (await ssm.send(new client_ssm_1.GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;
|
|
53
70
|
if (!ssmValue) {
|
|
54
71
|
await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `${ami} has no value`, 'ERROR', {});
|
|
@@ -58,7 +75,10 @@ async function handler(event, context) {
|
|
|
58
75
|
break;
|
|
59
76
|
}
|
|
60
77
|
if (ami.startsWith('lt-')) {
|
|
61
|
-
console.log(
|
|
78
|
+
console.log({
|
|
79
|
+
notice: 'Checking Launch Template',
|
|
80
|
+
launchTemplateId: ami,
|
|
81
|
+
});
|
|
62
82
|
const lts = await ec2.send(new client_ec2_1.DescribeLaunchTemplateVersionsCommand({ LaunchTemplateId: ami, Versions: ['$Latest'] }));
|
|
63
83
|
if (lts.LaunchTemplateVersions?.length !== 1) {
|
|
64
84
|
await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});
|
|
@@ -72,7 +92,10 @@ async function handler(event, context) {
|
|
|
72
92
|
break;
|
|
73
93
|
}
|
|
74
94
|
if (ami.match('^arn:aws[^:]*:imagebuilder:[^:]+:[^:]+:image/.*$')) {
|
|
75
|
-
console.log(
|
|
95
|
+
console.log({
|
|
96
|
+
notice: 'Checking Image Builder',
|
|
97
|
+
imageBuildVersionArn: ami,
|
|
98
|
+
});
|
|
76
99
|
const img = await ib.send(new client_imagebuilder_1.GetImageCommand({ imageBuildVersionArn: ami }));
|
|
77
100
|
const actualAmi = img.image?.outputResources?.amis?.[0]?.image;
|
|
78
101
|
if (!actualAmi) {
|
|
@@ -85,14 +108,20 @@ async function handler(event, context) {
|
|
|
85
108
|
await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', `Unknown type of AMI ${ami}`, 'ERROR', {});
|
|
86
109
|
break;
|
|
87
110
|
case 'Delete':
|
|
88
|
-
console.log(
|
|
111
|
+
console.log({
|
|
112
|
+
notice: 'Nothing to delete',
|
|
113
|
+
ami,
|
|
114
|
+
});
|
|
89
115
|
await (0, lambda_helpers_1.customResourceRespond)(event, 'SUCCESS', 'OK', event.PhysicalResourceId, {});
|
|
90
116
|
break;
|
|
91
117
|
}
|
|
92
118
|
}
|
|
93
119
|
catch (e) {
|
|
94
|
-
console.error(
|
|
120
|
+
console.error({
|
|
121
|
+
notice: 'Failed to resolve AMI root device',
|
|
122
|
+
error: `${e}`,
|
|
123
|
+
});
|
|
95
124
|
await (0, lambda_helpers_1.customResourceRespond)(event, 'FAILED', e.message || 'Internal Error', context.logStreamName, {});
|
|
96
125
|
}
|
|
97
126
|
}
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ami-root-device.lambda.js","sourceRoot":"","sources":["../../src/providers/ami-root-device.lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { DescribeImagesCommand, DescribeLaunchTemplateVersionsCommand, EC2Client } from '@aws-sdk/client-ec2';\nimport { GetImageCommand, ImagebuilderClient } from '@aws-sdk/client-imagebuilder';\nimport { GetParameterCommand, SSMClient } from '@aws-sdk/client-ssm';\nimport * as AWSLambda from 'aws-lambda';\nimport { customResourceRespond } from '../lambda-helpers';\n\nconst ssm = new SSMClient();\nconst ec2 = new EC2Client();\nconst ib = new ImagebuilderClient();\n\n\nasync function handleAmi(event: AWSLambda.CloudFormationCustomResourceEvent, ami: string) {\n  const imageDescs = (await ec2.send(new DescribeImagesCommand({ ImageIds: [ami] })));\n  if (imageDescs.Images?.length !== 1) {\n    await customResourceRespond(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});\n    return;\n  }\n\n  const rootDevice = imageDescs.Images[0].RootDeviceName;\n  if (!rootDevice) {\n    await customResourceRespond(event, 'FAILED', `${ami} has no root device`, 'ERROR', {});\n    return;\n  }\n\n  console.log(`Root device for ${ami} is ${rootDevice}`);\n\n  await customResourceRespond(event, 'SUCCESS', 'OK', rootDevice, {});\n  return;\n}\n\n\nexport async function handler(event: AWSLambda.CloudFormationCustomResourceEvent, context: AWSLambda.Context) {\n  try {\n    console.log({ ...event, ResponseURL: '...' });\n\n    const ami = event.ResourceProperties.Ami as string;\n\n    switch (event.RequestType) {\n      case 'Create':\n      case 'Update':\n        if (ami.startsWith('ami-')) {\n          console.log(`Checking AMI ${ami}`);\n\n          await handleAmi(event, ami);\n          break;\n        }\n\n        if (ami.startsWith('resolve:ssm:')) {\n          const ssmParam = ami.substring('resolve:ssm:'.length);\n          console.log(`Checking SSM ${ssmParam}`);\n\n          const ssmValue = (await ssm.send(new GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;\n          if (!ssmValue) {\n            await customResourceRespond(event, 'FAILED', `${ami} has no value`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, ssmValue);\n          break;\n        }\n\n        if (ami.startsWith('ssm:')) {\n          const ssmParam = ami.substring('ssm:'.length);\n          console.log(`Checking SSM ${ssmParam}`);\n\n          const ssmValue = (await ssm.send(new GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;\n          if (!ssmValue) {\n            await customResourceRespond(event, 'FAILED', `${ami} has no value`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, ssmValue);\n          break;\n        }\n\n        if (ami.startsWith('lt-')) {\n          console.log(`Checking Launch Template ${ami}`);\n\n          const lts = await ec2.send(new DescribeLaunchTemplateVersionsCommand({ LaunchTemplateId: ami, Versions: ['$Latest'] }));\n          if (lts.LaunchTemplateVersions?.length !== 1) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});\n            break;\n          }\n\n          if (!lts.LaunchTemplateVersions[0].LaunchTemplateData?.ImageId) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't have an AMI`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, lts.LaunchTemplateVersions[0].LaunchTemplateData.ImageId);\n          break;\n        }\n\n        if (ami.match('^arn:aws[^:]*:imagebuilder:[^:]+:[^:]+:image/.*$')) {\n          console.log(`Checking Image Builder ${ami}`);\n\n          const img = await ib.send(new GetImageCommand({ imageBuildVersionArn: ami }));\n          const actualAmi = img.image?.outputResources?.amis?.[0]?.image;\n          if (!actualAmi) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't have an AMI`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, actualAmi);\n          break;\n        }\n\n        await customResourceRespond(event, 'FAILED', `Unknown type of AMI ${ami}`, 'ERROR', {});\n        break;\n      case 'Delete':\n        console.log('Nothing to delete');\n        await customResourceRespond(event, 'SUCCESS', 'OK', event.PhysicalResourceId, {});\n        break;\n    }\n  } catch (e) {\n    console.error(e);\n    await customResourceRespond(event, 'FAILED', (e as Error).message || 'Internal Error', context.logStreamName, {});\n  }\n}\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ami-root-device.lambda.js","sourceRoot":"","sources":["../../src/providers/ami-root-device.lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { DescribeImagesCommand, DescribeLaunchTemplateVersionsCommand, EC2Client } from '@aws-sdk/client-ec2';\nimport { GetImageCommand, ImagebuilderClient } from '@aws-sdk/client-imagebuilder';\nimport { GetParameterCommand, SSMClient } from '@aws-sdk/client-ssm';\nimport * as AWSLambda from 'aws-lambda';\nimport { customResourceRespond } from '../lambda-helpers';\n\nconst ssm = new SSMClient();\nconst ec2 = new EC2Client();\nconst ib = new ImagebuilderClient();\n\n\nasync function handleAmi(event: AWSLambda.CloudFormationCustomResourceEvent, ami: string) {\n  const imageDescs = (await ec2.send(new DescribeImagesCommand({ ImageIds: [ami] })));\n  if (imageDescs.Images?.length !== 1) {\n    await customResourceRespond(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});\n    return;\n  }\n\n  const rootDevice = imageDescs.Images[0].RootDeviceName;\n  if (!rootDevice) {\n    await customResourceRespond(event, 'FAILED', `${ami} has no root device`, 'ERROR', {});\n    return;\n  }\n\n  console.log({\n    notice: 'Resolved AMI root device',\n    ami,\n    rootDevice,\n  });\n\n  await customResourceRespond(event, 'SUCCESS', 'OK', rootDevice, {});\n  return;\n}\n\n\nexport async function handler(event: AWSLambda.CloudFormationCustomResourceEvent, context: AWSLambda.Context) {\n  try {\n    console.log({\n      notice: 'CloudFormation custom resource request',\n      ...event,\n      ResponseURL: '...',\n    });\n\n    const ami = event.ResourceProperties.Ami as string;\n\n    switch (event.RequestType) {\n      case 'Create':\n      case 'Update':\n        if (ami.startsWith('ami-')) {\n          console.log({\n            notice: 'Checking AMI',\n            ami,\n          });\n\n          await handleAmi(event, ami);\n          break;\n        }\n\n        if (ami.startsWith('resolve:ssm:')) {\n          const ssmParam = ami.substring('resolve:ssm:'.length);\n          console.log({\n            notice: 'Checking SSM',\n            ssmParam,\n          });\n\n          const ssmValue = (await ssm.send(new GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;\n          if (!ssmValue) {\n            await customResourceRespond(event, 'FAILED', `${ami} has no value`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, ssmValue);\n          break;\n        }\n\n        if (ami.startsWith('ssm:')) {\n          const ssmParam = ami.substring('ssm:'.length);\n          console.log({\n            notice: 'Checking SSM',\n            ssmParam,\n          });\n\n          const ssmValue = (await ssm.send(new GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;\n          if (!ssmValue) {\n            await customResourceRespond(event, 'FAILED', `${ami} has no value`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, ssmValue);\n          break;\n        }\n\n        if (ami.startsWith('lt-')) {\n          console.log({\n            notice: 'Checking Launch Template',\n            launchTemplateId: ami,\n          });\n\n          const lts = await ec2.send(new DescribeLaunchTemplateVersionsCommand({ LaunchTemplateId: ami, Versions: ['$Latest'] }));\n          if (lts.LaunchTemplateVersions?.length !== 1) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't exist`, 'ERROR', {});\n            break;\n          }\n\n          if (!lts.LaunchTemplateVersions[0].LaunchTemplateData?.ImageId) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't have an AMI`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, lts.LaunchTemplateVersions[0].LaunchTemplateData.ImageId);\n          break;\n        }\n\n        if (ami.match('^arn:aws[^:]*:imagebuilder:[^:]+:[^:]+:image/.*$')) {\n          console.log({\n            notice: 'Checking Image Builder',\n            imageBuildVersionArn: ami,\n          });\n\n          const img = await ib.send(new GetImageCommand({ imageBuildVersionArn: ami }));\n          const actualAmi = img.image?.outputResources?.amis?.[0]?.image;\n          if (!actualAmi) {\n            await customResourceRespond(event, 'FAILED', `${ami} doesn't have an AMI`, 'ERROR', {});\n            break;\n          }\n\n          await handleAmi(event, actualAmi);\n          break;\n        }\n\n        await customResourceRespond(event, 'FAILED', `Unknown type of AMI ${ami}`, 'ERROR', {});\n        break;\n      case 'Delete':\n        console.log({\n          notice: 'Nothing to delete',\n          ami,\n        });\n        await customResourceRespond(event, 'SUCCESS', 'OK', event.PhysicalResourceId, {});\n        break;\n    }\n  } catch (e) {\n    console.error({\n      notice: 'Failed to resolve AMI root device',\n      error: `${e}`,\n    });\n    await customResourceRespond(event, 'FAILED', (e as Error).message || 'Internal Error', context.logStreamName, {});\n  }\n}\n"]}
|
|
@@ -265,7 +265,7 @@ class CodeBuildRunnerProvider extends common_1.BaseProvider {
|
|
|
265
265
|
}
|
|
266
266
|
exports.CodeBuildRunnerProvider = CodeBuildRunnerProvider;
|
|
267
267
|
_a = JSII_RTTI_SYMBOL_1;
|
|
268
|
-
CodeBuildRunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunnerProvider", version: "0.14.
|
|
268
|
+
CodeBuildRunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunnerProvider", version: "0.14.21" };
|
|
269
269
|
/**
|
|
270
270
|
* Path to Dockerfile for Linux x64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
|
|
271
271
|
*
|
|
@@ -301,5 +301,5 @@ class CodeBuildRunner extends CodeBuildRunnerProvider {
|
|
|
301
301
|
}
|
|
302
302
|
exports.CodeBuildRunner = CodeBuildRunner;
|
|
303
303
|
_b = JSII_RTTI_SYMBOL_1;
|
|
304
|
-
CodeBuildRunner[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunner", version: "0.14.
|
|
304
|
+
CodeBuildRunner[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunner", version: "0.14.21" };
|
|
305
305
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codebuild.js","sourceRoot":"","sources":["../../src/providers/codebuild.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Annotations,\n  aws_codebuild as codebuild,\n  aws_ec2 as ec2,\n  aws_iam as iam,\n  aws_logs as logs,\n  aws_stepfunctions as stepfunctions,\n  aws_stepfunctions_tasks as stepfunctions_tasks,\n  Duration,\n  RemovalPolicy,\n} from 'aws-cdk-lib';\nimport { ComputeType } from 'aws-cdk-lib/aws-codebuild';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { IntegrationPattern } from 'aws-cdk-lib/aws-stepfunctions';\nimport { Construct } from 'constructs';\nimport {\n  Architecture,\n  BaseProvider,\n  IRunnerProvider,\n  IRunnerProviderStatus,\n  Os,\n  RunnerImage,\n  RunnerProviderProps,\n  RunnerRuntimeParameters,\n  RunnerVersion,\n  generateStateName,\n} from './common';\nimport { IRunnerImageBuilder, RunnerImageBuilder, RunnerImageBuilderProps, RunnerImageComponent } from '../image-builders';\n\n\nexport interface CodeBuildRunnerProviderProps extends RunnerProviderProps {\n  /**\n   * Runner image builder used to build Docker images containing GitHub Runner and all requirements.\n   *\n   * The image builder must contain the {@link RunnerImageComponent.docker} component unless `dockerInDocker` is set to false.\n   *\n   * The image builder determines the OS and architecture of the runner.\n   *\n   * @default CodeBuildRunnerProvider.imageBuilder()\n   */\n  readonly imageBuilder?: IRunnerImageBuilder;\n\n  /**\n   * GitHub Actions label used for this provider.\n   *\n   * @default undefined\n   * @deprecated use {@link labels} instead\n   */\n  readonly label?: string;\n\n  /**\n   * GitHub Actions labels used for this provider.\n   *\n   * These labels are used to identify which provider should spawn a new on-demand runner. Every job sends a webhook with the labels it's looking for\n   * based on runs-on. We match the labels from the webhook with the labels specified here. If all the labels specified here are present in the\n   * job's labels, this provider will be chosen and spawn a new runner.\n   *\n   * @default ['codebuild']\n   */\n  readonly labels?: string[];\n\n  /**\n   * GitHub Actions runner group name.\n   *\n   * If specified, the runner will be registered with this group name. Setting a runner group can help managing access to self-hosted runners. It\n   * requires a paid GitHub account.\n   *\n   * The group must exist or the runner will not start.\n   *\n   * Users will still be able to trigger this runner with the correct labels. But the runner will only be able to run jobs from repos allowed to use the group.\n   *\n   * @default undefined\n   */\n  readonly group?: string;\n\n  /**\n   * VPC to launch the runners in.\n   *\n   * @default no VPC\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Security group to assign to this instance.\n   *\n   * @default public project with no security group\n   *\n   * @deprecated use {@link securityGroups}\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Security groups to assign to this instance.\n   *\n   * @default a new security group, if {@link vpc} is used\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * @default no subnet\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * The type of compute to use for this build.\n   * See the {@link ComputeType} enum for the possible values.\n   *\n   * The compute type determines CPU, memory, and disk space:\n   * - SMALL: 2 vCPU, 3 GB RAM, 64 GB disk\n   * - MEDIUM: 4 vCPU, 7 GB RAM, 128 GB disk\n   * - LARGE: 8 vCPU, 15 GB RAM, 128 GB disk\n   * - X2_LARGE: 72 vCPU, 145 GB RAM, 256 GB disk (Linux) or 824 GB disk (Windows)\n   *\n   * Use a larger compute type when you need more disk space for building larger Docker images.\n   *\n   * For more details, see https://docs.aws.amazon.com/codebuild/latest/userguide/build-env-ref-compute-types.html#environment.types\n   *\n   * @default {@link ComputeType#SMALL}\n   */\n  readonly computeType?: codebuild.ComputeType;\n\n  /**\n   * The number of minutes after which AWS CodeBuild stops the build if it's\n   * not complete. For valid values, see the timeoutInMinutes field in the AWS\n   * CodeBuild User Guide.\n   *\n   * @default Duration.hours(1)\n   */\n  readonly timeout?: Duration;\n\n  /**\n   * Support building and running Docker images by enabling Docker-in-Docker (dind) and the required CodeBuild privileged mode. Disabling this can\n   * speed up provisioning of CodeBuild runners. If you don't intend on running or building Docker images, disable this for faster start-up times.\n   *\n   * @default true\n   */\n  readonly dockerInDocker?: boolean;\n}\n\n/**\n * GitHub Actions runner provider using CodeBuild to execute jobs.\n *\n * Creates a project that gets started for each job.\n *\n * This construct is not meant to be used by itself. It should be passed in the providers property for GitHubRunners.\n */\nexport class CodeBuildRunnerProvider extends BaseProvider implements IRunnerProvider {\n  /**\n   * Path to Dockerfile for Linux x64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.\n   *\n   * Available build arguments that can be set in the image builder:\n   * * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   * * `DOCKER_CHANNEL` overrides the channel from which Docker will be downloaded. Defaults to `\"stable\"`.\n   * * `DIND_COMMIT` overrides the commit where dind is found.\n   * * `DOCKER_VERSION` overrides the installed Docker version.\n   * * `DOCKER_COMPOSE_VERSION` overrides the installed docker-compose version.\n   *\n   * @deprecated Use `imageBuilder()` instead.\n   */\n  public static readonly LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'codebuild', 'linux-x64');\n\n  /**\n   * Path to Dockerfile for Linux ARM64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.\n   *\n   * Available build arguments that can be set in the image builder:\n   * * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   * * `DOCKER_CHANNEL` overrides the channel from which Docker will be downloaded. Defaults to `\"stable\"`.\n   * * `DIND_COMMIT` overrides the commit where dind is found.\n   * * `DOCKER_VERSION` overrides the installed Docker version.\n   * * `DOCKER_COMPOSE_VERSION` overrides the installed docker-compose version.\n   *\n   * @deprecated Use `imageBuilder()` instead.\n   */\n  public static readonly LINUX_ARM64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'codebuild', 'linux-arm64');\n\n  /**\n   * Create new image builder that builds CodeBuild specific runner images.\n   *\n   * You can customize the OS, architecture, VPC, subnet, security groups, etc. by passing in props.\n   *\n   * You can add components to the image builder by calling `imageBuilder.addComponent()`.\n   *\n   * The default OS is Ubuntu running on x64 architecture.\n   *\n   * Included components:\n   *  * `RunnerImageComponent.requiredPackages()`\n   *  * `RunnerImageComponent.runnerUser()`\n   *  * `RunnerImageComponent.git()`\n   *  * `RunnerImageComponent.githubCli()`\n   *  * `RunnerImageComponent.awsCli()`\n   *  * `RunnerImageComponent.docker()`\n   *  * `RunnerImageComponent.githubRunner()`\n   */\n  public static imageBuilder(scope: Construct, id: string, props?: RunnerImageBuilderProps) {\n    return RunnerImageBuilder.new(scope, id, {\n      os: Os.LINUX_UBUNTU,\n      architecture: Architecture.X86_64,\n      components: [\n        RunnerImageComponent.requiredPackages(),\n        RunnerImageComponent.runnerUser(),\n        RunnerImageComponent.git(),\n        RunnerImageComponent.githubCli(),\n        RunnerImageComponent.awsCli(),\n        RunnerImageComponent.docker(),\n        RunnerImageComponent.githubRunner(props?.runnerVersion ?? RunnerVersion.latest()),\n      ],\n      ...props,\n    });\n  }\n\n  /**\n   * CodeBuild project hosting the runner.\n   */\n  readonly project: codebuild.Project;\n\n  /**\n   * Labels associated with this provider.\n   */\n  readonly labels: string[];\n\n  /**\n   * Grant principal used to add permissions to the runner role.\n   */\n  readonly grantPrincipal: iam.IPrincipal;\n\n  /**\n   * Docker image loaded with GitHub Actions Runner and its prerequisites. The image is built by an image builder and is specific to CodeBuild.\n   *\n   * @deprecated This field is internal and should not be accessed directly.\n   */\n  readonly image: RunnerImage;\n\n  /**\n   * Log group where provided runners will save their logs.\n   *\n   * Note that this is not the job log, but the runner itself. It will not contain output from the GitHub Action but only metadata on its execution.\n   */\n  readonly logGroup: logs.ILogGroup;\n\n  readonly retryableErrors = [\n    'CodeBuild.CodeBuildException',\n    'CodeBuild.AccountLimitExceededException',\n  ];\n\n  private readonly group?: string;\n  private readonly vpc?: ec2.IVpc;\n  private readonly securityGroups?: ec2.ISecurityGroup[];\n  private readonly dind: boolean;\n  private readonly defaultLabels: boolean;\n\n  constructor(scope: Construct, id: string, props?: CodeBuildRunnerProviderProps) {\n    super(scope, id, props);\n\n    // warn against isolated networks\n    if (props?.subnetSelection?.subnetType == ec2.SubnetType.PRIVATE_ISOLATED) {\n      Annotations.of(this).addWarning('Private isolated subnets cannot pull from public ECR and VPC endpoint is not supported yet. ' +\n        'See https://github.com/aws/containers-roadmap/issues/1160');\n    }\n\n    // error out on no-nat networks because the build will hang\n    if (props?.subnetSelection?.subnetType == ec2.SubnetType.PUBLIC) {\n      Annotations.of(this).addError('Public subnets do not work with CodeBuild as it cannot be assigned an IP. ' +\n        'See https://docs.aws.amazon.com/codebuild/latest/userguide/vpc-support.html#best-practices-for-vpcs');\n    }\n\n    this.labels = this.labelsFromProperties('codebuild', props?.label, props?.labels);\n    this.group = props?.group;\n    this.vpc = props?.vpc;\n    if (props?.securityGroup) {\n      this.securityGroups = [props.securityGroup];\n    } else {\n      if (props?.securityGroups) {\n        this.securityGroups = props.securityGroups;\n      } else {\n        if (this.vpc) {\n          this.securityGroups = [new ec2.SecurityGroup(this, 'SG', { vpc: this.vpc })];\n        }\n      }\n    }\n\n    this.dind = props?.dockerInDocker ?? true;\n    this.defaultLabels = props?.defaultLabels ?? true;\n\n    let buildSpec = {\n      version: 0.2,\n      env: {\n        variables: {\n          RUNNER_TOKEN: 'unspecified',\n          RUNNER_NAME: 'unspecified',\n          RUNNER_LABEL: 'unspecified',\n          OWNER: 'unspecified',\n          REPO: 'unspecified',\n          GITHUB_DOMAIN: 'github.com',\n          REGISTRATION_URL: 'unspecified',\n          RUNNER_GROUP1: '',\n          RUNNER_GROUP2: '',\n          DEFAULT_LABELS: '',\n        },\n      },\n      phases: {\n        install: {\n          commands: [\n            this.dind ? 'nohup dockerd --host=unix:///var/run/docker.sock --host=tcp://127.0.0.1:2375 --storage-driver=overlay2 &' : '',\n            this.dind ? 'timeout 15 sh -c \"until docker info; do echo .; sleep 1; done\"' : '',\n            'if [ \"${RUNNER_VERSION}\" = \"latest\" ]; then RUNNER_FLAGS=\"\"; else RUNNER_FLAGS=\"--disableupdate\"; fi',\n            'sudo -Hu runner /home/runner/config.sh --unattended --url \"${REGISTRATION_URL}\" --token \"${RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${RUNNER_LABEL},cdkghr:started:`date +%s`\" ${RUNNER_FLAGS} --name \"${RUNNER_NAME}\" ${RUNNER_GROUP1} ${RUNNER_GROUP2} ${DEFAULT_LABELS}',\n          ],\n        },\n        build: {\n          commands: [\n            'sudo --preserve-env=AWS_CONTAINER_CREDENTIALS_RELATIVE_URI,AWS_DEFAULT_REGION,AWS_REGION -Hu runner /home/runner/run.sh',\n            'STATUS=$(grep -Phors \"finish job request for job [0-9a-f\\\\-]+ with result: \\\\K.*\" /home/runner/_diag/ | tail -n1)',\n            '[ -n \"$STATUS\" ] && echo CDKGHA JOB DONE \"$RUNNER_LABEL\" \"$STATUS\"',\n          ],\n        },\n      },\n    };\n\n    const imageBuilder = props?.imageBuilder ?? CodeBuildRunnerProvider.imageBuilder(this, 'Image Builder');\n    const image = this.image = imageBuilder.bindDockerImage();\n\n    if (image.os.is(Os.WINDOWS)) {\n      buildSpec.phases.install.commands = [\n        'cd \\\\actions',\n        'if (${Env:RUNNER_VERSION} -eq \"latest\") { $RunnerFlags = \"\" } else { $RunnerFlags = \"--disableupdate\" }',\n        './config.cmd --unattended --url \"${Env:REGISTRATION_URL}\" --token \"${Env:RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${Env:RUNNER_LABEL},cdkghr:started:$(Get-Date -UFormat %s)\" ${RunnerFlags} --name \"${Env:RUNNER_NAME}\" ${Env:RUNNER_GROUP1} ${Env:RUNNER_GROUP2} ${Env:DEFAULT_LABELS}',\n      ];\n      buildSpec.phases.build.commands = [\n        'cd \\\\actions',\n        './run.cmd',\n        '$STATUS = Select-String -Path \\'./_diag/*.log\\' -Pattern \\'finish job request for job [0-9a-f\\\\-]+ with result: (.*)\\' | %{$_.Matches.Groups[1].Value} | Select-Object -Last 1',\n        'if ($STATUS) { echo \"CDKGHA JOB DONE $\\{Env:RUNNER_LABEL\\} $STATUS\" }',\n      ];\n    }\n\n    // choose build image\n    let buildImage: codebuild.IBuildImage | undefined;\n    if (image.os.isIn(Os._ALL_LINUX_VERSIONS)) {\n      if (image.architecture.is(Architecture.X86_64)) {\n        buildImage = codebuild.LinuxBuildImage.fromEcrRepository(image.imageRepository, image.imageTag);\n      } else if (image.architecture.is(Architecture.ARM64)) {\n        buildImage = codebuild.LinuxArmBuildImage.fromEcrRepository(image.imageRepository, image.imageTag);\n      }\n    }\n    if (image.os.is(Os.WINDOWS)) {\n      if (image.architecture.is(Architecture.X86_64)) {\n        buildImage = codebuild.WindowsBuildImage.fromEcrRepository(image.imageRepository, image.imageTag, codebuild.WindowsImageType.SERVER_2019);\n      }\n    }\n\n    if (buildImage === undefined) {\n      throw new Error(`Unable to find supported CodeBuild image for ${image.os.name}/${image.architecture.name}`);\n    }\n\n    // create project\n    this.logGroup = new logs.LogGroup(\n      this,\n      'Logs',\n      {\n        retention: props?.logRetention ?? RetentionDays.ONE_MONTH,\n        removalPolicy: RemovalPolicy.DESTROY,\n      },\n    );\n    this.project = new codebuild.Project(\n      this,\n      'CodeBuild',\n      {\n        description: `GitHub Actions self-hosted runner for labels ${this.labels}`,\n        buildSpec: codebuild.BuildSpec.fromObject(buildSpec),\n        vpc: this.vpc,\n        securityGroups: this.securityGroups,\n        subnetSelection: props?.subnetSelection,\n        timeout: props?.timeout ?? Duration.hours(1),\n        environment: {\n          buildImage,\n          computeType: props?.computeType ?? ComputeType.SMALL,\n          privileged: this.dind && !image.os.is(Os.WINDOWS),\n        },\n        logging: {\n          cloudWatch: {\n            logGroup: this.logGroup,\n          },\n        },\n      },\n    );\n\n    this.grantPrincipal = this.project.grantPrincipal;\n\n    // allow SSM Session Manager access\n    // this.project.role?.addToPrincipalPolicy(MINIMAL_SSM_SESSION_MANAGER_POLICY_STATEMENT);\n    // step function won't let us pass `debugSessionEnabled: true` unless we use batch, so we can't use this\n  }\n\n  /**\n   * Generate step function task(s) to start a new runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters workflow job details\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable {\n    return new stepfunctions_tasks.CodeBuildStartBuild(\n      this,\n      'State',\n      {\n        stateName: generateStateName(this),\n        integrationPattern: IntegrationPattern.RUN_JOB, // sync\n        project: this.project,\n        environmentVariablesOverride: {\n          RUNNER_TOKEN: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.runnerTokenPath,\n          },\n          RUNNER_NAME: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.runnerNamePath,\n          },\n          RUNNER_LABEL: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.labelsPath,\n          },\n          RUNNER_GROUP1: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.group ? '--runnergroup' : '',\n          },\n          RUNNER_GROUP2: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.group ? this.group : '',\n          },\n          DEFAULT_LABELS: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: this.defaultLabels ? '' : '--no-default-labels',\n          },\n          GITHUB_DOMAIN: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.githubDomainPath,\n          },\n          OWNER: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.ownerPath,\n          },\n          REPO: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.repoPath,\n          },\n          REGISTRATION_URL: {\n            type: codebuild.BuildEnvironmentVariableType.PLAINTEXT,\n            value: parameters.registrationUrl,\n          },\n        },\n      },\n    );\n  }\n\n  grantStateMachine(_: iam.IGrantable) {\n  }\n\n  status(statusFunctionRole: iam.IGrantable): IRunnerProviderStatus {\n    this.image.imageRepository.grant(statusFunctionRole, 'ecr:DescribeImages');\n\n    return {\n      type: this.constructor.name,\n      labels: this.labels,\n      constructPath: this.node.path,\n      vpcArn: this.vpc?.vpcArn,\n      securityGroups: this.securityGroups?.map(sg => sg.securityGroupId),\n      roleArn: this.project.role?.roleArn,\n      logGroup: this.logGroup.logGroupName,\n      image: {\n        imageRepository: this.image.imageRepository.repositoryUri,\n        imageTag: this.image.imageTag,\n        imageBuilderLogGroup: this.image.logGroup?.logGroupName,\n      },\n    };\n  }\n\n  /**\n   * The network connections associated with this resource.\n   */\n  public get connections(): ec2.Connections {\n    return this.project.connections;\n  }\n}\n\n/**\n * @deprecated use {@link CodeBuildRunnerProvider}\n */\nexport class CodeBuildRunner extends CodeBuildRunnerProvider {\n}\n"]}
|
package/lib/providers/common.js
CHANGED
|
@@ -45,7 +45,7 @@ class RunnerVersion {
|
|
|
45
45
|
}
|
|
46
46
|
exports.RunnerVersion = RunnerVersion;
|
|
47
47
|
_a = JSII_RTTI_SYMBOL_1;
|
|
48
|
-
RunnerVersion[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerVersion", version: "0.14.
|
|
48
|
+
RunnerVersion[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerVersion", version: "0.14.21" };
|
|
49
49
|
/**
|
|
50
50
|
* CPU architecture enum for an image.
|
|
51
51
|
*/
|
|
@@ -94,7 +94,7 @@ class Architecture {
|
|
|
94
94
|
}
|
|
95
95
|
exports.Architecture = Architecture;
|
|
96
96
|
_b = JSII_RTTI_SYMBOL_1;
|
|
97
|
-
Architecture[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Architecture", version: "0.14.
|
|
97
|
+
Architecture[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Architecture", version: "0.14.21" };
|
|
98
98
|
/**
|
|
99
99
|
* ARM64
|
|
100
100
|
*/
|
|
@@ -137,7 +137,7 @@ class Os {
|
|
|
137
137
|
}
|
|
138
138
|
exports.Os = Os;
|
|
139
139
|
_c = JSII_RTTI_SYMBOL_1;
|
|
140
|
-
Os[_c] = { fqn: "@cloudsnorkel/cdk-github-runners.Os", version: "0.14.
|
|
140
|
+
Os[_c] = { fqn: "@cloudsnorkel/cdk-github-runners.Os", version: "0.14.21" };
|
|
141
141
|
/**
|
|
142
142
|
* Linux
|
|
143
143
|
*
|
|
@@ -80,7 +80,7 @@ class CompositeProvider {
|
|
|
80
80
|
}
|
|
81
81
|
exports.CompositeProvider = CompositeProvider;
|
|
82
82
|
_a = JSII_RTTI_SYMBOL_1;
|
|
83
|
-
CompositeProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CompositeProvider", version: "0.14.
|
|
83
|
+
CompositeProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CompositeProvider", version: "0.14.21" };
|
|
84
84
|
/**
|
|
85
85
|
* Internal implementation of fallback runner provider.
|
|
86
86
|
*
|
package/lib/providers/ec2.js
CHANGED
|
@@ -423,7 +423,7 @@ class Ec2RunnerProvider extends common_1.BaseProvider {
|
|
|
423
423
|
}
|
|
424
424
|
exports.Ec2RunnerProvider = Ec2RunnerProvider;
|
|
425
425
|
_a = JSII_RTTI_SYMBOL_1;
|
|
426
|
-
Ec2RunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.Ec2RunnerProvider", version: "0.14.
|
|
426
|
+
Ec2RunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.Ec2RunnerProvider", version: "0.14.21" };
|
|
427
427
|
/**
|
|
428
428
|
* @deprecated use {@link Ec2RunnerProvider}
|
|
429
429
|
*/
|
|
@@ -431,5 +431,5 @@ class Ec2Runner extends Ec2RunnerProvider {
|
|
|
431
431
|
}
|
|
432
432
|
exports.Ec2Runner = Ec2Runner;
|
|
433
433
|
_b = JSII_RTTI_SYMBOL_1;
|
|
434
|
-
Ec2Runner[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Ec2Runner", version: "0.14.
|
|
434
|
+
Ec2Runner[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Ec2Runner", version: "0.14.21" };
|
|
435
435
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ec2.js","sourceRoot":"","sources":["../../src/providers/ec2.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport {\n  aws_ec2 as ec2,\n  aws_iam as iam,\n  aws_logs as logs,\n  aws_stepfunctions as stepfunctions,\n  aws_stepfunctions_tasks as stepfunctions_tasks,\n  Duration,\n  RemovalPolicy,\n  Stack,\n} from 'aws-cdk-lib';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { IntegrationPattern } from 'aws-cdk-lib/aws-stepfunctions';\nimport { Construct } from 'constructs';\nimport {\n  amiRootDevice,\n  Architecture,\n  BaseProvider,\n  IRunnerProvider,\n  IRunnerProviderStatus,\n  Os,\n  RunnerAmi,\n  RunnerProviderProps,\n  RunnerRuntimeParameters,\n  RunnerVersion,\n  generateStateName,\n  StorageOptions,\n} from './common';\nimport {\n  AwsImageBuilderRunnerImageBuilder,\n  IRunnerImageBuilder,\n  RunnerImageBuilder,\n  RunnerImageBuilderProps,\n  RunnerImageBuilderType,\n  RunnerImageComponent,\n} from '../image-builders';\nimport { MINIMAL_EC2_SSM_SESSION_MANAGER_POLICY_STATEMENT } from '../utils';\n\n// this script is specifically made so `poweroff` is absolutely always called\n// each `{}` is a variable coming from `params` below\nconst linuxUserDataTemplate = `#!/bin/bash -x\nTASK_TOKEN=\"{}\"\nlogGroupName=\"{}\"\nrunnerNamePath=\"{}\"\ngithubDomainPath=\"{}\"\nownerPath=\"{}\"\nrepoPath=\"{}\"\nrunnerTokenPath=\"{}\"\nlabels=\"{}\"\nregistrationURL=\"{}\"\nrunnerGroup1=\"{}\"\nrunnerGroup2=\"{}\"\ndefaultLabels=\"{}\"\n\nheartbeat () {\n  while true; do\n    aws stepfunctions send-task-heartbeat --task-token \"$TASK_TOKEN\"\n    sleep 60\n  done\n}\nsetup_logs () {\n  cat <<EOF > /tmp/log.conf || exit 1\n  {\n    \"logs\": {\n      \"log_stream_name\": \"unknown\",\n      \"logs_collected\": {\n        \"files\": {\n          \"collect_list\": [\n            {\n              \"file_path\": \"/var/log/runner.log\",\n              \"log_group_name\": \"$logGroupName\",\n              \"log_stream_name\": \"$runnerNamePath\",\n              \"timezone\": \"UTC\"\n            }\n          ]\n        }\n      }\n    }\n  }\nEOF\n  /opt/aws/amazon-cloudwatch-agent/bin/amazon-cloudwatch-agent-ctl -a fetch-config -m ec2 -s -c file:/tmp/log.conf || exit 2\n}\naction () {\n  # Determine the value of RUNNER_FLAGS\n  if [ \"$(< /home/runner/RUNNER_VERSION)\" = \"latest\" ]; then\n    RUNNER_FLAGS=\"\"\n  else\n    RUNNER_FLAGS=\"--disableupdate\"\n  fi\n\n  labelsTemplate=\"$labels,cdkghr:started:$(date +%s)\"\n\n  # Execute the configuration command for runner registration\n  sudo -Hu runner /home/runner/config.sh --unattended --url \"$registrationURL\" --token \"$runnerTokenPath\" --ephemeral --work _work --labels \"$labelsTemplate\" $RUNNER_FLAGS --name \"$runnerNamePath\" $runnerGroup1 $runnerGroup2 $defaultLabels || exit 1\n\n  # Execute the run command\n  sudo --preserve-env=AWS_REGION -Hu runner /home/runner/run.sh || exit 2\n\n  # Retrieve the status\n  STATUS=$(grep -Phors \"finish job request for job [0-9a-f\\\\-]+ with result: \\K.*\" /home/runner/_diag/ | tail -n1)\n\n  # Check and print the job status\n  [ -n \"$STATUS\" ] && echo CDKGHA JOB DONE \"$labels\" \"$STATUS\"\n}\nheartbeat &\nif setup_logs && action | tee /var/log/runner.log 2>&1; then\n  aws stepfunctions send-task-success --task-token \"$TASK_TOKEN\" --task-output '{\"ok\": true}'\nelse\n  aws stepfunctions send-task-failure --task-token \"$TASK_TOKEN\"\nfi\nsleep 10  # give cloudwatch agent its default 5 seconds buffer duration to upload logs\npoweroff\n`.replace(/{/g, '\\\\{').replace(/}/g, '\\\\}').replace(/\\\\{\\\\}/g, '{}');\n\n// this script is specifically made so `poweroff` is absolutely always called\n// each `{}` is a variable coming from `params` below and their order should match the linux script\nconst windowsUserDataTemplate = `<powershell>\n$TASK_TOKEN = \"{}\"\n$logGroupName=\"{}\"\n$runnerNamePath=\"{}\"\n$githubDomainPath=\"{}\"\n$ownerPath=\"{}\"\n$repoPath=\"{}\"\n$runnerTokenPath=\"{}\"\n$labels=\"{}\"\n$registrationURL=\"{}\"\n$runnerGroup1=\"{}\"\n$runnerGroup2=\"{}\"\n$defaultLabels=\"{}\"\n\n# EC2Launch only starts ssm agent after user data is done, so we need to start it ourselves (it is disabled by default)\nSet-Service -StartupType Manual AmazonSSMAgent\nStart-Service AmazonSSMAgent\n\nStart-Job -ScriptBlock {\n  while (1) {\n    aws stepfunctions send-task-heartbeat --task-token \"$using:TASK_TOKEN\"\n    sleep 60\n  }\n}\nfunction setup_logs () {\n  echo \"{\n    \\`\"logs\\`\": {\n      \\`\"log_stream_name\\`\": \\`\"unknown\\`\",\n      \\`\"logs_collected\\`\": {\n        \\`\"files\\`\": {\n         \\`\"collect_list\\`\": [\n            {\n              \\`\"file_path\\`\": \\`\"/actions/runner.log\\`\",\n              \\`\"log_group_name\\`\": \\`\"$logGroupName\\`\",\n              \\`\"log_stream_name\\`\": \\`\"$runnerNamePath\\`\",\n              \\`\"timezone\\`\": \\`\"UTC\\`\"\n            }\n          ]\n        }\n      }\n    }\n  }\" | Out-File -Encoding ASCII $Env:TEMP/log.conf\n  & \"C:/Program Files/Amazon/AmazonCloudWatchAgent/amazon-cloudwatch-agent-ctl.ps1\" -a fetch-config -m ec2 -s -c file:$Env:TEMP/log.conf\n}\nfunction action () {\n  cd /actions\n  $RunnerVersion = Get-Content /actions/RUNNER_VERSION -Raw\n  if ($RunnerVersion -eq \"latest\") { $RunnerFlags = \"\" } else { $RunnerFlags = \"--disableupdate\" }\n  ./config.cmd --unattended --url \"\\${registrationUrl}\" --token \"\\${runnerTokenPath}\" --ephemeral --work _work --labels \"\\${labels},cdkghr:started:$(Get-Date -UFormat +%s)\" $RunnerFlags --name \"\\${runnerNamePath}\" \\${runnerGroup1} \\${runnerGroup2} \\${defaultLabels} 2>&1 | Out-File -Encoding ASCII -Append /actions/runner.log\n\n  if ($LASTEXITCODE -ne 0) { return 1 }\n  ./run.cmd 2>&1 | Out-File -Encoding ASCII -Append /actions/runner.log\n  if ($LASTEXITCODE -ne 0) { return 2 }\n\n  $STATUS = Select-String -Path './_diag/*.log' -Pattern 'finish job request for job [0-9a-f\\\\-]+ with result: (.*)' | %{$_.Matches.Groups[1].Value} | Select-Object -Last 1\n\n  if ($STATUS) {\n      echo \"CDKGHA JOB DONE \\${labels} $STATUS\" | Out-File -Encoding ASCII -Append /actions/runner.log\n  }\n\n  return 0\n}\nsetup_logs\n$r = action\nif ($r -eq 0) {\n  aws stepfunctions send-task-success --task-token \"$TASK_TOKEN\" --task-output '{ }'\n} else {\n  aws stepfunctions send-task-failure --task-token \"$TASK_TOKEN\"\n}\nStart-Sleep -Seconds 10  # give cloudwatch agent its default 5 seconds buffer duration to upload logs\nStop-Computer -ComputerName localhost -Force\n</powershell>\n`.replace(/{/g, '\\\\{').replace(/}/g, '\\\\}').replace(/\\\\{\\\\}/g, '{}');\n\n\n/**\n * Properties for {@link Ec2RunnerProvider} construct.\n */\nexport interface Ec2RunnerProviderProps extends RunnerProviderProps {\n  /**\n   * Runner image builder used to build AMI containing GitHub Runner and all requirements.\n   *\n   * The image builder determines the OS and architecture of the runner.\n   *\n   * @default Ec2RunnerProvider.imageBuilder()\n   */\n  readonly imageBuilder?: IRunnerImageBuilder;\n\n  /**\n   * @deprecated use imageBuilder\n   */\n  readonly amiBuilder?: IRunnerImageBuilder;\n\n  /**\n   * GitHub Actions labels used for this provider.\n   *\n   * These labels are used to identify which provider should spawn a new on-demand runner. Every job sends a webhook with the labels it's looking for\n   * based on runs-on. We match the labels from the webhook with the labels specified here. If all the labels specified here are present in the\n   * job's labels, this provider will be chosen and spawn a new runner.\n   *\n   * @default ['ec2']\n   */\n  readonly labels?: string[];\n\n  /**\n   * GitHub Actions runner group name.\n   *\n   * If specified, the runner will be registered with this group name. Setting a runner group can help managing access to self-hosted runners. It\n   * requires a paid GitHub account.\n   *\n   * The group must exist or the runner will not start.\n   *\n   * Users will still be able to trigger this runner with the correct labels. But the runner will only be able to run jobs from repos allowed to use the group.\n   *\n   * @default undefined\n   */\n  readonly group?: string;\n\n  /**\n   * Instance type for launched runner instances.\n   *\n   * @default m6i.large\n   */\n  readonly instanceType?: ec2.InstanceType;\n\n  /**\n   * Size of volume available for launched runner instances. This modifies the boot volume size and doesn't add any additional volumes.\n   *\n   * @default 30GB\n   */\n  readonly storageSize?: cdk.Size;\n\n  /**\n   * Options for runner instance storage volume.\n   */\n  readonly storageOptions?: StorageOptions;\n\n  /**\n   * Security Group to assign to launched runner instances.\n   *\n   * @default a new security group\n   *\n   * @deprecated use {@link securityGroups}\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Security groups to assign to launched runner instances.\n   *\n   * @default a new security group\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * Subnet where the runner instances will be launched.\n   *\n   * @default default subnet of account's default VPC\n   *\n   * @deprecated use {@link vpc} and {@link subnetSelection}\n   */\n  readonly subnet?: ec2.ISubnet;\n\n  /**\n   * VPC where runner instances will be launched.\n   *\n   * @default default account VPC\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Where to place the network interfaces within the VPC. Only the first matched subnet will be used.\n   *\n   * @default default VPC subnet\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * Use spot instances to save money. Spot instances are cheaper but not always available and can be stopped prematurely.\n   *\n   * @default false\n   */\n  readonly spot?: boolean;\n\n  /**\n   * Set a maximum price for spot instances.\n   *\n   * @default no max price (you will pay current spot price)\n   */\n  readonly spotMaxPrice?: string;\n}\n\n/**\n * GitHub Actions runner provider using EC2 to execute jobs.\n *\n * This construct is not meant to be used by itself. It should be passed in the providers property for GitHubRunners.\n */\nexport class Ec2RunnerProvider extends BaseProvider implements IRunnerProvider {\n  /**\n   * Create new image builder that builds EC2 specific runner images.\n   *\n   * You can customize the OS, architecture, VPC, subnet, security groups, etc. by passing in props.\n   *\n   * You can add components to the image builder by calling `imageBuilder.addComponent()`.\n   *\n   * The default OS is Ubuntu running on x64 architecture.\n   *\n   * Included components:\n   *  * `RunnerImageComponent.requiredPackages()`\n   *  * `RunnerImageComponent.cloudWatchAgent()`\n   *  * `RunnerImageComponent.runnerUser()`\n   *  * `RunnerImageComponent.git()`\n   *  * `RunnerImageComponent.githubCli()`\n   *  * `RunnerImageComponent.awsCli()`\n   *  * `RunnerImageComponent.docker()`\n   *  * `RunnerImageComponent.githubRunner()`\n   */\n  public static imageBuilder(scope: Construct, id: string, props?: RunnerImageBuilderProps) {\n    return RunnerImageBuilder.new(scope, id, {\n      os: Os.LINUX_UBUNTU,\n      architecture: Architecture.X86_64,\n      builderType: RunnerImageBuilderType.AWS_IMAGE_BUILDER,\n      components: [\n        RunnerImageComponent.requiredPackages(),\n        RunnerImageComponent.cloudWatchAgent(),\n        RunnerImageComponent.runnerUser(),\n        RunnerImageComponent.git(),\n        RunnerImageComponent.githubCli(),\n        RunnerImageComponent.awsCli(),\n        RunnerImageComponent.docker(),\n        RunnerImageComponent.githubRunner(props?.runnerVersion ?? RunnerVersion.latest()),\n      ],\n      ...props,\n    });\n  }\n\n  /**\n   * Labels associated with this provider.\n   */\n  readonly labels: string[];\n\n  /**\n   * Grant principal used to add permissions to the runner role.\n   */\n  readonly grantPrincipal: iam.IPrincipal;\n\n  /**\n   * Log group where provided runners will save their logs.\n   *\n   * Note that this is not the job log, but the runner itself. It will not contain output from the GitHub Action but only metadata on its execution.\n   */\n  readonly logGroup: logs.ILogGroup;\n\n  readonly retryableErrors = [\n    'Ec2.Ec2Exception',\n    'States.Timeout',\n  ];\n\n  private readonly group?: string;\n  private readonly amiBuilder: IRunnerImageBuilder;\n  private readonly ami: RunnerAmi;\n  private readonly role: iam.Role;\n  private readonly instanceType: ec2.InstanceType;\n  private readonly storageSize: cdk.Size;\n  private readonly storageOptions?: StorageOptions;\n  private readonly spot: boolean;\n  private readonly spotMaxPrice: string | undefined;\n  private readonly vpc: ec2.IVpc;\n  private readonly subnets: ec2.ISubnet[];\n  private readonly securityGroups: ec2.ISecurityGroup[];\n  private readonly defaultLabels: boolean;\n\n  constructor(scope: Construct, id: string, props?: Ec2RunnerProviderProps) {\n    super(scope, id, props);\n\n    this.labels = props?.labels ?? ['ec2'];\n    this.group = props?.group;\n    this.vpc = props?.vpc ?? ec2.Vpc.fromLookup(this, 'Default VPC', { isDefault: true });\n    this.securityGroups = props?.securityGroup ? [props.securityGroup] : (props?.securityGroups ?? [new ec2.SecurityGroup(this, 'SG', { vpc: this.vpc })]);\n    this.subnets = props?.subnet ? [props.subnet] : this.vpc.selectSubnets(props?.subnetSelection).subnets;\n    this.instanceType = props?.instanceType ?? ec2.InstanceType.of(ec2.InstanceClass.M6I, ec2.InstanceSize.LARGE);\n    this.storageSize = props?.storageSize ?? cdk.Size.gibibytes(30); // 30 is the minimum for Windows\n    this.storageOptions = props?.storageOptions;\n    this.spot = props?.spot ?? false;\n    this.spotMaxPrice = props?.spotMaxPrice;\n    this.defaultLabels = props?.defaultLabels ?? true;\n\n    this.amiBuilder = props?.imageBuilder ?? props?.amiBuilder ?? Ec2RunnerProvider.imageBuilder(this, 'Ami Builder', {\n      vpc: props?.vpc,\n      subnetSelection: props?.subnetSelection,\n      securityGroups: this.securityGroups,\n    });\n    this.ami = this.amiBuilder.bindAmi();\n\n    if (this.amiBuilder instanceof AwsImageBuilderRunnerImageBuilder) {\n      if (this.amiBuilder.storageSize && this.storageSize.toBytes() < this.amiBuilder.storageSize.toBytes()) {\n        throw new Error(`Runner storage size (${this.storageSize.toGibibytes()} GiB) must be at least the same as the image builder storage size (${this.amiBuilder.storageSize.toGibibytes()} GiB)`);\n      }\n    }\n\n    if (!this.ami.architecture.instanceTypeMatch(this.instanceType)) {\n      throw new Error(`AMI architecture (${this.ami.architecture.name}) doesn't match runner instance type (${this.instanceType} / ${this.instanceType.architecture})`);\n    }\n\n    this.grantPrincipal = this.role = new iam.Role(this, 'Role', {\n      assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n    });\n    this.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['states:SendTaskFailure', 'states:SendTaskSuccess', 'states:SendTaskHeartbeat'],\n      resources: ['*'], // no support for stateMachine.stateMachineArn :(\n      conditions: {\n        StringEquals: {\n          'aws:ResourceTag/aws:cloudformation:stack-id': cdk.Stack.of(this).stackId,\n        },\n      },\n    }));\n    this.grantPrincipal.addToPrincipalPolicy(MINIMAL_EC2_SSM_SESSION_MANAGER_POLICY_STATEMENT);\n\n    this.logGroup = new logs.LogGroup(\n      this,\n      'Logs',\n      {\n        retention: props?.logRetention ?? RetentionDays.ONE_MONTH,\n        removalPolicy: RemovalPolicy.DESTROY,\n      },\n    );\n    this.logGroup.grantWrite(this);\n  }\n\n  /**\n   * Generate step function task(s) to start a new runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters workflow job details\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable {\n    // we need to build user data in two steps because passing the template as the first parameter to stepfunctions.JsonPath.format fails on syntax\n\n    const params = [\n      stepfunctions.JsonPath.taskToken,\n      this.logGroup.logGroupName,\n      parameters.runnerNamePath,\n      parameters.githubDomainPath,\n      parameters.ownerPath,\n      parameters.repoPath,\n      parameters.runnerTokenPath,\n      parameters.labelsPath,\n      parameters.registrationUrl,\n      this.group ? '--runnergroup' : '',\n      // this is split into 2 for powershell otherwise it will pass \"--runnergroup name\" as a single argument and config.sh will fail\n      this.group ? this.group : '',\n      this.defaultLabels ? '' : '--no-default-labels',\n    ];\n\n    const passUserData = new stepfunctions.Pass(this, 'Data', {\n      stateName: generateStateName(this, 'data'),\n      parameters: {\n        userdataTemplate: this.ami.os.is(Os.WINDOWS) ? windowsUserDataTemplate : linuxUserDataTemplate,\n      },\n      resultPath: stepfunctions.JsonPath.stringAt('$.ec2'),\n    });\n\n    // we use ec2:RunInstances because we must\n    // we can't use fleets because they don't let us override user data, security groups or even disk size\n    // we can't use requestSpotInstances because it doesn't support launch templates, and it's deprecated\n    // ec2:RunInstances also seemed like the only one to immediately return an error when spot capacity is not available\n\n    // we build a complicated chain of states here because ec2:RunInstances can only try one subnet at a time\n    // if someone can figure out a good way to use Map for this, please open a PR\n\n    // build a state for each subnet we want to try\n    const instanceProfile = new iam.CfnInstanceProfile(this, 'Instance Profile', {\n      roles: [this.role.roleName],\n    });\n    const rootDeviceResource = amiRootDevice(this, this.ami.launchTemplate.launchTemplateId);\n    rootDeviceResource.node.addDependency(this.amiBuilder);\n    const subnetRunners = this.subnets.map(subnet => {\n      return new stepfunctions_tasks.CallAwsService(this, subnet.subnetId, {\n        stateName: generateStateName(this, subnet.subnetId),\n        comment: subnet.availabilityZone,\n        integrationPattern: IntegrationPattern.WAIT_FOR_TASK_TOKEN,\n        service: 'ec2',\n        action: 'runInstances',\n        heartbeatTimeout: stepfunctions.Timeout.duration(Duration.minutes(10)),\n        parameters: {\n          LaunchTemplate: {\n            LaunchTemplateId: this.ami.launchTemplate.launchTemplateId,\n          },\n          MinCount: 1,\n          MaxCount: 1,\n          InstanceType: this.instanceType.toString(),\n          UserData: stepfunctions.JsonPath.base64Encode(\n            stepfunctions.JsonPath.format(\n              stepfunctions.JsonPath.stringAt('$.ec2.userdataTemplate'),\n              ...params,\n            ),\n          ),\n          InstanceInitiatedShutdownBehavior: ec2.InstanceInitiatedShutdownBehavior.TERMINATE,\n          IamInstanceProfile: {\n            Arn: instanceProfile.attrArn,\n          },\n          MetadataOptions: {\n            HttpTokens: 'required',\n          },\n          SecurityGroupIds: this.securityGroups.map(sg => sg.securityGroupId),\n          SubnetId: subnet.subnetId,\n          BlockDeviceMappings: [{\n            DeviceName: rootDeviceResource.ref,\n            Ebs: {\n              DeleteOnTermination: true,\n              VolumeSize: this.storageSize.toGibibytes(),\n              VolumeType: this.storageOptions?.volumeType,\n              Iops: this.storageOptions?.iops,\n              Throughput: this.storageOptions?.throughput,\n            },\n          }],\n          InstanceMarketOptions: this.spot ? {\n            MarketType: 'spot',\n            SpotOptions: {\n              MaxPrice: this.spotMaxPrice,\n              SpotInstanceType: 'one-time',\n            },\n          } : undefined,\n          TagSpecifications: [ // manually propagate tags\n            {\n              ResourceType: 'instance',\n              Tags: [{\n                Key: 'GitHubRunners:Provider',\n                Value: this.node.path,\n              }],\n            },\n            {\n              ResourceType: 'volume',\n              Tags: [{\n                Key: 'GitHubRunners:Provider',\n                Value: this.node.path,\n              }],\n            },\n          ],\n        },\n        iamResources: ['*'],\n      });\n    });\n\n    // start with the first subnet\n    passUserData.next(subnetRunners[0]);\n\n    // chain up the rest of the subnets\n    for (let i = 1; i < subnetRunners.length; i++) {\n      subnetRunners[i - 1].addCatch(subnetRunners[i], {\n        errors: ['Ec2.Ec2Exception', 'States.Timeout'],\n        resultPath: stepfunctions.JsonPath.stringAt('$.lastSubnetError'),\n      });\n    }\n\n    return passUserData;\n  }\n\n  grantStateMachine(stateMachineRole: iam.IGrantable) {\n    stateMachineRole.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['iam:PassRole'],\n      resources: [this.role.roleArn],\n      conditions: {\n        StringEquals: {\n          'iam:PassedToService': 'ec2.amazonaws.com',\n        },\n      },\n    }));\n\n    stateMachineRole.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['ec2:createTags'],\n      resources: [Stack.of(this).formatArn({\n        service: 'ec2',\n        resource: '*',\n      })],\n    }));\n\n    stateMachineRole.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['iam:CreateServiceLinkedRole'],\n      resources: ['*'],\n      conditions: {\n        StringEquals: {\n          'iam:AWSServiceName': 'spot.amazonaws.com',\n        },\n      },\n    }));\n  }\n\n  status(statusFunctionRole: iam.IGrantable): IRunnerProviderStatus {\n    statusFunctionRole.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['ec2:DescribeLaunchTemplateVersions'],\n      resources: ['*'],\n    }));\n\n    return {\n      type: this.constructor.name,\n      labels: this.labels,\n      constructPath: this.node.path,\n      securityGroups: this.securityGroups.map(sg => sg.securityGroupId),\n      roleArn: this.role.roleArn,\n      logGroup: this.logGroup.logGroupName,\n      ami: {\n        launchTemplate: this.ami.launchTemplate.launchTemplateId || 'unknown',\n        amiBuilderLogGroup: this.ami.logGroup?.logGroupName,\n      },\n    };\n  }\n\n  /**\n   * The network connections associated with this resource.\n   */\n  public get connections(): ec2.Connections {\n    return new ec2.Connections({ securityGroups: this.securityGroups });\n  }\n}\n\n/**\n * @deprecated use {@link Ec2RunnerProvider}\n */\nexport class Ec2Runner extends Ec2RunnerProvider {\n}\n"]}
|
package/lib/providers/ecs.js
CHANGED
|
@@ -359,5 +359,5 @@ class EcsRunnerProvider extends common_1.BaseProvider {
|
|
|
359
359
|
}
|
|
360
360
|
exports.EcsRunnerProvider = EcsRunnerProvider;
|
|
361
361
|
_a = JSII_RTTI_SYMBOL_1;
|
|
362
|
-
EcsRunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.EcsRunnerProvider", version: "0.14.
|
|
362
|
+
EcsRunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.EcsRunnerProvider", version: "0.14.21" };
|
|
363
363
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs.js","sourceRoot":"","sources":["../../src/providers/ecs.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport {\n  aws_ec2 as ec2,\n  aws_ecs as ecs,\n  aws_iam as iam,\n  aws_logs as logs,\n  aws_stepfunctions as stepfunctions,\n  aws_stepfunctions_tasks as stepfunctions_tasks,\n  RemovalPolicy,\n  Stack,\n} from 'aws-cdk-lib';\nimport * as autoscaling from 'aws-cdk-lib/aws-autoscaling';\nimport { MachineImageType } from 'aws-cdk-lib/aws-ecs';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { IntegrationPattern } from 'aws-cdk-lib/aws-stepfunctions';\nimport { Construct } from 'constructs';\nimport {\n  amiRootDevice,\n  Architecture,\n  BaseProvider,\n  IRunnerProvider,\n  IRunnerProviderStatus,\n  Os,\n  RunnerImage,\n  RunnerProviderProps,\n  RunnerRuntimeParameters,\n  RunnerVersion,\n  generateStateName,\n  StorageOptions,\n} from './common';\nimport { ecsRunCommand } from './fargate';\nimport { IRunnerImageBuilder, RunnerImageBuilder, RunnerImageBuilderProps, RunnerImageComponent } from '../image-builders';\nimport { MINIMAL_EC2_SSM_SESSION_MANAGER_POLICY_STATEMENT, MINIMAL_ECS_SSM_SESSION_MANAGER_POLICY_STATEMENT } from '../utils';\n\n/**\n * Properties for EcsRunnerProvider.\n */\nexport interface EcsRunnerProviderProps extends RunnerProviderProps {\n  /**\n   * Runner image builder used to build Docker images containing GitHub Runner and all requirements.\n   *\n   * The image builder determines the OS and architecture of the runner.\n   *\n   * @default EcsRunnerProvider.imageBuilder()\n   */\n  readonly imageBuilder?: IRunnerImageBuilder;\n\n  /**\n   * GitHub Actions labels used for this provider.\n   *\n   * These labels are used to identify which provider should spawn a new on-demand runner. Every job sends a webhook with the labels it's looking for\n   * based on runs-on. We match the labels from the webhook with the labels specified here. If all the labels specified here are present in the\n   * job's labels, this provider will be chosen and spawn a new runner.\n   *\n   * @default ['ecs']\n   */\n  readonly labels?: string[];\n\n  /**\n   * GitHub Actions runner group name.\n   *\n   * If specified, the runner will be registered with this group name. Setting a runner group can help managing access to self-hosted runners. It\n   * requires a paid GitHub account.\n   *\n   * The group must exist or the runner will not start.\n   *\n   * Users will still be able to trigger this runner with the correct labels. But the runner will only be able to run jobs from repos allowed to use the group.\n   *\n   * @default undefined\n   */\n  readonly group?: string;\n\n  /**\n   * VPC to launch the runners in.\n   *\n   * @default default account VPC\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Subnets to run the runners in.\n   *\n   * @default ECS default\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * Security groups to assign to the task.\n   *\n   * @default a new security group\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * Existing ECS cluster to use.\n   *\n   * @default a new cluster\n   */\n  readonly cluster?: ecs.Cluster;\n\n  /**\n   * Existing capacity provider to use.\n   *\n   * Make sure the AMI used by the capacity provider is compatible with ECS.\n   *\n   * @default new capacity provider\n   */\n  readonly capacityProvider?: ecs.AsgCapacityProvider;\n\n  /**\n   * Assign public IP to the runner task.\n   *\n   * Make sure the task will have access to GitHub. A public IP might be required unless you have NAT gateway.\n   *\n   * @default true\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * The number of cpu units used by the task. 1024 units is 1 vCPU. Fractions of a vCPU are supported.\n   *\n   * @default 1024\n   */\n  readonly cpu?: number;\n\n  /**\n   * The amount (in MiB) of memory used by the task.\n   *\n   * @default 3500, unless `memoryReservationMiB` is used and then it's undefined\n   */\n  readonly memoryLimitMiB?: number;\n\n  /**\n   * The soft limit (in MiB) of memory to reserve for the container.\n   *\n   * @default undefined\n   */\n  readonly memoryReservationMiB?: number;\n\n  /**\n   * Instance type of ECS cluster instances. Only used when creating a new cluster.\n   *\n   * @default m6i.large or m6g.large\n   */\n  readonly instanceType?: ec2.InstanceType;\n\n  /**\n   * The minimum number of instances to run in the cluster. Only used when creating a new cluster.\n   *\n   * @default 0\n   */\n  readonly minInstances?: number;\n\n  /**\n   * The maximum number of instances to run in the cluster. Only used when creating a new cluster.\n   *\n   * @default 5\n   */\n  readonly maxInstances?: number;\n\n  /**\n   * Size of volume available for launched cluster instances. This modifies the boot volume size and doesn't add any additional volumes.\n   *\n   * Each instance can be used by multiple runners, so make sure there is enough space for all of them.\n   *\n   * @default default size for AMI (usually 30GB for Linux and 50GB for Windows)\n   */\n  readonly storageSize?: cdk.Size;\n\n  /**\n   * Options for runner instance storage volume.\n   */\n  readonly storageOptions?: StorageOptions;\n\n  /**\n   * Support building and running Docker images by enabling Docker-in-Docker (dind) and the required CodeBuild privileged mode. Disabling this can\n   * speed up provisioning of CodeBuild runners. If you don't intend on running or building Docker images, disable this for faster start-up times.\n   *\n   * @default true\n   */\n  readonly dockerInDocker?: boolean;\n\n  /**\n   * Use spot capacity.\n   *\n   * @default false (true if spotMaxPrice is specified)\n   */\n  readonly spot?: boolean;\n\n  /**\n   * Maximum price for spot instances.\n   */\n  readonly spotMaxPrice?: string;\n\n  /**\n   * ECS placement strategies to influence task placement.\n   *\n   * Example: [ecs.PlacementStrategy.packedByCpu()]\n   *\n   * @default undefined (no placement strategies)\n   */\n  readonly placementStrategies?: ecs.PlacementStrategy[];\n\n  /**\n   * ECS placement constraints to influence task placement.\n   *\n   * Example: [ecs.PlacementConstraint.memberOf('ecs-placement')]\n   *\n   * @default undefined (no placement constraints)\n   */\n  readonly placementConstraints?: ecs.PlacementConstraint[];\n}\n\ninterface EcsEc2LaunchTargetOptions extends stepfunctions_tasks.EcsEc2LaunchTargetOptions {\n  readonly capacityProvider: string;\n}\n\n/**\n * Custom ECS EC2 launch target that allows specifying capacity provider strategy and propagating tags.\n */\nclass CustomEcsEc2LaunchTarget extends stepfunctions_tasks.EcsEc2LaunchTarget {\n  private readonly capacityProvider: string;\n\n  constructor(options: EcsEc2LaunchTargetOptions) {\n    super(options);\n    this.capacityProvider = options.capacityProvider;\n  }\n\n  /**\n   * Called when the ECS launch type configured on RunTask\n   */\n  public bind(_task: stepfunctions_tasks.EcsRunTask,\n    _launchTargetOptions: stepfunctions_tasks.LaunchTargetBindOptions): stepfunctions_tasks.EcsLaunchTargetConfig {\n    const base = super.bind(_task, _launchTargetOptions);\n    return {\n      ...base,\n      parameters: {\n        ...(base.parameters ?? {}),\n        PropagateTags: ecs.PropagatedTagSource.TASK_DEFINITION,\n        CapacityProviderStrategy: [\n          {\n            CapacityProvider: this.capacityProvider,\n          },\n        ],\n        LaunchType: undefined, // You may choose a capacity provider or a launch type but not both.\n      },\n    };\n  }\n}\n\n/**\n * GitHub Actions runner provider using ECS on EC2 to execute jobs.\n *\n * ECS can be useful when you want more control of the infrastructure running the GitHub Actions Docker containers. You can control the autoscaling\n * group to scale down to zero during the night and scale up during work hours. This way you can still save money, but have to wait less for\n * infrastructure to spin up.\n *\n * This construct is not meant to be used by itself. It should be passed in the providers property for GitHubRunners.\n */\nexport class EcsRunnerProvider extends BaseProvider implements IRunnerProvider {\n  /**\n   * Create new image builder that builds ECS specific runner images.\n   *\n   * You can customize the OS, architecture, VPC, subnet, security groups, etc. by passing in props.\n   *\n   * You can add components to the image builder by calling `imageBuilder.addComponent()`.\n   *\n   * The default OS is Ubuntu running on x64 architecture.\n   *\n   * Included components:\n   *  * `RunnerImageComponent.requiredPackages()`\n   *  * `RunnerImageComponent.runnerUser()`\n   *  * `RunnerImageComponent.git()`\n   *  * `RunnerImageComponent.githubCli()`\n   *  * `RunnerImageComponent.awsCli()`\n   *  * `RunnerImageComponent.docker()`\n   *  * `RunnerImageComponent.githubRunner()`\n   */\n  public static imageBuilder(scope: Construct, id: string, props?: RunnerImageBuilderProps) {\n    return RunnerImageBuilder.new(scope, id, {\n      os: Os.LINUX_UBUNTU,\n      architecture: Architecture.X86_64,\n      components: [\n        RunnerImageComponent.requiredPackages(),\n        RunnerImageComponent.runnerUser(),\n        RunnerImageComponent.git(),\n        RunnerImageComponent.githubCli(),\n        RunnerImageComponent.awsCli(),\n        RunnerImageComponent.docker(),\n        RunnerImageComponent.githubRunner(props?.runnerVersion ?? RunnerVersion.latest()),\n      ],\n      ...props,\n    });\n  }\n\n  /**\n   * Cluster hosting the task hosting the runner.\n   */\n  private readonly cluster: ecs.Cluster;\n\n  /**\n   * Capacity provider used to scale the cluster.\n   *\n   * Use capacityProvider.autoScalingGroup to access the auto scaling group. This can help set up custom scaling policies.\n   */\n  readonly capacityProvider: ecs.AsgCapacityProvider;\n\n  /**\n   * ECS task hosting the runner.\n   */\n  private readonly task: ecs.Ec2TaskDefinition;\n\n  /**\n   * Container definition hosting the runner.\n   */\n  private readonly container: ecs.ContainerDefinition;\n\n  /**\n   * Labels associated with this provider.\n   */\n  readonly labels: string[];\n\n  /**\n   * VPC used for hosting the runner task.\n   */\n  private readonly vpc?: ec2.IVpc;\n\n  /**\n   * Subnets used for hosting the runner task.\n   */\n  private readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * Whether runner task will have a public IP.\n   */\n  private readonly assignPublicIp: boolean;\n\n  /**\n   * Grant principal used to add permissions to the runner role.\n   */\n  readonly grantPrincipal: iam.IPrincipal;\n\n  /**\n   * The network connections associated with this resource.\n   */\n  readonly connections: ec2.Connections;\n\n  /**\n   * Docker image loaded with GitHub Actions Runner and its prerequisites. The image is built by an image builder and is specific to ECS tasks.\n   */\n  private readonly image: RunnerImage;\n\n  /**\n   * Log group where provided runners will save their logs.\n   *\n   * Note that this is not the job log, but the runner itself. It will not contain output from the GitHub Action but only metadata on its execution.\n   */\n  readonly logGroup: logs.ILogGroup;\n\n  /**\n   * Security groups associated with this provider.\n   */\n  private readonly securityGroups: ec2.ISecurityGroup[];\n\n  /**\n   * Run docker in docker.\n   */\n  private readonly dind: boolean;\n\n  /**\n   * Runner group name.\n   */\n  private readonly group?: string;\n\n  /**\n   * Include default labels (arch, os, self-hosted) for runner.\n   */\n  private readonly defaultLabels: boolean;\n\n  /**\n   * ECS placement strategies to influence task placement.\n   */\n  private readonly placementStrategies?: ecs.PlacementStrategy[];\n\n  /**\n   * ECS placement constraints to influence task placement.\n   */\n  private readonly placementConstraints?: ecs.PlacementConstraint[];\n\n  readonly retryableErrors = [\n    'Ecs.EcsException',\n    'ECS.AmazonECSException',\n    'Ecs.LimitExceededException',\n    'Ecs.UpdateInProgressException',\n  ];\n\n  constructor(scope: Construct, id: string, props?: EcsRunnerProviderProps) {\n    super(scope, id, props);\n\n    this.labels = props?.labels ?? ['ecs'];\n    this.group = props?.group;\n    this.defaultLabels = props?.defaultLabels ?? true;\n    this.vpc = props?.vpc ?? ec2.Vpc.fromLookup(this, 'default vpc', { isDefault: true });\n    this.subnetSelection = props?.subnetSelection;\n    this.securityGroups = props?.securityGroups ?? [new ec2.SecurityGroup(this, 'security group', { vpc: this.vpc })];\n    this.connections = new ec2.Connections({ securityGroups: this.securityGroups });\n    this.assignPublicIp = props?.assignPublicIp ?? true;\n    this.placementStrategies = props?.placementStrategies;\n    this.placementConstraints = props?.placementConstraints;\n    this.cluster = props?.cluster ? props.cluster : new ecs.Cluster(\n      this,\n      'cluster',\n      {\n        vpc: this.vpc,\n        enableFargateCapacityProviders: false,\n      },\n    );\n\n    if (props?.storageOptions && !props?.storageSize) {\n      throw new Error('storageSize is required when storageOptions are specified');\n    }\n\n    const imageBuilder = props?.imageBuilder ?? EcsRunnerProvider.imageBuilder(this, 'Image Builder');\n    const image = this.image = imageBuilder.bindDockerImage();\n\n    if (props?.capacityProvider) {\n      if (props?.minInstances || props?.maxInstances || props?.instanceType || props?.storageSize || props?.spot || props?.spotMaxPrice) {\n        cdk.Annotations.of(this).addWarning('When using a custom capacity provider, minInstances, maxInstances, instanceType, storageSize, spot, and spotMaxPrice will be ignored.');\n      }\n\n      this.capacityProvider = props.capacityProvider;\n    } else {\n      const spot = props?.spot ?? props?.spotMaxPrice !== undefined;\n\n      const launchTemplate = new ec2.LaunchTemplate(this, 'Launch Template', {\n        machineImage: this.defaultClusterInstanceAmi(),\n        instanceType: props?.instanceType ?? this.defaultClusterInstanceType(),\n        blockDevices: props?.storageSize ? [\n          {\n            deviceName: amiRootDevice(this, this.defaultClusterInstanceAmi().getImage(this).imageId).ref,\n            volume: {\n              ebsDevice: {\n                deleteOnTermination: true,\n                volumeSize: props.storageSize.toGibibytes(),\n                volumeType: props.storageOptions?.volumeType,\n                iops: props.storageOptions?.iops,\n                throughput: props.storageOptions?.throughput,\n              },\n            },\n          },\n        ] : undefined,\n        spotOptions: spot ? {\n          requestType: ec2.SpotRequestType.ONE_TIME,\n          maxPrice: props?.spotMaxPrice ? parseFloat(props?.spotMaxPrice) : undefined,\n        } : undefined,\n        requireImdsv2: true,\n        securityGroup: this.securityGroups[0],\n        role: new iam.Role(this, 'Launch Template Role', {\n          assumedBy: new iam.ServicePrincipal('ec2.amazonaws.com'),\n        }),\n        userData: ec2.UserData.forOperatingSystem(image.os.is(Os.WINDOWS) ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX),\n      });\n      this.securityGroups.slice(1).map(sg => launchTemplate.connections.addSecurityGroup(sg));\n\n      const autoScalingGroup = new autoscaling.AutoScalingGroup(this, 'Auto Scaling Group', {\n        vpc: this.vpc,\n        launchTemplate,\n        vpcSubnets: this.subnetSelection,\n        minCapacity: props?.minInstances ?? 0,\n        maxCapacity: props?.maxInstances ?? 5,\n      });\n\n      this.capacityProvider = props?.capacityProvider ?? new ecs.AsgCapacityProvider(this, 'Capacity Provider', {\n        autoScalingGroup,\n        spotInstanceDraining: false, // waste of money to restart jobs as the restarted job won't have a token\n      });\n    }\n\n    this.capacityProvider.autoScalingGroup.addUserData(\n      // we don't exit on errors because all of these commands are optional\n      ...this.loginCommands(),\n      this.pullCommand(),\n      ...this.ecsSettingsCommands(),\n    );\n    this.capacityProvider.autoScalingGroup.role.addToPrincipalPolicy(MINIMAL_EC2_SSM_SESSION_MANAGER_POLICY_STATEMENT);\n    image.imageRepository.grantPull(this.capacityProvider.autoScalingGroup);\n\n    this.cluster.addAsgCapacityProvider(\n      this.capacityProvider,\n      {\n        spotInstanceDraining: false,\n        machineImageType: MachineImageType.AMAZON_LINUX_2,\n      },\n    );\n\n    this.logGroup = new logs.LogGroup(this, 'logs', {\n      retention: props?.logRetention ?? RetentionDays.ONE_MONTH,\n      removalPolicy: RemovalPolicy.DESTROY,\n    });\n\n    this.dind = (props?.dockerInDocker ?? true) && !image.os.is(Os.WINDOWS);\n\n    this.task = new ecs.Ec2TaskDefinition(this, 'task');\n    this.container = this.task.addContainer(\n      'runner',\n      {\n        image: ecs.AssetImage.fromEcrRepository(image.imageRepository, image.imageTag),\n        cpu: props?.cpu ?? 1024,\n        memoryLimitMiB: props?.memoryLimitMiB ?? (props?.memoryReservationMiB ? undefined : 3500),\n        memoryReservationMiB: props?.memoryReservationMiB,\n        logging: ecs.AwsLogDriver.awsLogs({\n          logGroup: this.logGroup,\n          streamPrefix: 'runner',\n        }),\n        command: ecsRunCommand(this.image.os, this.dind),\n        user: image.os.is(Os.WINDOWS) ? undefined : 'runner',\n        privileged: this.dind,\n      },\n    );\n\n    this.grantPrincipal = this.task.taskRole;\n\n    // permissions for SSM Session Manager\n    this.task.taskRole.addToPrincipalPolicy(MINIMAL_ECS_SSM_SESSION_MANAGER_POLICY_STATEMENT);\n  }\n\n  private defaultClusterInstanceType() {\n    if (this.image.architecture.is(Architecture.X86_64)) {\n      return ec2.InstanceType.of(ec2.InstanceClass.M6I, ec2.InstanceSize.LARGE);\n    }\n    if (this.image.architecture.is(Architecture.ARM64)) {\n      return ec2.InstanceType.of(ec2.InstanceClass.M6G, ec2.InstanceSize.LARGE);\n    }\n\n    throw new Error(`Unable to find instance type for ECS instances for ${this.image.architecture.name}`);\n  }\n\n  private defaultClusterInstanceAmi() {\n    let baseImage: ec2.IMachineImage;\n    let ssmPath: string;\n    let found = false;\n\n    if (this.image.os.isIn(Os._ALL_LINUX_VERSIONS)) {\n      if (this.image.architecture.is(Architecture.X86_64)) {\n        baseImage = ecs.EcsOptimizedImage.amazonLinux2(ecs.AmiHardwareType.STANDARD);\n        ssmPath = '/aws/service/ecs/optimized-ami/amazon-linux-2023/recommended/image_id';\n        found = true;\n      }\n      if (this.image.architecture.is(Architecture.ARM64)) {\n        baseImage = ecs.EcsOptimizedImage.amazonLinux2(ecs.AmiHardwareType.ARM);\n        ssmPath = '/aws/service/ecs/optimized-ami/amazon-linux-2023/arm64/recommended/image_id';\n        found = true;\n      }\n    }\n\n    if (this.image.os.is(Os.WINDOWS)) {\n      baseImage = ecs.EcsOptimizedImage.windows(ecs.WindowsOptimizedVersion.SERVER_2019);\n      ssmPath = '/aws/service/ami-windows-latest/Windows_Server-2019-English-Full-ECS_Optimized/image_id';\n      found = true;\n    }\n\n    if (!found) {\n      throw new Error(`Unable to find AMI for ECS instances for ${this.image.os.name}/${this.image.architecture.name}`);\n    }\n\n    const image: ec2.IMachineImage = {\n      getImage(scope: Construct): ec2.MachineImageConfig {\n        const baseImageRes = baseImage.getImage(scope);\n\n        return {\n          imageId: `resolve:ssm:${ssmPath}`,\n          userData: baseImageRes.userData,\n          osType: baseImageRes.osType,\n        };\n      },\n    };\n\n    return image;\n  }\n\n  private pullCommand() {\n    if (this.image.os.is(Os.WINDOWS)) {\n      return `Start-Job -ScriptBlock { docker pull ${this.image.imageRepository.repositoryUri}:${this.image.imageTag} }`;\n    }\n    return `docker pull ${this.image.imageRepository.repositoryUri}:${this.image.imageTag} &`;\n  }\n\n  private loginCommands() {\n    const thisStack = Stack.of(this);\n    if (this.image.os.is(Os.WINDOWS)) {\n      return [`(Get-ECRLoginCommand).Password | docker login --username AWS --password-stdin ${thisStack.account}.dkr.ecr.${thisStack.region}.amazonaws.com`];\n    }\n    return [\n      'yum install -y awscli || dnf install -y awscli',\n      `aws ecr get-login-password --region ${thisStack.region} | docker login --username AWS --password-stdin ${thisStack.account}.dkr.ecr.${thisStack.region}.amazonaws.com`,\n    ];\n  }\n\n  private ecsSettingsCommands() {\n    // don't let ECS accumulate too many stopped tasks that can end up very big in our case\n    // the default is 10m duration with 1h jitter which can end up with 1h10m delay for cleaning up stopped tasks\n    if (this.image.os.is(Os.WINDOWS)) {\n      return [\n        '[Environment]::SetEnvironmentVariable(\"ECS_ENGINE_TASK_CLEANUP_WAIT_DURATION\", \"5s\", \"Machine\")',\n        '[Environment]::SetEnvironmentVariable(\"ECS_ENGINE_TASK_CLEANUP_WAIT_DURATION_JITTER\", \"5s\", \"Machine\")',\n      ];\n    }\n    return [\n      'echo ECS_ENGINE_TASK_CLEANUP_WAIT_DURATION=5s >> /etc/ecs/ecs.config',\n      'echo ECS_ENGINE_TASK_CLEANUP_WAIT_DURATION_JITTER=5s >> /etc/ecs/ecs.config',\n    ];\n  }\n\n  /**\n   * Generate step function task(s) to start a new runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters workflow job details\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable {\n    return new stepfunctions_tasks.EcsRunTask(\n      this,\n      'State',\n      {\n        stateName: generateStateName(this),\n        integrationPattern: IntegrationPattern.RUN_JOB, // sync\n        taskDefinition: this.task,\n        cluster: this.cluster,\n        launchTarget: new CustomEcsEc2LaunchTarget({\n          capacityProvider: this.capacityProvider.capacityProviderName,\n          placementStrategies: this.placementStrategies,\n          placementConstraints: this.placementConstraints,\n        }),\n        enableExecuteCommand: this.image.os.isIn(Os._ALL_LINUX_VERSIONS),\n        assignPublicIp: this.assignPublicIp,\n        containerOverrides: [\n          {\n            containerDefinition: this.container,\n            environment: [\n              {\n                name: 'RUNNER_TOKEN',\n                value: parameters.runnerTokenPath,\n              },\n              {\n                name: 'RUNNER_NAME',\n                value: parameters.runnerNamePath,\n              },\n              {\n                name: 'RUNNER_LABEL',\n                value: parameters.labelsPath,\n              },\n              {\n                name: 'RUNNER_GROUP1',\n                value: this.group ? '--runnergroup' : '',\n              },\n              {\n                name: 'RUNNER_GROUP2',\n                value: this.group ? this.group : '',\n              },\n              {\n                name: 'DEFAULT_LABELS',\n                value: this.defaultLabels ? '' : '--no-default-labels',\n              },\n              {\n                name: 'GITHUB_DOMAIN',\n                value: parameters.githubDomainPath,\n              },\n              {\n                name: 'OWNER',\n                value: parameters.ownerPath,\n              },\n              {\n                name: 'REPO',\n                value: parameters.repoPath,\n              },\n              {\n                name: 'REGISTRATION_URL',\n                value: parameters.registrationUrl,\n              },\n            ],\n          },\n        ],\n      },\n    );\n  }\n\n  grantStateMachine(_: iam.IGrantable) {\n  }\n\n  status(statusFunctionRole: iam.IGrantable): IRunnerProviderStatus {\n    this.image.imageRepository.grant(statusFunctionRole, 'ecr:DescribeImages');\n\n    return {\n      type: this.constructor.name,\n      labels: this.labels,\n      constructPath: this.node.path,\n      vpcArn: this.vpc?.vpcArn,\n      securityGroups: this.securityGroups.map(sg => sg.securityGroupId),\n      roleArn: this.task.taskRole.roleArn,\n      logGroup: this.logGroup.logGroupName,\n      image: {\n        imageRepository: this.image.imageRepository.repositoryUri,\n        imageTag: this.image.imageTag,\n        imageBuilderLogGroup: this.image.logGroup?.logGroupName,\n      },\n    };\n  }\n}\n"]}
|