@cloudsnorkel/cdk-github-runners 0.15.0 → 0.15.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.
Files changed (42) hide show
  1. package/.jsii +533 -327
  2. package/API.md +384 -174
  3. package/README.md +1 -1
  4. package/assets/delete-failed-runner.lambda/index.js +23 -6
  5. package/assets/idle-runner-repear.lambda/index.js +23 -6
  6. package/assets/setup.lambda/index.html +7 -7
  7. package/assets/setup.lambda/index.js +23 -6
  8. package/assets/status.lambda/index.js +23 -6
  9. package/assets/token-retriever.lambda/index.js +23 -6
  10. package/assets/warm-runner-manager.lambda/index.js +23 -6
  11. package/assets/webhook-handler.lambda/index.js +23 -6
  12. package/assets/webhook-redelivery.lambda/index.js +23 -6
  13. package/lib/access.js +1 -1
  14. package/lib/image-builders/api.js +1 -1
  15. package/lib/image-builders/aws-image-builder/base-image.js +2 -2
  16. package/lib/image-builders/aws-image-builder/builder.js +1 -1
  17. package/lib/image-builders/aws-image-builder/deprecated/ami.js +1 -1
  18. package/lib/image-builders/aws-image-builder/deprecated/container.js +1 -1
  19. package/lib/image-builders/aws-image-builder/deprecated/linux-components.js +1 -1
  20. package/lib/image-builders/aws-image-builder/deprecated/windows-components.js +1 -1
  21. package/lib/image-builders/codebuild-deprecated.js +1 -1
  22. package/lib/image-builders/components.js +1 -1
  23. package/lib/image-builders/static.js +1 -1
  24. package/lib/providers/codebuild.d.ts +2 -2
  25. package/lib/providers/codebuild.js +3 -3
  26. package/lib/providers/common.d.ts +47 -3
  27. package/lib/providers/common.js +29 -5
  28. package/lib/providers/composite.js +14 -19
  29. package/lib/providers/ec2.d.ts +4 -2
  30. package/lib/providers/ec2.js +58 -30
  31. package/lib/providers/ecs.d.ts +2 -2
  32. package/lib/providers/ecs.js +8 -8
  33. package/lib/providers/fargate.d.ts +2 -2
  34. package/lib/providers/fargate.js +13 -8
  35. package/lib/providers/lambda.d.ts +2 -2
  36. package/lib/providers/lambda.js +3 -3
  37. package/lib/runner.d.ts +6 -1
  38. package/lib/runner.js +54 -31
  39. package/lib/secrets.js +1 -1
  40. package/lib/warm-runner.d.ts +15 -7
  41. package/lib/warm-runner.js +19 -12
  42. package/package.json +15 -15
@@ -596,7 +596,7 @@ var require_fast_content_type_parse = __commonJS({
596
596
  });
597
597
 
598
598
  // node_modules/json-with-bigint/json-with-bigint.js
