@cloudsnorkel/cdk-github-runners 0.4.0 → 0.5.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.
@@ -7400,8 +7400,6 @@ var require_dist_node6 = __commonJS({
7400
7400
  } else {
7401
7401
  if (Object.keys(remainingParameters).length) {
7402
7402
  body = remainingParameters;
7403
- } else {
7404
- headers["content-length"] = 0;
7405
7403
  }
7406
7404
  }
7407
7405
  }
@@ -7434,7 +7432,7 @@ var require_dist_node6 = __commonJS({
7434
7432
  parse
7435
7433
  });
7436
7434
  }
7437
- var VERSION = "7.0.1";
7435
+ var VERSION = "7.0.2";
7438
7436
  var userAgent = `octokit-endpoint.js/${VERSION} ${universalUserAgent.getUserAgent()}`;
7439
7437
  var DEFAULTS = {
7440
7438
  method: "GET",
@@ -7958,8 +7956,6 @@ var require_dist_node10 = __commonJS({
7958
7956
  } else {
7959
7957
  if (Object.keys(remainingParameters).length) {
7960
7958
  body = remainingParameters;
7961
- } else {
7962
- headers["content-length"] = 0;
7963
7959
  }
7964
7960
  }
7965
7961
  }
@@ -7992,7 +7988,7 @@ var require_dist_node10 = __commonJS({
7992
7988
  parse
7993
7989
  });
7994
7990
  }
7995
- var VERSION = "7.0.1";
7991
+ var VERSION = "7.0.2";
7996
7992
  var userAgent = `octokit-endpoint.js/${VERSION} ${universalUserAgent.getUserAgent()}`;
