@cloudsnorkel/cdk-github-runners 0.1.1 → 0.3.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/.gitattributes +6 -1
- package/.jsii +1383 -218
- package/API.md +1199 -101
- package/README.md +57 -42
- package/demo-thumbnail.jpg +0 -0
- package/lib/index.d.ts +3 -2
- package/lib/index.js +7 -1
- package/lib/lambdas/build-image/index.js +121 -0
- package/lib/lambdas/delete-runner/index.js +12 -7
- package/lib/lambdas/setup/index.js +177 -66
- package/lib/lambdas/status/index.js +3 -2
- package/lib/lambdas/token-retriever/index.js +3 -2
- package/lib/lambdas/update-lambda/index.js +55 -0
- package/lib/lambdas/webhook-handler/index.js +1 -0
- package/lib/providers/codebuild.d.ts +32 -3
- package/lib/providers/codebuild.js +58 -13
- package/lib/providers/common.d.ts +87 -7
- 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 +46 -2
- package/lib/providers/fargate.js +65 -10
- 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 -2
- package/lib/providers/lambda.js +88 -9
- package/lib/runner.d.ts +56 -22
- package/lib/runner.js +38 -30
- package/lib/secrets.d.ts +0 -1
- package/lib/secrets.js +1 -1
- package/lib/utils.d.ts +2 -2
- package/lib/utils.js +14 -3
- package/lib/webhook.d.ts +0 -1
- package/lib/webhook.js +2 -1
- package/package.json +10 -9
- package/changelog.md +0 -7
- package/lib/index.d.ts.map +0 -1
- package/lib/providers/codebuild.d.ts.map +0 -1
- package/lib/providers/common.d.ts.map +0 -1
- package/lib/providers/docker-images/lambda/Dockerfile +0 -27
- package/lib/providers/fargate.d.ts.map +0 -1
- package/lib/providers/lambda.d.ts.map +0 -1
- package/lib/runner.d.ts.map +0 -1
- package/lib/secrets.d.ts.map +0 -1
- package/lib/utils.d.ts.map +0 -1
- package/lib/webhook.d.ts.map +0 -1
- package/releasetag.txt +0 -1
- package/version.txt +0 -1
package/README.md
CHANGED
|
@@ -31,11 +31,16 @@ The best way to browse API documentation is on [Constructs Hub][13]. It is avail
|
|
|
31
31
|
|
|
32
32
|
A runner provider creates compute resources on-demand and uses [actions/runner][5] to start a runner.
|
|
33
33
|
|
|
34
|
-
|
|
|
35
|
-
|
|
36
|
-
|
|
|
37
|
-
|
|
|
38
|
-
|
|
|
34
|
+
| | CodeBuild | Fargate | Lambda |
|
|
35
|
+
|------------------|--------------------------|----------------|----------------|
|
|
36
|
+
| **Time limit** | 8 hours | Unlimited | 15 minutes |
|
|
37
|
+
| **vCPUs** | 2, 4, 8, or 72 | 0.25 to 4 | 1 to 6 |
|
|
38
|
+
| **RAM** | 3gb, 7gb, 15gb, or 145gb | 512mb to 30gb | 128mb to 10gb |
|
|
39
|
+
| **Storage** | 50gb to 824gb | 20gb to 200gb | Up to 10gb |
|
|
40
|
+
| **Architecture** | x86_64, ARM64 | x86_64, ARM64 | x86_64, ARM64 |
|
|
41
|
+
| **sudo** | ✔ | ✔ | ❌ |
|
|
42
|
+
| **Docker** | ✔ | ❌ | ❌ |
|
|
43
|
+
| **Spot pricing** | ❌ | ✔ | ❌ |
|
|
39
44
|
|
|
40
45
|
The best provider to use mostly depends on your current infrastructure. When in doubt, CodeBuild is always a good choice. Execution history and logs are easy to view, and it has no restrictive limits unless you need to run for more than 8 hours.
|
|
41
46
|
|
|
@@ -77,58 +82,68 @@ You can also create your own provider by implementing `IRunnerProvider`.
|
|
|
77
82
|
9. Trigger a GitHub action that has a `self-hosted` label with `runs-on: [self-hosted, linux, codebuild]` or similar
|
|
78
83
|
10. If the action is not successful, see [troubleshooting](#Troubleshooting)
|
|
79
84
|
|
|
85
|
+
[](https://youtu.be/wlyv_3V8lIw)
|
|
86
|
+
|
|
80
87
|
## Customizing
|
|
81
88
|
|
|
82
|
-
The default providers configured by
|
|
89
|
+
The default providers configured by `GitHubRunners` are useful for testing but probably not too much for actual production work. They run in the default VPC or no VPC and have no added IAM permissions. You would usually want to configure the providers yourself.
|
|
83
90
|
|
|
84
91
|
For example:
|
|
85
92
|
|
|
86
93
|
```typescript
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
const app = new cdk.App();
|
|
92
|
-
const stack = new cdk.Stack(
|
|
93
|
-
app,
|
|
94
|
-
'github-runners-test',
|
|
95
|
-
{
|
|
96
|
-
env: {
|
|
97
|
-
account: process.env.CDK_DEFAULT_ACCOUNT,
|
|
98
|
-
region: process.env.CDK_DEFAULT_REGION,
|
|
99
|
-
},
|
|
100
|
-
},
|
|
101
|
-
);
|
|
102
|
-
|
|
103
|
-
const vpc = ec2.Vpc.fromLookup(stack, 'vpc', { vpcId: 'vpc-1234567' });
|
|
104
|
-
const runnerSg = new ec2.SecurityGroup(stack, 'runner security group', { vpc: vpc });
|
|
105
|
-
const dbSg = ec2.SecurityGroup.fromSecurityGroupId(stack, 'database security group', 'sg-1234567');
|
|
106
|
-
const bucket = new s3.Bucket(stack, 'runner bucket');
|
|
94
|
+
let vpc: ec2.Vpc;
|
|
95
|
+
let runnerSg: ec2.SecurityGroup;
|
|
96
|
+
let dbSg: ec2.SecurityGroup;
|
|
97
|
+
let bucket: s3.Bucket;
|
|
107
98
|
|
|
108
99
|
// create a custom CodeBuild provider
|
|
109
|
-
const myProvider = new CodeBuildRunner(
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
securityGroup: runnerSg,
|
|
115
|
-
},
|
|
116
|
-
);
|
|
100
|
+
const myProvider = new CodeBuildRunner(this, 'codebuild runner', {
|
|
101
|
+
label: 'my-codebuild',
|
|
102
|
+
vpc: vpc,
|
|
103
|
+
securityGroup: runnerSg,
|
|
104
|
+
});
|
|
117
105
|
// grant some permissions to the provider
|
|
118
106
|
bucket.grantReadWrite(myProvider);
|
|
119
107
|
dbSg.connections.allowFrom(runnerSg, ec2.Port.tcp(3306), 'allow runners to connect to MySQL database');
|
|
120
108
|
|
|
121
109
|
// create the runner infrastructure
|
|
122
|
-
new GitHubRunners(
|
|
123
|
-
stack,
|
|
124
|
-
'runners',
|
|
125
|
-
{
|
|
110
|
+
new GitHubRunners(this, 'runners', {
|
|
126
111
|
providers: [myProvider],
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
112
|
+
});
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
Another way to customize runners is by modifying the image used to spin them up. The image contains the [runner][5], any required dependencies, and integration code with the provider. You may choose to customize this image by adding more packages, for example.
|
|
116
|
+
|
|
117
|
+
```typescript
|
|
118
|
+
const myBuilder = new CodeBuildImageBuilder(this, 'image builder', {
|
|
119
|
+
dockerfilePath: FargateProvider.LINUX_X64_DOCKERFILE_PATH,
|
|
120
|
+
runnerVersion: RunnerVersion.specific('2.291.0'),
|
|
121
|
+
rebuildInterval: Duration.days(14),
|
|
122
|
+
});
|
|
123
|
+
myBuilder.setBuildArg('EXTRA_PACKAGES', 'nginx xz-utils');
|
|
124
|
+
|
|
125
|
+
const myProvider = new FargateProvider(this, 'fargate runner', {
|
|
126
|
+
label: 'my-codebuild',
|
|
127
|
+
vpc: vpc,
|
|
128
|
+
securityGroup: runnerSg,
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
// create the runner infrastructure
|
|
132
|
+
new GitHubRunners(stack, 'runners', {
|
|
133
|
+
providers: [myProvider],
|
|
134
|
+
});
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
Your workflow will then look like:
|
|
130
138
|
|
|
131
|
-
|
|
139
|
+
```yaml
|
|
140
|
+
name: self-hosted example
|
|
141
|
+
on: push
|
|
142
|
+
jobs:
|
|
143
|
+
self-hosted:
|
|
144
|
+
runs-on: [self-hosted, my-codebuild]
|
|
145
|
+
steps:
|
|
146
|
+
- run: echo hello world
|
|
132
147
|
```
|
|
133
148
|
|
|
134
149
|
## Architecture
|
|
Binary file
|
package/lib/index.d.ts
CHANGED
|
@@ -3,5 +3,6 @@ export { GitHubRunners, GitHubRunnersProps } from './runner';
|
|
|
3
3
|
export { CodeBuildRunner, CodeBuildRunnerProps } from './providers/codebuild';
|
|
4
4
|
export { LambdaRunner, LambdaRunnerProps } from './providers/lambda';
|
|
5
5
|
export { FargateRunner, FargateRunnerProps } from './providers/fargate';
|
|
6
|
-
export { IRunnerProvider, RunnerProviderProps, RunnerVersion, RunnerRuntimeParameters } from './providers/common';
|
|
7
|
-
|
|
6
|
+
export { IRunnerProvider, RunnerProviderProps, RunnerVersion, RunnerRuntimeParameters, RunnerImage, IImageBuilder, Architecture, Os } from './providers/common';
|
|
7
|
+
export { CodeBuildImageBuilder, CodeBuildImageBuilderProps } from './providers/image-builders/codebuild';
|
|
8
|
+
export { StaticRunnerImage } from './providers/image-builders/static';
|
package/lib/index.js
CHANGED
|
@@ -12,4 +12,10 @@ var fargate_1 = require("./providers/fargate");
|
|
|
12
12
|
Object.defineProperty(exports, "FargateRunner", { enumerable: true, get: function () { return fargate_1.FargateRunner; } });
|
|
13
13
|
var common_1 = require("./providers/common");
|
|
14
14
|
Object.defineProperty(exports, "RunnerVersion", { enumerable: true, get: function () { return common_1.RunnerVersion; } });
|
|
15
|
-
|
|
15
|
+
Object.defineProperty(exports, "Architecture", { enumerable: true, get: function () { return common_1.Architecture; } });
|
|
16
|
+
Object.defineProperty(exports, "Os", { enumerable: true, get: function () { return common_1.Os; } });
|
|
17
|
+
var codebuild_2 = require("./providers/image-builders/codebuild");
|
|
18
|
+
Object.defineProperty(exports, "CodeBuildImageBuilder", { enumerable: true, get: function () { return codebuild_2.CodeBuildImageBuilder; } });
|
|
19
|
+
var static_1 = require("./providers/image-builders/static");
|
|
20
|
+
Object.defineProperty(exports, "StaticRunnerImage", { enumerable: true, get: function () { return static_1.StaticRunnerImage; } });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxxQ0FBb0M7QUFBM0Isa0dBQUEsT0FBTyxPQUFBO0FBQ2hCLG1DQUE2RDtBQUFwRCx1R0FBQSxhQUFhLE9BQUE7QUFDdEIsbURBQThFO0FBQXJFLDRHQUFBLGVBQWUsT0FBQTtBQUN4Qiw2Q0FBcUU7QUFBNUQsc0dBQUEsWUFBWSxPQUFBO0FBQ3JCLCtDQUF3RTtBQUEvRCx3R0FBQSxhQUFhLE9BQUE7QUFDdEIsNkNBQWdLO0FBQWpILHVHQUFBLGFBQWEsT0FBQTtBQUF1RCxzR0FBQSxZQUFZLE9BQUE7QUFBRSw0RkFBQSxFQUFFLE9BQUE7QUFDbkksa0VBQXlHO0FBQWhHLGtIQUFBLHFCQUFxQixPQUFBO0FBQzlCLDREQUFzRTtBQUE3RCwyR0FBQSxpQkFBaUIsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFNlY3JldHMgfSBmcm9tICcuL3NlY3JldHMnO1xuZXhwb3J0IHsgR2l0SHViUnVubmVycywgR2l0SHViUnVubmVyc1Byb3BzIH0gZnJvbSAnLi9ydW5uZXInO1xuZXhwb3J0IHsgQ29kZUJ1aWxkUnVubmVyLCBDb2RlQnVpbGRSdW5uZXJQcm9wcyB9IGZyb20gJy4vcHJvdmlkZXJzL2NvZGVidWlsZCc7XG5leHBvcnQgeyBMYW1iZGFSdW5uZXIsIExhbWJkYVJ1bm5lclByb3BzIH0gZnJvbSAnLi9wcm92aWRlcnMvbGFtYmRhJztcbmV4cG9ydCB7IEZhcmdhdGVSdW5uZXIsIEZhcmdhdGVSdW5uZXJQcm9wcyB9IGZyb20gJy4vcHJvdmlkZXJzL2ZhcmdhdGUnO1xuZXhwb3J0IHsgSVJ1bm5lclByb3ZpZGVyLCBSdW5uZXJQcm92aWRlclByb3BzLCBSdW5uZXJWZXJzaW9uLCBSdW5uZXJSdW50aW1lUGFyYW1ldGVycywgUnVubmVySW1hZ2UsIElJbWFnZUJ1aWxkZXIsIEFyY2hpdGVjdHVyZSwgT3MgfSBmcm9tICcuL3Byb3ZpZGVycy9jb21tb24nO1xuZXhwb3J0IHsgQ29kZUJ1aWxkSW1hZ2VCdWlsZGVyLCBDb2RlQnVpbGRJbWFnZUJ1aWxkZXJQcm9wcyB9IGZyb20gJy4vcHJvdmlkZXJzL2ltYWdlLWJ1aWxkZXJzL2NvZGVidWlsZCc7XG5leHBvcnQgeyBTdGF0aWNSdW5uZXJJbWFnZSB9IGZyb20gJy4vcHJvdmlkZXJzL2ltYWdlLWJ1aWxkZXJzL3N0YXRpYyc7XG4iXX0=
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
|
|
21
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
22
|
+
|
|
23
|
+
// src/lambdas/build-image/index.ts
|
|
24
|
+
var build_image_exports = {};
|
|
25
|
+
__export(build_image_exports, {
|
|
26
|
+
handler: () => handler
|
|
27
|
+
});
|
|
28
|
+
module.exports = __toCommonJS(build_image_exports);
|
|
29
|
+
var AWS = __toESM(require("aws-sdk"));
|
|
30
|
+
var codebuild = new AWS.CodeBuild();
|
|
31
|
+
var ecr = new AWS.ECR();
|
|
32
|
+
async function handler(event, context) {
|
|
33
|
+
try {
|
|
34
|
+
console.log(JSON.stringify(event));
|
|
35
|
+
const repoName = event.ResourceProperties.RepoName;
|
|
36
|
+
const projectName = event.ResourceProperties.ProjectName;
|
|
37
|
+
switch (event.RequestType) {
|
|
38
|
+
case "Create":
|
|
39
|
+
case "Update":
|
|
40
|
+
console.log(`Starting CodeBuild project ${projectName}`);
|
|
41
|
+
await codebuild.startBuild({
|
|
42
|
+
projectName,
|
|
43
|
+
environmentVariablesOverride: [
|
|
44
|
+
{
|
|
45
|
+
type: "PLAINTEXT",
|
|
46
|
+
name: "STACK_ID",
|
|
47
|
+
value: event.StackId
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
type: "PLAINTEXT",
|
|
51
|
+
name: "REQUEST_ID",
|
|
52
|
+
value: event.RequestId
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
type: "PLAINTEXT",
|
|
56
|
+
name: "LOGICAL_RESOURCE_ID",
|
|
57
|
+
value: event.LogicalResourceId
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
type: "PLAINTEXT",
|
|
61
|
+
name: "RESPONSE_URL",
|
|
62
|
+
value: event.ResponseURL
|
|
63
|
+
}
|
|
64
|
+
]
|
|
65
|
+
}).promise();
|
|
66
|
+
break;
|
|
67
|
+
case "Delete":
|
|
68
|
+
const images = await ecr.listImages({ repositoryName: repoName, maxResults: 100 }).promise();
|
|
69
|
+
if (images.imageIds && images.imageIds.length > 0) {
|
|
70
|
+
await ecr.batchDeleteImage({
|
|
71
|
+
imageIds: images.imageIds.map((i) => {
|
|
72
|
+
return { imageDigest: i.imageDigest };
|
|
73
|
+
}),
|
|
74
|
+
repositoryName: repoName
|
|
75
|
+
}).promise();
|
|
76
|
+
}
|
|
77
|
+
await respond("SUCCESS", "OK", event.PhysicalResourceId, {});
|
|
78
|
+
break;
|
|
79
|
+
}
|
|
80
|
+
} catch (e) {
|
|
81
|
+
console.log(e);
|
|
82
|
+
await respond("FAILED", e.message || "Internal Error", context.logStreamName, {});
|
|
83
|
+
}
|
|
84
|
+
function respond(responseStatus, reason, physicalResourceId, data) {
|
|
85
|
+
const responseBody = JSON.stringify({
|
|
86
|
+
Status: responseStatus,
|
|
87
|
+
Reason: reason,
|
|
88
|
+
PhysicalResourceId: physicalResourceId,
|
|
89
|
+
StackId: event.StackId,
|
|
90
|
+
RequestId: event.RequestId,
|
|
91
|
+
LogicalResourceId: event.LogicalResourceId,
|
|
92
|
+
NoEcho: false,
|
|
93
|
+
Data: data
|
|
94
|
+
});
|
|
95
|
+
console.log("Responding", responseBody);
|
|
96
|
+
const parsedUrl = require("url").parse(event.ResponseURL);
|
|
97
|
+
const requestOptions = {
|
|
98
|
+
hostname: parsedUrl.hostname,
|
|
99
|
+
path: parsedUrl.path,
|
|
100
|
+
method: "PUT",
|
|
101
|
+
headers: {
|
|
102
|
+
"content-type": "",
|
|
103
|
+
"content-length": responseBody.length
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
return new Promise((resolve, reject) => {
|
|
107
|
+
try {
|
|
108
|
+
const request = require("https").request(requestOptions, resolve);
|
|
109
|
+
request.on("error", reject);
|
|
110
|
+
request.write(responseBody);
|
|
111
|
+
request.end();
|
|
112
|
+
} catch (e) {
|
|
113
|
+
reject(e);
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
119
|
+
0 && (module.exports = {
|
|
120
|
+
handler
|
|
121
|
+
});
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
"use strict";
|
|
1
2
|
var __create = Object.create;
|
|
2
3
|
var __defProp = Object.defineProperty;
|
|
3
4
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
@@ -11385,9 +11386,9 @@ var require_yallist = __commonJS({
|
|
|
11385
11386
|
}
|
|
11386
11387
|
});
|
|
11387
11388
|
|
|
11388
|
-
// node_modules/lru-cache/index.js
|
|
11389
|
+
// node_modules/@octokit/auth-app/node_modules/lru-cache/index.js
|
|
11389
11390
|
var require_lru_cache = __commonJS({
|
|
11390
|
-
"node_modules/lru-cache/index.js"(exports2, module2) {
|
|
11391
|
+
"node_modules/@octokit/auth-app/node_modules/lru-cache/index.js"(exports2, module2) {
|
|
11391
11392
|
"use strict";
|
|
11392
11393
|
var Yallist = require_yallist();
|
|
11393
11394
|
var MAX = Symbol("max");
|
|
@@ -12590,11 +12591,15 @@ async function getRunnerId(octokit, owner, repo, name) {
|
|
|
12590
12591
|
}
|
|
12591
12592
|
exports.handler = async function(event) {
|
|
12592
12593
|
const { octokit } = await getOctokit(event.installationId);
|
|
12593
|
-
|
|
12594
|
-
|
|
12595
|
-
|
|
12596
|
-
|
|
12597
|
-
|
|
12594
|
+
try {
|
|
12595
|
+
await octokit.request("POST /repos/{owner}/{repo}/actions/runs/{runId}/cancel", {
|
|
12596
|
+
owner: event.owner,
|
|
12597
|
+
repo: event.repo,
|
|
12598
|
+
runId: event.runId
|
|
12599
|
+
});
|
|
12600
|
+
} catch (e) {
|
|
12601
|
+
console.error(`Unable to cancel workflow: ${e}`);
|
|
12602
|
+
}
|
|
12598
12603
|
const runnerId = await getRunnerId(octokit, event.owner, event.repo, event.runnerName);
|
|
12599
12604
|
if (!runnerId) {
|
|
12600
12605
|
console.error(`Unable to find runner id for ${event.owner}/${event.repo}:${event.runnerName}`);
|