@cloudsnorkel/cdk-github-runners 0.14.18 → 0.14.19

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 (44) hide show
  1. package/.jsii +626 -140
  2. package/API.md +426 -17
  3. package/README.md +32 -2
  4. package/assets/providers/ami-root-device.lambda/index.js +11 -0
  5. package/lib/access.js +1 -1
  6. package/lib/image-builders/api.js +1 -1
  7. package/lib/image-builders/aws-image-builder/ami.d.ts +3 -2
  8. package/lib/image-builders/aws-image-builder/ami.js +9 -34
  9. package/lib/image-builders/aws-image-builder/base-image.d.ts +118 -0
  10. package/lib/image-builders/aws-image-builder/base-image.js +130 -0
  11. package/lib/image-builders/aws-image-builder/builder.js +17 -5
  12. package/lib/image-builders/aws-image-builder/container.d.ts +2 -1
  13. package/lib/image-builders/aws-image-builder/container.js +7 -6
  14. package/lib/image-builders/aws-image-builder/deprecated/ami.js +1 -1
  15. package/lib/image-builders/aws-image-builder/deprecated/container.js +1 -1
  16. package/lib/image-builders/aws-image-builder/deprecated/linux-components.js +1 -1
  17. package/lib/image-builders/aws-image-builder/deprecated/windows-components.js +1 -1
  18. package/lib/image-builders/aws-image-builder/index.d.ts +1 -0
  19. package/lib/image-builders/aws-image-builder/index.js +2 -1
  20. package/lib/image-builders/codebuild-deprecated.js +1 -1
  21. package/lib/image-builders/codebuild.js +15 -4
  22. package/lib/image-builders/common.d.ts +22 -3
  23. package/lib/image-builders/common.js +1 -1
  24. package/lib/image-builders/components.d.ts +1 -1
  25. package/lib/image-builders/components.js +31 -21
  26. package/lib/image-builders/static.js +4 -3
  27. package/lib/providers/ami-root-device.lambda.js +12 -1
  28. package/lib/providers/codebuild.js +4 -4
  29. package/lib/providers/common.js +3 -3
  30. package/lib/providers/composite.js +5 -5
  31. package/lib/providers/ec2.js +5 -5
  32. package/lib/providers/ecs.js +3 -3
  33. package/lib/providers/fargate.js +4 -4
  34. package/lib/providers/lambda.js +4 -4
  35. package/lib/runner.d.ts +24 -5
  36. package/lib/runner.js +46 -9
  37. package/lib/secrets.js +1 -1
  38. package/lib/utils.d.ts +13 -0
  39. package/lib/utils.js +47 -1
  40. package/lib/webhook-redelivery.d.ts +11 -0
  41. package/lib/webhook-redelivery.js +3 -1
  42. package/lib/webhook.d.ts +10 -0
  43. package/lib/webhook.js +3 -1
  44. package/package.json +1 -1
@@ -1,5 +1,6 @@
1
1
  import * as cdk from 'aws-cdk-lib';
2
2
  import { Construct } from 'constructs';
3
+ import { BaseImage } from './base-image';
3
4
  import { ImageBuilderComponent } from './builder';
4
5
  import { Architecture, Os } from '../../providers';
5
6
  /**
@@ -19,7 +20,7 @@ interface AmiRecipeProperties {
19
20
  /**
20
21
  * Base AMI to use for the new runner AMI.
21
22
  */
22
- readonly baseAmi: string;
23
+ readonly baseAmi: BaseImage;
23
24
  /**
24
25
  * Storage size for the builder.
25
26
  */