599
- var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
599
+ var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, featureCache, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
600
600
  var init_json_with_bigint = __esm({
601
601
  "node_modules/json-with-bigint/json-with-bigint.js"() {
602
602
  "use strict";
@@ -624,7 +624,7 @@ var init_json_with_bigint = __esm({
624
624
  const convertedToCustomJSON = originalStringify(
625
625
  value,
626
626
  (key, value2) => {
627
- const isNoise = typeof value2 === "string" && Boolean(value2.match(noiseValue));
627
+ const isNoise = typeof value2 === "string" && noiseValue.test(value2);
628
628
  if (isNoise) return value2.toString() + "n";
629
629
  if (typeof value2 === "bigint") return value2.toString() + "n";
630
630
  if (typeof replacer === "function") return replacer(key, value2);
@@ -640,11 +640,28 @@ var init_json_with_bigint = __esm({
640
640
  const denoisedJSON = processedJSON.replace(noiseStringify, "$1$2$3");
641
641
  return denoisedJSON;
642
642
  };
643
- isContextSourceSupported = () => JSON.parse("1", (_, __, context) => !!context && context.source === "1");
643
+ featureCache = /* @__PURE__ */ new Map();
644
+ isContextSourceSupported = () => {
645
+ const parseFingerprint = JSON.parse.toString();
646
+ if (featureCache.has(parseFingerprint)) {
647
+ return featureCache.get(parseFingerprint);
648
+ }
649
+ try {
650
+ const result = JSON.parse(
651
+ "1",
652
+ (_, __, context) => !!context?.source && context.source === "1"
653
+ );
654
+ featureCache.set(parseFingerprint, result);
655
+ return result;
656
+ } catch {
657
+ featureCache.set(parseFingerprint, false);
658
+ return false;
659
+ }
660
+ };
644
661
  convertMarkedBigIntsReviver = (key, value, context, userReviver) => {
645
- const isCustomFormatBigInt = typeof value === "string" && value.match(customFormat);
662
+ const isCustomFormatBigInt = typeof value === "string" && customFormat.test(value);
646
663
  if (isCustomFormatBigInt) return BigInt(value.slice(0, -1));
647
- const isNoiseValue = typeof value === "string" && value.match(noiseValue);
664
+ const isNoiseValue = typeof value === "string" && noiseValue.test(value);
648
665
  if (isNoiseValue) return value.slice(0, -1);
649
666
  if (typeof userReviver !== "function") return value;
650
667
  return userReviver(key, value, context);
@@ -670,7 +687,7 @@ var init_json_with_bigint = __esm({
670
687
  stringsOrLargeNumbers,
671
688
  (text2, digits, fractional, exponential) => {
672
689
  const isString = text2[0] === '"';
673
- const isNoise = isString && Boolean(text2.match(noiseValueWithQuotes));
690
+ const isNoise = isString && noiseValueWithQuotes.test(text2);
674
691
  if (isNoise) return text2.substring(0, text2.length - 1) + 'n"';
675
692
  const isFractionalOrExponential = fractional || exponential;
676
693
  const isLessThanMaxSafeInt = digits && (digits.length < MAX_DIGITS || digits.length === MAX_DIGITS && digits <= MAX_INT);
@@ -596,7 +596,7 @@ var require_fast_content_type_parse = __commonJS({
596
596
  });
597
597
 
598
598
  // node_modules/json-with-bigint/json-with-bigint.js
599
- var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
599
+ var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, featureCache, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
600
600
  var init_json_with_bigint = __esm({
601
601
  "node_modules/json-with-bigint/json-with-bigint.js"() {
602
602
  "use strict";
@@ -624,7 +624,7 @@ var init_json_with_bigint = __esm({
624
624
  const convertedToCustomJSON = originalStringify(
625
625
  value,
626
626
  (key, value2) => {
627
- const isNoise = typeof value2 === "string" && Boolean(value2.match(noiseValue));
627
+ const isNoise = typeof value2 === "string" && noiseValue.test(value2);
628
628
  if (isNoise) return value2.toString() + "n";
629
629
  if (typeof value2 === "bigint") return value2.toString() + "n";
630
630
  if (typeof replacer === "function") return replacer(key, value2);
@@ -640,11 +640,28 @@ var init_json_with_bigint = __esm({
640
640
  const denoisedJSON = processedJSON.replace(noiseStringify, "$1$2$3");
641
641
  return denoisedJSON;
642
642
  };
643
- isContextSourceSupported = () => JSON.parse("1", (_, __, context) => !!context && context.source === "1");
643
+ featureCache = /* @__PURE__ */ new Map();
644
+ isContextSourceSupported = () => {
645
+ const parseFingerprint = JSON.parse.toString();
646
+ if (featureCache.has(parseFingerprint)) {
647
+ return featureCache.get(parseFingerprint);
648
+ }
649
+ try {
650
+ const result = JSON.parse(
651
+ "1",
652
+ (_, __, context) => !!context?.source && context.source === "1"
653
+ );
654
+ featureCache.set(parseFingerprint, result);
655
+ return result;
656
+ } catch {
657
+ featureCache.set(parseFingerprint, false);
658
+ return false;
659
+ }
660
+ };
644
661
  convertMarkedBigIntsReviver = (key, value, context, userReviver) => {
645
- const isCustomFormatBigInt = typeof value === "string" && value.match(customFormat);
662
+ const isCustomFormatBigInt = typeof value === "string" && customFormat.test(value);
646
663
  if (isCustomFormatBigInt) return BigInt(value.slice(0, -1));
647
- const isNoiseValue = typeof value === "string" && value.match(noiseValue);
664
+ const isNoiseValue = typeof value === "string" && noiseValue.test(value);
648
665
  if (isNoiseValue) return value.slice(0, -1);
649
666
  if (typeof userReviver !== "function") return value;
650
667
  return userReviver(key, value, context);
@@ -670,7 +687,7 @@ var init_json_with_bigint = __esm({
670
687
  stringsOrLargeNumbers,
671
688
  (text2, digits, fractional, exponential) => {
672
689
  const isString = text2[0] === '"';
673
- const isNoise = isString && Boolean(text2.match(noiseValueWithQuotes));
690
+ const isNoise = isString && noiseValueWithQuotes.test(text2);
674
691
  if (isNoise) return text2.substring(0, text2.length - 1) + 'n"';
675
692
  const isFractionalOrExponential = fractional || exponential;
676
693
  const isLessThanMaxSafeInt = digits && (digits.length < MAX_DIGITS || digits.length === MAX_DIGITS && digits <= MAX_INT);
@@ -596,7 +596,7 @@ var require_fast_content_type_parse = __commonJS({
596
596
  });
597
597
 
598
598
  // node_modules/json-with-bigint/json-with-bigint.js
599
- var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
599
+ var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, featureCache, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
600
600
  var init_json_with_bigint = __esm({
601
601
  "node_modules/json-with-bigint/json-with-bigint.js"() {
602
602
  "use strict";
@@ -624,7 +624,7 @@ var init_json_with_bigint = __esm({
624
624
  const convertedToCustomJSON = originalStringify(
625
625
  value,
626
626
  (key, value2) => {
627
- const isNoise = typeof value2 === "string" && Boolean(value2.match(noiseValue));
627
+ const isNoise = typeof value2 === "string" && noiseValue.test(value2);
628
628
  if (isNoise) return value2.toString() + "n";
629
629
  if (typeof value2 === "bigint") return value2.toString() + "n";
630
630
  if (typeof replacer === "function") return replacer(key, value2);
@@ -640,11 +640,28 @@ var init_json_with_bigint = __esm({
640
640
  const denoisedJSON = processedJSON.replace(noiseStringify, "$1$2$3");
641
641
  return denoisedJSON;
642
642
  };
643
- isContextSourceSupported = () => JSON.parse("1", (_, __, context) => !!context && context.source === "1");
643
+ featureCache = /* @__PURE__ */ new Map();
644
+ isContextSourceSupported = () => {
645
+ const parseFingerprint = JSON.parse.toString();
646
+ if (featureCache.has(parseFingerprint)) {
647
+ return featureCache.get(parseFingerprint);
648
+ }
649
+ try {
650
+ const result = JSON.parse(
651
+ "1",
652
+ (_, __, context) => !!context?.source && context.source === "1"
653
+ );
654
+ featureCache.set(parseFingerprint, result);
655
+ return result;
656
+ } catch {
657
+ featureCache.set(parseFingerprint, false);
658
+ return false;
659
+ }
660
+ };
644
661
  convertMarkedBigIntsReviver = (key, value, context, userReviver) => {
645
- const isCustomFormatBigInt = typeof value === "string" && value.match(customFormat);
662
+ const isCustomFormatBigInt = typeof value === "string" && customFormat.test(value);
646
663
  if (isCustomFormatBigInt) return BigInt(value.slice(0, -1));
647
- const isNoiseValue = typeof value === "string" && value.match(noiseValue);
664
+ const isNoiseValue = typeof value === "string" && noiseValue.test(value);
648
665
  if (isNoiseValue) return value.slice(0, -1);
649
666
  if (typeof userReviver !== "function") return value;
650
667
  return userReviver(key, value, context);
@@ -670,7 +687,7 @@ var init_json_with_bigint = __esm({
670
687
  stringsOrLargeNumbers,
671
688
  (text2, digits, fractional, exponential) => {
672
689
  const isString = text2[0] === '"';
673
- const isNoise = isString && Boolean(text2.match(noiseValueWithQuotes));
690
+ const isNoise = isString && noiseValueWithQuotes.test(text2);
674
691
  if (isNoise) return text2.substring(0, text2.length - 1) + 'n"';
675
692
  const isFractionalOrExponential = fractional || exponential;
676
693
  const isLessThanMaxSafeInt = digits && (digits.length < MAX_DIGITS || digits.length === MAX_DIGITS && digits <= MAX_INT);
@@ -596,7 +596,7 @@ var require_fast_content_type_parse = __commonJS({
596
596
  });
597
597
 
598
598
  // node_modules/json-with-bigint/json-with-bigint.js
599
- var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
599
+ var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, featureCache, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
600
600
  var init_json_with_bigint = __esm({
601
601
  "node_modules/json-with-bigint/json-with-bigint.js"() {
602
602
  "use strict";
@@ -624,7 +624,7 @@ var init_json_with_bigint = __esm({
624
624
  const convertedToCustomJSON = originalStringify(
625
625
  value,
626
626
  (key, value2) => {
627
- const isNoise = typeof value2 === "string" && Boolean(value2.match(noiseValue));
627
+ const isNoise = typeof value2 === "string" && noiseValue.test(value2);
628
628
  if (isNoise) return value2.toString() + "n";
629
629
  if (typeof value2 === "bigint") return value2.toString() + "n";
630
630
  if (typeof replacer === "function") return replacer(key, value2);
@@ -640,11 +640,28 @@ var init_json_with_bigint = __esm({
640
640
  const denoisedJSON = processedJSON.replace(noiseStringify, "$1$2$3");
641
641
  return denoisedJSON;
642
642
  };
643
- isContextSourceSupported = () => JSON.parse("1", (_, __, context) => !!context && context.source === "1");
643
+ featureCache = /* @__PURE__ */ new Map();
644
+ isContextSourceSupported = () => {
645
+ const parseFingerprint = JSON.parse.toString();
646
+ if (featureCache.has(parseFingerprint)) {
647
+ return featureCache.get(parseFingerprint);
648
+ }
649
+ try {
650
+ const result = JSON.parse(
651
+ "1",
652
+ (_, __, context) => !!context?.source && context.source === "1"
653
+ );
654
+ featureCache.set(parseFingerprint, result);
655
+ return result;
656
+ } catch {
657
+ featureCache.set(parseFingerprint, false);
658
+ return false;
659
+ }
660
+ };
644
661
  convertMarkedBigIntsReviver = (key, value, context, userReviver) => {
645
- const isCustomFormatBigInt = typeof value === "string" && value.match(customFormat);
662
+ const isCustomFormatBigInt = typeof value === "string" && customFormat.test(value);
646
663
  if (isCustomFormatBigInt) return BigInt(value.slice(0, -1));
647
- const isNoiseValue = typeof value === "string" && value.match(noiseValue);
664
+ const isNoiseValue = typeof value === "string" && noiseValue.test(value);
648
665
  if (isNoiseValue) return value.slice(0, -1);
649
666
  if (typeof userReviver !== "function") return value;
650
667
  return userReviver(key, value, context);
@@ -670,7 +687,7 @@ var init_json_with_bigint = __esm({
670
687
  stringsOrLargeNumbers,
671
688
  (text2, digits, fractional, exponential) => {
672
689
  const isString = text2[0] === '"';
673
- const isNoise = isString && Boolean(text2.match(noiseValueWithQuotes));
690
+ const isNoise = isString && noiseValueWithQuotes.test(text2);
674
691
  if (isNoise) return text2.substring(0, text2.length - 1) + 'n"';
675
692
  const isFractionalOrExponential = fractional || exponential;
676
693
  const isLessThanMaxSafeInt = digits && (digits.length < MAX_DIGITS || digits.length === MAX_DIGITS && digits <= MAX_INT);
@@ -596,7 +596,7 @@ var require_fast_content_type_parse = __commonJS({
596
596
  });
597
597
 
598
598
  // node_modules/json-with-bigint/json-with-bigint.js
599
- var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
599
+ var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, featureCache, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
600
600
  var init_json_with_bigint = __esm({
601
601
  "node_modules/json-with-bigint/json-with-bigint.js"() {
602
602
  "use strict";
@@ -624,7 +624,7 @@ var init_json_with_bigint = __esm({
624
624
  const convertedToCustomJSON = originalStringify(
625
625
  value,
626
626
  (key, value2) => {
627
- const isNoise = typeof value2 === "string" && Boolean(value2.match(noiseValue));
627
+ const isNoise = typeof value2 === "string" && noiseValue.test(value2);
628
628
  if (isNoise) return value2.toString() + "n";
629
629
  if (typeof value2 === "bigint") return value2.toString() + "n";
630
630
  if (typeof replacer === "function") return replacer(key, value2);
@@ -640,11 +640,28 @@ var init_json_with_bigint = __esm({
640
640
  const denoisedJSON = processedJSON.replace(noiseStringify, "$1$2$3");
641
641
  return denoisedJSON;
642
642
  };
643
- isContextSourceSupported = () => JSON.parse("1", (_, __, context) => !!context && context.source === "1");
643
+ featureCache = /* @__PURE__ */ new Map();
644
+ isContextSourceSupported = () => {
645
+ const parseFingerprint = JSON.parse.toString();
646
+ if (featureCache.has(parseFingerprint)) {
647
+ return featureCache.get(parseFingerprint);
648
+ }
649
+ try {
650
+ const result = JSON.parse(
651
+ "1",
652
+ (_, __, context) => !!context?.source && context.source === "1"
653
+ );
654
+ featureCache.set(parseFingerprint, result);
655
+ return result;
656
+ } catch {
657
+ featureCache.set(parseFingerprint, false);
658
+ return false;
659
+ }
660
+ };
644
661
  convertMarkedBigIntsReviver = (key, value, context, userReviver) => {
645
- const isCustomFormatBigInt = typeof value === "string" && value.match(customFormat);
662
+ const isCustomFormatBigInt = typeof value === "string" && customFormat.test(value);
646
663
  if (isCustomFormatBigInt) return BigInt(value.slice(0, -1));
647
- const isNoiseValue = typeof value === "string" && value.match(noiseValue);
664
+ const isNoiseValue = typeof value === "string" && noiseValue.test(value);
648
665
  if (isNoiseValue) return value.slice(0, -1);
649
666
  if (typeof userReviver !== "function") return value;
650
667
  return userReviver(key, value, context);
@@ -670,7 +687,7 @@ var init_json_with_bigint = __esm({
670
687
  stringsOrLargeNumbers,
671
688
  (text2, digits, fractional, exponential) => {
672
689
  const isString = text2[0] === '"';
673
- const isNoise = isString && Boolean(text2.match(noiseValueWithQuotes));
690
+ const isNoise = isString && noiseValueWithQuotes.test(text2);
674
691
  if (isNoise) return text2.substring(0, text2.length - 1) + 'n"';
675
692
  const isFractionalOrExponential = fractional || exponential;
676
693
  const isLessThanMaxSafeInt = digits && (digits.length < MAX_DIGITS || digits.length === MAX_DIGITS && digits <= MAX_INT);
@@ -596,7 +596,7 @@ var require_fast_content_type_parse = __commonJS({
596
596
  });
597
597
 
598
598
  // node_modules/json-with-bigint/json-with-bigint.js
599
- var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
599
+ var intRegex, noiseValue, originalStringify, originalParse, customFormat, bigIntsStringify, noiseStringify, JSONStringify, featureCache, isContextSourceSupported, convertMarkedBigIntsReviver, JSONParseV2, MAX_INT, MAX_DIGITS, stringsOrLargeNumbers, noiseValueWithQuotes, JSONParse;
600
600
  var init_json_with_bigint = __esm({
601
601
  "node_modules/json-with-bigint/json-with-bigint.js"() {
602
602
  "use strict";
@@ -624,7 +624,7 @@ var init_json_with_bigint = __esm({
624
624
  const convertedToCustomJSON = originalStringify(
625
625
  value,
626
626
  (key, value2) => {
627
- const isNoise = typeof value2 === "string" && Boolean(value2.match(noiseValue));
627
+ const isNoise = typeof value2 === "string" && noiseValue.test(value2);
628
628
  if (isNoise) return value2.toString() + "n";
629
629
  if (typeof value2 === "bigint") return value2.toString() + "n";
630
630
  if (typeof replacer === "function") return replacer(key, value2);
@@ -640,11 +640,28 @@ var init_json_with_bigint = __esm({
640
640
  const denoisedJSON = processedJSON.replace(noiseStringify, "$1$2$3");
641
641
  return denoisedJSON;
642
642
  };
643
- isContextSourceSupported = () => JSON.parse("1", (_, __, context) => !!context && context.source === "1");
643
+ featureCache = /* @__PURE__ */ new Map();
644
+ isContextSourceSupported = () => {
645
+ const parseFingerprint = JSON.parse.toString();
646
+ if (featureCache.has(parseFingerprint)) {
647
+ return featureCache.get(parseFingerprint);
648
+ }
649
+ try {
650
+ const result = JSON.parse(
651
+ "1",
652
+ (_, __, context) => !!context?.source && context.source === "1"
653
+ );
654
+ featureCache.set(parseFingerprint, result);
655
+ return result;
656
+ } catch {
657
+ featureCache.set(parseFingerprint, false);
658
+ return false;
659
+ }
660
+ };
644
661
  convertMarkedBigIntsReviver = (key, value, context, userReviver) => {
645
- const isCustomFormatBigInt = typeof value === "string" && value.match(customFormat);
662
+ const isCustomFormatBigInt = typeof value === "string" && customFormat.test(value);
646
663
  if (isCustomFormatBigInt) return BigInt(value.slice(0, -1));
647
- const isNoiseValue = typeof value === "string" && value.match(noiseValue);
664
+ const isNoiseValue = typeof value === "string" && noiseValue.test(value);
648
665
  if (isNoiseValue) return value.slice(0, -1);
649
666
  if (typeof userReviver !== "function") return value;
650
667
  return userReviver(key, value, context);
@@ -670,7 +687,7 @@ var init_json_with_bigint = __esm({
670
687
  stringsOrLargeNumbers,
671
688
  (text2, digits, fractional, exponential) => {
672
689
  const isString = text2[0] === '"';
673
- const isNoise = isString && Boolean(text2.match(noiseValueWithQuotes));
690
+ const isNoise = isString && noiseValueWithQuotes.test(text2);
674
691
  if (isNoise) return text2.substring(0, text2.length - 1) + 'n"';
675
692
  const isFractionalOrExponential = fractional || exponential;
676
693
  const isLessThanMaxSafeInt = digits && (digits.length < MAX_DIGITS || digits.length === MAX_DIGITS && digits <= MAX_INT);
package/lib/access.js CHANGED
@@ -59,7 +59,7 @@ class LambdaAccess {
59
59
  }
60
60
  exports.LambdaAccess = LambdaAccess;
61
61
  _a = JSII_RTTI_SYMBOL_1;
62
- LambdaAccess[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaAccess", version: "0.15.0" };
62
+ LambdaAccess[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaAccess", version: "0.15.1" };
63
63
  /**
64
64
  * @internal
65
65
  */
@@ -43,5 +43,5 @@ class RunnerImageBuilder extends common_1.RunnerImageBuilderBase {
43
43
  }
44
44
  exports.RunnerImageBuilder = RunnerImageBuilder;
45
45
  _a = JSII_RTTI_SYMBOL_1;
46
- RunnerImageBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerImageBuilder", version: "0.15.0" };
46
+ RunnerImageBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerImageBuilder", version: "0.15.1" };
47
47
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ltYWdlLWJ1aWxkZXJzL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUEwQztBQUUxQywyREFBd0U7QUFDeEUsMkNBQTBEO0FBQzFELHFDQUFvSTtBQUNwSSw0Q0FBa0M7QUFFbEM7Ozs7OztHQU1HO0FBQ0gsTUFBc0Isa0JBQW1CLFNBQVEsK0JBQXNCO0lBQ3JFOztPQUVHO0lBQ0gsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUErQjtRQUN0RSxJQUFJLEtBQUssRUFBRSxVQUFVLElBQUksS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzdDLHlCQUFXLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsQ0FBQyxrSEFBa0gsQ0FBQyxDQUFDO1FBQ3ZKLENBQUM7UUFFRCxJQUFJLEtBQUssRUFBRSxXQUFXLEtBQUssK0JBQXNCLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDN0QsT0FBTyxJQUFJLHVDQUEyQixDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0QsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFdBQVcsS0FBSywrQkFBc0IsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQzNFLE9BQU8sSUFBSSxxREFBaUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFFRCxNQUFNLEVBQUUsR0FBRyxLQUFLLEVBQUUsRUFBRSxJQUFJLGNBQUUsQ0FBQyxZQUFZLENBQUM7UUFDeEMsSUFBSSxFQUFFLENBQUMsSUFBSSxDQUFDLGNBQUUsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLENBQUM7WUFDcEMsT0FBTyxJQUFJLHVDQUEyQixDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0QsQ0FBQzthQUFNLElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxjQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUM3QixPQUFPLElBQUkscURBQWlDLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNqRSxDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsMERBQTBELEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZGLENBQUM7SUFDSCxDQUFDOztBQXZCSCxnREF3QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBbm5vdGF0aW9ucyB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQXdzSW1hZ2VCdWlsZGVyUnVubmVySW1hZ2VCdWlsZGVyIH0gZnJvbSAnLi9hd3MtaW1hZ2UtYnVpbGRlcic7XG5pbXBvcnQgeyBDb2RlQnVpbGRSdW5uZXJJbWFnZUJ1aWxkZXIgfSBmcm9tICcuL2NvZGVidWlsZCc7XG5pbXBvcnQgeyBJQ29uZmlndXJhYmxlUnVubmVySW1hZ2VCdWlsZGVyLCBSdW5uZXJJbWFnZUJ1aWxkZXJCYXNlLCBSdW5uZXJJbWFnZUJ1aWxkZXJQcm9wcywgUnVubmVySW1hZ2VCdWlsZGVyVHlwZSB9IGZyb20gJy4vY29tbW9uJztcbmltcG9ydCB7IE9zIH0gZnJvbSAnLi4vcHJvdmlkZXJzJztcblxuLyoqXG4gKiBHaXRIdWIgUnVubmVyIGltYWdlIGJ1aWxkZXIuIEJ1aWxkcyBhIERvY2tlciBpbWFnZSBvciBBTUkgd2l0aCBHaXRIdWIgUnVubmVyIGFuZCBvdGhlciByZXF1aXJlbWVudHMgaW5zdGFsbGVkLlxuICpcbiAqIEltYWdlcyBjYW4gYmUgY3VzdG9taXplZCBiZWZvcmUgcGFzc2VkIGludG8gdGhlIHByb3ZpZGVyIGJ5IGFkZGluZyBvciByZW1vdmluZyBjb21wb25lbnRzIHRvIGJlIGluc3RhbGxlZC5cbiAqXG4gKiBJbWFnZXMgYXJlIHJlYnVpbHQgZXZlcnkgd2VlayBieSBkZWZhdWx0IHRvIGVuc3VyZSB0aGF0IHRoZSBsYXRlc3Qgc2VjdXJpdHkgcGF0Y2hlcyBhcmUgYXBwbGllZC5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFJ1bm5lckltYWdlQnVpbGRlciBleHRlbmRzIFJ1bm5lckltYWdlQnVpbGRlckJhc2Uge1xuICAvKipcbiAgICogQ3JlYXRlIGEgbmV3IGltYWdlIGJ1aWxkZXIgYmFzZWQgb24gdGhlIHByb3ZpZGVkIHByb3BlcnRpZXMuIFRoZSBpbXBsZW1lbnRhdGlvbiB3aWxsIGRpZmZlciBiYXNlZCBvbiB0aGUgT1MsIGFyY2hpdGVjdHVyZSwgYW5kIHJlcXVlc3RlZCBidWlsZGVyIHR5cGUuXG4gICAqL1xuICBzdGF0aWMgbmV3KHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogUnVubmVySW1hZ2VCdWlsZGVyUHJvcHMpOiBJQ29uZmlndXJhYmxlUnVubmVySW1hZ2VCdWlsZGVyIHtcbiAgICBpZiAocHJvcHM/LmNvbXBvbmVudHMgJiYgcHJvcHMucnVubmVyVmVyc2lvbikge1xuICAgICAgQW5ub3RhdGlvbnMub2Yoc2NvcGUpLmFkZFdhcm5pbmcoJ3J1bm5lclZlcnNpb24gaXMgaWdub3JlZCB3aGVuIGNvbXBvbmVudHMgYXJlIHNwZWNpZmllZC4gVGhlIHJ1bm5lciB2ZXJzaW9uIHdpbGwgYmUgZGV0ZXJtaW5lZCBieSB0aGUgY29tcG9uZW50cy4nKTtcbiAgICB9XG5cbiAgICBpZiAocHJvcHM/LmJ1aWxkZXJUeXBlID09PSBSdW5uZXJJbWFnZUJ1aWxkZXJUeXBlLkNPREVfQlVJTEQpIHtcbiAgICAgIHJldHVybiBuZXcgQ29kZUJ1aWxkUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSBpZiAocHJvcHM/LmJ1aWxkZXJUeXBlID09PSBSdW5uZXJJbWFnZUJ1aWxkZXJUeXBlLkFXU19JTUFHRV9CVUlMREVSKSB7XG4gICAgICByZXR1cm4gbmV3IEF3c0ltYWdlQnVpbGRlclJ1bm5lckltYWdlQnVpbGRlcihzY29wZSwgaWQsIHByb3BzKTtcbiAgICB9XG5cbiAgICBjb25zdCBvcyA9IHByb3BzPy5vcyA/PyBPcy5MSU5VWF9VQlVOVFU7XG4gICAgaWYgKG9zLmlzSW4oT3MuX0FMTF9MSU5VWF9WRVJTSU9OUykpIHtcbiAgICAgIHJldHVybiBuZXcgQ29kZUJ1aWxkUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSBpZiAob3MuaXMoT3MuV0lORE9XUykpIHtcbiAgICAgIHJldHVybiBuZXcgQXdzSW1hZ2VCdWlsZGVyUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVuYWJsZSB0byBmaW5kIHJ1bm5lciBpbWFnZSBidWlsZGVyIGltcGxlbWVudGF0aW9uIGZvciAke29zLm5hbWV9YCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -108,7 +108,7 @@ class BaseImage {
108
108
  }
109
109
  exports.BaseImage = BaseImage;
110
110
  _a = JSII_RTTI_SYMBOL_1;
111
- BaseImage[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.BaseImage", version: "0.15.0" };
111
+ BaseImage[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.BaseImage", version: "0.15.1" };
112
112
  /**
113
113
  * Represents a base container image that is used to start from in EC2 Image Builder container builds.
114
114
  *
@@ -159,5 +159,5 @@ class BaseContainerImage {
159
159
  }
160
160
  exports.BaseContainerImage = BaseContainerImage;
161
161
  _b = JSII_RTTI_SYMBOL_1;
162
- BaseContainerImage[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.BaseContainerImage", version: "0.15.0" };
162
+ BaseContainerImage[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.BaseContainerImage", version: "0.15.1" };
163
163
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-image.js","sourceRoot":"","sources":["../../../src/image-builders/aws-image-builder/base-image.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport * as ecr from 'aws-cdk-lib/aws-ecr';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\nimport { Architecture, Os } from '../../providers';\n\n/**\n * Type that can be used to specify a base image - either a string (deprecated) or a BaseImage object.\n *\n * To create a BaseImage object, use the static factory methods like BaseImage.fromAmiId().\n *\n * Note: String support is deprecated and will be removed in a future version. Use BaseImage static factory methods instead.\n */\nexport type BaseImageInput = string | BaseImage;\n\n/**\n * Represents a base image that is used to start from in EC2 Image Builder image builds.\n *\n * This class is adapted from AWS CDK's BaseImage class to support both string and object inputs.\n */\nexport class BaseImage {\n  /**\n   * The AMI ID to use as a base image in an image recipe\n   *\n   * @param amiId The AMI ID to use as the base image\n   */\n  public static fromAmiId(amiId: string): BaseImage {\n    return new BaseImage(amiId);\n  }\n\n  /**\n   * An AWS-provided EC2 Image Builder image to use as a base image in an image recipe.\n   *\n   * This constructs an Image Builder ARN for AWS-provided images like `ubuntu-server-22-lts-x86/x.x.x`.\n   *\n   * @param scope The construct scope (used to determine the stack and region)\n   * @param resourceName The Image Builder resource name pattern (e.g., `ubuntu-server-22-lts-x86` or `ubuntu-server-22-lts-${arch}`)\n   * @param version The version pattern (defaults to `x.x.x` to use the latest version)\n   */\n  public static fromImageBuilder(scope: Construct, resourceName: string, version: string = 'x.x.x'): BaseImage {\n    const stack = cdk.Stack.of(scope);\n    return new BaseImage(stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `${resourceName}/${version}`,\n    }));\n  }\n\n  /**\n   * The marketplace product ID for an AMI product to use as the base image in an image recipe\n   *\n   * @param productId The Marketplace AMI product ID to use as the base image\n   */\n  public static fromMarketplaceProductId(productId: string): BaseImage {\n    return new BaseImage(productId);\n  }\n\n  /**\n   * The SSM parameter to use as the base image in an image recipe\n   *\n   * @param parameter The SSM parameter to use as the base image\n   */\n  public static fromSsmParameter(parameter: ssm.IParameter): BaseImage {\n    return new BaseImage(`ssm:${parameter.parameterArn}`);\n  }\n\n  /**\n   * The parameter name for the SSM parameter to use as the base image in an image recipe\n   *\n   * @param parameterName The name of the SSM parameter to use as the base image\n   */\n  public static fromSsmParameterName(parameterName: string): BaseImage {\n    return new BaseImage(`ssm:${parameterName}`);\n  }\n\n  /**\n   * The direct string value of the base image to use in an image recipe. This can be an EC2 Image Builder image ARN,\n   * an SSM parameter, an AWS Marketplace product ID, or an AMI ID.\n   *\n   * @param baseImageString The base image as a direct string value\n   */\n  public static fromString(baseImageString: string): BaseImage {\n    return new BaseImage(baseImageString);\n  }\n\n  /**\n   * A base AMI with NVIDIA drivers pre-installed for GPU workloads.\n   *\n   * Uses AWS Deep Learning AMIs for Linux (Ubuntu, Amazon Linux 2, Amazon Linux 2023).\n   * For Windows, subscribe to NVIDIA RTX Virtual Workstation in AWS Marketplace, then use\n   * {@link fromMarketplaceProductId} with the product ID.\n   *\n   * @param os Target operating system\n   * @param architecture Target architecture\n   * @throws Error if the OS/architecture combo has no GPU base AMI\n   */\n  public static fromGpuBase(os: Os, architecture: Architecture): BaseImage {\n    const arch = architecture.is(Architecture.X86_64) ? 'x86_64' : 'arm64';\n\n    if (os.is(Os.LINUX_UBUNTU) || os.is(Os.LINUX_UBUNTU_2204) || os.is(Os.LINUX)) {\n      return BaseImage.fromSsmParameterName(`/aws/service/deeplearning/ami/${arch}/base-oss-nvidia-driver-gpu-ubuntu-22.04/latest/ami-id`);\n    }\n    if (os.is(Os.LINUX_UBUNTU_2404)) {\n      return BaseImage.fromSsmParameterName(`/aws/service/deeplearning/ami/${arch}/base-oss-nvidia-driver-gpu-ubuntu-24.04/latest/ami-id`);\n    }\n    if (os.is(Os.LINUX_AMAZON_2)) {\n      return BaseImage.fromSsmParameterName(`/aws/service/deeplearning/ami/${arch}/base-oss-nvidia-driver-amazon-linux-2/latest/ami-id`);\n    }\n    if (os.is(Os.LINUX_AMAZON_2023)) {\n      return BaseImage.fromSsmParameterName(`/aws/service/deeplearning/ami/${arch}/base-oss-nvidia-driver-gpu-amazon-linux-2023/latest/ami-id`);\n    }\n    if (os.is(Os.WINDOWS) && architecture.is(Architecture.X86_64)) {\n      throw new Error(\n        'No GPU base AMI for Windows. Subscribe to NVIDIA RTX Virtual Workstation (WinServer 2022) at ' +\n        'https://aws.amazon.com/marketplace/pp/prodview-f4reygwmtxipu (free), then use ' +\n        \"`baseAmi: BaseImage.fromMarketplaceProductId('prod-77u2eeb33lmrm')` (other AMIs with NVIDIA drivers installed can also be used).\",\n      );\n    }\n\n    throw new Error(\n      `No GPU base AMI for ${os.name} / ${architecture.name}.`,\n    );\n  }\n\n  /**\n   * The rendered base image to use\n   */\n  public readonly image: string;\n\n  protected constructor(image: string) {\n    this.image = image;\n  }\n}\n\n/**\n * Type that can be used to specify a base container image - either a string (deprecated) or a BaseContainerImage object.\n *\n * To create a BaseContainerImage object, use the static factory methods like BaseContainerImage.fromEcr().\n *\n * Note: String support is deprecated and will be removed in a future version. Use BaseContainerImage static factory methods instead.\n */\nexport type BaseContainerImageInput = string | BaseContainerImage;\n\n/**\n * Represents a base container image that is used to start from in EC2 Image Builder container builds.\n *\n * This class is adapted from AWS CDK's BaseContainerImage class to support both string and object inputs.\n */\nexport class BaseContainerImage {\n  /**\n   * The DockerHub image to use as the base image in a container recipe\n   *\n   * @param repository The DockerHub repository where the base image resides in\n   * @param tag The tag of the base image in the DockerHub repository\n   */\n  public static fromDockerHub(repository: string, tag: string): BaseContainerImage {\n    return new BaseContainerImage(`${repository}:${tag}`);\n  }\n\n  /**\n   * The ECR container image to use as the base image in a container recipe\n   *\n   * @param repository The ECR repository where the base image resides in\n   * @param tag The tag of the base image in the ECR repository\n   */\n  public static fromEcr(repository: ecr.IRepository, tag: string): BaseContainerImage {\n    return new BaseContainerImage(repository.repositoryUriForTag(tag), repository);\n  }\n\n  /**\n   * The ECR public container image to use as the base image in a container recipe\n   *\n   * @param registryAlias The alias of the ECR public registry where the base image resides in\n   * @param repositoryName The name of the ECR public repository, where the base image resides in\n   * @param tag The tag of the base image in the ECR public repository\n   */\n  public static fromEcrPublic(registryAlias: string, repositoryName: string, tag: string): BaseContainerImage {\n    return new BaseContainerImage(`public.ecr.aws/${registryAlias}/${repositoryName}:${tag}`);\n  }\n\n  /**\n   * The string value of the base image to use in a container recipe. This can be an EC2 Image Builder image ARN,\n   * an ECR or ECR public image, or a container URI sourced from a third-party container registry such as DockerHub.\n   *\n   * @param baseContainerImageString The base image as a direct string value\n   */\n  public static fromString(baseContainerImageString: string): BaseContainerImage {\n    return new BaseContainerImage(baseContainerImageString);\n  }\n\n  /**\n   * The rendered base image to use\n   */\n  public readonly image: string;\n\n  /**\n   * The ECR repository if this image was created from an ECR repository.\n   * This allows automatic permission granting for CodeBuild.\n   */\n  public readonly ecrRepository?: ecr.IRepository;\n\n  protected constructor(image: string, ecrRepository?: ecr.IRepository) {\n    this.image = image;\n    this.ecrRepository = ecrRepository;\n  }\n}\n"]}
@@ -149,7 +149,7 @@ class ImageBuilderComponent extends cdk.Resource {
149
149
  }
150
150
  exports.ImageBuilderComponent = ImageBuilderComponent;
151
151
  _a = JSII_RTTI_SYMBOL_1;
152
- ImageBuilderComponent[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.ImageBuilderComponent", version: "0.15.0" };
152
+ ImageBuilderComponent[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.ImageBuilderComponent", version: "0.15.1" };
153
153
  /**
154
154
  * @internal
155
155
  */
@@ -217,5 +217,5 @@ class AmiBuilder extends common_1.ImageBuilderBase {
217
217
  }
218
218
  exports.AmiBuilder = AmiBuilder;
219
219
  _a = JSII_RTTI_SYMBOL_1;
220
- AmiBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.AmiBuilder", version: "0.15.0" };
220
+ AmiBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.AmiBuilder", version: "0.15.1" };
221
221
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ami.js","sourceRoot":"","sources":["../../../../src/image-builders/aws-image-builder/deprecated/ami.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { aws_ec2 as ec2, aws_iam as iam, aws_imagebuilder as imagebuilder, aws_logs as logs, Duration, RemovalPolicy, Stack } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ImageBuilderBase } from './common';\nimport { LinuxUbuntuComponents } from './linux-components';\nimport { WindowsComponents } from './windows-components';\nimport { Architecture, Os, RunnerAmi, RunnerImage, RunnerVersion } from '../../../providers';\nimport { singletonLambda } from '../../../utils';\nimport { uniqueImageBuilderName } from '../../common';\nimport { AmiRecipe, defaultBaseAmi } from '../ami';\nimport { ImageBuilderComponent } from '../builder';\nimport { DeleteResourcesFunction } from '../delete-resources-function';\n\n/**\n * Properties for {@link AmiBuilder} construct.\n */\nexport interface AmiBuilderProps {\n  /**\n   * Image architecture.\n   *\n   * @default Architecture.X86_64\n   */\n  readonly architecture?: Architecture;\n\n  /**\n   * Image OS.\n   *\n   * @default OS.LINUX\n   */\n  readonly os?: Os;\n\n  /**\n   * Version of GitHub Runners to install.\n   *\n   * @default latest version available\n   */\n  readonly runnerVersion?: RunnerVersion;\n\n  /**\n   * Schedule the AMI to be rebuilt every given interval. Useful for keeping the AMI up-do-date with the latest GitHub runner version and latest OS updates.\n   *\n   * Set to zero to disable.\n   *\n   * @default Duration.days(7)\n   */\n  readonly rebuildInterval?: Duration;\n\n  /**\n   * VPC where builder instances will be launched.\n   *\n   * @default default account VPC\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * Security group to assign to launched builder instances.\n   *\n   * @default new security group\n   *\n   * @deprecated use {@link securityGroups}\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Security groups to assign to launched builder instances.\n   *\n   * @default new security group\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * Where to place the network interfaces within the VPC. Only the first matched subnet will be used.\n   *\n   * @default default VPC subnet\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * The instance type used to build the image.\n   *\n   * @default m6i.large\n   */\n  readonly instanceType?: ec2.InstanceType;\n\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   * Removal policy for logs of image builds. If deployment fails on the custom resource, try setting this to `RemovalPolicy.RETAIN`. This way the logs can still be viewed, and you can see why the build failed.\n   *\n   * We try to not leave anything behind when removed. But sometimes a log staying behind is useful.\n   *\n   * @default RemovalPolicy.DESTROY\n   */\n  readonly logRemovalPolicy?: RemovalPolicy;\n\n  /**\n   * Install Docker inside the image, so it can be used by the runner.\n   *\n   * @default true\n   */\n  readonly installDocker?: boolean;\n}\n\n/**\n * An AMI builder that uses AWS Image Builder to build AMIs pre-baked with all the GitHub Actions runner requirements. Builders can be used with {@link Ec2RunnerProvider}.\n *\n * Each builder re-runs automatically at a set interval to make sure the AMIs contain the latest versions of everything.\n *\n * You can create an instance of this construct to customize the AMI used to spin-up runners. Some runner providers may require custom components. Check the runner provider documentation.\n *\n * For example, to set a specific runner version, rebuild the image every 2 weeks, and add a few packages for the EC2 provider, use:\n *\n * ```\n * const builder = new AmiBuilder(this, 'Builder', {\n *     runnerVersion: RunnerVersion.specific('2.293.0'),\n *     rebuildInterval: Duration.days(14),\n * });\n * builder.addComponent(new ImageBuilderComponent(scope, id, {\n *   platform: 'Linux',\n *   displayName: 'p7zip',\n *   description: 'Install some more packages',\n *   commands: [\n *     'apt-get install p7zip',\n *   ],\n * }));\n * new Ec2RunnerProvider(this, 'EC2 provider', {\n *     labels: ['custom-ec2'],\n *     amiBuilder: builder,\n * });\n * ```\n *\n * @deprecated use RunnerImageBuilder, e.g. with Ec2RunnerProvider.imageBuilder()\n */\nexport class AmiBuilder extends ImageBuilderBase {\n  private boundAmi?: RunnerAmi;\n\n  constructor(scope: Construct, id: string, props?: AmiBuilderProps) {\n    super(scope, id, {\n      os: props?.os,\n      supportedOs: [Os.LINUX, Os.LINUX_UBUNTU, Os.LINUX_UBUNTU_2204, Os.LINUX_AMAZON_2, Os.WINDOWS],\n      architecture: props?.architecture,\n      supportedArchitectures: [Architecture.X86_64, Architecture.ARM64],\n      instanceType: props?.instanceType,\n      vpc: props?.vpc,\n      securityGroups: props?.securityGroup ? [props.securityGroup] : props?.securityGroups,\n      subnetSelection: props?.subnetSelection,\n      logRemovalPolicy: props?.logRemovalPolicy,\n      logRetention: props?.logRetention,\n      runnerVersion: props?.runnerVersion,\n      rebuildInterval: props?.rebuildInterval,\n      imageTypeName: 'AMI',\n    });\n\n    // add all basic components\n    if (this.os.is(Os.WINDOWS)) {\n      this.addBaseWindowsComponents(props?.installDocker ?? true);\n    } else if (this.os.is(Os.LINUX) || this.os.is(Os.LINUX_UBUNTU_2204)) {\n      this.addBaseLinuxComponents(props?.installDocker ?? true);\n    } else {\n      throw new Error(`Unsupported OS for AMI builder: ${this.os.name}`);\n    }\n  }\n\n  private addBaseWindowsComponents(installDocker: boolean) {\n    this.addComponent(WindowsComponents.cloudwatchAgent(this, 'CloudWatch agent'));\n    this.addComponent(WindowsComponents.awsCli(this, 'AWS CLI'));\n    this.addComponent(WindowsComponents.githubCli(this, 'GitHub CLI'));\n    this.addComponent(WindowsComponents.git(this, 'git'));\n    this.addComponent(WindowsComponents.githubRunner(this, 'GitHub Actions Runner', this.runnerVersion));\n    if (installDocker) {\n      this.addComponent(WindowsComponents.docker(this, 'Docker'));\n    }\n  }\n\n  private addBaseLinuxComponents(installDocker: boolean) {\n    this.addComponent(LinuxUbuntuComponents.requiredPackages(this, 'Upgrade packages and install basics', this.architecture));\n    this.addComponent(LinuxUbuntuComponents.runnerUser(this, 'User', this.architecture));\n    this.addComponent(LinuxUbuntuComponents.awsCli(this, 'AWS CLI', this.architecture));\n    this.addComponent(LinuxUbuntuComponents.githubCli(this, 'GitHub CLI', this.architecture));\n    this.addComponent(LinuxUbuntuComponents.git(this, 'git', this.architecture));\n    this.addComponent(LinuxUbuntuComponents.githubRunner(this, 'GitHub Actions Runner', this.runnerVersion, this.architecture));\n    if (installDocker) {\n      this.addComponent(LinuxUbuntuComponents.docker(this, 'Docker', this.architecture));\n    }\n  }\n\n  /**\n   * Add a component to be installed before any other components. Useful for required system settings like certificates or proxy settings.\n   * @param component\n   */\n  prependComponent(component: ImageBuilderComponent) {\n    if (this.boundAmi) {\n      throw new Error('AMI is already bound. Use this method before passing the builder to a runner provider.');\n    }\n    if (component.platform != this.platform) {\n      throw new Error('Component platform doesn\\'t match builder platform');\n    }\n    this.components = [component].concat(this.components);\n  }\n\n  /**\n   * Add a component to be installed.\n   * @param component\n   */\n  addComponent(component: ImageBuilderComponent) {\n    if (this.boundAmi) {\n      throw new Error('AMI is already bound. Use this method before passing the builder to a runner provider.');\n    }\n    if (component.platform != this.platform) {\n      throw new Error('Component platform doesn\\'t match builder platform');\n    }\n    this.components.push(component);\n  }\n\n  /**\n   * Add extra trusted certificates. This helps deal with self-signed certificates for GitHub Enterprise Server.\n   *\n   * @param path path to directory containing a file called certs.pem containing all the required certificates\n   */\n  public addExtraCertificates(path: string) {\n    if (this.platform == 'Linux') {\n      this.prependComponent(LinuxUbuntuComponents.extraCertificates(this, 'Extra Certs', path));\n    } else if (this.platform == 'Windows') {\n      this.prependComponent(WindowsComponents.extraCertificates(this, 'Extra Certs', path));\n    } else {\n      throw new Error(`Unknown platform: ${this.platform}`);\n    }\n  }\n\n  /**\n   * Called by IRunnerProvider to finalize settings and create the AMI builder.\n   */\n  bindAmi(): RunnerAmi {\n    if (this.boundAmi) {\n      return this.boundAmi;\n    }\n\n    const launchTemplate = new ec2.LaunchTemplate(this, 'Launch template', {\n      requireImdsv2: true,\n    });\n\n    const stackName = cdk.Stack.of(this).stackName;\n    const builderName = this.node.path;\n\n    const dist = new imagebuilder.CfnDistributionConfiguration(this, 'Distribution', {\n      name: uniqueImageBuilderName(this),\n      description: this.description,\n      distributions: [\n        {\n          region: Stack.of(this).region,\n          amiDistributionConfiguration: {\n            Name: `${cdk.Names.uniqueResourceName(this, {\n              maxLength: 100,\n              separator: '-',\n              allowedSpecialCharacters: '_-',\n            })}-{{ imagebuilder:buildDate }}`,\n            AmiTags: {\n              'Name': this.node.id,\n              'GitHubRunners:Stack': stackName,\n              'GitHubRunners:Builder': builderName,\n            },\n          },\n          launchTemplateConfigurations: [\n            {\n              launchTemplateId: launchTemplate.launchTemplateId,\n            },\n          ],\n        },\n      ],\n    });\n\n    const recipe = new AmiRecipe(this, 'Ami Recipe', {\n      platform: this.platform,\n      components: this.components,\n      architecture: this.architecture,\n      baseAmi: defaultBaseAmi(this, this.os, this.architecture),\n      tags: {\n        'GitHubRunners:Stack': stackName,\n        'GitHubRunners:Builder': builderName,\n      },\n    });\n\n    const log = this.createLog(recipe.name);\n    const infra = this.createInfrastructure([\n      iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n      iam.ManagedPolicy.fromAwsManagedPolicyName('EC2InstanceProfileForImageBuilder'),\n    ]);\n    this.createImage(infra, dist, log, recipe.arn, undefined);\n    this.createPipeline(infra, dist, log, recipe.arn, undefined);\n\n    this.boundAmi = {\n      launchTemplate: launchTemplate,\n      architecture: this.architecture,\n      os: this.os,\n      logGroup: log,\n      runnerVersion: this.runnerVersion,\n    };\n\n    this.imageCleaner();\n\n    return this.boundAmi;\n  }\n\n  private imageCleaner() {\n    // the lambda no longer implements the schedule feature\n    // this hasn't worked since https://github.com/CloudSnorkel/cdk-github-runners/pull/476\n    cdk.Annotations.of(this).addWarning('The AMI cleaner for this deprecated class has been broken since v0.12.0 (PR #476) and will not delete any AMIs. Please manually delete old AMIs and upgrade to e.g. Ec2RunnerProvider.imageBuilder() instead of AmiBuilder.');\n\n    // we keep the lambda itself around, in case the user doesn't have any other instances of it\n    // if there are no other instances of it, the custom resource will be deleted with the original lambda source code which may delete the AMIs on its way out\n    singletonLambda(DeleteResourcesFunction, this, 'delete-ami', {\n      description: 'Delete old GitHub Runner AMIs (defunct)',\n      timeout: cdk.Duration.minutes(5),\n      logRetention: logs.RetentionDays.ONE_MONTH,\n    });\n  }\n\n  bindDockerImage(): RunnerImage {\n    throw new Error('AmiBuilder cannot be used to build Docker images');\n  }\n}\n"]}
@@ -194,5 +194,5 @@ class ContainerImageBuilder extends common_1.ImageBuilderBase {
194
194
  }
195
195
  exports.ContainerImageBuilder = ContainerImageBuilder;
196
196
  _a = JSII_RTTI_SYMBOL_1;
197
- ContainerImageBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.ContainerImageBuilder", version: "0.15.0" };
197
+ ContainerImageBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.ContainerImageBuilder", version: "0.15.1" };
198
198
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.js","sourceRoot":"","sources":["../../../../src/image-builders/aws-image-builder/deprecated/container.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport {\n  aws_ec2 as ec2,\n  aws_ecr as ecr,\n  aws_iam as iam,\n  aws_imagebuilder as imagebuilder,\n  aws_logs as logs,\n  Duration,\n  RemovalPolicy,\n  Stack,\n} from 'aws-cdk-lib';\nimport { TagMutability, TagStatus } from 'aws-cdk-lib/aws-ecr';\nimport { Construct } from 'constructs';\nimport { ImageBuilderBase } from './common';\nimport { LinuxUbuntuComponents } from './linux-components';\nimport { WindowsComponents } from './windows-components';\nimport { Architecture, Os, RunnerAmi, RunnerImage, RunnerVersion } from '../../../providers';\nimport { singletonLambda } from '../../../utils';\nimport { BuildImageFunction } from '../../build-image-function';\nimport { uniqueImageBuilderName } from '../../common';\nimport { ImageBuilderComponent } from '../builder';\nimport { ContainerRecipe } from '../container';\n\nconst dockerfileTemplate = `FROM {{{ imagebuilder:parentImage }}}\nENV RUNNER_VERSION=___RUNNER_VERSION___\n{{{ imagebuilder:environments }}}\n{{{ imagebuilder:components }}}`;\n\n/**\n * Properties for ContainerImageBuilder construct.\n */\nexport interface ContainerImageBuilderProps {\n  /**\n   * Image architecture.\n   *\n   * @default Architecture.X86_64\n   */\n  readonly architecture?: Architecture;\n\n  /**\n   * Image OS.\n   *\n   * @default OS.LINUX\n   */\n  readonly os?: Os;\n\n  /**\n   * Parent image for the new Docker Image. You can use either Image Builder image ARN or public registry image.\n   *\n   * @default 'mcr.microsoft.com/windows/servercore:ltsc2019-amd64'\n   */\n  readonly parentImage?: string;\n\n  /**\n   * Version of GitHub Runners to install.\n   *\n   * @default latest version available\n   */\n  readonly runnerVersion?: RunnerVersion;\n\n  /**\n   * 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.\n   *\n   * Set to zero to disable.\n   *\n   * @default Duration.days(7)\n   */\n  readonly rebuildInterval?: Duration;\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 launched builder instances.\n   *\n   * @default new security group\n   *\n   * @deprecated use {@link securityGroups}\n   */\n  readonly securityGroup?: ec2.ISecurityGroup;\n\n  /**\n   * Security groups to assign to launched builder instances.\n   *\n   * @default new security group\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * @default default VPC subnet\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * The instance type used to build the image.\n   *\n   * @default m6i.large\n   */\n  readonly instanceType?: ec2.InstanceType;\n\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   * 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.\n   *\n   * We try to not leave anything behind when removed. But sometimes a log staying behind is useful.\n   *\n   * @default RemovalPolicy.DESTROY\n   */\n  readonly logRemovalPolicy?: RemovalPolicy;\n}\n\n/**\n * An image builder that uses AWS Image Builder to build Docker images pre-baked with all the GitHub Actions runner requirements. Builders can be used with runner providers.\n *\n * The CodeBuild builder is better and faster. Only use this one if you have no choice. For example, if you need Windows containers.\n *\n * Each builder re-runs automatically at a set interval to make sure the images contain the latest versions of everything.\n *\n * You can create an instance of this construct to customize the image used to spin-up runners. Some runner providers may require custom components. Check the runner provider documentation. The default components work with CodeBuild and Fargate.\n *\n * For example, to set a specific runner version, rebuild the image every 2 weeks, and add a few packages for the Fargate provider, use:\n *\n * ```\n * const builder = new ContainerImageBuilder(this, 'Builder', {\n *     runnerVersion: RunnerVersion.specific('2.293.0'),\n *     rebuildInterval: Duration.days(14),\n * });\n * new CodeBuildRunnerProvider(this, 'CodeBuild provider', {\n *     labels: ['custom-codebuild'],\n *     imageBuilder: builder,\n * });\n * ```\n *\n * @deprecated use RunnerImageBuilder\n */\nexport class ContainerImageBuilder extends ImageBuilderBase {\n  readonly repository: ecr.IRepository;\n  private readonly parentImage: string;\n  private boundImage?: RunnerImage;\n\n  constructor(scope: Construct, id: string, props?: ContainerImageBuilderProps) {\n    super(scope, id, {\n      os: props?.os,\n      supportedOs: [Os.WINDOWS],\n      architecture: props?.architecture,\n      supportedArchitectures: [Architecture.X86_64],\n      instanceType: props?.instanceType,\n      vpc: props?.vpc,\n      securityGroups: props?.securityGroup ? [props.securityGroup] : props?.securityGroups,\n      subnetSelection: props?.subnetSelection,\n      logRemovalPolicy: props?.logRemovalPolicy,\n      logRetention: props?.logRetention,\n      runnerVersion: props?.runnerVersion,\n      rebuildInterval: props?.rebuildInterval,\n      imageTypeName: 'image',\n    });\n\n    this.parentImage = props?.parentImage ?? 'mcr.microsoft.com/windows/servercore:ltsc2019-amd64';\n\n    // create repository that only keeps one tag\n    this.repository = new ecr.Repository(this, 'Repository', {\n      imageScanOnPush: true,\n      imageTagMutability: TagMutability.MUTABLE,\n      removalPolicy: RemovalPolicy.DESTROY,\n      emptyOnDelete: true,\n      lifecycleRules: [\n        {\n          description: 'Remove all but the latest image',\n          tagStatus: TagStatus.ANY,\n          maxImageCount: 1,\n        },\n      ],\n    });\n\n    // add all basic components\n    this.addBaseWindowsComponents();\n  }\n\n  private addBaseWindowsComponents() {\n    this.addComponent(WindowsComponents.awsCli(this, 'AWS CLI'));\n    this.addComponent(WindowsComponents.githubCli(this, 'GitHub CLI'));\n    this.addComponent(WindowsComponents.git(this, 'git'));\n    this.addComponent(WindowsComponents.githubRunner(this, 'GitHub Actions Runner', this.runnerVersion));\n  }\n\n  /**\n   * Add a component to be installed before any other components. Useful for required system settings like certificates or proxy settings.\n   * @param component\n   */\n  prependComponent(component: ImageBuilderComponent) {\n    if (this.boundImage) {\n      throw new Error('Image is already bound. Use this method before passing the builder to a runner provider.');\n    }\n    if (component.platform != this.platform) {\n      throw new Error('Component platform doesn\\'t match builder platform');\n    }\n    this.components = [component].concat(this.components);\n  }\n\n  /**\n   * Add a component to be installed.\n   * @param component\n   */\n  addComponent(component: ImageBuilderComponent) {\n    if (this.boundImage) {\n      throw new Error('Image is already bound. Use this method before passing the builder to a runner provider.');\n    }\n    if (component.platform != this.platform) {\n      throw new Error('Component platform doesn\\'t match builder platform');\n    }\n    this.components.push(component);\n  }\n\n  /**\n   * Add extra trusted certificates. This helps deal with self-signed certificates for GitHub Enterprise Server.\n   *\n   * All first party Dockerfiles support this. Others may not.\n   *\n   * @param path path to directory containing a file called certs.pem containing all the required certificates\n   */\n  public addExtraCertificates(path: string) {\n    if (this.platform == 'Linux') {\n      this.prependComponent(LinuxUbuntuComponents.extraCertificates(this, 'Extra Certs', path));\n    } else if (this.platform == 'Windows') {\n      this.prependComponent(WindowsComponents.extraCertificates(this, 'Extra Certs', path));\n    } else {\n      throw new Error(`Unknown platform: ${this.platform}`);\n    }\n  }\n\n  /**\n   * Called by IRunnerProvider to finalize settings and create the image builder.\n   */\n  bindDockerImage(): RunnerImage {\n    if (this.boundImage) {\n      return this.boundImage;\n    }\n\n    const dist = new imagebuilder.CfnDistributionConfiguration(this, 'Distribution', {\n      name: uniqueImageBuilderName(this),\n      description: this.description,\n      distributions: [\n        {\n          region: Stack.of(this).region,\n          containerDistributionConfiguration: {\n            ContainerTags: ['latest'],\n            TargetRepository: {\n              Service: 'ECR',\n              RepositoryName: this.repository.repositoryName,\n            },\n          },\n        },\n      ],\n    });\n\n    const recipe = new ContainerRecipe(this, 'Container Recipe', {\n      platform: this.platform,\n      components: this.components,\n      targetRepository: this.repository,\n      dockerfileTemplate: dockerfileTemplate.replace('___RUNNER_VERSION___', this.runnerVersion.version),\n      parentImage: this.parentImage,\n      tags: {},\n    });\n\n    const log = this.createLog(recipe.name);\n    const infra = this.createInfrastructure([\n      iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonSSMManagedInstanceCore'),\n      iam.ManagedPolicy.fromAwsManagedPolicyName('EC2InstanceProfileForImageBuilderECRContainerBuilds'),\n    ]);\n    this.createImage(infra, dist, log, undefined, recipe.arn);\n    this.createPipeline(infra, dist, log, undefined, recipe.arn);\n\n    this.imageCleaner();\n\n    this.boundImage = {\n      imageRepository: this.repository,\n      imageTag: 'latest',\n      os: this.os,\n      architecture: this.architecture,\n      logGroup: log,\n      runnerVersion: this.runnerVersion,\n      // no dependable as CloudFormation will fail to get image ARN once the image is deleted (we delete old images daily)\n    };\n\n    return this.boundImage;\n  }\n\n  private imageCleaner() {\n    // cleaning up in the image builder was always ugly... time to get rid of it\n    cdk.Annotations.of(this).addWarning('The image cleaner for this deprecated class has been disabled. Some EC2 Image Builder resources may be left behind once you remove this construct. You can manually delete them from the AWS Management Console.');\n\n    // we keep the lambda itself around, in case the user doesn't have any other instances of it\n    // if there are no other instances of it, the custom resource will be deleted with the original lambda source code which may delete the images on its way out\n    singletonLambda(BuildImageFunction, this, 'build-image', {\n      description: 'Custom resource handler that triggers CodeBuild to build runner images',\n      timeout: cdk.Duration.minutes(3),\n      logRetention: logs.RetentionDays.ONE_MONTH,\n    });\n  }\n\n  bindAmi(): RunnerAmi {\n    throw new Error('ContainerImageBuilder cannot be used to build AMIs');\n  }\n}\n"]}
@@ -167,5 +167,5 @@ class LinuxUbuntuComponents {
167
167
  }
168
168
  exports.LinuxUbuntuComponents = LinuxUbuntuComponents;
169
169
  _a = JSII_RTTI_SYMBOL_1;
170
- LinuxUbuntuComponents[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LinuxUbuntuComponents", version: "0.15.0" };
170
+ LinuxUbuntuComponents[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LinuxUbuntuComponents", version: "0.15.1" };
171
171
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"linux-components.js","sourceRoot":"","sources":["../../../../src/image-builders/aws-image-builder/deprecated/linux-components.ts"],"names":[],"mappings":";;;;;AAAA,6CAAyD;AAEzD,kDAAiE;AACjE,oCAAiD;AAEjD;;;;GAIG;AACH,MAAa,qBAAqB;IACzB,MAAM,CAAC,gBAAgB,CAAC,KAAgB,EAAE,EAAU,EAAE,YAA0B;QACrF,IAAI,OAAO,CAAC;QACZ,IAAI,YAAY,CAAC,EAAE,CAAC,wBAAY,CAAC,MAAM,CAAC,EAAE,CAAC;YACzC,OAAO,GAAG,OAAO,CAAC;QACpB,CAAC;aAAM,IAAI,YAAY,CAAC,EAAE,CAAC,wBAAY,CAAC,KAAK,CAAC,EAAE,CAAC;YAC/C,OAAO,GAAG,OAAO,CAAC;QACpB,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,mDAAmD,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC;QAC1F,CAAC;QAED,OAAO,IAAI,6BAAqB,CAAC,KAAK,EAAE,EAAE,EAAE;YAC1C,QAAQ,EAAE,OAAO;YACjB,WAAW,EAAE,mBAAmB;YAChC,WAAW,EAAE,sEAAsE;YACnF,QAAQ,EAAE;gBACR,gBAAgB;gBAChB,mDAAmD;gBACnD,mIAAmI;gBACnI,sGAAsG,OAAO,qCAAqC;gBAClJ,6CAA6C;gBAC7C,qCAAqC;aACtC;SACF,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,UAAU,CAAC,KAAgB,EAAE,EAAU,EAAE,aAA2B;QAChF,OAAO,IAAI,6BAAqB,CAAC,KAAK,EAAE,EAAE,EAAE;YAC1C,QAAQ,EAAE,OAAO;YACjB,WAAW,EAAE,oBAAoB;YACjC,WAAW,EAAE,mCAAmC;YAChD,QAAQ,EAAE;gBACR,iBAAiB;gBACjB,kFAAkF;gBAClF,sEAAsE;aACvE;SACF,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,MAAM,CAAC,KAAgB,EAAE,EAAU,EAAE,YAA0B;QAC3E,IAAI,OAAO,CAAC;QACZ,IAAI,YAAY,CAAC,EAAE,CAAC,wBAAY,CAAC,MAAM,CAAC,EAAE,CAAC;YACzC,OAAO,GAAG,QAAQ,CAAC;QACrB,CAAC;aAAM,IAAI,YAAY,CAAC,EAAE,CAAC,wBAAY,CAAC,KAAK,CAAC,EAAE,CAAC;YAC/C,OAAO,GAAG,SAAS,CAAC;QACtB,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,wCAAwC,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC;QAC/E,CAAC;QAED,OAAO,IAAI,6BAAqB,CAAC,KAAK,EAAE,EAAE,EAAE;YAC1C,QAAQ,EAAE,OAAO;YACjB,WAAW,EAAE,SAAS;YACtB,WAAW,EAAE,mCAAmC;YAChD,QAAQ,EAAE;gBACR,6DAA6D,OAAO,uBAAuB;gBAC3F,uBAAuB;gBACvB,eAAe;gBACf,yBAAyB;aAC1B;SACF,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,KAAgB,EAAE,EAAU,EAAE,aAA2B;QAC/E,OAAO,IAAI,6BAAqB,CAAC,KAAK,EAAE,EAAE,EAAE;YAC1C,QAAQ,EAAE,OAAO;YACjB,WAAW,EAAE,YAAY;YACzB,WAAW,EAAE,8BAA8B;YAC3C,QAAQ,EAAE;gBACR,yIAAyI;gBACzI,4GAA4G;oBAC5G,+GAA+G;gBAC/G,gBAAgB;gBAChB,sDAAsD;aACvD;SACF,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,GAAG,CAAC,KAAgB,EAAE,EAAU,EAAE,aAA2B;QACzE,OAAO,IAAI,6BAAqB,CAAC,KAAK,EAAE,EAAE,EAAE;YAC1C,QAAQ,EAAE,OAAO;YACjB,WAAW,EAAE,KAAK;YAClB,WAAW,EAAE,+BAA+B;YAC5C,QAAQ,EAAE;gBACR,qCAAqC;gBACrC,gBAAgB;gBAChB,uDAAuD;aACxD;SACF,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,YAAY,CAAC,KAAgB,EAAE,EAAU,EAAE,aAA4B,EAAE,YAA0B;QAC/G,IAAI,cAAsB,CAAC;QAC3B,IAAI,aAAa,CAAC,EAAE,CAAC,yBAAa,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC;YAC7C,cAAc,GAAG,wHAAwH,CAAC;QAC5I,CAAC;aAAM,CAAC;YACN,cAAc,GAAG,mBAAmB,aAAa,CAAC,OAAO,GAAG,CAAC;QAC/D,CAAC;QAED,IAAI,OAAO,CAAC;QACZ,IAAI,YAAY,CAAC,EAAE,CAAC,wBAAY,CAAC,MAAM,CAAC,EAAE,CAAC;YACzC,OAAO,GAAG,KAAK,CAAC;QAClB,CAAC;aAAM,IAAI,YAAY,CAAC,EAAE,CAAC,wBAAY,CAAC,KAAK,CAAC,EAAE,CAAC;YAC/C,OAAO,GAAG,OAAO,CAAC;QACpB,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,+CAA+C,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC;QACtF,CAAC;QAED,OAAO,IAAI,6BAAqB,CAAC,KAAK,EAAE,EAAE,EAAE;YAC1C,QAAQ,EAAE,OAAO;YACjB,WAAW,EAAE,uBAAuB;YACpC,WAAW,EAAE,iDAAiD;YAC9D,QAAQ,EAAE;gBACR,cAAc;gBACd,6GAA6G,OAAO,6BAA6B;gBACjJ,iCAAiC,OAAO,6BAA6B;gBACrE,2BAA2B,OAAO,4BAA4B;gBAC9D,8BAA8B;gBAC9B,WAAW,aAAa,CAAC,OAAO,mBAAmB;aACpD;SACF,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,MAAM,CAAC,KAAgB,EAAE,EAAU,EAAE,aAA2B;QAC5E,OAAO,IAAI,6BAAqB,CAAC,KAAK,EAAE,EAAE,EAAE;YAC1C,QAAQ,EAAE,OAAO;YACjB,WAAW,EAAE,QAAQ;YACrB,WAAW,EAAE,kCAAkC;YAC/C,QAAQ,EAAE;gBACR,gHAAgH;gBAChH,OAAO;oBACP,+HAA+H;oBAC/H,yFAAyF;gBACzF,gBAAgB;gBAChB,+GAA+G;gBAC/G,2BAA2B;gBAC3B,8EAA8E;aAC/E;SACF,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,iBAAiB,CAAC,KAAgB,EAAE,EAAU,EAAE,IAAY;QACxE,OAAO,IAAI,6BAAqB,CAAC,KAAK,EAAE,EAAE,EAAE;YAC1C,QAAQ,EAAE,OAAO;YACjB,WAAW,EAAE,oBAAoB;YACjC,WAAW,EAAE,gFAAgF;YAC7F,QAAQ,EAAE;gBACR,kFAAkF;gBAClF,wBAAwB;aACzB;YACD,MAAM,EAAE;gBACN;oBACE,IAAI,EAAE,OAAO;oBACb,KAAK,EAAE,IAAI,2BAAS,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,CAAC;iBAC3D;aACF;SACF,CAAC,CAAC;IACL,CAAC;;AA5JH,sDA6JC","sourcesContent":["import { aws_s3_assets as s3_assets } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { Architecture, RunnerVersion } from '../../../providers';\nimport { ImageBuilderComponent } from '../index';\n\n/**\n * Components for Ubuntu Linux that can be used with AWS Image Builder based builders. These cannot be used by {@link CodeBuildImageBuilder}.\n *\n * @deprecated Use `RunnerImageComponent` instead.\n */\nexport class LinuxUbuntuComponents {\n  public static requiredPackages(scope: Construct, id: string, architecture: Architecture) {\n    let archUrl;\n    if (architecture.is(Architecture.X86_64)) {\n      archUrl = 'amd64';\n    } else if (architecture.is(Architecture.ARM64)) {\n      archUrl = 'arm64';\n    } else {\n      throw new Error(`Unsupported architecture for required packages: ${architecture.name}`);\n    }\n\n    return new ImageBuilderComponent(scope, id, {\n      platform: 'Linux',\n      displayName: 'Required packages',\n      description: 'Install packages required for GitHub Runner and upgrade all packages',\n      commands: [\n        'apt-get update',\n        'DEBIAN_FRONTEND=noninteractive apt-get upgrade -y',\n        'DEBIAN_FRONTEND=noninteractive apt-get install -y curl sudo jq bash zip unzip iptables software-properties-common ca-certificates',\n        `curl -sfLo /tmp/amazon-cloudwatch-agent.deb https://s3.amazonaws.com/amazoncloudwatch-agent/ubuntu/${archUrl}/latest/amazon-cloudwatch-agent.deb`,\n        'dpkg -i -E /tmp/amazon-cloudwatch-agent.deb',\n        'rm /tmp/amazon-cloudwatch-agent.deb',\n      ],\n    });\n  }\n\n  public static runnerUser(scope: Construct, id: string, _architecture: Architecture) {\n    return new ImageBuilderComponent(scope, id, {\n      platform: 'Linux',\n      displayName: 'GitHub Runner user',\n      description: 'Install latest version of AWS CLI',\n      commands: [\n        'addgroup runner',\n        'adduser --system --disabled-password --home /home/runner --ingroup runner runner',\n        'echo \"%runner   ALL=(ALL:ALL) NOPASSWD: ALL\" > /etc/sudoers.d/runner',\n      ],\n    });\n  }\n\n  public static awsCli(scope: Construct, id: string, architecture: Architecture) {\n    let archUrl;\n    if (architecture.is(Architecture.X86_64)) {\n      archUrl = 'x86_64';\n    } else if (architecture.is(Architecture.ARM64)) {\n      archUrl = 'aarch64';\n    } else {\n      throw new Error(`Unsupported architecture for awscli: ${architecture.name}`);\n    }\n\n    return new ImageBuilderComponent(scope, id, {\n      platform: 'Linux',\n      displayName: 'AWS CLI',\n      description: 'Install latest version of AWS CLI',\n      commands: [\n        `curl -fsSL \"https://awscli.amazonaws.com/awscli-exe-linux-${archUrl}.zip\" -o awscliv2.zip`,\n        'unzip -q awscliv2.zip',\n        './aws/install',\n        'rm -rf awscliv2.zip aws',\n      ],\n    });\n  }\n\n  public static githubCli(scope: Construct, id: string, _architecture: Architecture) {\n    return new ImageBuilderComponent(scope, id, {\n      platform: 'Linux',\n      displayName: 'GitHub CLI',\n      description: 'Install latest version of gh',\n      commands: [\n        'curl -fsSL https://cli.github.com/packages/githubcli-archive-keyring.gpg | sudo dd of=/usr/share/keyrings/githubcli-archive-keyring.gpg',\n        'echo \"deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/githubcli-archive-keyring.gpg] ' +\n        '  https://cli.github.com/packages stable main\" | sudo tee /etc/apt/sources.list.d/github-cli.list > /dev/null',\n        'apt-get update',\n        'DEBIAN_FRONTEND=noninteractive apt-get install -y gh',\n      ],\n    });\n  }\n\n  public static git(scope: Construct, id: string, _architecture: Architecture) {\n    return new ImageBuilderComponent(scope, id, {\n      platform: 'Linux',\n      displayName: 'Git',\n      description: 'Install latest version of git',\n      commands: [\n        'add-apt-repository ppa:git-core/ppa',\n        'apt-get update',\n        'DEBIAN_FRONTEND=noninteractive apt-get install -y git',\n      ],\n    });\n  }\n\n  public static githubRunner(scope: Construct, id: string, runnerVersion: RunnerVersion, architecture: Architecture) {\n    let versionCommand: string;\n    if (runnerVersion.is(RunnerVersion.latest())) {\n      versionCommand = 'RUNNER_VERSION=`curl -w \"%{redirect_url}\" -fsS https://github.com/actions/runner/releases/latest | grep -oE \"[^/v]+$\"`';\n    } else {\n      versionCommand = `RUNNER_VERSION='${runnerVersion.version}'`;\n    }\n\n    let archUrl;\n    if (architecture.is(Architecture.X86_64)) {\n      archUrl = 'x64';\n    } else if (architecture.is(Architecture.ARM64)) {\n      archUrl = 'arm64';\n    } else {\n      throw new Error(`Unsupported architecture for GitHub Runner: ${architecture.name}`);\n    }\n\n    return new ImageBuilderComponent(scope, id, {\n      platform: 'Linux',\n      displayName: 'GitHub Actions Runner',\n      description: 'Install latest version of GitHub Actions Runner',\n      commands: [\n        versionCommand,\n        `curl -fsSLO \"https://github.com/actions/runner/releases/download/v\\${RUNNER_VERSION}/actions-runner-linux-${archUrl}-\\${RUNNER_VERSION}.tar.gz\"`,\n        `tar xzf \"actions-runner-linux-${archUrl}-\\${RUNNER_VERSION}.tar.gz\"`,\n        `rm actions-runner-linux-${archUrl}-\\${RUNNER_VERSION}.tar.gz`,\n        './bin/installdependencies.sh',\n        `echo -n ${runnerVersion.version} > RUNNER_VERSION`,\n      ],\n    });\n  }\n\n  public static docker(scope: Construct, id: string, _architecture: Architecture) {\n    return new ImageBuilderComponent(scope, id, {\n      platform: 'Linux',\n      displayName: 'Docker',\n      description: 'Install latest version of Docker',\n      commands: [\n        'curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker.gpg',\n        'echo ' +\n        '  \"deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu ' +\n        '  $(lsb_release -cs) stable\" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null',\n        'apt-get update',\n        'DEBIAN_FRONTEND=noninteractive apt-get install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin',\n        'usermod -aG docker runner',\n        'ln -s /usr/libexec/docker/cli-plugins/docker-compose /usr/bin/docker-compose',\n      ],\n    });\n  }\n\n  public static extraCertificates(scope: Construct, id: string, path: string) {\n    return new ImageBuilderComponent(scope, id, {\n      platform: 'Linux',\n      displayName: 'Extra certificates',\n      description: 'Install self-signed certificates to provide access to GitHub Enterprise Server',\n      commands: [\n        'cp certs/certs.pem /usr/local/share/ca-certificates/github-enterprise-server.crt',\n        'update-ca-certificates',\n      ],\n      assets: [\n        {\n          path: 'certs',\n          asset: new s3_assets.Asset(scope, `${id} Asset`, { path }),\n        },\n      ],\n    });\n  }\n}\n"]}