7997
7993
  var DEFAULTS = {
7998
7994
  method: "GET",
@@ -8232,7 +8228,7 @@ var require_dist_node13 = __commonJS({
8232
8228
  var request = require_dist_node12();
8233
8229
  var requestError = require_dist_node11();
8234
8230
  var btoa = _interopDefault(require_btoa_node());
8235
- var VERSION = "2.0.2";
8231
+ var VERSION = "2.0.3";
8236
8232
  function requestToOAuthBaseUrl(request2) {
8237
8233
  const endpointDefaults = request2.endpoint.DEFAULTS;
8238
8234
  return /^https:\/\/(api\.)?github\.com$/.test(endpointDefaults.baseUrl) ? "https://github.com" : endpointDefaults.baseUrl.replace("/api/v3", "");
@@ -8391,21 +8387,25 @@ var require_dist_node13 = __commonJS({
8391
8387
  }
8392
8388
  async function scopeToken(options) {
8393
8389
  const {
8394
- request: request$1,
8390
+ request: optionsRequest,
8395
8391
  clientType,
8396
8392
  clientId,
8397
8393
  clientSecret,
8398
8394
  token,
8399
8395
  ...requestOptions
8400
8396
  } = options;
8401
- const response = await (request$1 || request.request)("POST /applications/{client_id}/token/scoped", {
8402
- headers: {
8403
- authorization: `basic ${btoa(`${clientId}:${clientSecret}`)}`
8404
- },
8405
- client_id: clientId,
8406
- access_token: token,
8407
- ...requestOptions
8408
- });
8397
+ const request$1 = optionsRequest || request.request;
8398
+ const response = await request$1(
8399
+ "POST /applications/{client_id}/token/scoped",
8400
+ {
8401
+ headers: {
8402
+ authorization: `basic ${btoa(`${clientId}:${clientSecret}`)}`
8403
+ },
8404
+ client_id: clientId,
8405
+ access_token: token,
8406
+ ...requestOptions
8407
+ }
8408
+ );
8409
8409
  const authentication = Object.assign({
8410
8410
  clientType,
8411
8411
  clientId,
@@ -8422,13 +8422,16 @@ var require_dist_node13 = __commonJS({
8422
8422
  async function resetToken(options) {
8423
8423
  const request$1 = options.request || request.request;
8424
8424
  const auth = btoa(`${options.clientId}:${options.clientSecret}`);
8425
- const response = await request$1("PATCH /applications/{client_id}/token", {
8426
- headers: {
8427
- authorization: `basic ${auth}`
8428
- },
8429
- client_id: options.clientId,
8430
- access_token: options.token
8431
- });
8425
+ const response = await request$1(
8426
+ "PATCH /applications/{client_id}/token",
8427
+ {
8428
+ headers: {
8429
+ authorization: `basic ${auth}`
8430
+ },
8431
+ client_id: options.clientId,
8432
+ access_token: options.token
8433
+ }
8434
+ );
8432
8435
  const authentication = {
8433
8436
  clientType: options.clientType,
8434
8437
  clientId: options.clientId,
@@ -8449,24 +8452,30 @@ var require_dist_node13 = __commonJS({
8449
8452
  async function deleteToken(options) {
8450
8453
  const request$1 = options.request || request.request;
8451
8454
  const auth = btoa(`${options.clientId}:${options.clientSecret}`);
8452
- return request$1("DELETE /applications/{client_id}/token", {
8453
- headers: {
8454
- authorization: `basic ${auth}`
8455
- },
8456
- client_id: options.clientId,
8457
- access_token: options.token
8458
- });
8455
+ return request$1(
8456
+ "DELETE /applications/{client_id}/token",
8457
+ {
8458
+ headers: {
8459
+ authorization: `basic ${auth}`
8460
+ },
8461
+ client_id: options.clientId,
8462
+ access_token: options.token
8463
+ }
8464
+ );
8459
8465
  }
8460
8466
  async function deleteAuthorization(options) {
8461
8467
  const request$1 = options.request || request.request;
8462
8468
  const auth = btoa(`${options.clientId}:${options.clientSecret}`);
8463
- return request$1("DELETE /applications/{client_id}/grant", {
8464
- headers: {
8465
- authorization: `basic ${auth}`
8466
- },
8467
- client_id: options.clientId,
8468
- access_token: options.token
8469
- });
8469
+ return request$1(
8470
+ "DELETE /applications/{client_id}/grant",
8471
+ {
8472
+ headers: {
8473
+ authorization: `basic ${auth}`
8474
+ },
8475
+ client_id: options.clientId,
8476
+ access_token: options.token
8477
+ }
8478
+ );
8470
8479
  }
8471
8480
  exports2.VERSION = VERSION;
8472
8481
  exports2.checkToken = checkToken;
@@ -8580,7 +8589,7 @@ var require_dist_node14 = __commonJS({
8580
8589
  endpoint.headers.authorization = `token ${token}`;
8581
8590
  return request2(endpoint);
8582
8591
  }
8583
- var VERSION = "4.0.1";
8592
+ var VERSION = "4.0.2";
8584
8593
  function createOAuthDeviceAuth(options) {
8585
8594
  const requestWithDefaults = options.request || request.request.defaults({
8586
8595
  headers: {
@@ -12724,8 +12733,6 @@ var require_dist_node18 = __commonJS({
12724
12733
  } else {
12725
12734
  if (Object.keys(remainingParameters).length) {
12726
12735
  body = remainingParameters;
12727
- } else {
12728
- headers["content-length"] = 0;
12729
12736
  }
12730
12737
  }
12731
12738
  }
@@ -12758,7 +12765,7 @@ var require_dist_node18 = __commonJS({
12758
12765
  parse
12759
12766
  });
12760
12767
  }
12761
- var VERSION = "7.0.1";
12768
+ var VERSION = "7.0.2";
12762
12769
  var userAgent = `octokit-endpoint.js/${VERSION} ${universalUserAgent.getUserAgent()}`;
12763
12770
  var DEFAULTS = {
12764
12771
  method: "GET",
@@ -7400,8 +7400,6 @@ var require_dist_node6 = __commonJS({
7400
7400
  } else {
7401
7401
  if (Object.keys(remainingParameters).length) {
7402
7402
  body = remainingParameters;
7403
- } else {
7404
- headers["content-length"] = 0;
7405
7403
  }
7406
7404
  }
7407
7405
  }
@@ -7434,7 +7432,7 @@ var require_dist_node6 = __commonJS({
7434
7432
  parse
7435
7433
  });
7436
7434
  }
7437
- var VERSION = "7.0.1";
7435
+ var VERSION = "7.0.2";
7438
7436
  var userAgent = `octokit-endpoint.js/${VERSION} ${universalUserAgent.getUserAgent()}`;
7439
7437
  var DEFAULTS = {
7440
7438
  method: "GET",
@@ -7958,8 +7956,6 @@ var require_dist_node10 = __commonJS({
7958
7956
  } else {
7959
7957
  if (Object.keys(remainingParameters).length) {
7960
7958
  body = remainingParameters;
7961
- } else {
7962
- headers["content-length"] = 0;
7963
7959
  }
7964
7960
  }
7965
7961
  }
@@ -7992,7 +7988,7 @@ var require_dist_node10 = __commonJS({
7992
7988
  parse
7993
7989
  });
7994
7990
  }
7995
- var VERSION = "7.0.1";
7991
+ var VERSION = "7.0.2";
7996
7992
  var userAgent = `octokit-endpoint.js/${VERSION} ${universalUserAgent.getUserAgent()}`;
7997
7993
  var DEFAULTS = {
7998
7994
  method: "GET",
@@ -8232,7 +8228,7 @@ var require_dist_node13 = __commonJS({
8232
8228
  var request = require_dist_node12();
8233
8229
  var requestError = require_dist_node11();
8234
8230
  var btoa = _interopDefault(require_btoa_node());
8235
- var VERSION = "2.0.2";
8231
+ var VERSION = "2.0.3";
8236
8232
  function requestToOAuthBaseUrl(request2) {
8237
8233
  const endpointDefaults = request2.endpoint.DEFAULTS;
8238
8234
  return /^https:\/\/(api\.)?github\.com$/.test(endpointDefaults.baseUrl) ? "https://github.com" : endpointDefaults.baseUrl.replace("/api/v3", "");
@@ -8391,21 +8387,25 @@ var require_dist_node13 = __commonJS({
8391
8387
  }
8392
8388
  async function scopeToken(options) {
8393
8389
  const {
8394
- request: request$1,
8390
+ request: optionsRequest,
8395
8391
  clientType,
8396
8392
  clientId,
8397
8393
  clientSecret,
8398
8394
  token,
8399
8395
  ...requestOptions
8400
8396
  } = options;
8401
- const response = await (request$1 || request.request)("POST /applications/{client_id}/token/scoped", {
8402
- headers: {
8403
- authorization: `basic ${btoa(`${clientId}:${clientSecret}`)}`
8404
- },
8405
- client_id: clientId,
8406
- access_token: token,
8407
- ...requestOptions
8408
- });
8397
+ const request$1 = optionsRequest || request.request;
8398
+ const response = await request$1(
8399
+ "POST /applications/{client_id}/token/scoped",
8400
+ {
8401
+ headers: {
8402
+ authorization: `basic ${btoa(`${clientId}:${clientSecret}`)}`
8403
+ },
8404
+ client_id: clientId,
8405
+ access_token: token,
8406
+ ...requestOptions
8407
+ }
8408
+ );
8409
8409
  const authentication = Object.assign({
8410
8410
  clientType,
8411
8411
  clientId,
@@ -8422,13 +8422,16 @@ var require_dist_node13 = __commonJS({
8422
8422
  async function resetToken(options) {
8423
8423
  const request$1 = options.request || request.request;
8424
8424
  const auth = btoa(`${options.clientId}:${options.clientSecret}`);
8425
- const response = await request$1("PATCH /applications/{client_id}/token", {
8426
- headers: {
8427
- authorization: `basic ${auth}`
8428
- },
8429
- client_id: options.clientId,
8430
- access_token: options.token
8431
- });
8425
+ const response = await request$1(
8426
+ "PATCH /applications/{client_id}/token",
8427
+ {
8428
+ headers: {
8429
+ authorization: `basic ${auth}`
8430
+ },
8431
+ client_id: options.clientId,
8432
+ access_token: options.token
8433
+ }
8434
+ );
8432
8435
  const authentication = {
8433
8436
  clientType: options.clientType,
8434
8437
  clientId: options.clientId,
@@ -8449,24 +8452,30 @@ var require_dist_node13 = __commonJS({
8449
8452
  async function deleteToken(options) {
8450
8453
  const request$1 = options.request || request.request;
8451
8454
  const auth = btoa(`${options.clientId}:${options.clientSecret}`);
8452
- return request$1("DELETE /applications/{client_id}/token", {
8453
- headers: {
8454
- authorization: `basic ${auth}`
8455
- },
8456
- client_id: options.clientId,
8457
- access_token: options.token
8458
- });
8455
+ return request$1(
8456
+ "DELETE /applications/{client_id}/token",
8457
+ {
8458
+ headers: {
8459
+ authorization: `basic ${auth}`
8460
+ },
8461
+ client_id: options.clientId,
8462
+ access_token: options.token
8463
+ }
8464
+ );
8459
8465
  }
8460
8466
  async function deleteAuthorization(options) {
8461
8467
  const request$1 = options.request || request.request;
8462
8468
  const auth = btoa(`${options.clientId}:${options.clientSecret}`);
8463
- return request$1("DELETE /applications/{client_id}/grant", {
8464
- headers: {
8465
- authorization: `basic ${auth}`
8466
- },
8467
- client_id: options.clientId,
8468
- access_token: options.token
8469
- });
8469
+ return request$1(
8470
+ "DELETE /applications/{client_id}/grant",
8471
+ {
8472
+ headers: {
8473
+ authorization: `basic ${auth}`
8474
+ },
8475
+ client_id: options.clientId,
8476
+ access_token: options.token
8477
+ }
8478
+ );
8470
8479
  }
8471
8480
  exports2.VERSION = VERSION;
8472
8481
  exports2.checkToken = checkToken;
@@ -8580,7 +8589,7 @@ var require_dist_node14 = __commonJS({
8580
8589
  endpoint.headers.authorization = `token ${token}`;
8581
8590
  return request2(endpoint);
8582
8591
  }
8583
- var VERSION = "4.0.1";
8592
+ var VERSION = "4.0.2";
8584
8593
  function createOAuthDeviceAuth(options) {
8585
8594
  const requestWithDefaults = options.request || request.request.defaults({
8586
8595
  headers: {
@@ -12724,8 +12733,6 @@ var require_dist_node18 = __commonJS({
12724
12733
  } else {
12725
12734
  if (Object.keys(remainingParameters).length) {
12726
12735
  body = remainingParameters;
12727
- } else {
12728
- headers["content-length"] = 0;
12729
12736
  }
12730
12737
  }
12731
12738
  }
@@ -12758,7 +12765,7 @@ var require_dist_node18 = __commonJS({
12758
12765
  parse
12759
12766
  });
12760
12767
  }
12761
- var VERSION = "7.0.1";
12768
+ var VERSION = "7.0.2";
12762
12769
  var userAgent = `octokit-endpoint.js/${VERSION} ${universalUserAgent.getUserAgent()}`;
12763
12770
  var DEFAULTS = {
12764
12771
  method: "GET",
@@ -155,7 +155,7 @@ class CodeBuildRunner extends constructs_1.Construct {
155
155
  }
156
156
  exports.CodeBuildRunner = CodeBuildRunner;
157
157
  _a = JSII_RTTI_SYMBOL_1;
158
- CodeBuildRunner[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunner", version: "0.4.0" };
158
+ CodeBuildRunner[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.CodeBuildRunner", version: "0.5.1" };
159
159
  /**
160
160
  * Path to Dockerfile for Linux x64 with all the requirements for CodeBuild runner. Use this Dockerfile unless you need to customize it further than allowed by hooks.
161
161
  *
@@ -71,14 +71,6 @@ export interface RunnerImage {
71
71
  * Static image tag where the image will be pushed.
72
72
  */
73
73
  readonly imageTag: string;
74
- /**
75
- * Image digest for providers that need to know the digest like Lambda.
76
- *
77
- * If the digest is not specified, imageTag must always point to a new tag on update. If not, the build may try to use the old image.
78
- *
79
- * WARNING: the digest might change when the builder automatically rebuilds the image on a schedule. Do not expect for this digest to stay the same between deploys.
80
- */
81
- readonly imageDigest?: string;
82
74
  /**
83
75
  * Architecture of the image.
84
76
  */
@@ -29,7 +29,7 @@ class RunnerVersion {
29
29
  }
30
30
  exports.RunnerVersion = RunnerVersion;
31
31
  _a = JSII_RTTI_SYMBOL_1;
32
- RunnerVersion[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerVersion", version: "0.4.0" };
32
+ RunnerVersion[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerVersion", version: "0.5.1" };
33
33
  /**
34
34
  * CPU architecture enum for an image.
35
35
  */
@@ -51,7 +51,7 @@ class Architecture {
51
51
  }
52
52
  exports.Architecture = Architecture;
53
53
  _b = JSII_RTTI_SYMBOL_1;
54
- Architecture[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Architecture", version: "0.4.0" };
54
+ Architecture[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.Architecture", version: "0.5.1" };
55
55
  /**
56
56
  * ARM64
57
57
  */
@@ -81,7 +81,7 @@ class Os {
81
81
  }
82
82
  exports.Os = Os;
83
83
  _c = JSII_RTTI_SYMBOL_1;
84
- Os[_c] = { fqn: "@cloudsnorkel/cdk-github-runners.Os", version: "0.4.0" };
84
+ Os[_c] = { fqn: "@cloudsnorkel/cdk-github-runners.Os", version: "0.5.1" };
85
85
  /**
86
86
  * Linux
87
87
  */
@@ -90,4 +90,4 @@ Os.LINUX = Os.of('Linux');
90
90
  * Windows
91
91
  */
92
92
  Os.WINDOWS = Os.of('Windows');
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/providers/common.ts"],"names":[],"mappings":";;;;;AAEA;;GAEG;AACH,MAAa,aAAa;IAmBxB,YAA+B,OAAe;QAAf,YAAO,GAAP,OAAO,CAAQ;IAC9C,CAAC;IAnBD;;OAEG;IACI,MAAM,CAAC,MAAM;QAClB,OAAO,IAAI,aAAa,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,QAAQ,CAAC,OAAe;QACpC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC;;AAjBH,sCAqBC;;;AAED;;GAEG;AACH,MAAa,YAAY;IAevB,YAAoC,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;IAChD,CAAC;IALO,MAAM,CAAC,EAAE,CAAC,YAAoB;QACpC,OAAO,IAAI,YAAY,CAAC,YAAY,CAAC,CAAC;IACxC,CAAC;IAKD;;;;MAIE;IACK,EAAE,CAAC,IAAkB;QAC1B,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC;IAChC,CAAC;;AAzBH,oCA0BC;;;AAzBC;;GAEG;AACoB,kBAAK,GAAG,YAAY,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;AAExD;;GAEG;AACoB,mBAAM,GAAG,YAAY,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;AAmB5D;;GAEG;AACH,MAAa,EAAE;IAeb,YAAoC,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;IAChD,CAAC;IALO,MAAM,CAAC,EAAE,CAAC,EAAU;QAC1B,OAAO,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;IACpB,CAAC;IAKD;;;;MAIE;IACK,EAAE,CAAC,EAAM;QACd,OAAO,EAAE,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC;IAC9B,CAAC;;AAzBH,gBA0BC;;;AAzBC;;EAEE;AACqB,QAAK,GAAG,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;AAE9C;;EAEE;AACqB,UAAO,GAAG,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC","sourcesContent":["import { aws_ec2 as ec2, aws_ecr as ecr, aws_iam as iam, aws_logs as logs, aws_stepfunctions as stepfunctions } from 'aws-cdk-lib';\n\n/**\n * Defines desired GitHub Actions runner version.\n */\nexport class RunnerVersion {\n  /**\n   * Use the latest version available at the time the runner provider image is built.\n   */\n  public static latest(): RunnerVersion {\n    return new RunnerVersion('latest');\n  }\n\n  /**\n   * Use a specific version.\n   *\n   * @see https://github.com/actions/runner/releases\n   *\n   * @param version GitHub Runner version\n   */\n  public static specific(version: string) {\n    return new RunnerVersion(version);\n  }\n\n  protected constructor(readonly version: string) {\n  }\n}\n\n/**\n * CPU architecture enum for an image.\n */\nexport class Architecture {\n  /**\n   * ARM64\n   */\n  public static readonly ARM64 = Architecture.of('ARM64');\n\n  /**\n   * X86_64\n   */\n  public static readonly X86_64 = Architecture.of('X86_64');\n\n  private static of(architecture: string) {\n    return new Architecture(architecture);\n  }\n\n  private constructor(public readonly name: string) {\n  }\n\n  /**\n  * Checks if the given architecture is the same as this one.\n  *\n  * @param arch architecture to compare\n  */\n  public is(arch: Architecture) {\n    return arch.name == this.name;\n  }\n}\n\n/**\n * OS enum for an image.\n */\nexport class Os {\n  /**\n  * Linux\n  */\n  public static readonly LINUX = Os.of('Linux');\n\n  /**\n  * Windows\n  */\n  public static readonly WINDOWS = Os.of('Windows');\n\n  private static of(os: string) {\n    return new Os(os);\n  }\n\n  private constructor(public readonly name: string) {\n  }\n\n  /**\n  * Checks if the given OS is the same as this one.\n  *\n  * @param os OS to compare\n  */\n  public is(os: Os) {\n    return os.name == this.name;\n  }\n}\n\nexport interface RunnerImage {\n  /**\n   * ECR repository containing the image.\n   */\n  readonly imageRepository: ecr.IRepository;\n\n  /**\n   * Static image tag where the image will be pushed.\n   */\n  readonly imageTag: string;\n\n  /**\n   * Image digest for providers that need to know the digest like Lambda.\n   *\n   * If the digest is not specified, imageTag must always point to a new tag on update. If not, the build may try to use the old image.\n   *\n   * WARNING: the digest might change when the builder automatically rebuilds the image on a schedule. Do not expect for this digest to stay the same between deploys.\n   */\n  readonly imageDigest?: string;\n\n  /**\n   * Architecture of the image.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * OS type of the image.\n   */\n  readonly os: Os;\n\n  /**\n   * Log group where image builds are logged.\n   */\n  readonly logGroup?: logs.LogGroup;\n}\n\n/**\n * Interface for constructs that build an image that can be used in {@link IRunnerProvider}.\n *\n * Anything that ends up with an ECR repository containing a Docker image that runs GitHub self-hosted runners can be used. A simple implementation could even point to an existing image and nothing else.\n *\n * It's important that the specified image tag be available at the time the repository is available. Providers usually assume the image is ready and will fail if it's not.\n *\n * The image can be further updated over time manually or using a schedule as long as it is always written to the same tag.\n */\nexport interface IImageBuilder {\n  /**\n   * ECR repository containing the image.\n   *\n   * This method can be called multiple times if the image is bound to multiple providers. Make sure you cache the image when implementing or return an error if this builder doesn't support reusing images.\n   *\n   * @return image\n   */\n  bind(): RunnerImage;\n}\n\n/**\n * Common properties for all runner providers.\n */\nexport interface RunnerProviderProps {\n  /**\n   * The number of days log events are kept in CloudWatch Logs. When updating\n   * this property, unsetting it doesn't remove the log retention policy. To\n   * remove the retention policy, set the value to `INFINITE`.\n   *\n   * @default logs.RetentionDays.ONE_MONTH\n   */\n  readonly logRetention?: logs.RetentionDays;\n}\n\n/**\n * Workflow job parameters as parsed from the webhook event. Pass these into your runner executor and run something like:\n *\n * ```sh\n * ./config.sh --unattended --url \"https://${GITHUB_DOMAIN}/${OWNER}/${REPO}\" --token \"${RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${RUNNER_LABEL}\" --name \"${RUNNER_NAME}\" --disableupdate\n * ```\n *\n * All parameters are specified as step function paths and therefore must be used only in step function task parameters.\n */\nexport interface RunnerRuntimeParameters {\n  /**\n   * Path to runner token used to register token.\n   */\n  readonly runnerTokenPath: string;\n\n  /**\n   * Path to desired runner name. We specifically set the name to make troubleshooting easier.\n   */\n  readonly runnerNamePath: string;\n\n  /**\n   * Path to GitHub domain. Most of the time this will be github.com but for self-hosted GitHub instances, this will be different.\n   */\n  readonly githubDomainPath: string;\n\n  /**\n   * Path to repostiroy owner name.\n   */\n  readonly ownerPath: string;\n\n  /**\n   * Path to repository name.\n   */\n  readonly repoPath: string;\n}\n\n/**\n * Interface for runner image status used by status.json.\n */\nexport interface IRunnerImageStatus {\n  /**\n   * Image repository where runner image is pushed.\n   */\n  readonly imageRepository?: string;\n\n  /**\n   * Tag of image that should be used.\n   */\n  readonly imageTag?: string;\n\n  /**\n   * Log group name for the image builder where history of image builds can be analyzed.\n   */\n  readonly imageBuilderLogGroup?: string;\n}\n\n/**\n * Interface for all runner providers. Implementations create all required resources and return a step function task that starts those resources from {@link getStepFunctionTask}.\n */\nexport interface IRunnerProvider extends ec2.IConnectable, iam.IGrantable {\n  /**\n   * GitHub Actions label associated with this runner provider.\n   */\n  readonly label: string;\n\n  /**\n   * VPC network in which runners will be placed.\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Security group associated with runners.\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Image used to create a new resource compute. Can be Docker image, AMI, or something else.\n   */\n  readonly image: RunnerImage;\n\n  /**\n   * Generate step function tasks that execute the runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters specific build parameters\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable;\n}\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/providers/common.ts"],"names":[],"mappings":";;;;;AAEA;;GAEG;AACH,MAAa,aAAa;IAmBxB,YAA+B,OAAe;QAAf,YAAO,GAAP,OAAO,CAAQ;IAC9C,CAAC;IAnBD;;OAEG;IACI,MAAM,CAAC,MAAM;QAClB,OAAO,IAAI,aAAa,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,QAAQ,CAAC,OAAe;QACpC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC;;AAjBH,sCAqBC;;;AAED;;GAEG;AACH,MAAa,YAAY;IAevB,YAAoC,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;IAChD,CAAC;IALO,MAAM,CAAC,EAAE,CAAC,YAAoB;QACpC,OAAO,IAAI,YAAY,CAAC,YAAY,CAAC,CAAC;IACxC,CAAC;IAKD;;;;MAIE;IACK,EAAE,CAAC,IAAkB;QAC1B,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC;IAChC,CAAC;;AAzBH,oCA0BC;;;AAzBC;;GAEG;AACoB,kBAAK,GAAG,YAAY,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;AAExD;;GAEG;AACoB,mBAAM,GAAG,YAAY,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;AAmB5D;;GAEG;AACH,MAAa,EAAE;IAeb,YAAoC,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;IAChD,CAAC;IALO,MAAM,CAAC,EAAE,CAAC,EAAU;QAC1B,OAAO,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;IACpB,CAAC;IAKD;;;;MAIE;IACK,EAAE,CAAC,EAAM;QACd,OAAO,EAAE,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC;IAC9B,CAAC;;AAzBH,gBA0BC;;;AAzBC;;EAEE;AACqB,QAAK,GAAG,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;AAE9C;;EAEE;AACqB,UAAO,GAAG,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC","sourcesContent":["import { aws_ec2 as ec2, aws_ecr as ecr, aws_iam as iam, aws_logs as logs, aws_stepfunctions as stepfunctions } from 'aws-cdk-lib';\n\n/**\n * Defines desired GitHub Actions runner version.\n */\nexport class RunnerVersion {\n  /**\n   * Use the latest version available at the time the runner provider image is built.\n   */\n  public static latest(): RunnerVersion {\n    return new RunnerVersion('latest');\n  }\n\n  /**\n   * Use a specific version.\n   *\n   * @see https://github.com/actions/runner/releases\n   *\n   * @param version GitHub Runner version\n   */\n  public static specific(version: string) {\n    return new RunnerVersion(version);\n  }\n\n  protected constructor(readonly version: string) {\n  }\n}\n\n/**\n * CPU architecture enum for an image.\n */\nexport class Architecture {\n  /**\n   * ARM64\n   */\n  public static readonly ARM64 = Architecture.of('ARM64');\n\n  /**\n   * X86_64\n   */\n  public static readonly X86_64 = Architecture.of('X86_64');\n\n  private static of(architecture: string) {\n    return new Architecture(architecture);\n  }\n\n  private constructor(public readonly name: string) {\n  }\n\n  /**\n  * Checks if the given architecture is the same as this one.\n  *\n  * @param arch architecture to compare\n  */\n  public is(arch: Architecture) {\n    return arch.name == this.name;\n  }\n}\n\n/**\n * OS enum for an image.\n */\nexport class Os {\n  /**\n  * Linux\n  */\n  public static readonly LINUX = Os.of('Linux');\n\n  /**\n  * Windows\n  */\n  public static readonly WINDOWS = Os.of('Windows');\n\n  private static of(os: string) {\n    return new Os(os);\n  }\n\n  private constructor(public readonly name: string) {\n  }\n\n  /**\n  * Checks if the given OS is the same as this one.\n  *\n  * @param os OS to compare\n  */\n  public is(os: Os) {\n    return os.name == this.name;\n  }\n}\n\nexport interface RunnerImage {\n  /**\n   * ECR repository containing the image.\n   */\n  readonly imageRepository: ecr.IRepository;\n\n  /**\n   * Static image tag where the image will be pushed.\n   */\n  readonly imageTag: string;\n\n  /**\n   * Architecture of the image.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * OS type of the image.\n   */\n  readonly os: Os;\n\n  /**\n   * Log group where image builds are logged.\n   */\n  readonly logGroup?: logs.LogGroup;\n}\n\n/**\n * Interface for constructs that build an image that can be used in {@link IRunnerProvider}.\n *\n * Anything that ends up with an ECR repository containing a Docker image that runs GitHub self-hosted runners can be used. A simple implementation could even point to an existing image and nothing else.\n *\n * It's important that the specified image tag be available at the time the repository is available. Providers usually assume the image is ready and will fail if it's not.\n *\n * The image can be further updated over time manually or using a schedule as long as it is always written to the same tag.\n */\nexport interface IImageBuilder {\n  /**\n   * ECR repository containing the image.\n   *\n   * This method can be called multiple times if the image is bound to multiple providers. Make sure you cache the image when implementing or return an error if this builder doesn't support reusing images.\n   *\n   * @return image\n   */\n  bind(): RunnerImage;\n}\n\n/**\n * Common properties for all runner providers.\n */\nexport interface RunnerProviderProps {\n  /**\n   * The number of days log events are kept in CloudWatch Logs. When updating\n   * this property, unsetting it doesn't remove the log retention policy. To\n   * remove the retention policy, set the value to `INFINITE`.\n   *\n   * @default logs.RetentionDays.ONE_MONTH\n   */\n  readonly logRetention?: logs.RetentionDays;\n}\n\n/**\n * Workflow job parameters as parsed from the webhook event. Pass these into your runner executor and run something like:\n *\n * ```sh\n * ./config.sh --unattended --url \"https://${GITHUB_DOMAIN}/${OWNER}/${REPO}\" --token \"${RUNNER_TOKEN}\" --ephemeral --work _work --labels \"${RUNNER_LABEL}\" --name \"${RUNNER_NAME}\" --disableupdate\n * ```\n *\n * All parameters are specified as step function paths and therefore must be used only in step function task parameters.\n */\nexport interface RunnerRuntimeParameters {\n  /**\n   * Path to runner token used to register token.\n   */\n  readonly runnerTokenPath: string;\n\n  /**\n   * Path to desired runner name. We specifically set the name to make troubleshooting easier.\n   */\n  readonly runnerNamePath: string;\n\n  /**\n   * Path to GitHub domain. Most of the time this will be github.com but for self-hosted GitHub instances, this will be different.\n   */\n  readonly githubDomainPath: string;\n\n  /**\n   * Path to repostiroy owner name.\n   */\n  readonly ownerPath: string;\n\n  /**\n   * Path to repository name.\n   */\n  readonly repoPath: string;\n}\n\n/**\n * Interface for runner image status used by status.json.\n */\nexport interface IRunnerImageStatus {\n  /**\n   * Image repository where runner image is pushed.\n   */\n  readonly imageRepository?: string;\n\n  /**\n   * Tag of image that should be used.\n   */\n  readonly imageTag?: string;\n\n  /**\n   * Log group name for the image builder where history of image builds can be analyzed.\n   */\n  readonly imageBuilderLogGroup?: string;\n}\n\n/**\n * Interface for all runner providers. Implementations create all required resources and return a step function task that starts those resources from {@link getStepFunctionTask}.\n */\nexport interface IRunnerProvider extends ec2.IConnectable, iam.IGrantable {\n  /**\n   * GitHub Actions label associated with this runner provider.\n   */\n  readonly label: string;\n\n  /**\n   * VPC network in which runners will be placed.\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Security group associated with runners.\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Image used to create a new resource compute. Can be Docker image, AMI, or something else.\n   */\n  readonly image: RunnerImage;\n\n  /**\n   * Generate step function tasks that execute the runner.\n   *\n   * Called by GithubRunners and shouldn't be called manually.\n   *\n   * @param parameters specific build parameters\n   */\n  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable;\n}\n"]}
@@ -41,8 +41,8 @@ RUN if [ "$RUNNER_VERSION" = "latest" ]; then RUNNER_VERSION=`curl -w "%{redire
41
41
  # docker-in-docker
42
42
  ARG DOCKER_CHANNEL="stable"
43
43
  ARG DIND_COMMIT="42b1175eda071c0e9121e1d64345928384a93df1"
44
- ARG DOCKER_VERSION="20.10.16"
45
- ARG DOCKER_COMPOSE_VERSION="2.5.1"
44
+ ARG DOCKER_VERSION="20.10.18"
45
+ ARG DOCKER_COMPOSE_VERSION="2.11.0"
46
46
 
47
47
  RUN curl -fsSL "https://download.docker.com/linux/static/${DOCKER_CHANNEL}/aarch64/docker-${DOCKER_VERSION}.tgz" -o docker.tgz && \
48
48
  tar --strip-components 1 -C /usr/local/bin/ -xzf docker.tgz && \
@@ -54,6 +54,7 @@ RUN curl -fsSL "https://download.docker.com/linux/static/${DOCKER_CHANNEL}/aarch
54
54
  echo 'dockremap:165536:65536' >> /etc/subgid && \
55
55
  curl -fsSL "https://raw.githubusercontent.com/docker/docker/${DIND_COMMIT}/hack/dind" -o /usr/local/bin/dind && \
56
56
  curl -fsSL https://github.com/docker/compose/releases/download/v${DOCKER_COMPOSE_VERSION}/docker-compose-linux-aarch64 -o /usr/local/bin/docker-compose && \
57
+ mkdir -p /home/runner/.docker/cli-plugins && ln -s /usr/local/bin/docker-compose /home/runner/.docker/cli-plugins/docker-compose && \
57
58
  chmod +x /usr/local/bin/dind /usr/local/bin/docker-compose && \
58
59
  addgroup docker && usermod -aG docker runner
59
60
 
@@ -41,8 +41,8 @@ RUN if [ "${RUNNER_VERSION}" = "latest" ]; then RUNNER_VERSION=`curl -w "%{redi
41
41
  # docker-in-docker
42
42
  ARG DOCKER_CHANNEL="stable"
43
43
  ARG DIND_COMMIT="42b1175eda071c0e9121e1d64345928384a93df1"
44
- ARG DOCKER_VERSION="20.10.16"
45
- ARG DOCKER_COMPOSE_VERSION="2.5.1"
44
+ ARG DOCKER_VERSION="20.10.18"
45
+ ARG DOCKER_COMPOSE_VERSION="2.11.0"
46
46
 
47
47
  RUN curl -fsSL "https://download.docker.com/linux/static/${DOCKER_CHANNEL}/x86_64/docker-${DOCKER_VERSION}.tgz" -o docker.tgz && \
48
48
  tar --strip-components 1 -C /usr/local/bin/ -xzf docker.tgz && \
@@ -54,6 +54,7 @@ RUN curl -fsSL "https://download.docker.com/linux/static/${DOCKER_CHANNEL}/x86_6
54
54
  echo 'dockremap:165536:65536' >> /etc/subgid && \
55
55
  curl -fsSL "https://raw.githubusercontent.com/docker/docker/${DIND_COMMIT}/hack/dind" -o /usr/local/bin/dind && \
56
56
  curl -fsSL https://github.com/docker/compose/releases/download/v${DOCKER_COMPOSE_VERSION}/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose && \
57
+ mkdir -p /home/runner/.docker/cli-plugins && ln -s /usr/local/bin/docker-compose /home/runner/.docker/cli-plugins/docker-compose && \
57
58
  chmod +x /usr/local/bin/dind /usr/local/bin/docker-compose && \
58
59
  addgroup docker && usermod -aG docker runner
59
60
 
@@ -41,5 +41,3 @@ RUN if [ "${RUNNER_VERSION}" = "latest" ]; then RUNNER_VERSION=`curl -w "%{redi
41
41
  # configure runner
42
42
  USER runner
43
43
 
44
- ADD runner.sh .
45
- CMD ["bash", "/home/runner/runner.sh"]
@@ -40,6 +40,3 @@ RUN if [ "${RUNNER_VERSION}" = "latest" ]; then RUNNER_VERSION=`curl -w "%{redi
40
40
 
41
41
  # configure runner
42
42
  USER runner
43
-
44
- ADD runner.sh .
45
- CMD ["bash", "/home/runner/runner.sh"]
@@ -183,4 +183,5 @@ export declare class FargateRunner extends Construct implements IRunnerProvider
183
183
  * @param parameters workflow job details
184
184
  */
185
185
  getStepFunctionTask(parameters: RunnerRuntimeParameters): stepfunctions.IChainable;
186
+ private runCommand;
186
187
  }