@cloudsnorkel/cdk-github-runners 0.8.4 → 0.9.1
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 +2258 -745
- package/API.md +2006 -559
- package/README.md +44 -42
- package/assets/docker-images/codebuild/linux-arm64/Dockerfile +2 -0
- package/assets/docker-images/codebuild/linux-x64/Dockerfile +2 -0
- package/assets/docker-images/fargate/linux-arm64/Dockerfile +2 -0
- package/assets/docker-images/fargate/linux-x64/Dockerfile +2 -0
- package/assets/docker-images/lambda/linux-arm64/Dockerfile +3 -1
- package/assets/docker-images/lambda/linux-arm64/runner.sh +1 -1
- package/assets/docker-images/lambda/linux-x64/Dockerfile +3 -1
- package/assets/docker-images/lambda/linux-x64/runner.sh +1 -1
- package/assets/lambdas/setup.lambda/index.html +1 -1
- package/assets/lambdas/webhook-handler.lambda/index.js +1 -1
- package/lib/index.js +7 -3
- package/lib/lambdas/aws-image-builder-versioner.lambda.js +6 -6
- package/lib/lambdas/build-image.lambda.js +4 -4
- package/lib/lambdas/delete-ami.lambda.js +4 -4
- package/lib/lambdas/delete-runner.lambda.js +2 -2
- package/lib/lambdas/github.js +3 -3
- package/lib/lambdas/setup.lambda.js +16 -16
- package/lib/lambdas/status.lambda.js +5 -5
- package/lib/lambdas/token-retriever.lambda.js +2 -2
- package/lib/lambdas/webhook-handler.lambda.js +3 -3
- package/lib/providers/codebuild.d.ts +24 -4
- package/lib/providers/codebuild.js +42 -12
- package/lib/providers/common.d.ts +17 -39
- package/lib/providers/common.js +26 -16
- package/lib/providers/ec2.d.ts +23 -5
- package/lib/providers/ec2.js +43 -12
- package/lib/providers/ecs.d.ts +214 -0
- package/lib/providers/ecs.js +258 -0
- package/lib/providers/fargate.d.ts +26 -6
- package/lib/providers/fargate.js +81 -42
- package/lib/providers/image-builders/api.d.ts +15 -0
- package/lib/providers/image-builders/api.js +47 -0
- package/lib/providers/image-builders/aws-image-builder/ami.d.ts +43 -0
- package/lib/providers/image-builders/aws-image-builder/ami.js +81 -0
- package/lib/providers/image-builders/aws-image-builder/builder.d.ts +133 -0
- package/lib/providers/image-builders/aws-image-builder/builder.js +488 -0
- package/lib/providers/image-builders/aws-image-builder/common.d.ts +10 -0
- package/lib/providers/image-builders/aws-image-builder/common.js +46 -0
- package/lib/providers/image-builders/aws-image-builder/container.d.ts +58 -0
- package/lib/providers/image-builders/aws-image-builder/container.js +63 -0
- package/lib/providers/image-builders/{ami.d.ts → aws-image-builder/deprecated/ami.d.ts} +8 -4
- package/lib/providers/image-builders/aws-image-builder/deprecated/ami.js +239 -0
- package/lib/providers/image-builders/aws-image-builder/deprecated/common.d.ts +34 -0
- package/lib/providers/image-builders/aws-image-builder/deprecated/common.js +139 -0
- package/lib/providers/image-builders/{container.d.ts → aws-image-builder/deprecated/container.d.ts} +8 -4
- package/lib/providers/image-builders/aws-image-builder/deprecated/container.js +222 -0
- package/lib/providers/image-builders/aws-image-builder/deprecated/index.d.ts +5 -0
- package/lib/providers/image-builders/aws-image-builder/deprecated/index.js +22 -0
- package/lib/providers/image-builders/{linux-components.d.ts → aws-image-builder/deprecated/linux-components.d.ts} +4 -2
- package/lib/providers/image-builders/aws-image-builder/deprecated/linux-components.js +180 -0
- package/lib/providers/image-builders/{windows-components.d.ts → aws-image-builder/deprecated/windows-components.d.ts} +4 -2
- package/lib/providers/image-builders/aws-image-builder/deprecated/windows-components.js +142 -0
- package/lib/providers/image-builders/aws-image-builder/index.d.ts +5 -0
- package/lib/providers/image-builders/aws-image-builder/index.js +22 -0
- package/lib/providers/image-builders/codebuild-deprecated.d.ts +195 -0
- package/lib/providers/image-builders/codebuild-deprecated.js +373 -0
- package/lib/providers/image-builders/codebuild.d.ts +26 -157
- package/lib/providers/image-builders/codebuild.js +118 -210
- package/lib/providers/image-builders/common.d.ts +164 -107
- package/lib/providers/image-builders/common.js +30 -272
- package/lib/providers/image-builders/components.d.ts +114 -0
- package/lib/providers/image-builders/components.js +535 -0
- package/lib/providers/image-builders/index.d.ts +6 -4
- package/lib/providers/image-builders/index.js +13 -7
- package/lib/providers/image-builders/static.d.ts +4 -3
- package/lib/providers/image-builders/static.js +10 -10
- package/lib/providers/index.js +7 -3
- package/lib/providers/lambda.d.ts +25 -6
- package/lib/providers/lambda.js +50 -13
- package/lib/runner.d.ts +3 -5
- package/lib/runner.js +4 -4
- package/lib/secrets.js +3 -3
- package/package.json +7 -11
- package/lib/providers/image-builders/ami.js +0 -280
- package/lib/providers/image-builders/container.js +0 -247
- package/lib/providers/image-builders/linux-components.js +0 -177
- package/lib/providers/image-builders/windows-components.js +0 -139
|
@@ -1,20 +1,26 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
8
12
|
}));
|
|
9
13
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
-
for (var p in m) if (p !== "default" && !
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
15
|
};
|
|
12
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
__exportStar(require("./
|
|
17
|
+
__exportStar(require("./api"), exports);
|
|
18
|
+
__exportStar(require("./aws-image-builder"), exports);
|
|
14
19
|
__exportStar(require("./codebuild"), exports);
|
|
20
|
+
__exportStar(require("./codebuild-deprecated"), exports);
|
|
15
21
|
__exportStar(require("./common"), exports);
|
|
16
|
-
__exportStar(require("./
|
|
17
|
-
__exportStar(require("./windows-components"), exports);
|
|
18
|
-
__exportStar(require("./linux-components"), exports);
|
|
22
|
+
__exportStar(require("./components"), exports);
|
|
23
|
+
__exportStar(require("./aws-image-builder/deprecated/windows-components"), exports);
|
|
24
|
+
__exportStar(require("./aws-image-builder/deprecated/linux-components"), exports);
|
|
19
25
|
__exportStar(require("./static"), exports);
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcHJvdmlkZXJzL2ltYWdlLWJ1aWxkZXJzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx3Q0FBc0I7QUFDdEIsc0RBQW9DO0FBQ3BDLDhDQUE0QjtBQUM1Qix5REFBdUM7QUFDdkMsMkNBQXlCO0FBQ3pCLCtDQUE2QjtBQUM3QixvRkFBa0U7QUFDbEUsa0ZBQWdFO0FBQ2hFLDJDQUF5QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vYXdzLWltYWdlLWJ1aWxkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9jb2RlYnVpbGQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2RlYnVpbGQtZGVwcmVjYXRlZCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1vbic7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9hd3MtaW1hZ2UtYnVpbGRlci9kZXByZWNhdGVkL3dpbmRvd3MtY29tcG9uZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2F3cy1pbWFnZS1idWlsZGVyL2RlcHJlY2F0ZWQvbGludXgtY29tcG9uZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3N0YXRpYyc7XG4iXX0=
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { aws_ecr as ecr } from 'aws-cdk-lib';
|
|
2
2
|
import { Construct } from 'constructs';
|
|
3
|
-
import {
|
|
3
|
+
import { IRunnerImageBuilder } from './common';
|
|
4
|
+
import { Architecture, Os } from '../common';
|
|
4
5
|
/**
|
|
5
6
|
* Helper class with methods to use static images that are built outside the context of this project.
|
|
6
7
|
*/
|
|
@@ -13,7 +14,7 @@ export declare class StaticRunnerImage {
|
|
|
13
14
|
* @param architecture image architecture
|
|
14
15
|
* @param os image OS
|
|
15
16
|
*/
|
|
16
|
-
static fromEcrRepository(repository: ecr.IRepository, tag?: string, architecture?: Architecture, os?: Os):
|
|
17
|
+
static fromEcrRepository(repository: ecr.IRepository, tag?: string, architecture?: Architecture, os?: Os): IRunnerImageBuilder;
|
|
17
18
|
/**
|
|
18
19
|
* Create a builder from an existing Docker Hub image. The image must already have GitHub Actions runner installed. You are responsible to update it and remove it when done.
|
|
19
20
|
*
|
|
@@ -25,5 +26,5 @@ export declare class StaticRunnerImage {
|
|
|
25
26
|
* @param architecture image architecture
|
|
26
27
|
* @param os image OS
|
|
27
28
|
*/
|
|
28
|
-
static fromDockerHub(scope: Construct, id: string, image: string, architecture?: Architecture, os?: Os):
|
|
29
|
+
static fromDockerHub(scope: Construct, id: string, image: string, architecture?: Architecture, os?: Os): IRunnerImageBuilder;
|
|
29
30
|
}
|
|
@@ -4,7 +4,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
4
4
|
exports.StaticRunnerImage = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const codebuild_1 = require("./codebuild");
|
|
7
|
-
const codebuild_2 = require("../codebuild");
|
|
8
7
|
const common_1 = require("../common");
|
|
9
8
|
/**
|
|
10
9
|
* Helper class with methods to use static images that are built outside the context of this project.
|
|
@@ -20,7 +19,7 @@ class StaticRunnerImage {
|
|
|
20
19
|
*/
|
|
21
20
|
static fromEcrRepository(repository, tag = 'latest', architecture = common_1.Architecture.X86_64, os = common_1.Os.LINUX) {
|
|
22
21
|
return {
|
|
23
|
-
|
|
22
|
+
bindDockerImage() {
|
|
24
23
|
return {
|
|
25
24
|
imageRepository: repository,
|
|
26
25
|
imageTag: tag,
|
|
@@ -29,6 +28,9 @@ class StaticRunnerImage {
|
|
|
29
28
|
runnerVersion: common_1.RunnerVersion.latest(),
|
|
30
29
|
};
|
|
31
30
|
},
|
|
31
|
+
bindAmi() {
|
|
32
|
+
throw new Error('fromEcrRepository() cannot be used to build AMIs');
|
|
33
|
+
},
|
|
32
34
|
};
|
|
33
35
|
}
|
|
34
36
|
/**
|
|
@@ -43,16 +45,14 @@ class StaticRunnerImage {
|
|
|
43
45
|
* @param os image OS
|
|
44
46
|
*/
|
|
45
47
|
static fromDockerHub(scope, id, image, architecture = common_1.Architecture.X86_64, os = common_1.Os.LINUX) {
|
|
46
|
-
|
|
47
|
-
dockerfilePath: codebuild_2.CodeBuildRunnerProvider.LINUX_X64_DOCKERFILE_PATH,
|
|
48
|
-
architecture,
|
|
48
|
+
return new codebuild_1.CodeBuildRunnerImageBuilder(scope, id, {
|
|
49
49
|
os,
|
|
50
|
+
architecture,
|
|
51
|
+
baseDockerImage: image,
|
|
50
52
|
});
|
|
51
|
-
builder.addPreBuildCommand(`echo "FROM ${image}" > Dockerfile`);
|
|
52
|
-
return builder;
|
|
53
53
|
}
|
|
54
54
|
}
|
|
55
|
-
exports.StaticRunnerImage = StaticRunnerImage;
|
|
56
55
|
_a = JSII_RTTI_SYMBOL_1;
|
|
57
|
-
StaticRunnerImage[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.StaticRunnerImage", version: "0.
|
|
58
|
-
|
|
56
|
+
StaticRunnerImage[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.StaticRunnerImage", version: "0.9.1" };
|
|
57
|
+
exports.StaticRunnerImage = StaticRunnerImage;
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGljLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Byb3ZpZGVycy9pbWFnZS1idWlsZGVycy9zdGF0aWMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFFQSwyQ0FBMEQ7QUFFMUQsc0NBQW9GO0FBRXBGOztHQUVHO0FBQ0gsTUFBYSxpQkFBaUI7SUFDNUI7Ozs7Ozs7T0FPRztJQUNJLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxVQUEyQixFQUFFLE1BQWMsUUFBUSxFQUFFLFlBQVksR0FBRyxxQkFBWSxDQUFDLE1BQU0sRUFBRSxFQUFFLEdBQUcsV0FBRSxDQUFDLEtBQUs7UUFDcEksT0FBTztZQUNMLGVBQWU7Z0JBQ2IsT0FBTztvQkFDTCxlQUFlLEVBQUUsVUFBVTtvQkFDM0IsUUFBUSxFQUFFLEdBQUc7b0JBQ2IsWUFBWTtvQkFDWixFQUFFO29CQUNGLGFBQWEsRUFBRSxzQkFBYSxDQUFDLE1BQU0sRUFBRTtpQkFDdEMsQ0FBQztZQUNKLENBQUM7WUFFRCxPQUFPO2dCQUNMLE1BQU0sSUFBSSxLQUFLLENBQUMsa0RBQWtELENBQUMsQ0FBQztZQUN0RSxDQUFDO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRDs7Ozs7Ozs7OztPQVVHO0lBQ0ksTUFBTSxDQUFDLGFBQWEsQ0FBQyxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFhLEVBQUUsWUFBWSxHQUFHLHFCQUFZLENBQUMsTUFBTSxFQUFFLEVBQUUsR0FBRyxXQUFFLENBQUMsS0FBSztRQUN4SCxPQUFPLElBQUksdUNBQTJCLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNoRCxFQUFFO1lBQ0YsWUFBWTtZQUNaLGVBQWUsRUFBRSxLQUFLO1NBQ3ZCLENBQUMsQ0FBQztJQUNMLENBQUM7Ozs7QUE1Q1UsOENBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYXdzX2VjciBhcyBlY3IgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IENvZGVCdWlsZFJ1bm5lckltYWdlQnVpbGRlciB9IGZyb20gJy4vY29kZWJ1aWxkJztcbmltcG9ydCB7IElSdW5uZXJJbWFnZUJ1aWxkZXIgfSBmcm9tICcuL2NvbW1vbic7XG5pbXBvcnQgeyBBcmNoaXRlY3R1cmUsIE9zLCBSdW5uZXJBbWksIFJ1bm5lckltYWdlLCBSdW5uZXJWZXJzaW9uIH0gZnJvbSAnLi4vY29tbW9uJztcblxuLyoqXG4gKiBIZWxwZXIgY2xhc3Mgd2l0aCBtZXRob2RzIHRvIHVzZSBzdGF0aWMgaW1hZ2VzIHRoYXQgYXJlIGJ1aWx0IG91dHNpZGUgdGhlIGNvbnRleHQgb2YgdGhpcyBwcm9qZWN0LlxuICovXG5leHBvcnQgY2xhc3MgU3RhdGljUnVubmVySW1hZ2Uge1xuICAvKipcbiAgICogQ3JlYXRlIGEgYnVpbGRlciAodGhhdCBkb2Vzbid0IGFjdHVhbGx5IGJ1aWxkIGFueXRoaW5nKSBmcm9tIGFuIGV4aXN0aW5nIGltYWdlIGluIGFuIGV4aXN0aW5nIHJlcG9zaXRvcnkuIFRoZSBpbWFnZSBtdXN0IGFscmVhZHkgaGF2ZSBHaXRIdWIgQWN0aW9ucyBydW5uZXIgaW5zdGFsbGVkLiBZb3UgYXJlIHJlc3BvbnNpYmxlIHRvIHVwZGF0ZSBpdCBhbmQgcmVtb3ZlIGl0IHdoZW4gZG9uZS5cbiAgICpcbiAgICogQHBhcmFtIHJlcG9zaXRvcnkgRUNSIHJlcG9zaXRvcnlcbiAgICogQHBhcmFtIHRhZyBpbWFnZSB0YWdcbiAgICogQHBhcmFtIGFyY2hpdGVjdHVyZSBpbWFnZSBhcmNoaXRlY3R1cmVcbiAgICogQHBhcmFtIG9zIGltYWdlIE9TXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGZyb21FY3JSZXBvc2l0b3J5KHJlcG9zaXRvcnk6IGVjci5JUmVwb3NpdG9yeSwgdGFnOiBzdHJpbmcgPSAnbGF0ZXN0JywgYXJjaGl0ZWN0dXJlID0gQXJjaGl0ZWN0dXJlLlg4Nl82NCwgb3MgPSBPcy5MSU5VWCk6IElSdW5uZXJJbWFnZUJ1aWxkZXIge1xuICAgIHJldHVybiB7XG4gICAgICBiaW5kRG9ja2VySW1hZ2UoKTogUnVubmVySW1hZ2Uge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIGltYWdlUmVwb3NpdG9yeTogcmVwb3NpdG9yeSxcbiAgICAgICAgICBpbWFnZVRhZzogdGFnLFxuICAgICAgICAgIGFyY2hpdGVjdHVyZSxcbiAgICAgICAgICBvcyxcbiAgICAgICAgICBydW5uZXJWZXJzaW9uOiBSdW5uZXJWZXJzaW9uLmxhdGVzdCgpLFxuICAgICAgICB9O1xuICAgICAgfSxcblxuICAgICAgYmluZEFtaSgpOiBSdW5uZXJBbWkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ2Zyb21FY3JSZXBvc2l0b3J5KCkgY2Fubm90IGJlIHVzZWQgdG8gYnVpbGQgQU1JcycpO1xuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZSBhIGJ1aWxkZXIgZnJvbSBhbiBleGlzdGluZyBEb2NrZXIgSHViIGltYWdlLiBUaGUgaW1hZ2UgbXVzdCBhbHJlYWR5IGhhdmUgR2l0SHViIEFjdGlvbnMgcnVubmVyIGluc3RhbGxlZC4gWW91IGFyZSByZXNwb25zaWJsZSB0byB1cGRhdGUgaXQgYW5kIHJlbW92ZSBpdCB3aGVuIGRvbmUuXG4gICAqXG4gICAqIFdlIGNyZWF0ZSBhIENvZGVCdWlsZCBpbWFnZSBidWlsZGVyIGJlaGluZCB0aGUgc2NlbmVzIHRvIGNvcHkgdGhlIGltYWdlIG92ZXIgdG8gRUNSLiBUaGlzIGhlbHBzIGF2b2lkIERvY2tlciBIdWIgcmF0ZSBsaW1pdHMgYW5kIHByZXZlbnQgZmFpbHVyZXMuXG4gICAqXG4gICAqIEBwYXJhbSBzY29wZVxuICAgKiBAcGFyYW0gaWRcbiAgICogQHBhcmFtIGltYWdlIERvY2tlciBIdWIgaW1hZ2Ugd2l0aCBvcHRpb25hbCB0YWdcbiAgICogQHBhcmFtIGFyY2hpdGVjdHVyZSBpbWFnZSBhcmNoaXRlY3R1cmVcbiAgICogQHBhcmFtIG9zIGltYWdlIE9TXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGZyb21Eb2NrZXJIdWIoc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgaW1hZ2U6IHN0cmluZywgYXJjaGl0ZWN0dXJlID0gQXJjaGl0ZWN0dXJlLlg4Nl82NCwgb3MgPSBPcy5MSU5VWCk6IElSdW5uZXJJbWFnZUJ1aWxkZXIge1xuICAgIHJldHVybiBuZXcgQ29kZUJ1aWxkUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwge1xuICAgICAgb3MsXG4gICAgICBhcmNoaXRlY3R1cmUsXG4gICAgICBiYXNlRG9ja2VySW1hZ2U6IGltYWdlLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
|
package/lib/providers/index.js
CHANGED
|
@@ -1,13 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
8
12
|
}));
|
|
9
13
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
-
for (var p in m) if (p !== "default" && !
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
15
|
};
|
|
12
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
17
|
__exportStar(require("./ec2"), exports);
|
|
@@ -16,4 +20,4 @@ __exportStar(require("./lambda"), exports);
|
|
|
16
20
|
__exportStar(require("./fargate"), exports);
|
|
17
21
|
__exportStar(require("./common"), exports);
|
|
18
22
|
__exportStar(require("./image-builders"), exports);
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcHJvdmlkZXJzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx3Q0FBc0I7QUFDdEIsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6Qiw0Q0FBMEI7QUFDMUIsMkNBQXlCO0FBQ3pCLG1EQUFpQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZWMyJztcbmV4cG9ydCAqIGZyb20gJy4vY29kZWJ1aWxkJztcbmV4cG9ydCAqIGZyb20gJy4vbGFtYmRhJztcbmV4cG9ydCAqIGZyb20gJy4vZmFyZ2F0ZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1vbic7XG5leHBvcnQgKiBmcm9tICcuL2ltYWdlLWJ1aWxkZXJzJztcbiJdfQ==
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
import * as cdk from 'aws-cdk-lib';
|
|
2
2
|
import { aws_ec2 as ec2, aws_iam as iam, aws_lambda as lambda, aws_logs as logs, aws_stepfunctions as stepfunctions } from 'aws-cdk-lib';
|
|
3
3
|
import { Construct } from 'constructs';
|
|
4
|
-
import { BaseProvider,
|
|
4
|
+
import { BaseProvider, IRunnerProvider, IRunnerProviderStatus, RunnerImage, RunnerProviderProps, RunnerRuntimeParameters } from './common';
|
|
5
|
+
import { IRunnerImageBuilder, RunnerImageBuilder, RunnerImageBuilderProps } from './image-builders';
|
|
5
6
|
export interface LambdaRunnerProviderProps extends RunnerProviderProps {
|
|
6
7
|
/**
|
|
7
|
-
*
|
|
8
|
+
* Runner image builder used to build Docker images containing GitHub Runner and all requirements.
|
|
8
9
|
*
|
|
9
|
-
* The
|
|
10
|
+
* The image builder must contain the {@link RunnerImageComponent.lambdaEntrypoint} component.
|
|
10
11
|
*
|
|
11
12
|
* The image builder determines the OS and architecture of the runner.
|
|
12
13
|
*
|
|
13
|
-
* @
|
|
14
|
-
* @default image builder with LambdaRunner.LINUX_X64_DOCKERFILE_PATH as Dockerfile
|
|
14
|
+
* @default LambdaRunnerProvider.imageBuilder()
|
|
15
15
|
*/
|
|
16
|
-
readonly imageBuilder?:
|
|
16
|
+
readonly imageBuilder?: IRunnerImageBuilder;
|
|
17
17
|
/**
|
|
18
18
|
* GitHub Actions label used for this provider.
|
|
19
19
|
*
|
|
@@ -95,6 +95,8 @@ export declare class LambdaRunnerProvider extends BaseProvider implements IRunne
|
|
|
95
95
|
* Available build arguments that can be set in the image builder:
|
|
96
96
|
* * `BASE_IMAGE` sets the `FROM` line. This should be similar to public.ecr.aws/lambda/nodejs:14.
|
|
97
97
|
* * `EXTRA_PACKAGES` can be used to install additional packages.
|
|
98
|
+
*
|
|
99
|
+
* @deprecated Use `imageBuilder()` instead.
|
|
98
100
|
*/
|
|
99
101
|
static readonly LINUX_X64_DOCKERFILE_PATH: string;
|
|
100
102
|
/**
|
|
@@ -103,8 +105,25 @@ export declare class LambdaRunnerProvider extends BaseProvider implements IRunne
|
|
|
103
105
|
* Available build arguments that can be set in the image builder:
|
|
104
106
|
* * `BASE_IMAGE` sets the `FROM` line. This should be similar to public.ecr.aws/lambda/nodejs:14.
|
|
105
107
|
* * `EXTRA_PACKAGES` can be used to install additional packages.
|
|
108
|
+
*
|
|
109
|
+
* @deprecated Use `imageBuilder()` instead.
|
|
106
110
|
*/
|
|
107
111
|
static readonly LINUX_ARM64_DOCKERFILE_PATH: string;
|
|
112
|
+
/**
|
|
113
|
+
* Create new image builder that builds Lambda specific runner images using Amazon Linux 2.
|
|
114
|
+
*
|
|
115
|
+
* Included components:
|
|
116
|
+
* * `RunnerImageComponent.requiredPackages()`
|
|
117
|
+
* * `RunnerImageComponent.runnerUser()`
|
|
118
|
+
* * `RunnerImageComponent.git()`
|
|
119
|
+
* * `RunnerImageComponent.githubCli()`
|
|
120
|
+
* * `RunnerImageComponent.awsCli()`
|
|
121
|
+
* * `RunnerImageComponent.githubRunner()`
|
|
122
|
+
* * `RunnerImageComponent.lambdaEntrypoint()`
|
|
123
|
+
*
|
|
124
|
+
* Base Docker image: `public.ecr.aws/lambda/nodejs:14-x86_64` or `public.ecr.aws/lambda/nodejs:14-arm64`
|
|
125
|
+
*/
|
|
126
|
+
static imageBuilder(scope: Construct, id: string, props?: RunnerImageBuilderProps): RunnerImageBuilder;
|
|
108
127
|
/**
|
|
109
128
|
* The function hosting the GitHub runner.
|
|
110
129
|
*/
|
package/lib/providers/lambda.js
CHANGED
|
@@ -8,7 +8,7 @@ const cdk = require("aws-cdk-lib");
|
|
|
8
8
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
9
9
|
const aws_logs_1 = require("aws-cdk-lib/aws-logs");
|
|
10
10
|
const common_1 = require("./common");
|
|
11
|
-
const
|
|
11
|
+
const image_builders_1 = require("./image-builders");
|
|
12
12
|
const update_lambda_function_1 = require("../lambdas/update-lambda-function");
|
|
13
13
|
const utils_1 = require("../utils");
|
|
14
14
|
/**
|
|
@@ -19,17 +19,50 @@ const utils_1 = require("../utils");
|
|
|
19
19
|
* This construct is not meant to be used by itself. It should be passed in the providers property for GitHubRunners.
|
|
20
20
|
*/
|
|
21
21
|
class LambdaRunnerProvider extends common_1.BaseProvider {
|
|
22
|
+
/**
|
|
23
|
+
* Create new image builder that builds Lambda specific runner images using Amazon Linux 2.
|
|
24
|
+
*
|
|
25
|
+
* Included components:
|
|
26
|
+
* * `RunnerImageComponent.requiredPackages()`
|
|
27
|
+
* * `RunnerImageComponent.runnerUser()`
|
|
28
|
+
* * `RunnerImageComponent.git()`
|
|
29
|
+
* * `RunnerImageComponent.githubCli()`
|
|
30
|
+
* * `RunnerImageComponent.awsCli()`
|
|
31
|
+
* * `RunnerImageComponent.githubRunner()`
|
|
32
|
+
* * `RunnerImageComponent.lambdaEntrypoint()`
|
|
33
|
+
*
|
|
34
|
+
* Base Docker image: `public.ecr.aws/lambda/nodejs:14-x86_64` or `public.ecr.aws/lambda/nodejs:14-arm64`
|
|
35
|
+
*/
|
|
36
|
+
static imageBuilder(scope, id, props) {
|
|
37
|
+
let baseDockerImage = 'public.ecr.aws/lambda/nodejs:14-x86_64';
|
|
38
|
+
if (props?.architecture === common_1.Architecture.ARM64) {
|
|
39
|
+
baseDockerImage = 'public.ecr.aws/lambda/nodejs:14-arm64';
|
|
40
|
+
}
|
|
41
|
+
return image_builders_1.RunnerImageBuilder.new(scope, id, {
|
|
42
|
+
os: common_1.Os.LINUX_AMAZON_2,
|
|
43
|
+
architecture: props?.architecture ?? common_1.Architecture.X86_64,
|
|
44
|
+
baseDockerImage,
|
|
45
|
+
components: [
|
|
46
|
+
image_builders_1.RunnerImageComponent.requiredPackages(),
|
|
47
|
+
image_builders_1.RunnerImageComponent.runnerUser(),
|
|
48
|
+
image_builders_1.RunnerImageComponent.git(),
|
|
49
|
+
image_builders_1.RunnerImageComponent.githubCli(),
|
|
50
|
+
image_builders_1.RunnerImageComponent.awsCli(),
|
|
51
|
+
image_builders_1.RunnerImageComponent.githubRunner(props?.runnerVersion ?? common_1.RunnerVersion.latest()),
|
|
52
|
+
image_builders_1.RunnerImageComponent.lambdaEntrypoint(),
|
|
53
|
+
],
|
|
54
|
+
...props,
|
|
55
|
+
});
|
|
56
|
+
}
|
|
22
57
|
constructor(scope, id, props) {
|
|
23
58
|
super(scope, id, props);
|
|
24
59
|
this.labels = this.labelsFromProperties('lambda', props?.label, props?.labels);
|
|
25
60
|
this.vpc = props?.vpc;
|
|
26
61
|
this.securityGroups = props?.securityGroup ? [props.securityGroup] : props?.securityGroups;
|
|
27
|
-
const imageBuilder = props?.imageBuilder ??
|
|
28
|
-
|
|
29
|
-
});
|
|
30
|
-
const image = this.image = imageBuilder.bind();
|
|
62
|
+
const imageBuilder = props?.imageBuilder ?? LambdaRunnerProvider.imageBuilder(this, 'Image Builder');
|
|
63
|
+
const image = this.image = imageBuilder.bindDockerImage();
|
|
31
64
|
let architecture;
|
|
32
|
-
if (image.os.is(common_1.Os.
|
|
65
|
+
if (image.os.is(common_1.Os.LINUX_AMAZON_2) || image.os.is(common_1.Os.LINUX_UBUNTU)) {
|
|
33
66
|
if (image.architecture.is(common_1.Architecture.X86_64)) {
|
|
34
67
|
architecture = aws_cdk_lib_1.aws_lambda.Architecture.X86_64;
|
|
35
68
|
}
|
|
@@ -38,7 +71,7 @@ class LambdaRunnerProvider extends common_1.BaseProvider {
|
|
|
38
71
|
}
|
|
39
72
|
}
|
|
40
73
|
if (!architecture) {
|
|
41
|
-
throw new Error(`Unable to find
|
|
74
|
+
throw new Error(`Unable to find supported Lambda architecture for ${image.os.name}/${image.architecture.name}`);
|
|
42
75
|
}
|
|
43
76
|
// get image digest and make sure to get it every time the lambda function might be updated
|
|
44
77
|
// pass all variables that may change and cause a function update
|
|
@@ -104,7 +137,7 @@ class LambdaRunnerProvider extends common_1.BaseProvider {
|
|
|
104
137
|
addImageUpdater(image) {
|
|
105
138
|
// Lambda needs to be pointing to a specific image digest and not just a tag.
|
|
106
139
|
// Whenever we update the tag to a new digest, we need to update the lambda.
|
|
107
|
-
const updater = utils_1.singletonLambda(update_lambda_function_1.UpdateLambdaFunction, this, 'update-lambda', {
|
|
140
|
+
const updater = (0, utils_1.singletonLambda)(update_lambda_function_1.UpdateLambdaFunction, this, 'update-lambda', {
|
|
108
141
|
description: 'Function that updates a GitHub Actions runner function with the latest image digest after the image has been rebuilt',
|
|
109
142
|
timeout: cdk.Duration.minutes(15),
|
|
110
143
|
logRetention: aws_cdk_lib_1.aws_logs.RetentionDays.ONE_MONTH,
|
|
@@ -210,15 +243,16 @@ class LambdaRunnerProvider extends common_1.BaseProvider {
|
|
|
210
243
|
return cdk.Fn.split(':', reader.getResponseField('imageDetails.0.imageDigest'), 2)[1];
|
|
211
244
|
}
|
|
212
245
|
}
|
|
213
|
-
exports.LambdaRunnerProvider = LambdaRunnerProvider;
|
|
214
246
|
_a = JSII_RTTI_SYMBOL_1;
|
|
215
|
-
LambdaRunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaRunnerProvider", version: "0.
|
|
247
|
+
LambdaRunnerProvider[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaRunnerProvider", version: "0.9.1" };
|
|
216
248
|
/**
|
|
217
249
|
* Path to Dockerfile for Linux x64 with all the requirement for Lambda runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
|
|
218
250
|
*
|
|
219
251
|
* Available build arguments that can be set in the image builder:
|
|
220
252
|
* * `BASE_IMAGE` sets the `FROM` line. This should be similar to public.ecr.aws/lambda/nodejs:14.
|
|
221
253
|
* * `EXTRA_PACKAGES` can be used to install additional packages.
|
|
254
|
+
*
|
|
255
|
+
* @deprecated Use `imageBuilder()` instead.
|
|
222
256
|
*/
|
|
223
257
|
LambdaRunnerProvider.LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'lambda', 'linux-x64');
|
|
224
258
|
/**
|
|
@@ -227,14 +261,17 @@ LambdaRunnerProvider.LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, '..', '..'
|
|
|
227
261
|
* Available build arguments that can be set in the image builder:
|
|
228
262
|
* * `BASE_IMAGE` sets the `FROM` line. This should be similar to public.ecr.aws/lambda/nodejs:14.
|
|
229
263
|
* * `EXTRA_PACKAGES` can be used to install additional packages.
|
|
264
|
+
*
|
|
265
|
+
* @deprecated Use `imageBuilder()` instead.
|
|
230
266
|
*/
|
|
231
267
|
LambdaRunnerProvider.LINUX_ARM64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'lambda', 'linux-arm64');
|
|
268
|
+
exports.LambdaRunnerProvider = LambdaRunnerProvider;
|
|
232
269
|
/**
|
|
233
270
|
* @deprecated use {@link LambdaRunnerProvider}
|
|
234
271
|
*/
|
|
235
272
|
class LambdaRunner extends LambdaRunnerProvider {
|
|
236
273
|
}
|
|
237
|
-
exports.LambdaRunner = LambdaRunner;
|
|
238
274
|
_b = JSII_RTTI_SYMBOL_1;
|
|
239
|
-
LambdaRunner[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaRunner", version: "0.
|
|
240
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda.js","sourceRoot":"","sources":["../../src/providers/lambda.ts"],"names":[],"mappings":";;;;;AAAA,6BAA6B;AAC7B,mCAAmC;AACnC,6CAUqB;AACrB,mDAAqD;AAErD,qCAUkB;AAClB,0DAAmE;AACnE,8EAAyE;AACzE,oCAA2C;AA2F3C;;;;;;GAMG;AACH,MAAa,oBAAqB,SAAQ,qBAAY;IAiDpD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAiC;QACzE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;QAC/E,IAAI,CAAC,GAAG,GAAG,KAAK,EAAE,GAAG,CAAC;QACtB,IAAI,CAAC,cAAc,GAAG,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,cAAc,CAAC;QAE3F,MAAM,YAAY,GAAG,KAAK,EAAE,YAAY,IAAI,IAAI,iCAAqB,CAAC,IAAI,EAAE,eAAe,EAAE;YAC3F,cAAc,EAAE,oBAAoB,CAAC,yBAAyB;SAC/D,CAAC,CAAC;QACH,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,IAAI,EAAE,CAAC;QAE/C,IAAI,YAA6C,CAAC;QAClD,IAAI,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,WAAE,CAAC,KAAK,CAAC,EAAE;YACzB,IAAI,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC,qBAAY,CAAC,MAAM,CAAC,EAAE;gBAC9C,YAAY,GAAG,wBAAM,CAAC,YAAY,CAAC,MAAM,CAAC;aAC3C;YACD,IAAI,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC,qBAAY,CAAC,KAAK,CAAC,EAAE;gBAC7C,YAAY,GAAG,wBAAM,CAAC,YAAY,CAAC,MAAM,CAAC;aAC3C;SACF;QAED,IAAI,CAAC,YAAY,EAAE;YACjB,MAAM,IAAI,KAAK,CAAC,kDAAkD,KAAK,CAAC,EAAE,CAAC,IAAI,IAAI,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC;SAC/G;QAED,2FAA2F;QAC3F,iEAAiE;QACjE,0HAA0H;QAC1H,8EAA8E;QAC9E,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;YAC1C,OAAO,EAAE,CAAC;YACV,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,YAAY,EAAE,YAAY,CAAC,IAAI;YAC/B,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK;YACpB,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC;YAClE,UAAU,EAAE,KAAK,EAAE,eAAe,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;YACjE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE;YACpC,UAAU,EAAE,KAAK,EAAE,UAAU;YAC7B,oBAAoB,EAAE,KAAK,EAAE,oBAAoB,EAAE,WAAW,EAAE;YAChE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE;SAC7C,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,GAAG,IAAI,wBAAM,CAAC,mBAAmB,CAC5C,IAAI,EACJ,UAAU,EACV;YACE,WAAW,EAAE,oCAAoC,IAAI,CAAC,MAAM,EAAE;YAC9D,2KAA2K;YAC3K,IAAI,EAAE,wBAAM,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,EAAE,EAAE,WAAW,EAAE,UAAU,WAAW,EAAE,EAAE,CAAC;YACrG,YAAY;YACZ,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,UAAU,EAAE,KAAK,EAAE,eAAe;YAClC,OAAO,EAAE,KAAK,EAAE,OAAO,IAAI,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YACnD,UAAU,EAAE,KAAK,EAAE,UAAU,IAAI,IAAI;YACrC,oBAAoB,EAAE,KAAK,EAAE,oBAAoB,IAAI,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;YAC3E,YAAY,EAAE,KAAK,EAAE,YAAY,IAAI,wBAAa,CAAC,SAAS;SAC7D,CACF,CAAC;QAEF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC;QACnD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAEvC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED;;OAEG;IACH,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC;IACnC,CAAC;IAED;;;;;;OAMG;IACH,mBAAmB,CAAC,UAAmC;QACrD,MAAM,MAAM,GAAG,IAAI,qCAAmB,CAAC,YAAY,CACjD,IAAI,EACJ,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EACtB;YACE,cAAc,EAAE,IAAI,CAAC,QAAQ;YAC7B,OAAO,EAAE,+BAAa,CAAC,SAAS,CAAC,UAAU,CAAC;gBAC1C,KAAK,EAAE,UAAU,CAAC,eAAe;gBACjC,UAAU,EAAE,UAAU,CAAC,cAAc;gBACrC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC5B,YAAY,EAAE,UAAU,CAAC,gBAAgB;gBACzC,KAAK,EAAE,UAAU,CAAC,SAAS;gBAC3B,IAAI,EAAE,UAAU,CAAC,QAAQ;aAC1B,CAAC;SACH,CACF,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,wBAAwB,EAAE,8BAA8B,EAAE,+BAA+B,EAAE,iCAAiC,EAAE,iCAAiC,CAAC,CAAC,CAAC;QAEzL,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,eAAe,CAAC,KAAkB;QACxC,6EAA6E;QAC7E,4EAA4E;QAE5E,MAAM,OAAO,GAAG,uBAAe,CAAC,6CAAoB,EAAE,IAAI,EAAE,eAAe,EAAE;YAC3E,WAAW,EAAE,sHAAsH;YACnI,OAAO,EAAE,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YACjC,YAAY,EAAE,sBAAI,CAAC,aAAa,CAAC,SAAS;SAC3C,CAAC,CAAC;QAEH,OAAO,CAAC,eAAe,CAAC,IAAI,qBAAG,CAAC,eAAe,CAAC;YAC9C,OAAO,EAAE,CAAC,2BAA2B,CAAC;YACtC,SAAS,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC;SACvC,CAAC,CAAC,CAAC;QAEJ,IAAI,YAAY,GAAG,IAAI,gCAAc,CAAC,cAAc,CAAC,OAAO,EAAE;YAC5D,KAAK,EAAE,wBAAM,CAAC,eAAe,CAAC,UAAU,CAAC;gBACvC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,YAAY;gBACtC,aAAa,EAAE,KAAK,CAAC,eAAe,CAAC,aAAa;gBAClD,aAAa,EAAE,KAAK,CAAC,QAAQ;aAC9B,CAAC;SACH,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,WAAW,EAAE;YACtD,WAAW,EAAE,uDAAuD;YACpE,YAAY,EAAE;gBACZ,UAAU,EAAE,CAAC,kBAAkB,CAAC;gBAChC,MAAM,EAAE;oBACN,aAAa,EAAE,CAAC,MAAM,CAAC;oBACvB,iBAAiB,EAAE,CAAC,KAAK,CAAC,eAAe,CAAC,cAAc,CAAC;oBACzD,WAAW,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC;oBAC7B,QAAQ,EAAE,CAAC,SAAS,CAAC;iBACtB;aACF;YACD,MAAM,EAAE,YAAY;SACrB,CAAC,CAAC;QAEH,uDAAuD;QACtD,IAAI,CAAC,IAAI,CAAC,YAA+B,CAAC,mBAAmB,CAAC,mCAAmC,CAAC,CAAC;IACtG,CAAC;IAED,iBAAiB,CAAC,CAAiB;IACnC,CAAC;IAED,MAAM,CAAC,kBAAkC;QACvC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,KAAK,CAAC,kBAAkB,EAAE,oBAAoB,CAAC,CAAC;QAE3E,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI;YAC3B,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,MAAM;YACxB,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC;YAClE,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO;YACpC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY;YAC7C,KAAK,EAAE;gBACL,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,aAAa;gBACzD,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ;gBAC7B,oBAAoB,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,YAAY;aACxD;SACF,CAAC;IACJ,CAAC;IAEO,WAAW,CAAC,KAAkB,EAAE,gBAAqB;QAC3D,uCAAuC;QACvC,8IAA8I;QAC9I,MAAM,MAAM,GAAG,IAAI,8BAAE,CAAC,iBAAiB,CAAC,IAAI,EAAE,qBAAqB,EAAE;YACnE,QAAQ,EAAE;gBACR,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,gBAAgB;gBACxB,UAAU,EAAE;oBACV,cAAc,EAAE,KAAK,CAAC,eAAe,CAAC,cAAc;oBACpD,QAAQ,EAAE;wBACR;4BACE,QAAQ,EAAE,KAAK,CAAC,QAAQ;yBACzB;qBACF;iBACF;gBACD,kBAAkB,EAAE,8BAAE,CAAC,kBAAkB,CAAC,EAAE,CAAC,aAAa,CAAC;aAC5D;YACD,QAAQ,EAAE;gBACR,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,gBAAgB;gBACxB,UAAU,EAAE;oBACV,cAAc,EAAE,KAAK,CAAC,eAAe,CAAC,cAAc;oBACpD,QAAQ,EAAE;wBACR;4BACE,QAAQ,EAAE,KAAK,CAAC,QAAQ;yBACzB;qBACF;iBACF;gBACD,kBAAkB,EAAE,8BAAE,CAAC,kBAAkB,CAAC,EAAE,CAAC,aAAa,CAAC;aAC5D;YACD,QAAQ,EAAE;gBACR,+DAA+D;gBAC/D,wFAAwF;gBACxF,OAAO,EAAE,MAAM;gBACf,MAAM,EAAE,MAAM;gBACd,UAAU,EAAE,gBAAgB;aAC7B;YACD,MAAM,EAAE,8BAAE,CAAC,uBAAuB,CAAC,YAAY,CAAC;gBAC9C,SAAS,EAAE,CAAC,KAAK,CAAC,eAAe,CAAC,aAAa,CAAC;aACjD,CAAC;YACF,YAAY,EAAE,wBAAwB;YACtC,mBAAmB,EAAE,KAAK;YAC1B,YAAY,EAAE,wBAAa,CAAC,SAAS;SACtC,CAAC,CAAC;QAEH,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAmC,CAAC;QACnF,IAAI,GAAG,EAAE;YACP,8CAA8C;YAC9C,GAAG,CAAC,kBAAkB,CAAC,GAAG,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;SAClD;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,wHAAwH,CAAC,CAAC;SAC3I;QAED,qEAAqE;QACrE,OAAO,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,gBAAgB,CAAC,4BAA4B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACxF,CAAC;;AA7QH,oDA8QC;;;AA7QC;;;;;;GAMG;AACoB,8CAAyB,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,eAAe,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;AAEtI;;;;;;GAMG;AACoB,gDAA2B,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,eAAe,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;AA+P5I;;GAEG;AACH,MAAa,YAAa,SAAQ,oBAAoB;;AAAtD,oCACC","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport {\n  aws_ec2 as ec2,\n  aws_events as events,\n  aws_events_targets as events_targets,\n  aws_iam as iam,\n  aws_lambda as lambda,\n  aws_logs as logs,\n  aws_stepfunctions as stepfunctions,\n  aws_stepfunctions_tasks as stepfunctions_tasks,\n  custom_resources as cr,\n} from 'aws-cdk-lib';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Construct } from 'constructs';\nimport {\n  Architecture,\n  BaseProvider,\n  IImageBuilder,\n  IRunnerProvider,\n  IRunnerProviderStatus,\n  Os,\n  RunnerImage,\n  RunnerProviderProps,\n  RunnerRuntimeParameters,\n} from './common';\nimport { CodeBuildImageBuilder } from './image-builders/codebuild';\nimport { UpdateLambdaFunction } from '../lambdas/update-lambda-function';\nimport { singletonLambda } from '../utils';\n\nexport interface LambdaRunnerProviderProps extends RunnerProviderProps {\n  /**\n   * Provider running an image to run inside CodeBuild with GitHub runner pre-configured.\n   *\n   * The default command (`CMD`) should be `[\"runner.handler\"]` which points to an included `runner.js` with a function named `handler`. The function should start the GitHub runner.\n   *\n   * The image builder determines the OS and architecture of the runner.\n   *\n   * @see https://github.com/CloudSnorkel/cdk-github-runners/tree/main/src/providers/docker-images/lambda\n   * @default image builder with LambdaRunner.LINUX_X64_DOCKERFILE_PATH as Dockerfile\n   */\n  readonly imageBuilder?: IImageBuilder;\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 ['lambda']\n   */\n  readonly labels?: string[];\n\n  /**\n   * The amount of memory, in MB, that is allocated to your Lambda function.\n   * Lambda uses this value to proportionally allocate the amount of CPU\n   * power. For more information, see Resource Model in the AWS Lambda\n   * Developer Guide.\n   *\n   * @default 2048\n   */\n  readonly memorySize?: number;\n\n  /**\n   * The size of the function’s /tmp directory in MiB.\n   *\n   * @default 10 GiB\n   */\n  readonly ephemeralStorageSize?: cdk.Size;\n\n  /**\n   * The function execution time (in seconds) after which Lambda terminates\n   * the function. Because the execution time affects cost, set this value\n   * based on the function's expected execution time.\n   *\n   * @default Duration.minutes(15)\n   */\n  readonly timeout?: cdk.Duration;\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 lambda 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 public lambda with no security group\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/**\n * GitHub Actions runner provider using Lambda to execute jobs.\n *\n * Creates a Docker-based function that gets executed 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 LambdaRunnerProvider extends BaseProvider implements IRunnerProvider {\n  /**\n   * Path to Dockerfile for Linux x64 with all the requirement for Lambda 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 similar to public.ecr.aws/lambda/nodejs:14.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   */\n  public static readonly LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'lambda', 'linux-x64');\n\n  /**\n   * Path to Dockerfile for Linux ARM64 with all the requirement for Lambda 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 similar to public.ecr.aws/lambda/nodejs:14.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   */\n  public static readonly LINUX_ARM64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'lambda', 'linux-arm64');\n\n  /**\n   * The function hosting the GitHub runner.\n   */\n  readonly function: lambda.Function;\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 Lambda.\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  private readonly vpc?: ec2.IVpc;\n  private readonly securityGroups?: ec2.ISecurityGroup[];\n\n  constructor(scope: Construct, id: string, props?: LambdaRunnerProviderProps) {\n    super(scope, id, props);\n\n    this.labels = this.labelsFromProperties('lambda', props?.label, props?.labels);\n    this.vpc = props?.vpc;\n    this.securityGroups = props?.securityGroup ? [props.securityGroup] : props?.securityGroups;\n\n    const imageBuilder = props?.imageBuilder ?? new CodeBuildImageBuilder(this, 'Image Builder', {\n      dockerfilePath: LambdaRunnerProvider.LINUX_X64_DOCKERFILE_PATH,\n    });\n    const image = this.image = imageBuilder.bind();\n\n    let architecture: lambda.Architecture | undefined;\n    if (image.os.is(Os.LINUX)) {\n      if (image.architecture.is(Architecture.X86_64)) {\n        architecture = lambda.Architecture.X86_64;\n      }\n      if (image.architecture.is(Architecture.ARM64)) {\n        architecture = lambda.Architecture.ARM_64;\n      }\n    }\n\n    if (!architecture) {\n      throw new Error(`Unable to find support Lambda architecture for ${image.os.name}/${image.architecture.name}`);\n    }\n\n    // get image digest and make sure to get it every time the lambda function might be updated\n    // pass all variables that may change and cause a function update\n    // if we don't get the latest digest, the update may fail as a new image was already built outside the stack on a schedule\n    // we automatically delete old images, so we must always get the latest digest\n    const imageDigest = this.imageDigest(image, {\n      version: 1, // bump this for any non-user changes like description or defaults\n      labels: this.labels,\n      architecture: architecture.name,\n      vpc: this.vpc?.vpcId,\n      securityGroups: this.securityGroups?.map(sg => sg.securityGroupId),\n      vpcSubnets: props?.subnetSelection?.subnets?.map(s => s.subnetId),\n      timeout: props?.timeout?.toSeconds(),\n      memorySize: props?.memorySize,\n      ephemeralStorageSize: props?.ephemeralStorageSize?.toKibibytes(),\n      logRetention: props?.logRetention?.toFixed(),\n    });\n\n    this.function = new lambda.DockerImageFunction(\n      this,\n      'Function',\n      {\n        description: `GitHub Actions runner for labels ${this.labels}`,\n        // CDK requires \"sha256:\" literal prefix -- https://github.com/aws/aws-cdk/blob/ba91ca45ad759ab5db6da17a62333e2bc11e1075/packages/%40aws-cdk/aws-ecr/lib/repository.ts#L184\n        code: lambda.DockerImageCode.fromEcr(image.imageRepository, { tagOrDigest: `sha256:${imageDigest}` }),\n        architecture,\n        vpc: this.vpc,\n        securityGroups: this.securityGroups,\n        vpcSubnets: props?.subnetSelection,\n        timeout: props?.timeout || cdk.Duration.minutes(15),\n        memorySize: props?.memorySize || 2048,\n        ephemeralStorageSize: props?.ephemeralStorageSize || cdk.Size.gibibytes(10),\n        logRetention: props?.logRetention || RetentionDays.ONE_MONTH,\n      },\n    );\n\n    this.grantPrincipal = this.function.grantPrincipal;\n    this.logGroup = this.function.logGroup;\n\n    this.addImageUpdater(image);\n  }\n\n  /**\n   * The network connections associated with this resource.\n   */\n  public get connections(): ec2.Connections {\n    return this.function.connections;\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    const invoke = new stepfunctions_tasks.LambdaInvoke(\n      this,\n      this.labels.join(', '),\n      {\n        lambdaFunction: this.function,\n        payload: stepfunctions.TaskInput.fromObject({\n          token: parameters.runnerTokenPath,\n          runnerName: parameters.runnerNamePath,\n          label: this.labels.join(','),\n          githubDomain: parameters.githubDomainPath,\n          owner: parameters.ownerPath,\n          repo: parameters.repoPath,\n        }),\n      },\n    );\n\n    this.addRetry(invoke, ['Lambda.LambdaException', 'Lambda.Ec2ThrottledException', 'Lambda.Ec2UnexpectedException', 'Lambda.EniLimitReachedException', 'Lambda.TooManyRequestsException']);\n\n    return invoke;\n  }\n\n  private addImageUpdater(image: RunnerImage) {\n    // Lambda needs to be pointing to a specific image digest and not just a tag.\n    // Whenever we update the tag to a new digest, we need to update the lambda.\n\n    const updater = singletonLambda(UpdateLambdaFunction, this, 'update-lambda', {\n      description: 'Function that updates a GitHub Actions runner function with the latest image digest after the image has been rebuilt',\n      timeout: cdk.Duration.minutes(15),\n      logRetention: logs.RetentionDays.ONE_MONTH,\n    });\n\n    updater.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['lambda:UpdateFunctionCode'],\n      resources: [this.function.functionArn],\n    }));\n\n    let lambdaTarget = new events_targets.LambdaFunction(updater, {\n      event: events.RuleTargetInput.fromObject({\n        lambdaName: this.function.functionName,\n        repositoryUri: image.imageRepository.repositoryUri,\n        repositoryTag: image.imageTag,\n      }),\n    });\n\n    const rule = image.imageRepository.onEvent('Push rule', {\n      description: 'Update GitHub Actions runner Lambda on ECR image push',\n      eventPattern: {\n        detailType: ['ECR Image Action'],\n        detail: {\n          'action-type': ['PUSH'],\n          'repository-name': [image.imageRepository.repositoryName],\n          'image-tag': [image.imageTag],\n          'result': ['SUCCESS'],\n        },\n      },\n      target: lambdaTarget,\n    });\n\n    // the event never triggers without this - not sure why\n    (rule.node.defaultChild as events.CfnRule).addDeletionOverride('Properties.EventPattern.resources');\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      vpcArn: this.vpc?.vpcArn,\n      securityGroups: this.securityGroups?.map(sg => sg.securityGroupId),\n      roleArn: this.function.role?.roleArn,\n      logGroup: this.function.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  private imageDigest(image: RunnerImage, variableSettings: any): string {\n    // describe ECR image to get its digest\n    // the physical id is random so the resource always runs and always gets the latest digest, even if a scheduled build replaced the stack image\n    const reader = new cr.AwsCustomResource(this, 'Image Digest Reader', {\n      onCreate: {\n        service: 'ECR',\n        action: 'describeImages',\n        parameters: {\n          repositoryName: image.imageRepository.repositoryName,\n          imageIds: [\n            {\n              imageTag: image.imageTag,\n            },\n          ],\n        },\n        physicalResourceId: cr.PhysicalResourceId.of('ImageDigest'),\n      },\n      onUpdate: {\n        service: 'ECR',\n        action: 'describeImages',\n        parameters: {\n          repositoryName: image.imageRepository.repositoryName,\n          imageIds: [\n            {\n              imageTag: image.imageTag,\n            },\n          ],\n        },\n        physicalResourceId: cr.PhysicalResourceId.of('ImageDigest'),\n      },\n      onDelete: {\n        // this will NOT be called thanks to RemovalPolicy.RETAIN below\n        // we only use this to force the custom resource to be called again and get a new digest\n        service: 'fake',\n        action: 'fake',\n        parameters: variableSettings,\n      },\n      policy: cr.AwsCustomResourcePolicy.fromSdkCalls({\n        resources: [image.imageRepository.repositoryArn],\n      }),\n      resourceType: 'Custom::EcrImageDigest',\n      installLatestAwsSdk: false, // no need and it takes 60 seconds\n      logRetention: RetentionDays.ONE_MONTH,\n    });\n\n    const res = reader.node.tryFindChild('Resource') as cdk.CustomResource | undefined;\n    if (res) {\n      // don't actually call the fake onDelete above\n      res.applyRemovalPolicy(cdk.RemovalPolicy.RETAIN);\n    } else {\n      throw new Error('Resource not found in AwsCustomResource. Report this bug at https://github.com/CloudSnorkel/cdk-github-runners/issues.');\n    }\n\n    // return only the digest because CDK expects 'sha256:' literal above\n    return cdk.Fn.split(':', reader.getResponseField('imageDetails.0.imageDigest'), 2)[1];\n  }\n}\n\n/**\n * @deprecated use {@link LambdaRunnerProvider}\n */\nexport class LambdaRunner extends LambdaRunnerProvider {\n}\n"]}
|
|
275
|
+
LambdaRunner[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaRunner", version: "0.9.1" };
|
|
276
|
+
exports.LambdaRunner = LambdaRunner;
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda.js","sourceRoot":"","sources":["../../src/providers/lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport {\n  aws_ec2 as ec2,\n  aws_events as events,\n  aws_events_targets as events_targets,\n  aws_iam as iam,\n  aws_lambda as lambda,\n  aws_logs as logs,\n  aws_stepfunctions as stepfunctions,\n  aws_stepfunctions_tasks as stepfunctions_tasks,\n  custom_resources as cr,\n} from 'aws-cdk-lib';\nimport { RetentionDays } from 'aws-cdk-lib/aws-logs';\nimport { Construct } from 'constructs';\nimport {\n  Architecture,\n  BaseProvider,\n  IRunnerProvider,\n  IRunnerProviderStatus,\n  Os,\n  RunnerImage,\n  RunnerProviderProps,\n  RunnerRuntimeParameters,\n  RunnerVersion,\n} from './common';\nimport { IRunnerImageBuilder, RunnerImageBuilder, RunnerImageBuilderProps, RunnerImageComponent } from './image-builders';\nimport { UpdateLambdaFunction } from '../lambdas/update-lambda-function';\nimport { singletonLambda } from '../utils';\n\nexport interface LambdaRunnerProviderProps 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.lambdaEntrypoint} component.\n   *\n   * The image builder determines the OS and architecture of the runner.\n   *\n   * @default LambdaRunnerProvider.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 ['lambda']\n   */\n  readonly labels?: string[];\n\n  /**\n   * The amount of memory, in MB, that is allocated to your Lambda function.\n   * Lambda uses this value to proportionally allocate the amount of CPU\n   * power. For more information, see Resource Model in the AWS Lambda\n   * Developer Guide.\n   *\n   * @default 2048\n   */\n  readonly memorySize?: number;\n\n  /**\n   * The size of the function’s /tmp directory in MiB.\n   *\n   * @default 10 GiB\n   */\n  readonly ephemeralStorageSize?: cdk.Size;\n\n  /**\n   * The function execution time (in seconds) after which Lambda terminates\n   * the function. Because the execution time affects cost, set this value\n   * based on the function's expected execution time.\n   *\n   * @default Duration.minutes(15)\n   */\n  readonly timeout?: cdk.Duration;\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 lambda 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 public lambda with no security group\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/**\n * GitHub Actions runner provider using Lambda to execute jobs.\n *\n * Creates a Docker-based function that gets executed 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 LambdaRunnerProvider extends BaseProvider implements IRunnerProvider {\n  /**\n   * Path to Dockerfile for Linux x64 with all the requirement for Lambda 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 similar to public.ecr.aws/lambda/nodejs:14.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   *\n   * @deprecated Use `imageBuilder()` instead.\n   */\n  public static readonly LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'lambda', 'linux-x64');\n\n  /**\n   * Path to Dockerfile for Linux ARM64 with all the requirement for Lambda 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 similar to public.ecr.aws/lambda/nodejs:14.\n   * * `EXTRA_PACKAGES` can be used to install additional packages.\n   *\n   * @deprecated Use `imageBuilder()` instead.\n   */\n  public static readonly LINUX_ARM64_DOCKERFILE_PATH = path.join(__dirname, '..', '..', 'assets', 'docker-images', 'lambda', 'linux-arm64');\n\n  /**\n   * Create new image builder that builds Lambda specific runner images using Amazon Linux 2.\n   *\n   * Included components:\n   *  * `RunnerImageComponent.requiredPackages()`\n   *  * `RunnerImageComponent.runnerUser()`\n   *  * `RunnerImageComponent.git()`\n   *  * `RunnerImageComponent.githubCli()`\n   *  * `RunnerImageComponent.awsCli()`\n   *  * `RunnerImageComponent.githubRunner()`\n   *  * `RunnerImageComponent.lambdaEntrypoint()`\n   *\n   *  Base Docker image: `public.ecr.aws/lambda/nodejs:14-x86_64` or `public.ecr.aws/lambda/nodejs:14-arm64`\n   */\n  public static imageBuilder(scope: Construct, id: string, props?: RunnerImageBuilderProps) {\n    let baseDockerImage = 'public.ecr.aws/lambda/nodejs:14-x86_64';\n    if (props?.architecture === Architecture.ARM64) {\n      baseDockerImage = 'public.ecr.aws/lambda/nodejs:14-arm64';\n    }\n\n    return RunnerImageBuilder.new(scope, id, {\n      os: Os.LINUX_AMAZON_2,\n      architecture: props?.architecture ?? Architecture.X86_64,\n      baseDockerImage,\n      components: [\n        RunnerImageComponent.requiredPackages(),\n        RunnerImageComponent.runnerUser(),\n        RunnerImageComponent.git(),\n        RunnerImageComponent.githubCli(),\n        RunnerImageComponent.awsCli(),\n        RunnerImageComponent.githubRunner(props?.runnerVersion ?? RunnerVersion.latest()),\n        RunnerImageComponent.lambdaEntrypoint(),\n      ],\n      ...props,\n    });\n  }\n\n  /**\n   * The function hosting the GitHub runner.\n   */\n  readonly function: lambda.Function;\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 Lambda.\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  private readonly vpc?: ec2.IVpc;\n  private readonly securityGroups?: ec2.ISecurityGroup[];\n\n  constructor(scope: Construct, id: string, props?: LambdaRunnerProviderProps) {\n    super(scope, id, props);\n\n    this.labels = this.labelsFromProperties('lambda', props?.label, props?.labels);\n    this.vpc = props?.vpc;\n    this.securityGroups = props?.securityGroup ? [props.securityGroup] : props?.securityGroups;\n\n    const imageBuilder = props?.imageBuilder ?? LambdaRunnerProvider.imageBuilder(this, 'Image Builder');\n    const image = this.image = imageBuilder.bindDockerImage();\n\n    let architecture: lambda.Architecture | undefined;\n    if (image.os.is(Os.LINUX_AMAZON_2) || image.os.is(Os.LINUX_UBUNTU)) {\n      if (image.architecture.is(Architecture.X86_64)) {\n        architecture = lambda.Architecture.X86_64;\n      }\n      if (image.architecture.is(Architecture.ARM64)) {\n        architecture = lambda.Architecture.ARM_64;\n      }\n    }\n\n    if (!architecture) {\n      throw new Error(`Unable to find supported Lambda architecture for ${image.os.name}/${image.architecture.name}`);\n    }\n\n    // get image digest and make sure to get it every time the lambda function might be updated\n    // pass all variables that may change and cause a function update\n    // if we don't get the latest digest, the update may fail as a new image was already built outside the stack on a schedule\n    // we automatically delete old images, so we must always get the latest digest\n    const imageDigest = this.imageDigest(image, {\n      version: 1, // bump this for any non-user changes like description or defaults\n      labels: this.labels,\n      architecture: architecture.name,\n      vpc: this.vpc?.vpcId,\n      securityGroups: this.securityGroups?.map(sg => sg.securityGroupId),\n      vpcSubnets: props?.subnetSelection?.subnets?.map(s => s.subnetId),\n      timeout: props?.timeout?.toSeconds(),\n      memorySize: props?.memorySize,\n      ephemeralStorageSize: props?.ephemeralStorageSize?.toKibibytes(),\n      logRetention: props?.logRetention?.toFixed(),\n    });\n\n    this.function = new lambda.DockerImageFunction(\n      this,\n      'Function',\n      {\n        description: `GitHub Actions runner for labels ${this.labels}`,\n        // CDK requires \"sha256:\" literal prefix -- https://github.com/aws/aws-cdk/blob/ba91ca45ad759ab5db6da17a62333e2bc11e1075/packages/%40aws-cdk/aws-ecr/lib/repository.ts#L184\n        code: lambda.DockerImageCode.fromEcr(image.imageRepository, { tagOrDigest: `sha256:${imageDigest}` }),\n        architecture,\n        vpc: this.vpc,\n        securityGroups: this.securityGroups,\n        vpcSubnets: props?.subnetSelection,\n        timeout: props?.timeout || cdk.Duration.minutes(15),\n        memorySize: props?.memorySize || 2048,\n        ephemeralStorageSize: props?.ephemeralStorageSize || cdk.Size.gibibytes(10),\n        logRetention: props?.logRetention || RetentionDays.ONE_MONTH,\n      },\n    );\n\n    this.grantPrincipal = this.function.grantPrincipal;\n    this.logGroup = this.function.logGroup;\n\n    this.addImageUpdater(image);\n  }\n\n  /**\n   * The network connections associated with this resource.\n   */\n  public get connections(): ec2.Connections {\n    return this.function.connections;\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    const invoke = new stepfunctions_tasks.LambdaInvoke(\n      this,\n      this.labels.join(', '),\n      {\n        lambdaFunction: this.function,\n        payload: stepfunctions.TaskInput.fromObject({\n          token: parameters.runnerTokenPath,\n          runnerName: parameters.runnerNamePath,\n          label: this.labels.join(','),\n          githubDomain: parameters.githubDomainPath,\n          owner: parameters.ownerPath,\n          repo: parameters.repoPath,\n        }),\n      },\n    );\n\n    this.addRetry(invoke, ['Lambda.LambdaException', 'Lambda.Ec2ThrottledException', 'Lambda.Ec2UnexpectedException', 'Lambda.EniLimitReachedException', 'Lambda.TooManyRequestsException']);\n\n    return invoke;\n  }\n\n  private addImageUpdater(image: RunnerImage) {\n    // Lambda needs to be pointing to a specific image digest and not just a tag.\n    // Whenever we update the tag to a new digest, we need to update the lambda.\n\n    const updater = singletonLambda(UpdateLambdaFunction, this, 'update-lambda', {\n      description: 'Function that updates a GitHub Actions runner function with the latest image digest after the image has been rebuilt',\n      timeout: cdk.Duration.minutes(15),\n      logRetention: logs.RetentionDays.ONE_MONTH,\n    });\n\n    updater.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['lambda:UpdateFunctionCode'],\n      resources: [this.function.functionArn],\n    }));\n\n    let lambdaTarget = new events_targets.LambdaFunction(updater, {\n      event: events.RuleTargetInput.fromObject({\n        lambdaName: this.function.functionName,\n        repositoryUri: image.imageRepository.repositoryUri,\n        repositoryTag: image.imageTag,\n      }),\n    });\n\n    const rule = image.imageRepository.onEvent('Push rule', {\n      description: 'Update GitHub Actions runner Lambda on ECR image push',\n      eventPattern: {\n        detailType: ['ECR Image Action'],\n        detail: {\n          'action-type': ['PUSH'],\n          'repository-name': [image.imageRepository.repositoryName],\n          'image-tag': [image.imageTag],\n          'result': ['SUCCESS'],\n        },\n      },\n      target: lambdaTarget,\n    });\n\n    // the event never triggers without this - not sure why\n    (rule.node.defaultChild as events.CfnRule).addDeletionOverride('Properties.EventPattern.resources');\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      vpcArn: this.vpc?.vpcArn,\n      securityGroups: this.securityGroups?.map(sg => sg.securityGroupId),\n      roleArn: this.function.role?.roleArn,\n      logGroup: this.function.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  private imageDigest(image: RunnerImage, variableSettings: any): string {\n    // describe ECR image to get its digest\n    // the physical id is random so the resource always runs and always gets the latest digest, even if a scheduled build replaced the stack image\n    const reader = new cr.AwsCustomResource(this, 'Image Digest Reader', {\n      onCreate: {\n        service: 'ECR',\n        action: 'describeImages',\n        parameters: {\n          repositoryName: image.imageRepository.repositoryName,\n          imageIds: [\n            {\n              imageTag: image.imageTag,\n            },\n          ],\n        },\n        physicalResourceId: cr.PhysicalResourceId.of('ImageDigest'),\n      },\n      onUpdate: {\n        service: 'ECR',\n        action: 'describeImages',\n        parameters: {\n          repositoryName: image.imageRepository.repositoryName,\n          imageIds: [\n            {\n              imageTag: image.imageTag,\n            },\n          ],\n        },\n        physicalResourceId: cr.PhysicalResourceId.of('ImageDigest'),\n      },\n      onDelete: {\n        // this will NOT be called thanks to RemovalPolicy.RETAIN below\n        // we only use this to force the custom resource to be called again and get a new digest\n        service: 'fake',\n        action: 'fake',\n        parameters: variableSettings,\n      },\n      policy: cr.AwsCustomResourcePolicy.fromSdkCalls({\n        resources: [image.imageRepository.repositoryArn],\n      }),\n      resourceType: 'Custom::EcrImageDigest',\n      installLatestAwsSdk: false, // no need and it takes 60 seconds\n      logRetention: RetentionDays.ONE_MONTH,\n    });\n\n    const res = reader.node.tryFindChild('Resource') as cdk.CustomResource | undefined;\n    if (res) {\n      // don't actually call the fake onDelete above\n      res.applyRemovalPolicy(cdk.RemovalPolicy.RETAIN);\n    } else {\n      throw new Error('Resource not found in AwsCustomResource. Report this bug at https://github.com/CloudSnorkel/cdk-github-runners/issues.');\n    }\n\n    // return only the digest because CDK expects 'sha256:' literal above\n    return cdk.Fn.split(':', reader.getResponseField('imageDetails.0.imageDigest'), 2)[1];\n  }\n}\n\n/**\n * @deprecated use {@link LambdaRunnerProvider}\n */\nexport class LambdaRunner extends LambdaRunnerProvider {\n}\n"]}
|
package/lib/runner.d.ts
CHANGED
|
@@ -37,12 +37,10 @@ export interface GitHubRunnersProps {
|
|
|
37
37
|
* You may also want to use custom images for your runner providers that contain the same certificates. See {@link CodeBuildImageBuilder.addCertificates}.
|
|
38
38
|
*
|
|
39
39
|
* ```typescript
|
|
40
|
-
* const imageBuilder =
|
|
41
|
-
*
|
|
42
|
-
* });
|
|
43
|
-
* imageBuilder.addExtraCertificates('path-to-my-extra-certs-folder');
|
|
40
|
+
* const imageBuilder = CodeBuildRunnerProvider.imageBuilder(this, 'Image Builder with Certs');
|
|
41
|
+
* imageBuilder.addComponent(RunnerImageComponent.extraCertificates('path-to-my-extra-certs-folder/certs.pem', 'private-ca');
|
|
44
42
|
*
|
|
45
|
-
* const provider = new
|
|
43
|
+
* const provider = new CodeBuildRunnerProvider(this, 'CodeBuild', {
|
|
46
44
|
* imageBuilder: imageBuilder,
|
|
47
45
|
* });
|
|
48
46
|
*
|