@cloudsnorkel/cdk-github-runners 0.2.0 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitattributes +8 -1
- package/.jsii +1371 -206
- package/API.md +1191 -93
- package/README.md +59 -49
- package/lib/index.d.ts +3 -1
- package/lib/index.js +7 -1
- package/lib/lambdas/build-image/index.js +121 -0
- package/lib/lambdas/delete-runner/index.js +5151 -2999
- package/lib/lambdas/setup/index.html +37 -0
- package/lib/lambdas/setup/index.js +140 -255
- package/lib/lambdas/status/index.js +5151 -2999
- package/lib/lambdas/token-retriever/index.js +5151 -2999
- package/lib/lambdas/update-lambda/index.js +55 -0
- package/lib/providers/codebuild.d.ts +31 -1
- package/lib/providers/codebuild.js +57 -13
- package/lib/providers/common.d.ts +87 -6
- package/lib/providers/common.js +64 -4
- package/lib/providers/docker-images/codebuild/linux-arm64/Dockerfile +63 -0
- package/lib/providers/docker-images/codebuild/{Dockerfile → linux-x64/Dockerfile} +14 -5
- package/lib/providers/docker-images/fargate/linux-arm64/Dockerfile +45 -0
- package/lib/providers/docker-images/fargate/{runner.sh → linux-arm64/runner.sh} +0 -0
- package/lib/providers/docker-images/fargate/{Dockerfile → linux-x64/Dockerfile} +14 -5
- package/lib/providers/docker-images/fargate/linux-x64/runner.sh +5 -0
- package/lib/providers/docker-images/lambda/linux-arm64/Dockerfile +36 -0
- package/lib/providers/docker-images/lambda/{runner.js → linux-arm64/runner.js} +0 -0
- package/lib/providers/docker-images/lambda/{runner.sh → linux-arm64/runner.sh} +0 -0
- package/lib/providers/docker-images/lambda/linux-x64/Dockerfile +35 -0
- package/lib/providers/docker-images/lambda/linux-x64/runner.js +29 -0
- package/lib/providers/docker-images/lambda/linux-x64/runner.sh +12 -0
- package/lib/providers/fargate.d.ts +33 -1
- package/lib/providers/fargate.js +39 -8
- package/lib/providers/image-builders/codebuild.d.ts +178 -0
- package/lib/providers/image-builders/codebuild.js +354 -0
- package/lib/providers/image-builders/static.d.ts +29 -0
- package/lib/providers/image-builders/static.js +58 -0
- package/lib/providers/lambda.d.ts +27 -1
- package/lib/providers/lambda.js +88 -9
- package/lib/runner.d.ts +56 -9
- package/lib/runner.js +37 -11
- package/lib/secrets.js +1 -1
- package/lib/utils.d.ts +2 -1
- package/lib/utils.js +14 -3
- package/lib/webhook.js +2 -1
- package/package.json +30 -12
- package/setup/index.html +12 -0
- package/setup/src/App.svelte +291 -0
- package/setup/src/app.scss +15 -0
- package/setup/src/main.ts +8 -0
- package/setup/src/vite-env.d.ts +2 -0
- package/setup/svelte.config.mjs +7 -0
- package/setup/tsconfig.json +21 -0
- package/setup/tsconfig.node.json +8 -0
- package/setup/vite.config.ts +15 -0
- package/lib/providers/docker-images/lambda/Dockerfile +0 -27
|
@@ -1,13 +1,22 @@
|
|
|
1
|
-
|
|
1
|
+
ARG BASE_IMAGE="public.ecr.aws/lts/ubuntu:20.04"
|
|
2
|
+
FROM $BASE_IMAGE
|
|
2
3
|
|
|
3
4
|
# setup user
|
|
4
5
|
RUN addgroup runner && adduser --system --disabled-password --home /home/runner --ingroup runner runner
|
|
5
6
|
|
|
6
7
|
# add dependencies and sudo
|
|
7
|
-
|
|
8
|
+
ARG EXTRA_PACKAGES=""
|
|
9
|
+
RUN apt-get update && apt-get upgrade -y && apt-get install -y curl sudo jq bash zip unzip software-properties-common ca-certificates $EXTRA_PACKAGES && \
|
|
8
10
|
usermod -aG sudo runner && \
|
|
9
11
|
echo "%sudo ALL=(ALL:ALL) NOPASSWD: ALL" > /etc/sudoers.d/runner
|
|
10
12
|
|
|
13
|
+
# install extra certificates
|
|
14
|
+
COPY extra_certs/. /tmp/certs/
|
|
15
|
+
RUN if [ -f /tmp/certs/certs.pem ]; then cp /tmp/certs/certs.pem /usr/local/share/ca-certificates/github-enterprise-server.crt; update-ca-certificates; else echo no self-signed certificates; fi
|
|
16
|
+
|
|
17
|
+
# add latest git
|
|
18
|
+
RUN add-apt-repository ppa:git-core/ppa && apt update && apt-get install -y git
|
|
19
|
+
|
|
11
20
|
# add awscli
|
|
12
21
|
RUN curl -fsSL "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o awscliv2.zip && \
|
|
13
22
|
unzip -q awscliv2.zip && ./aws/install && rm -rf awscliv2.zip aws
|
|
@@ -21,9 +30,9 @@ RUN curl -fsSL https://cli.github.com/packages/githubcli-archive-keyring.gpg | s
|
|
|
21
30
|
# setup working directory
|
|
22
31
|
WORKDIR /home/runner
|
|
23
32
|
|
|
24
|
-
# add runner
|
|
25
|
-
ARG RUNNER_VERSION
|
|
26
|
-
RUN if [ "${RUNNER_VERSION}" = "latest" ]; then RUNNER_VERSION=`curl -
|
|
33
|
+
# add runner without github's api which is rate limited
|
|
34
|
+
ARG RUNNER_VERSION=latest
|
|
35
|
+
RUN if [ "${RUNNER_VERSION}" = "latest" ]; then RUNNER_VERSION=`curl -w "%{redirect_url}" -fsS https://github.com/actions/runner/releases/latest | grep -oE "[^/v]+$"`; fi && \
|
|
27
36
|
curl -fsSLO "https://github.com/actions/runner/releases/download/v${RUNNER_VERSION}/actions-runner-linux-x64-${RUNNER_VERSION}.tar.gz" && \
|
|
28
37
|
tar xzf "actions-runner-linux-x64-${RUNNER_VERSION}.tar.gz" && \
|
|
29
38
|
rm actions-runner-linux-x64-${RUNNER_VERSION}.tar.gz && \
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
# https://docs.aws.amazon.com/lambda/latest/dg/images-create.html
|
|
2
|
+
|
|
3
|
+
ARG BASE_IMAGE="public.ecr.aws/lambda/nodejs:14-arm64"
|
|
4
|
+
FROM $BASE_IMAGE
|
|
5
|
+
|
|
6
|
+
WORKDIR /runner
|
|
7
|
+
|
|
8
|
+
# install extra certificates
|
|
9
|
+
COPY extra_certs/. /tmp/certs/
|
|
10
|
+
RUN if [ -f /tmp/certs/certs.pem ]; then cp /tmp/certs/certs.pem /etc/pki/ca-trust/source/anchors/ghe.crt; update-ca-trust; else echo no self-signed certificates; fi
|
|
11
|
+
|
|
12
|
+
# add dependencies
|
|
13
|
+
ARG EXTRA_PACKAGES=""
|
|
14
|
+
RUN yum update -y && yum install -y jq tar gzip bzip2 which binutils git zip unzip $EXTRA_PACKAGES
|
|
15
|
+
|
|
16
|
+
# add awscli
|
|
17
|
+
RUN curl -fsSL "https://awscli.amazonaws.com/awscli-exe-linux-aarch64.zip" -o awscliv2.zip && \
|
|
18
|
+
unzip -q awscliv2.zip && ./aws/install && rm -rf awscliv2.zip aws
|
|
19
|
+
|
|
20
|
+
# add ghcli
|
|
21
|
+
RUN curl -fsSSL https://cli.github.com/packages/rpm/gh-cli.repo -o /etc/yum.repos.d/gh-cli.repo && \
|
|
22
|
+
yum install -y gh
|
|
23
|
+
|
|
24
|
+
# add runner without github's api which is rate limited
|
|
25
|
+
ARG RUNNER_VERSION=latest
|
|
26
|
+
RUN if [ "${RUNNER_VERSION}" = "latest" ]; then RUNNER_VERSION=`curl -w "%{redirect_url}" -fsS https://github.com/actions/runner/releases/latest | grep -oE "[^/v]+$"`; fi && \
|
|
27
|
+
curl -fsSLO "https://github.com/actions/runner/releases/download/v${RUNNER_VERSION}/actions-runner-linux-arm64-${RUNNER_VERSION}.tar.gz" && \
|
|
28
|
+
tar xzf "actions-runner-linux-arm64-${RUNNER_VERSION}.tar.gz" && \
|
|
29
|
+
rm actions-runner-linux-arm64-${RUNNER_VERSION}.tar.gz && \
|
|
30
|
+
yum install -y openssl-libs krb5-libs zlib libicu60
|
|
31
|
+
# doesn't work on CentOS - RUN ./bin/installdependencies.sh
|
|
32
|
+
|
|
33
|
+
# prepare for execution
|
|
34
|
+
WORKDIR ${LAMBDA_TASK_ROOT}
|
|
35
|
+
COPY runner.js runner.sh ${LAMBDA_TASK_ROOT}/
|
|
36
|
+
CMD ["runner.handler"]
|
|
File without changes
|
|
File without changes
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
# https://docs.aws.amazon.com/lambda/latest/dg/images-create.html
|
|
2
|
+
|
|
3
|
+
ARG BASE_IMAGE="public.ecr.aws/lambda/nodejs:14-x86_64"
|
|
4
|
+
FROM $BASE_IMAGE
|
|
5
|
+
|
|
6
|
+
WORKDIR /runner
|
|
7
|
+
|
|
8
|
+
# install extra certificates
|
|
9
|
+
COPY extra_certs/. /tmp/certs/
|
|
10
|
+
RUN if [ -f /tmp/certs/certs.pem ]; then cp /tmp/certs/certs.pem /etc/pki/ca-trust/source/anchors/ghe.crt; update-ca-trust; else echo no self-signed certificates; fi
|
|
11
|
+
|
|
12
|
+
# add dependencies
|
|
13
|
+
ARG EXTRA_PACKAGES=""
|
|
14
|
+
RUN yum update -y && yum install -y jq tar gzip bzip2 which binutils git zip unzip $EXTRA_PACKAGES
|
|
15
|
+
|
|
16
|
+
# add awscli
|
|
17
|
+
RUN curl -fsSL "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o awscliv2.zip && \
|
|
18
|
+
unzip -q awscliv2.zip && ./aws/install && rm -rf awscliv2.zip aws
|
|
19
|
+
|
|
20
|
+
# add ghcli
|
|
21
|
+
RUN curl -fsSSL https://cli.github.com/packages/rpm/gh-cli.repo -o /etc/yum.repos.d/gh-cli.repo && \
|
|
22
|
+
yum install -y gh
|
|
23
|
+
|
|
24
|
+
# add runner without github's api which is rate limited
|
|
25
|
+
ARG RUNNER_VERSION=latest
|
|
26
|
+
RUN if [ "${RUNNER_VERSION}" = "latest" ]; then RUNNER_VERSION=`curl -w "%{redirect_url}" -fsS https://github.com/actions/runner/releases/latest | grep -oE "[^/v]+$"`; fi && \
|
|
27
|
+
curl -fsSLO "https://github.com/actions/runner/releases/download/v${RUNNER_VERSION}/actions-runner-linux-x64-${RUNNER_VERSION}.tar.gz" && \
|
|
28
|
+
tar xzf "actions-runner-linux-x64-${RUNNER_VERSION}.tar.gz" && \
|
|
29
|
+
rm -f actions-runner-linux-x64-*.tar.gz && \
|
|
30
|
+
yum install -y openssl-libs krb5-libs zlib libicu60
|
|
31
|
+
|
|
32
|
+
# prepare for execution
|
|
33
|
+
WORKDIR ${LAMBDA_TASK_ROOT}
|
|
34
|
+
COPY runner.js runner.sh ${LAMBDA_TASK_ROOT}/
|
|
35
|
+
CMD ["runner.handler"]
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
const exec = require('child_process').exec;
|
|
2
|
+
|
|
3
|
+
exports.handler = async (event, context) => {
|
|
4
|
+
await new Promise((resolve, reject) => {
|
|
5
|
+
const shellScript = exec('sh runner.sh', {
|
|
6
|
+
env: {
|
|
7
|
+
OWNER: event.owner,
|
|
8
|
+
REPO: event.repo,
|
|
9
|
+
GITHUB_DOMAIN: event.githubDomain,
|
|
10
|
+
RUNNER_TOKEN: event.token,
|
|
11
|
+
RUNNER_NAME: event.runnerName,
|
|
12
|
+
RUNNER_LABEL: event.label,
|
|
13
|
+
},
|
|
14
|
+
});
|
|
15
|
+
shellScript.stdout.on('data', (data) => {
|
|
16
|
+
console.log(data);
|
|
17
|
+
});
|
|
18
|
+
shellScript.stderr.on('data', (data) => {
|
|
19
|
+
console.error(data);
|
|
20
|
+
});
|
|
21
|
+
shellScript.on('exit', (code) => {
|
|
22
|
+
if (code) {
|
|
23
|
+
reject(new Error(`Runner failed with exit code ${code}`));
|
|
24
|
+
} else {
|
|
25
|
+
resolve();
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
|
|
3
|
+
set -e -u -o pipefail
|
|
4
|
+
|
|
5
|
+
cp -r /runner /tmp/
|
|
6
|
+
cd /tmp/runner
|
|
7
|
+
|
|
8
|
+
export PATH=/var/lang/bin:/usr/local/bin:/usr/bin/:/bin:/opt/bin
|
|
9
|
+
./config.sh --unattended --url "https://${GITHUB_DOMAIN}/${OWNER}/${REPO}" --token "${RUNNER_TOKEN}" --ephemeral --work _work --labels "${RUNNER_LABEL}" --name "${RUNNER_NAME}" --disableupdate
|
|
10
|
+
echo Config done
|
|
11
|
+
./run.sh
|
|
12
|
+
echo Run done
|
|
@@ -1,10 +1,26 @@
|
|
|
1
1
|
import { aws_ec2 as ec2, aws_ecs as ecs, aws_iam as iam, aws_stepfunctions as stepfunctions } from 'aws-cdk-lib';
|
|
2
2
|
import { Construct } from 'constructs';
|
|
3
|
-
import { IRunnerProvider, RunnerProviderProps, RunnerRuntimeParameters } from './common';
|
|
3
|
+
import { IImageBuilder, IRunnerProvider, RunnerProviderProps, RunnerRuntimeParameters } from './common';
|
|
4
4
|
/**
|
|
5
5
|
* Properties for FargateRunner.
|
|
6
6
|
*/
|
|
7
7
|
export interface FargateRunnerProps extends RunnerProviderProps {
|
|
8
|
+
/**
|
|
9
|
+
* Provider running an image to run inside CodeBuild with GitHub runner pre-configured. A user named `runner` is expected to exist.
|
|
10
|
+
*
|
|
11
|
+
* The entry point should start GitHub runner. For example:
|
|
12
|
+
*
|
|
13
|
+
* ```
|
|
14
|
+
* #!/bin/bash
|
|
15
|
+
* set -e -u -o pipefail
|
|
16
|
+
*
|
|
17
|
+
* /home/runner/config.sh --unattended --url "https://${GITHUB_DOMAIN}/${OWNER}/${REPO}" --token "${RUNNER_TOKEN}" --ephemeral --work _work --labels "${RUNNER_LABEL}" --disableupdate --name "${RUNNER_NAME}"
|
|
18
|
+
* /home/runner/run.sh
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
* @default image builder with `FargateRunner.LINUX_X64_DOCKERFILE_PATH` as Dockerfile
|
|
22
|
+
*/
|
|
23
|
+
readonly imageBuilder?: IImageBuilder;
|
|
8
24
|
/**
|
|
9
25
|
* GitHub Actions label used for this provider.
|
|
10
26
|
*
|
|
@@ -98,6 +114,22 @@ export interface FargateRunnerProps extends RunnerProviderProps {
|
|
|
98
114
|
* This construct is not meant to be used by itself. It should be passed in the providers property for GitHubRunners.
|
|
99
115
|
*/
|
|
100
116
|
export declare class FargateRunner extends Construct implements IRunnerProvider {
|
|
117
|
+
/**
|
|
118
|
+
* Path to Dockerfile for Linux x64 with all the requirement for Fargate runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
|
|
119
|
+
*
|
|
120
|
+
* Available build arguments that can be set in the image builder:
|
|
121
|
+
* * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.
|
|
122
|
+
* * `EXTRA_PACKAGES` can be used to install additional packages.
|
|
123
|
+
*/
|
|
124
|
+
static readonly LINUX_X64_DOCKERFILE_PATH: string;
|
|
125
|
+
/**
|
|
126
|
+
* Path to Dockerfile for Linux ARM64 with all the requirement for Fargate runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
|
|
127
|
+
*
|
|
128
|
+
* Available build arguments that can be set in the image builder:
|
|
129
|
+
* * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.
|
|
130
|
+
* * `EXTRA_PACKAGES` can be used to install additional packages.
|
|
131
|
+
*/
|
|
132
|
+
static readonly LINUX_ARM64_DOCKERFILE_PATH: string;
|
|
101
133
|
/**
|
|
102
134
|
* Cluster hosting the task hosting the runner.
|
|
103
135
|
*/
|
package/lib/providers/fargate.js
CHANGED
|
@@ -9,6 +9,7 @@ const aws_logs_1 = require("aws-cdk-lib/aws-logs");
|
|
|
9
9
|
const aws_stepfunctions_1 = require("aws-cdk-lib/aws-stepfunctions");
|
|
10
10
|
const constructs_1 = require("constructs");
|
|
11
11
|
const common_1 = require("./common");
|
|
12
|
+
const codebuild_1 = require("./image-builders/codebuild");
|
|
12
13
|
class EcsFargateSpotLaunchTarget {
|
|
13
14
|
/**
|
|
14
15
|
* Called when the Fargate launch type configured on RunTask
|
|
@@ -48,17 +49,31 @@ class FargateRunner extends constructs_1.Construct {
|
|
|
48
49
|
enableFargateCapacityProviders: true,
|
|
49
50
|
});
|
|
50
51
|
this.spot = props.spot ?? false;
|
|
52
|
+
const imageBuilder = props.imageBuilder ?? new codebuild_1.CodeBuildImageBuilder(this, 'Image Builder', {
|
|
53
|
+
dockerfilePath: FargateRunner.LINUX_X64_DOCKERFILE_PATH,
|
|
54
|
+
});
|
|
55
|
+
const image = imageBuilder.bind();
|
|
56
|
+
let arch;
|
|
57
|
+
if (image.architecture.is(common_1.Architecture.ARM64)) {
|
|
58
|
+
arch = aws_cdk_lib_1.aws_ecs.CpuArchitecture.ARM64;
|
|
59
|
+
}
|
|
60
|
+
else if (image.architecture.is(common_1.Architecture.X86_64)) {
|
|
61
|
+
arch = aws_cdk_lib_1.aws_ecs.CpuArchitecture.X86_64;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
throw new Error(`${image.architecture.name} is not supported on Fargate`);
|
|
65
|
+
}
|
|
51
66
|
this.task = new aws_cdk_lib_1.aws_ecs.FargateTaskDefinition(this, 'task', {
|
|
52
67
|
cpu: props.cpu || 1024,
|
|
53
68
|
memoryLimitMiB: props.memoryLimitMiB || 2048,
|
|
54
69
|
ephemeralStorageGiB: props.ephemeralStorageGiB || 25,
|
|
70
|
+
runtimePlatform: {
|
|
71
|
+
operatingSystemFamily: aws_cdk_lib_1.aws_ecs.OperatingSystemFamily.LINUX,
|
|
72
|
+
cpuArchitecture: arch,
|
|
73
|
+
},
|
|
55
74
|
});
|
|
56
75
|
this.container = this.task.addContainer('runner', {
|
|
57
|
-
image: aws_cdk_lib_1.aws_ecs.AssetImage.
|
|
58
|
-
buildArgs: {
|
|
59
|
-
RUNNER_VERSION: props.runnerVersion ? props.runnerVersion.version : common_1.RunnerVersion.latest().version,
|
|
60
|
-
},
|
|
61
|
-
}),
|
|
76
|
+
image: aws_cdk_lib_1.aws_ecs.AssetImage.fromEcrRepository(image.imageRepository, image.imageTag),
|
|
62
77
|
logging: aws_cdk_lib_1.aws_ecs.AwsLogDriver.awsLogs({
|
|
63
78
|
logGroup: new aws_cdk_lib_1.aws_logs.LogGroup(this, 'logs', {
|
|
64
79
|
retention: props.logRetention || aws_logs_1.RetentionDays.ONE_MONTH,
|
|
@@ -77,7 +92,7 @@ class FargateRunner extends constructs_1.Construct {
|
|
|
77
92
|
* @param parameters workflow job details
|
|
78
93
|
*/
|
|
79
94
|
getStepFunctionTask(parameters) {
|
|
80
|
-
return new aws_cdk_lib_1.aws_stepfunctions_tasks.EcsRunTask(this,
|
|
95
|
+
return new aws_cdk_lib_1.aws_stepfunctions_tasks.EcsRunTask(this, this.label, {
|
|
81
96
|
integrationPattern: aws_stepfunctions_1.IntegrationPattern.RUN_JOB,
|
|
82
97
|
taskDefinition: this.task,
|
|
83
98
|
cluster: this.cluster,
|
|
@@ -120,5 +135,21 @@ class FargateRunner extends constructs_1.Construct {
|
|
|
120
135
|
}
|
|
121
136
|
exports.FargateRunner = FargateRunner;
|
|
122
137
|
_a = JSII_RTTI_SYMBOL_1;
|
|
123
|
-
FargateRunner[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.FargateRunner", version: "0.2
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fargate.js","sourceRoot":"","sources":["../../src/providers/fargate.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\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, RemovalPolicy,\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 { IRunnerProvider, RunnerProviderProps, RunnerRuntimeParameters, RunnerVersion } from './common';\n\n/**\n * Properties for FargateRunner.\n */\nexport interface FargateRunnerProps extends RunnerProviderProps {\n  /**\n   * GitHub Actions label used for this provider.\n   *\n   * @default 'fargate'\n   */\n  readonly label?: 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   * Security Group to assign to the task.\n   *\n   * @default a new security group\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Existing Fargate cluster to use.\n   *\n   * @default a new cluster\n   */\n  readonly cluster?: ecs.Cluster;\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. For tasks using the Fargate launch type,\n   * this field is required and you must use one of the following values,\n   * which determines your range of valid values for the memory parameter:\n   *\n   * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB)\n   *\n   * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB)\n   *\n   * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)\n   *\n   * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB)\n   *\n   * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB)\n   *\n   * @default 1024\n   */\n  readonly cpu?: number;\n\n  /**\n   * The amount (in MiB) of memory used by the task. For tasks using the Fargate launch type,\n   * this field is required and you must use one of the following values, which determines your range of valid values for the cpu parameter:\n   *\n   * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25 vCPU)\n   *\n   * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values: 512 (.5 vCPU)\n   *\n   * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)\n   *\n   * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) - Available cpu values: 2048 (2 vCPU)\n   *\n   * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) - Available cpu values: 4096 (4 vCPU)\n   *\n   * @default 2048\n   */\n  readonly memoryLimitMiB?: number;\n\n  /**\n   * The amount (in GiB) of ephemeral storage to be allocated to the task. The maximum supported value is 200 GiB.\n   *\n   * NOTE: This parameter is only supported for tasks hosted on AWS Fargate using platform version 1.4.0 or later.\n   *\n   * @default 20\n   */\n  readonly ephemeralStorageGiB?: number;\n\n  /**\n   * Use Fargate spot capacity provider to save money.\n   *\n   * * Runners may fail to start due to missing capacity.\n   * * Runners might be stopped prematurely with spot pricing.\n   *\n   * @default false\n   */\n  readonly spot?: boolean;\n}\n\nclass EcsFargateSpotLaunchTarget implements stepfunctions_tasks.IEcsLaunchTarget {\n  /**\n   * Called when the Fargate launch type configured on RunTask\n   */\n  public bind(_task: stepfunctions_tasks.EcsRunTask,\n    launchTargetOptions: stepfunctions_tasks.LaunchTargetBindOptions): stepfunctions_tasks.EcsLaunchTargetConfig {\n    if (!launchTargetOptions.taskDefinition.isFargateCompatible) {\n      throw new Error('Supplied TaskDefinition is not compatible with Fargate');\n    }\n\n    return {\n      parameters: {\n        CapacityProviderStrategy: [\n          {\n            CapacityProvider: 'FARGATE_SPOT',\n          },\n        ],\n      },\n    };\n  }\n}\n\n/**\n * GitHub Actions runner provider using Fargate to execute the actions.\n *\n * Creates a task definition with a single container 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 FargateRunner extends Construct implements IRunnerProvider {\n  /**\n   * Cluster hosting the task hosting the runner.\n   */\n  readonly cluster: ecs.Cluster;\n\n  /**\n   * Fargate task hosting the runner.\n   */\n  readonly task: ecs.FargateTaskDefinition;\n\n  /**\n   * Container definition hosting the runner.\n   */\n  readonly container: ecs.ContainerDefinition;\n\n  /**\n   * Label associated with this provider.\n   */\n  readonly label: string;\n\n  /**\n   * VPC used for hosting the task.\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Security group attached to the task.\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Whether task will have a public IP.\n   */\n  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   * Use spot pricing for Fargate tasks.\n   */\n  readonly spot: boolean;\n\n  constructor(scope: Construct, id: string, props: FargateRunnerProps) {\n    super(scope, id);\n\n    this.label = props.label || 'fargate';\n    this.vpc = props.vpc || ec2.Vpc.fromLookup(this, 'default vpc', { isDefault: true });\n    this.securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'security group', { vpc: this.vpc });\n    this.connections = this.securityGroup.connections;\n    this.assignPublicIp = props.assignPublicIp || true;\n    this.cluster = props.cluster ? props.cluster : new ecs.Cluster(\n      this,\n      'cluster',\n      {\n        vpc: this.vpc,\n        enableFargateCapacityProviders: true,\n      },\n    );\n    this.spot = props.spot ?? false;\n\n    this.task = new ecs.FargateTaskDefinition(\n      this,\n      'task',\n      {\n        cpu: props.cpu || 1024,\n        memoryLimitMiB: props.memoryLimitMiB || 2048,\n        ephemeralStorageGiB: props.ephemeralStorageGiB || 25,\n      },\n    );\n    this.container = this.task.addContainer(\n      'runner',\n      {\n        image: ecs.AssetImage.fromAsset(\n          path.join(__dirname, 'docker-images', 'fargate'),\n          {\n            buildArgs: {\n              RUNNER_VERSION: props.runnerVersion ? props.runnerVersion.version : RunnerVersion.latest().version,\n            },\n          },\n        ),\n        logging: ecs.AwsLogDriver.awsLogs({\n          logGroup: new logs.LogGroup(this, 'logs', {\n            retention: props.logRetention || RetentionDays.ONE_MONTH,\n            removalPolicy: RemovalPolicy.DESTROY,\n          }),\n          streamPrefix: 'runner',\n        }),\n      },\n    );\n\n    this.grantPrincipal = new iam.UnknownPrincipal({ resource: this.task.taskRole });\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      'Fargate Runner',\n      {\n        integrationPattern: IntegrationPattern.RUN_JOB, // sync\n        taskDefinition: this.task,\n        cluster: this.cluster,\n        launchTarget: this.spot ? new EcsFargateSpotLaunchTarget() : new stepfunctions_tasks.EcsFargateLaunchTarget(),\n        assignPublicIp: this.assignPublicIp,\n        securityGroups: this.securityGroup ? [this.securityGroup] : undefined,\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: this.label,\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          },\n        ],\n      },\n    );\n  }\n}\n"]}
|
|
138
|
+
FargateRunner[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.FargateRunner", version: "0.3.2" };
|
|
139
|
+
/**
|
|
140
|
+
* Path to Dockerfile for Linux x64 with all the requirement for Fargate runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
|
|
141
|
+
*
|
|
142
|
+
* Available build arguments that can be set in the image builder:
|
|
143
|
+
* * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.
|
|
144
|
+
* * `EXTRA_PACKAGES` can be used to install additional packages.
|
|
145
|
+
*/
|
|
146
|
+
FargateRunner.LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, 'docker-images', 'fargate', 'linux-x64');
|
|
147
|
+
/**
|
|
148
|
+
* Path to Dockerfile for Linux ARM64 with all the requirement for Fargate runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
|
|
149
|
+
*
|
|
150
|
+
* Available build arguments that can be set in the image builder:
|
|
151
|
+
* * `BASE_IMAGE` sets the `FROM` line. This should be an Ubuntu compatible image.
|
|
152
|
+
* * `EXTRA_PACKAGES` can be used to install additional packages.
|
|
153
|
+
*/
|
|
154
|
+
FargateRunner.LINUX_ARM64_DOCKERFILE_PATH = path.join(__dirname, 'docker-images', 'fargate', 'linux-arm64');
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fargate.js","sourceRoot":"","sources":["../../src/providers/fargate.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\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, RemovalPolicy,\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 { Architecture, IImageBuilder, IRunnerProvider, RunnerProviderProps, RunnerRuntimeParameters } from './common';\nimport { CodeBuildImageBuilder } from './image-builders/codebuild';\n\n/**\n * Properties for FargateRunner.\n */\nexport interface FargateRunnerProps extends RunnerProviderProps {\n  /**\n   * Provider running an image to run inside CodeBuild with GitHub runner pre-configured. A user named `runner` is expected to exist.\n   *\n   * The entry point should start GitHub runner. For example:\n   *\n   * ```\n   * #!/bin/bash\n   * set -e -u -o pipefail\n   *\n   * /home/runner/config.sh --unattended --url \"https://${GITHUB_DOMAIN}/${OWNER}/${REPO}\" --token \"${RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${RUNNER_LABEL}\" --disableupdate --name \"${RUNNER_NAME}\"\n   * /home/runner/run.sh\n   * ```\n   *\n   * @default image builder with `FargateRunner.LINUX_X64_DOCKERFILE_PATH` as Dockerfile\n   */\n  readonly imageBuilder?: IImageBuilder;\n\n  /**\n   * GitHub Actions label used for this provider.\n   *\n   * @default 'fargate'\n   */\n  readonly label?: 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   * Security Group to assign to the task.\n   *\n   * @default a new security group\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Existing Fargate cluster to use.\n   *\n   * @default a new cluster\n   */\n  readonly cluster?: ecs.Cluster;\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. For tasks using the Fargate launch type,\n   * this field is required and you must use one of the following values,\n   * which determines your range of valid values for the memory parameter:\n   *\n   * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB)\n   *\n   * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB)\n   *\n   * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)\n   *\n   * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB)\n   *\n   * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB)\n   *\n   * @default 1024\n   */\n  readonly cpu?: number;\n\n  /**\n   * The amount (in MiB) of memory used by the task. For tasks using the Fargate launch type,\n   * this field is required and you must use one of the following values, which determines your range of valid values for the cpu parameter:\n   *\n   * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25 vCPU)\n   *\n   * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values: 512 (.5 vCPU)\n   *\n   * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)\n   *\n   * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) - Available cpu values: 2048 (2 vCPU)\n   *\n   * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) - Available cpu values: 4096 (4 vCPU)\n   *\n   * @default 2048\n   */\n  readonly memoryLimitMiB?: number;\n\n  /**\n   * The amount (in GiB) of ephemeral storage to be allocated to the task. The maximum supported value is 200 GiB.\n   *\n   * NOTE: This parameter is only supported for tasks hosted on AWS Fargate using platform version 1.4.0 or later.\n   *\n   * @default 20\n   */\n  readonly ephemeralStorageGiB?: number;\n\n  /**\n   * Use Fargate spot capacity provider to save money.\n   *\n   * * Runners may fail to start due to missing capacity.\n   * * Runners might be stopped prematurely with spot pricing.\n   *\n   * @default false\n   */\n  readonly spot?: boolean;\n}\n\nclass EcsFargateSpotLaunchTarget implements stepfunctions_tasks.IEcsLaunchTarget {\n  /**\n   * Called when the Fargate launch type configured on RunTask\n   */\n  public bind(_task: stepfunctions_tasks.EcsRunTask,\n    launchTargetOptions: stepfunctions_tasks.LaunchTargetBindOptions): stepfunctions_tasks.EcsLaunchTargetConfig {\n    if (!launchTargetOptions.taskDefinition.isFargateCompatible) {\n      throw new Error('Supplied TaskDefinition is not compatible with Fargate');\n    }\n\n    return {\n      parameters: {\n        CapacityProviderStrategy: [\n          {\n            CapacityProvider: 'FARGATE_SPOT',\n          },\n        ],\n      },\n    };\n  }\n}\n\n/**\n * GitHub Actions runner provider using Fargate to execute the actions.\n *\n * Creates a task definition with a single container 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 FargateRunner extends Construct implements IRunnerProvider {\n  /**\n   * Path to Dockerfile for Linux x64 with all the requirement for Fargate 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   */\n  public static readonly LINUX_X64_DOCKERFILE_PATH = path.join(__dirname, 'docker-images', 'fargate', 'linux-x64');\n\n  /**\n   * Path to Dockerfile for Linux ARM64 with all the requirement for Fargate 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   */\n  public static readonly LINUX_ARM64_DOCKERFILE_PATH = path.join(__dirname, 'docker-images', 'fargate', 'linux-arm64');\n\n  /**\n   * Cluster hosting the task hosting the runner.\n   */\n  readonly cluster: ecs.Cluster;\n\n  /**\n   * Fargate task hosting the runner.\n   */\n  readonly task: ecs.FargateTaskDefinition;\n\n  /**\n   * Container definition hosting the runner.\n   */\n  readonly container: ecs.ContainerDefinition;\n\n  /**\n   * Label associated with this provider.\n   */\n  readonly label: string;\n\n  /**\n   * VPC used for hosting the task.\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Security group attached to the task.\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Whether task will have a public IP.\n   */\n  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   * Use spot pricing for Fargate tasks.\n   */\n  readonly spot: boolean;\n\n  constructor(scope: Construct, id: string, props: FargateRunnerProps) {\n    super(scope, id);\n\n    this.label = props.label || 'fargate';\n    this.vpc = props.vpc || ec2.Vpc.fromLookup(this, 'default vpc', { isDefault: true });\n    this.securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'security group', { vpc: this.vpc });\n    this.connections = this.securityGroup.connections;\n    this.assignPublicIp = props.assignPublicIp || true;\n    this.cluster = props.cluster ? props.cluster : new ecs.Cluster(\n      this,\n      'cluster',\n      {\n        vpc: this.vpc,\n        enableFargateCapacityProviders: true,\n      },\n    );\n    this.spot = props.spot ?? false;\n\n    const imageBuilder = props.imageBuilder ?? new CodeBuildImageBuilder(this, 'Image Builder', {\n      dockerfilePath: FargateRunner.LINUX_X64_DOCKERFILE_PATH,\n    });\n    const image = imageBuilder.bind();\n\n    let arch: ecs.CpuArchitecture;\n    if (image.architecture.is(Architecture.ARM64)) {\n      arch = ecs.CpuArchitecture.ARM64;\n    } else if (image.architecture.is(Architecture.X86_64)) {\n      arch = ecs.CpuArchitecture.X86_64;\n    } else {\n      throw new Error(`${image.architecture.name} is not supported on Fargate`);\n    }\n\n    this.task = new ecs.FargateTaskDefinition(\n      this,\n      'task',\n      {\n        cpu: props.cpu || 1024,\n        memoryLimitMiB: props.memoryLimitMiB || 2048,\n        ephemeralStorageGiB: props.ephemeralStorageGiB || 25,\n        runtimePlatform: {\n          operatingSystemFamily: ecs.OperatingSystemFamily.LINUX,\n          cpuArchitecture: arch,\n        },\n      },\n    );\n    this.container = this.task.addContainer(\n      'runner',\n      {\n        image: ecs.AssetImage.fromEcrRepository(image.imageRepository, image.imageTag),\n        logging: ecs.AwsLogDriver.awsLogs({\n          logGroup: new logs.LogGroup(this, 'logs', {\n            retention: props.logRetention || RetentionDays.ONE_MONTH,\n            removalPolicy: RemovalPolicy.DESTROY,\n          }),\n          streamPrefix: 'runner',\n        }),\n      },\n    );\n\n    this.grantPrincipal = new iam.UnknownPrincipal({ resource: this.task.taskRole });\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      this.label,\n      {\n        integrationPattern: IntegrationPattern.RUN_JOB, // sync\n        taskDefinition: this.task,\n        cluster: this.cluster,\n        launchTarget: this.spot ? new EcsFargateSpotLaunchTarget() : new stepfunctions_tasks.EcsFargateLaunchTarget(),\n        assignPublicIp: this.assignPublicIp,\n        securityGroups: this.securityGroup ? [this.securityGroup] : undefined,\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: this.label,\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          },\n        ],\n      },\n    );\n  }\n}\n"]}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import { aws_codebuild as codebuild, aws_ec2 as ec2, aws_iam as iam, aws_logs as logs, Duration, RemovalPolicy } from 'aws-cdk-lib';
|
|
2
|
+
import { Construct } from 'constructs';
|
|
3
|
+
import { Architecture, IImageBuilder, Os, RunnerImage, RunnerVersion } from '../common';
|
|
4
|
+
/**
|
|
5
|
+
* Properties for CodeBuildImageBuilder construct.
|
|
6
|
+
*/
|
|
7
|
+
export interface CodeBuildImageBuilderProps {
|
|
8
|
+
/**
|
|
9
|
+
* Image architecture.
|
|
10
|
+
*
|
|
11
|
+
* @default Architecture.X86_64
|
|
12
|
+
*/
|
|
13
|
+
readonly architecture?: Architecture;
|
|
14
|
+
/**
|
|
15
|
+
* Image OS.
|
|
16
|
+
*
|
|
17
|
+
* @default OS.LINUX
|
|
18
|
+
*/
|
|
19
|
+
readonly os?: Os;
|
|
20
|
+
/**
|
|
21
|
+
* Path to Dockerfile to be built. It can be a path to a Dockerfile, a folder containing a Dockerfile, or a zip file containing a Dockerfile.
|
|
22
|
+
*/
|
|
23
|
+
readonly dockerfilePath: string;
|
|
24
|
+
/**
|
|
25
|
+
* Version of GitHub Runners to install.
|
|
26
|
+
*
|
|
27
|
+
* @default latest version available
|
|
28
|
+
*/
|
|
29
|
+
readonly runnerVersion?: RunnerVersion;
|
|
30
|
+
/**
|
|
31
|
+
* Schedule the image to be rebuilt every given interval. Useful for keeping the image up-do-date with the latest GitHub runner version and latest OS updates.
|
|
32
|
+
*
|
|
33
|
+
* Set to zero to disable.
|
|
34
|
+
*
|
|
35
|
+
* @default Duration.days(7)
|
|
36
|
+
*/
|
|
37
|
+
readonly rebuildInterval?: Duration;
|
|
38
|
+
/**
|
|
39
|
+
* VPC to launch the runners in.
|
|
40
|
+
*
|
|
41
|
+
* @default no VPC
|
|
42
|
+
*/
|
|
43
|
+
readonly vpc?: ec2.IVpc;
|
|
44
|
+
/**
|
|
45
|
+
* Security Group to assign to this instance.
|
|
46
|
+
*
|
|
47
|
+
* @default public project with no security group
|
|
48
|
+
*/
|
|
49
|
+
readonly securityGroup?: ec2.ISecurityGroup;
|
|
50
|
+
/**
|
|
51
|
+
* Where to place the network interfaces within the VPC.
|
|
52
|
+
*
|
|
53
|
+
* @default no subnet
|
|
54
|
+
*/
|
|
55
|
+
readonly subnetSelection?: ec2.SubnetSelection;
|
|
56
|
+
/**
|
|
57
|
+
* The type of compute to use for this build.
|
|
58
|
+
* See the {@link ComputeType} enum for the possible values.
|
|
59
|
+
*
|
|
60
|
+
* @default {@link ComputeType#SMALL}
|
|
61
|
+
*/
|
|
62
|
+
readonly computeType?: codebuild.ComputeType;
|
|
63
|
+
/**
|
|
64
|
+
* The number of minutes after which AWS CodeBuild stops the build if it's
|
|
65
|
+
* not complete. For valid values, see the timeoutInMinutes field in the AWS
|
|
66
|
+
* CodeBuild User Guide.
|
|
67
|
+
*
|
|
68
|
+
* @default Duration.hours(1)
|
|
69
|
+
*/
|
|
70
|
+
readonly timeout?: Duration;
|
|
71
|
+
/**
|
|
72
|
+
* The number of days log events are kept in CloudWatch Logs. When updating
|
|
73
|
+
* this property, unsetting it doesn't remove the log retention policy. To
|
|
74
|
+
* remove the retention policy, set the value to `INFINITE`.
|
|
75
|
+
*
|
|
76
|
+
* @default logs.RetentionDays.ONE_MONTH
|
|
77
|
+
*/
|
|
78
|
+
readonly logRetention?: logs.RetentionDays;
|
|
79
|
+
/**
|
|
80
|
+
* Removal policy for logs of image builds. If deployment fails on the custom resource, try setting this to `RemovalPolicy.RETAIN`. This way the CodeBuild logs can still be viewed, and you can see why the build failed.
|
|
81
|
+
*
|
|
82
|
+
* We try to not leave anything behind when removed. But sometimes a log staying behind is useful.
|
|
83
|
+
*
|
|
84
|
+
* @default RemovalPolicy.DESTROY
|
|
85
|
+
*/
|
|
86
|
+
readonly logRemovalPolicy?: RemovalPolicy;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* An image builder that uses CodeBuild to build Docker images pre-baked with all the GitHub Actions runner requirements. Builders can be used with runner providers.
|
|
90
|
+
*
|
|
91
|
+
* Each builder re-runs automatically at a set interval to make sure the images contain the latest versions of everything.
|
|
92
|
+
*
|
|
93
|
+
* You can create an instance of this construct to customize the image used to spin-up runners. Each provider has its own requirements for what an image should do. That's why they each provide their own Dockerfile.
|
|
94
|
+
*
|
|
95
|
+
* For example, to set a specific runner version, rebuild the image every 2 weeks, and add a few packages for the Fargate provider, use:
|
|
96
|
+
*
|
|
97
|
+
* ```
|
|
98
|
+
* const builder = new CodeBuildImageBuilder(this, 'Builder', {
|
|
99
|
+
* dockerfilePath: FargateProvider.LINUX_X64_DOCKERFILE_PATH,
|
|
100
|
+
* runnerVersion: RunnerVersion.specific('2.293.0'),
|
|
101
|
+
* rebuildInterval: Duration.days(14),
|
|
102
|
+
* });
|
|
103
|
+
* builder.setBuildArg('EXTRA_PACKAGES', 'nginx xz-utils');
|
|
104
|
+
* new FargateProvider(this, 'Fargate provider', {
|
|
105
|
+
* label: 'customized-fargate',
|
|
106
|
+
* imageBuilder: builder,
|
|
107
|
+
* });
|
|
108
|
+
* ```
|
|
109
|
+
*/
|
|
110
|
+
export declare class CodeBuildImageBuilder extends Construct implements IImageBuilder {
|
|
111
|
+
readonly props: CodeBuildImageBuilderProps;
|
|
112
|
+
private static BUILDSPEC_VERSION;
|
|
113
|
+
private readonly architecture;
|
|
114
|
+
private readonly os;
|
|
115
|
+
private readonly repository;
|
|
116
|
+
private readonly dockerfile;
|
|
117
|
+
private preBuild;
|
|
118
|
+
private postBuild;
|
|
119
|
+
private buildArgs;
|
|
120
|
+
private policyStatements;
|
|
121
|
+
private secondaryAssets;
|
|
122
|
+
private readonly buildImage;
|
|
123
|
+
private boundImage?;
|
|
124
|
+
constructor(scope: Construct, id: string, props: CodeBuildImageBuilderProps);
|
|
125
|
+
/**
|
|
126
|
+
* Uploads a folder to the build server at a given folder name.
|
|
127
|
+
*
|
|
128
|
+
* @param sourcePath path to source directory
|
|
129
|
+
* @param destName name of destination folder
|
|
130
|
+
*/
|
|
131
|
+
addFiles(sourcePath: string, destName: string): void;
|
|
132
|
+
/**
|
|
133
|
+
* Adds a command that runs before `docker build`.
|
|
134
|
+
*
|
|
135
|
+
* @param command command to add
|
|
136
|
+
*/
|
|
137
|
+
addPreBuildCommand(command: string): void;
|
|
138
|
+
/**
|
|
139
|
+
* Adds a command that runs after `docker build` and `docker push`.
|
|
140
|
+
*
|
|
141
|
+
* @param command command to add
|
|
142
|
+
*/
|
|
143
|
+
addPostBuildCommand(command: string): void;
|
|
144
|
+
/**
|
|
145
|
+
* Adds a build argument for Docker. See the documentation for the Dockerfile you're using for a list of supported build arguments.
|
|
146
|
+
*
|
|
147
|
+
* @param name build argument name
|
|
148
|
+
* @param value build argument value
|
|
149
|
+
*/
|
|
150
|
+
setBuildArg(name: string, value: string): void;
|
|
151
|
+
/**
|
|
152
|
+
* Add a policy statement to the builder to access resources required to the image build.
|
|
153
|
+
*
|
|
154
|
+
* @param statement IAM policy statement
|
|
155
|
+
*/
|
|
156
|
+
addPolicyStatement(statement: iam.PolicyStatement): void;
|
|
157
|
+
/**
|
|
158
|
+
* Add extra trusted certificates. This helps deal with self-signed certificates for GitHub Enterprise Server.
|
|
159
|
+
*
|
|
160
|
+
* All first party Dockerfiles support this. Others may not.
|
|
161
|
+
*
|
|
162
|
+
* @param path path to directory containing a file called certs.pem containing all the required certificates
|
|
163
|
+
*/
|
|
164
|
+
addExtraCertificates(path: string): void;
|
|
165
|
+
/**
|
|
166
|
+
* Called by IRunnerProvider to finalize settings and create the image builder.
|
|
167
|
+
*/
|
|
168
|
+
bind(): RunnerImage;
|
|
169
|
+
private getBuildImage;
|
|
170
|
+
private getBuildSpec;
|
|
171
|
+
private customResource;
|
|
172
|
+
/**
|
|
173
|
+
* Return hash of all settings that can affect the result image so we can trigger the build when it changes.
|
|
174
|
+
* @private
|
|
175
|
+
*/
|
|
176
|
+
private hashBuildSettings;
|
|
177
|
+
private rebuildImageOnSchedule;
|
|
178
|
+
}
|