@@ -51,5 +52,5 @@ export declare class AmiRecipe extends cdk.Resource {
51
52
  *
52
53
  * @internal
53
54
  */
54
- export declare function defaultBaseAmi(scope: Construct, os: Os, architecture: Architecture): string;
55
+ export declare function defaultBaseAmi(scope: Construct, os: Os, architecture: Architecture): BaseImage;
55
56
  export {};
@@ -4,6 +4,7 @@ exports.AmiRecipe = void 0;
4
4
  exports.defaultBaseAmi = defaultBaseAmi;
5
5
  const cdk = require("aws-cdk-lib");
6
6
  const aws_cdk_lib_1 = require("aws-cdk-lib");
7
+ const base_image_1 = require("./base-image");
7
8
  const providers_1 = require("../../providers");
8
9
  const common_1 = require("../common");
9
10
  /**
@@ -21,7 +22,7 @@ class AmiRecipe extends cdk.Resource {
21
22
  });
22
23
  const blockDeviceMappings = props.storageSize ? [
23
24
  {
24
- deviceName: (0, providers_1.amiRootDevice)(this, props.baseAmi).ref,
25
+ deviceName: (0, providers_1.amiRootDevice)(this, props.baseAmi.image).ref,
25
26
  ebs: {
26
27
  volumeSize: props.storageSize.toGibibytes(),
27
28
  deleteOnTermination: true,
@@ -42,7 +43,7 @@ class AmiRecipe extends cdk.Resource {
42
43
  const recipe = new aws_cdk_lib_1.aws_imagebuilder.CfnImageRecipe(this, 'Recipe', {
43
44
  name: this.name,
44
45
  version: '1.0.x',
45
- parentImage: props.baseAmi,
46
+ parentImage: props.baseAmi.image,
46
47
  components,
47
48
  workingDirectory,
48
49
  tags: props.tags,
@@ -59,7 +60,6 @@ exports.AmiRecipe = AmiRecipe;
59
60
  * @internal
60
61
  */
61
62
  function defaultBaseAmi(scope, os, architecture) {
62
- const stack = cdk.Stack.of(scope);
63
63
  let arch;
64
64
  if (architecture.is(providers_1.Architecture.X86_64)) {
65
65
  arch = 'x86';
@@ -71,45 +71,20 @@ function defaultBaseAmi(scope, os, architecture) {
71
71
  throw new Error(`Unsupported architecture for base AMI: ${architecture.name}`);
72
72
  }
73
73
  if (os.is(providers_1.Os.LINUX_UBUNTU) || os.is(providers_1.Os.LINUX_UBUNTU_2204) || os.is(providers_1.Os.LINUX)) {
74
- return stack.formatArn({
75
- service: 'imagebuilder',
76
- resource: 'image',
77
- account: 'aws',
78
- resourceName: `ubuntu-server-22-lts-${arch}/x.x.x`,
79
- });
74
+ return base_image_1.BaseImage.fromImageBuilder(scope, `ubuntu-server-22-lts-${arch}`);
80
75
  }
81
76
  if (os.is(providers_1.Os.LINUX_UBUNTU_2404)) {
82
- return stack.formatArn({
83
- service: 'imagebuilder',
84
- resource: 'image',
85
- account: 'aws',
86
- resourceName: `ubuntu-server-24-lts-${arch}/x.x.x`,
87
- });
77
+ return base_image_1.BaseImage.fromImageBuilder(scope, `ubuntu-server-24-lts-${arch}`);
88
78
  }
89
79
  if (os.is(providers_1.Os.LINUX_AMAZON_2)) {
90
- return stack.formatArn({
91
- service: 'imagebuilder',
92
- resource: 'image',
93
- account: 'aws',
94
- resourceName: `amazon-linux-2-${arch}/x.x.x`,
95
- });
80
+ return base_image_1.BaseImage.fromImageBuilder(scope, `amazon-linux-2-${arch}`);
96
81
  }
97
82
  if (os.is(providers_1.Os.LINUX_AMAZON_2023)) {
98
- return stack.formatArn({
99
- service: 'imagebuilder',
100
- resource: 'image',
101
- account: 'aws',
102
- resourceName: `amazon-linux-2023-${arch}/x.x.x`,
103
- });
83
+ return base_image_1.BaseImage.fromImageBuilder(scope, `amazon-linux-2023-${arch}`);
104
84
  }
105
85
  if (os.is(providers_1.Os.WINDOWS)) {
106
- return stack.formatArn({
107
- service: 'imagebuilder',
108
- resource: 'image',
109
- account: 'aws',
110
- resourceName: `windows-server-2022-english-full-base-${arch}/x.x.x`,
111
- });
86
+ return base_image_1.BaseImage.fromImageBuilder(scope, `windows-server-2022-english-full-base-${arch}`);
112
87
  }
113
88
  throw new Error(`OS ${os.name} not supported for AMI runner image`);
114
89
  }
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ami.js","sourceRoot":"","sources":["../../../src/image-builders/aws-image-builder/ami.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { aws_imagebuilder as imagebuilder } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ImageBuilderComponent } from './builder';\nimport { amiRootDevice, Architecture, Os } from '../../providers';\nimport { uniqueImageBuilderName } from '../common';\n\n/**\n * Properties for AmiRecipe construct.\n *\n * @internal\n */\ninterface AmiRecipeProperties {\n  /**\n   * Target platform. Must match builder platform.\n   */\n  readonly platform: 'Linux' | 'Windows';\n\n  /**\n   * Target architecture. Must match builder platform.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * Base AMI to use for the new runner AMI.\n   */\n  readonly baseAmi: string;\n\n  /**\n   * Storage size for the builder.\n   */\n  readonly storageSize?: cdk.Size;\n\n  /**\n   * Components to add to target container image.\n   */\n  readonly components: ImageBuilderComponent[];\n\n  /**\n   * Tags to apply to the recipe and image.\n   */\n  readonly tags: { [key: string]: string };\n}\n\n/**\n * Image builder recipe for Amazon Machine Image (AMI).\n *\n * @internal\n */\nexport class AmiRecipe extends cdk.Resource {\n  public readonly arn: string;\n  public readonly name: string;\n  public readonly version: string;\n\n  constructor(scope: Construct, id: string, props: AmiRecipeProperties) {\n    super(scope, id);\n\n    let components = props.components.map(component => {\n      return {\n        componentArn: component.arn,\n      };\n    });\n\n    const blockDeviceMappings = props.storageSize ? [\n      {\n        deviceName: amiRootDevice(this, props.baseAmi).ref,\n        ebs: {\n          volumeSize: props.storageSize.toGibibytes(),\n          deleteOnTermination: true,\n        },\n      },\n    ] : undefined;\n\n    this.name = uniqueImageBuilderName(this);\n\n    let workingDirectory;\n    if (props.platform == 'Linux') {\n      workingDirectory = '/home/runner';\n    } else if (props.platform == 'Windows') {\n      workingDirectory = 'C:/'; // must exist or Image Builder fails and must not be empty or git will stall installing from the default windows\\system32\n    } else {\n      throw new Error(`Unsupported AMI recipe platform: ${props.platform}`);\n    }\n\n    const recipe = new imagebuilder.CfnImageRecipe(this, 'Recipe', {\n      name: this.name,\n      version: '1.0.x',\n      parentImage: props.baseAmi,\n      components,\n      workingDirectory,\n      tags: props.tags,\n      blockDeviceMappings,\n    });\n\n    this.arn = recipe.attrArn;\n    this.version = recipe.getAtt('Version', cdk.ResolutionTypeHint.STRING).toString();\n  }\n}\n\n/**\n * Default base AMI for given OS and architecture.\n *\n * @internal\n */\nexport function defaultBaseAmi(scope: Construct, os: Os, architecture: Architecture) {\n  const stack = cdk.Stack.of(scope);\n\n  let arch;\n  if (architecture.is(Architecture.X86_64)) {\n    arch = 'x86';\n  } else if (architecture.is(Architecture.ARM64)) {\n    arch = 'arm64';\n  } else {\n    throw new Error(`Unsupported architecture for base AMI: ${architecture.name}`);\n  }\n\n  if (os.is(Os.LINUX_UBUNTU) || os.is(Os.LINUX_UBUNTU_2204) || os.is(Os.LINUX)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `ubuntu-server-22-lts-${arch}/x.x.x`,\n    });\n  }\n\n  if (os.is(Os.LINUX_UBUNTU_2404)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `ubuntu-server-24-lts-${arch}/x.x.x`,\n    });\n  }\n\n  if (os.is(Os.LINUX_AMAZON_2)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `amazon-linux-2-${arch}/x.x.x`,\n    });\n  }\n\n  if (os.is(Os.LINUX_AMAZON_2023)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `amazon-linux-2023-${arch}/x.x.x`,\n    });\n  }\n\n  if (os.is(Os.WINDOWS)) {\n    return stack.formatArn({\n      service: 'imagebuilder',\n      resource: 'image',\n      account: 'aws',\n      resourceName: `windows-server-2022-english-full-base-${arch}/x.x.x`,\n    });\n  }\n\n  throw new Error(`OS ${os.name} not supported for AMI runner image`);\n}\n\n"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ami.js","sourceRoot":"","sources":["../../../src/image-builders/aws-image-builder/ami.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { aws_imagebuilder as imagebuilder } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { BaseImage } from './base-image';\nimport { ImageBuilderComponent } from './builder';\nimport { amiRootDevice, Architecture, Os } from '../../providers';\nimport { uniqueImageBuilderName } from '../common';\n\n/**\n * Properties for AmiRecipe construct.\n *\n * @internal\n */\ninterface AmiRecipeProperties {\n  /**\n   * Target platform. Must match builder platform.\n   */\n  readonly platform: 'Linux' | 'Windows';\n\n  /**\n   * Target architecture. Must match builder platform.\n   */\n  readonly architecture: Architecture;\n\n  /**\n   * Base AMI to use for the new runner AMI.\n   */\n  readonly baseAmi: BaseImage;\n\n  /**\n   * Storage size for the builder.\n   */\n  readonly storageSize?: cdk.Size;\n\n  /**\n   * Components to add to target container image.\n   */\n  readonly components: ImageBuilderComponent[];\n\n  /**\n   * Tags to apply to the recipe and image.\n   */\n  readonly tags: { [key: string]: string };\n}\n\n/**\n * Image builder recipe for Amazon Machine Image (AMI).\n *\n * @internal\n */\nexport class AmiRecipe extends cdk.Resource {\n  public readonly arn: string;\n  public readonly name: string;\n  public readonly version: string;\n\n  constructor(scope: Construct, id: string, props: AmiRecipeProperties) {\n    super(scope, id);\n\n    let components = props.components.map(component => {\n      return {\n        componentArn: component.arn,\n      };\n    });\n\n    const blockDeviceMappings = props.storageSize ? [\n      {\n        deviceName: amiRootDevice(this, props.baseAmi.image).ref,\n        ebs: {\n          volumeSize: props.storageSize.toGibibytes(),\n          deleteOnTermination: true,\n        },\n      },\n    ] : undefined;\n\n    this.name = uniqueImageBuilderName(this);\n\n    let workingDirectory;\n    if (props.platform == 'Linux') {\n      workingDirectory = '/home/runner';\n    } else if (props.platform == 'Windows') {\n      workingDirectory = 'C:/'; // must exist or Image Builder fails and must not be empty or git will stall installing from the default windows\\system32\n    } else {\n      throw new Error(`Unsupported AMI recipe platform: ${props.platform}`);\n    }\n\n    const recipe = new imagebuilder.CfnImageRecipe(this, 'Recipe', {\n      name: this.name,\n      version: '1.0.x',\n      parentImage: props.baseAmi.image,\n      components,\n      workingDirectory,\n      tags: props.tags,\n      blockDeviceMappings,\n    });\n\n    this.arn = recipe.attrArn;\n    this.version = recipe.getAtt('Version', cdk.ResolutionTypeHint.STRING).toString();\n  }\n}\n\n/**\n * Default base AMI for given OS and architecture.\n *\n * @internal\n */\nexport function defaultBaseAmi(scope: Construct, os: Os, architecture: Architecture): BaseImage {\n  let arch;\n  if (architecture.is(Architecture.X86_64)) {\n    arch = 'x86';\n  } else if (architecture.is(Architecture.ARM64)) {\n    arch = 'arm64';\n  } else {\n    throw new Error(`Unsupported architecture for base AMI: ${architecture.name}`);\n  }\n\n  if (os.is(Os.LINUX_UBUNTU) || os.is(Os.LINUX_UBUNTU_2204) || os.is(Os.LINUX)) {\n    return BaseImage.fromImageBuilder(scope, `ubuntu-server-22-lts-${arch}`);\n  }\n\n  if (os.is(Os.LINUX_UBUNTU_2404)) {\n    return BaseImage.fromImageBuilder(scope, `ubuntu-server-24-lts-${arch}`);\n  }\n\n  if (os.is(Os.LINUX_AMAZON_2)) {\n    return BaseImage.fromImageBuilder(scope, `amazon-linux-2-${arch}`);\n  }\n\n  if (os.is(Os.LINUX_AMAZON_2023)) {\n    return BaseImage.fromImageBuilder(scope, `amazon-linux-2023-${arch}`);\n  }\n\n  if (os.is(Os.WINDOWS)) {\n    return BaseImage.fromImageBuilder(scope, `windows-server-2022-english-full-base-${arch}`);\n  }\n\n  throw new Error(`OS ${os.name} not supported for AMI runner image`);\n}\n\n"]}
@@ -0,0 +1,118 @@
1
+ import * as ecr from 'aws-cdk-lib/aws-ecr';
2
+ import * as ssm from 'aws-cdk-lib/aws-ssm';
3
+ import { Construct } from 'constructs';
4
+ /**
5
+ * Type that can be used to specify a base image - either a string (deprecated) or a BaseImage object.
6
+ *
7
+ * To create a BaseImage object, use the static factory methods like BaseImage.fromAmiId().
8
+ *
9
+ * Note: String support is deprecated and will be removed in a future version. Use BaseImage static factory methods instead.
10
+ */
11
+ export type BaseImageInput = string | BaseImage;
12
+ /**
13
+ * Represents a base image that is used to start from in EC2 Image Builder image builds.
14
+ *
15
+ * This class is adapted from AWS CDK's BaseImage class to support both string and object inputs.
16
+ */
17
+ export declare class BaseImage {
18
+ /**
19
+ * The AMI ID to use as a base image in an image recipe
20
+ *
21
+ * @param amiId The AMI ID to use as the base image
22
+ */
23
+ static fromAmiId(amiId: string): BaseImage;
24
+ /**
25
+ * An AWS-provided EC2 Image Builder image to use as a base image in an image recipe.
26
+ *
27
+ * This constructs an Image Builder ARN for AWS-provided images like `ubuntu-server-22-lts-x86/x.x.x`.
28
+ *
29
+ * @param scope The construct scope (used to determine the stack and region)
30
+ * @param resourceName The Image Builder resource name pattern (e.g., `ubuntu-server-22-lts-x86` or `ubuntu-server-22-lts-${arch}`)
31
+ * @param version The version pattern (defaults to `x.x.x` to use the latest version)
32
+ */
33
+ static fromImageBuilder(scope: Construct, resourceName: string, version?: string): BaseImage;
34
+ /**
35
+ * The marketplace product ID for an AMI product to use as the base image in an image recipe
36
+ *
37
+ * @param productId The Marketplace AMI product ID to use as the base image
38
+ */
39
+ static fromMarketplaceProductId(productId: string): BaseImage;
40
+ /**
41
+ * The SSM parameter to use as the base image in an image recipe
42
+ *
43
+ * @param parameter The SSM parameter to use as the base image
44
+ */
45
+ static fromSsmParameter(parameter: ssm.IParameter): BaseImage;
46
+ /**
47
+ * The parameter name for the SSM parameter to use as the base image in an image recipe
48
+ *
49
+ * @param parameterName The name of the SSM parameter to use as the base image
50
+ */
51
+ static fromSsmParameterName(parameterName: string): BaseImage;
52
+ /**
53
+ * The direct string value of the base image to use in an image recipe. This can be an EC2 Image Builder image ARN,
54
+ * an SSM parameter, an AWS Marketplace product ID, or an AMI ID.
55
+ *
56
+ * @param baseImageString The base image as a direct string value
57
+ */
58
+ static fromString(baseImageString: string): BaseImage;
59
+ /**
60
+ * The rendered base image to use
61
+ */
62
+ readonly image: string;
63
+ protected constructor(image: string);
64
+ }
65
+ /**
66
+ * Type that can be used to specify a base container image - either a string (deprecated) or a BaseContainerImage object.
67
+ *
68
+ * To create a BaseContainerImage object, use the static factory methods like BaseContainerImage.fromEcr().
69
+ *
70
+ * Note: String support is deprecated and will be removed in a future version. Use BaseContainerImage static factory methods instead.
71
+ */
72
+ export type BaseContainerImageInput = string | BaseContainerImage;
73
+ /**
74
+ * Represents a base container image that is used to start from in EC2 Image Builder container builds.
75
+ *
76
+ * This class is adapted from AWS CDK's BaseContainerImage class to support both string and object inputs.
77
+ */
78
+ export declare class BaseContainerImage {
79
+ /**
80
+ * The DockerHub image to use as the base image in a container recipe
81
+ *
82
+ * @param repository The DockerHub repository where the base image resides in
83
+ * @param tag The tag of the base image in the DockerHub repository
84
+ */
85
+ static fromDockerHub(repository: string, tag: string): BaseContainerImage;
86
+ /**
87
+ * The ECR container image to use as the base image in a container recipe
88
+ *
89
+ * @param repository The ECR repository where the base image resides in
90
+ * @param tag The tag of the base image in the ECR repository
91
+ */
92
+ static fromEcr(repository: ecr.IRepository, tag: string): BaseContainerImage;
93
+ /**
94
+ * The ECR public container image to use as the base image in a container recipe
95
+ *
96
+ * @param registryAlias The alias of the ECR public registry where the base image resides in
97
+ * @param repositoryName The name of the ECR public repository, where the base image resides in
98
+ * @param tag The tag of the base image in the ECR public repository
99
+ */
100
+ static fromEcrPublic(registryAlias: string, repositoryName: string, tag: string): BaseContainerImage;
101
+ /**
102
+ * The string value of the base image to use in a container recipe. This can be an EC2 Image Builder image ARN,
103
+ * an ECR or ECR public image, or a container URI sourced from a third-party container registry such as DockerHub.
104
+ *
105
+ * @param baseContainerImageString The base image as a direct string value
106
+ */
107
+ static fromString(baseContainerImageString: string): BaseContainerImage;
108
+ /**
109
+ * The rendered base image to use
110
+ */
111
+ readonly image: string;
112
+ /**
113
+ * The ECR repository if this image was created from an ECR repository.
114
+ * This allows automatic permission granting for CodeBuild.
115
+ */
116
+ readonly ecrRepository?: ecr.IRepository;
117
+ protected constructor(image: string, ecrRepository?: ecr.IRepository);
118
+ }
@@ -0,0 +1,130 @@
1
+ "use strict";
2
+ var _a, _b;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.BaseContainerImage = exports.BaseImage = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const cdk = require("aws-cdk-lib");
7
+ /**
8
+ * Represents a base image that is used to start from in EC2 Image Builder image builds.
9
+ *
10
+ * This class is adapted from AWS CDK's BaseImage class to support both string and object inputs.
11
+ */
12
+ class BaseImage {
13
+ /**
14
+ * The AMI ID to use as a base image in an image recipe
15
+ *
16
+ * @param amiId The AMI ID to use as the base image
17
+ */
18
+ static fromAmiId(amiId) {
19
+ return new BaseImage(amiId);
20
+ }
21
+ /**
22
+ * An AWS-provided EC2 Image Builder image to use as a base image in an image recipe.
23
+ *
24
+ * This constructs an Image Builder ARN for AWS-provided images like `ubuntu-server-22-lts-x86/x.x.x`.
25
+ *
26
+ * @param scope The construct scope (used to determine the stack and region)
27
+ * @param resourceName The Image Builder resource name pattern (e.g., `ubuntu-server-22-lts-x86` or `ubuntu-server-22-lts-${arch}`)
28
+ * @param version The version pattern (defaults to `x.x.x` to use the latest version)
29
+ */
30
+ static fromImageBuilder(scope, resourceName, version = 'x.x.x') {
31
+ const stack = cdk.Stack.of(scope);
32
+ return new BaseImage(stack.formatArn({
33
+ service: 'imagebuilder',
34
+ resource: 'image',
35
+ account: 'aws',
36
+ resourceName: `${resourceName}/${version}`,
37
+ }));
38
+ }
39
+ /**
40
+ * The marketplace product ID for an AMI product to use as the base image in an image recipe
41
+ *
42
+ * @param productId The Marketplace AMI product ID to use as the base image
43
+ */
44
+ static fromMarketplaceProductId(productId) {
45
+ return new BaseImage(productId);
46
+ }
47
+ /**
48
+ * The SSM parameter to use as the base image in an image recipe
49
+ *
50
+ * @param parameter The SSM parameter to use as the base image
51
+ */
52
+ static fromSsmParameter(parameter) {
53
+ return new BaseImage(`ssm:${parameter.parameterArn}`);
54
+ }
55
+ /**
56
+ * The parameter name for the SSM parameter to use as the base image in an image recipe
57
+ *
58
+ * @param parameterName The name of the SSM parameter to use as the base image
59
+ */
60
+ static fromSsmParameterName(parameterName) {
61
+ return new BaseImage(`ssm:${parameterName}`);
62
+ }
63
+ /**
64
+ * The direct string value of the base image to use in an image recipe. This can be an EC2 Image Builder image ARN,
65
+ * an SSM parameter, an AWS Marketplace product ID, or an AMI ID.
66
+ *
67
+ * @param baseImageString The base image as a direct string value
68
+ */
69
+ static fromString(baseImageString) {
70
+ return new BaseImage(baseImageString);
71
+ }
72
+ constructor(image) {
73
+ this.image = image;
74
+ }
75
+ }
76
+ exports.BaseImage = BaseImage;
77
+ _a = JSII_RTTI_SYMBOL_1;
78
+ BaseImage[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.BaseImage", version: "0.14.19" };
79
+ /**
80
+ * Represents a base container image that is used to start from in EC2 Image Builder container builds.
81
+ *
82
+ * This class is adapted from AWS CDK's BaseContainerImage class to support both string and object inputs.
83
+ */
84
+ class BaseContainerImage {
85
+ /**
86
+ * The DockerHub image to use as the base image in a container recipe
87
+ *
88
+ * @param repository The DockerHub repository where the base image resides in
89
+ * @param tag The tag of the base image in the DockerHub repository
90
+ */
91
+ static fromDockerHub(repository, tag) {
92
+ return new BaseContainerImage(`${repository}:${tag}`);
93
+ }
94
+ /**
95
+ * The ECR container image to use as the base image in a container recipe
96
+ *
97
+ * @param repository The ECR repository where the base image resides in
98
+ * @param tag The tag of the base image in the ECR repository
99
+ */
100
+ static fromEcr(repository, tag) {
101
+ return new BaseContainerImage(repository.repositoryUriForTag(tag), repository);
102
+ }
103
+ /**
104
+ * The ECR public container image to use as the base image in a container recipe
105
+ *
106
+ * @param registryAlias The alias of the ECR public registry where the base image resides in
107
+ * @param repositoryName The name of the ECR public repository, where the base image resides in
108
+ * @param tag The tag of the base image in the ECR public repository
109
+ */
110
+ static fromEcrPublic(registryAlias, repositoryName, tag) {
111
+ return new BaseContainerImage(`public.ecr.aws/${registryAlias}/${repositoryName}:${tag}`);
112
+ }
113
+ /**
114
+ * The string value of the base image to use in a container recipe. This can be an EC2 Image Builder image ARN,
115
+ * an ECR or ECR public image, or a container URI sourced from a third-party container registry such as DockerHub.
116
+ *
117
+ * @param baseContainerImageString The base image as a direct string value
118
+ */
119
+ static fromString(baseContainerImageString) {
120
+ return new BaseContainerImage(baseContainerImageString);
121
+ }
122
+ constructor(image, ecrRepository) {
123
+ this.image = image;
124
+ this.ecrRepository = ecrRepository;
125
+ }
126
+ }
127
+ exports.BaseContainerImage = BaseContainerImage;
128
+ _b = JSII_RTTI_SYMBOL_1;
129
+ BaseContainerImage[_b] = { fqn: "@cloudsnorkel/cdk-github-runners.BaseContainerImage", version: "0.14.19" };
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-image.js","sourceRoot":"","sources":["../../../src/image-builders/aws-image-builder/base-image.ts"],"names":[],"mappings":";;;;;AAAA,mCAAmC;AAcnC;;;;GAIG;AACH,MAAa,SAAS;IACpB;;;;OAIG;IACI,MAAM,CAAC,SAAS,CAAC,KAAa;QACnC,OAAO,IAAI,SAAS,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED;;;;;;;;OAQG;IACI,MAAM,CAAC,gBAAgB,CAAC,KAAgB,EAAE,YAAoB,EAAE,UAAkB,OAAO;QAC9F,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QAClC,OAAO,IAAI,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC;YACnC,OAAO,EAAE,cAAc;YACvB,QAAQ,EAAE,OAAO;YACjB,OAAO,EAAE,KAAK;YACd,YAAY,EAAE,GAAG,YAAY,IAAI,OAAO,EAAE;SAC3C,CAAC,CAAC,CAAC;IACN,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,wBAAwB,CAAC,SAAiB;QACtD,OAAO,IAAI,SAAS,CAAC,SAAS,CAAC,CAAC;IAClC,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,gBAAgB,CAAC,SAAyB;QACtD,OAAO,IAAI,SAAS,CAAC,OAAO,SAAS,CAAC,YAAY,EAAE,CAAC,CAAC;IACxD,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,oBAAoB,CAAC,aAAqB;QACtD,OAAO,IAAI,SAAS,CAAC,OAAO,aAAa,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,UAAU,CAAC,eAAuB;QAC9C,OAAO,IAAI,SAAS,CAAC,eAAe,CAAC,CAAC;IACxC,CAAC;IAOD,YAAsB,KAAa;QACjC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;;AAzEH,8BA0EC;;;AAWD;;;;GAIG;AACH,MAAa,kBAAkB;IAC7B;;;;;OAKG;IACI,MAAM,CAAC,aAAa,CAAC,UAAkB,EAAE,GAAW;QACzD,OAAO,IAAI,kBAAkB,CAAC,GAAG,UAAU,IAAI,GAAG,EAAE,CAAC,CAAC;IACxD,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,OAAO,CAAC,UAA2B,EAAE,GAAW;QAC5D,OAAO,IAAI,kBAAkB,CAAC,UAAU,CAAC,mBAAmB,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;IACjF,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,aAAa,CAAC,aAAqB,EAAE,cAAsB,EAAE,GAAW;QACpF,OAAO,IAAI,kBAAkB,CAAC,kBAAkB,aAAa,IAAI,cAAc,IAAI,GAAG,EAAE,CAAC,CAAC;IAC5F,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,UAAU,CAAC,wBAAgC;QACvD,OAAO,IAAI,kBAAkB,CAAC,wBAAwB,CAAC,CAAC;IAC1D,CAAC;IAaD,YAAsB,KAAa,EAAE,aAA+B;QAClE,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;IACrC,CAAC;;AAxDH,gDAyDC","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';\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   * 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"]}