@cloudsnorkel/cdk-github-runners 0.14.18 → 0.14.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +741 -230
- package/API.md +499 -41
- package/README.md +34 -4
- package/assets/providers/ami-root-device.lambda/index.js +11 -0
- package/lib/access.js +1 -1
- package/lib/image-builders/api.js +1 -1
- package/lib/image-builders/aws-image-builder/ami.d.ts +3 -2
- package/lib/image-builders/aws-image-builder/ami.js +9 -34
- package/lib/image-builders/aws-image-builder/base-image.d.ts +118 -0
- package/lib/image-builders/aws-image-builder/base-image.js +130 -0
- package/lib/image-builders/aws-image-builder/builder.js +17 -5
- package/lib/image-builders/aws-image-builder/container.d.ts +2 -1
- package/lib/image-builders/aws-image-builder/container.js +7 -6
- package/lib/image-builders/aws-image-builder/deprecated/ami.js +1 -1
- package/lib/image-builders/aws-image-builder/deprecated/container.js +1 -1
- package/lib/image-builders/aws-image-builder/deprecated/linux-components.js +1 -1
- package/lib/image-builders/aws-image-builder/deprecated/windows-components.js +1 -1
- package/lib/image-builders/aws-image-builder/index.d.ts +1 -0
- package/lib/image-builders/aws-image-builder/index.js +2 -1
- package/lib/image-builders/codebuild-deprecated.js +1 -1
- package/lib/image-builders/codebuild.d.ts +10 -0
- package/lib/image-builders/codebuild.js +15 -4
- package/lib/image-builders/common.d.ts +22 -3
- package/lib/image-builders/common.js +1 -1
- package/lib/image-builders/components.d.ts +1 -1
- package/lib/image-builders/components.js +31 -21
- package/lib/image-builders/static.js +4 -3
- package/lib/providers/ami-root-device.lambda.js +12 -1
- package/lib/providers/codebuild.d.ts +12 -0
- package/lib/providers/codebuild.js +4 -4
- package/lib/providers/common.js +3 -3
- package/lib/providers/composite.js +18 -33
- package/lib/providers/ec2.js +5 -5
- package/lib/providers/ecs.d.ts +3 -1
- package/lib/providers/ecs.js +3 -3
- package/lib/providers/fargate.d.ts +14 -0
- package/lib/providers/fargate.js +4 -4
- package/lib/providers/lambda.d.ts +2 -0
- package/lib/providers/lambda.js +4 -4
- package/lib/runner.d.ts +24 -5
- package/lib/runner.js +46 -9
- package/lib/secrets.js +1 -1
- package/lib/utils.d.ts +13 -0
- package/lib/utils.js +47 -1
- package/lib/webhook-redelivery.d.ts +11 -0
- package/lib/webhook-redelivery.js +3 -1
- package/lib/webhook.d.ts +10 -0
- package/lib/webhook.js +3 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -447,9 +447,39 @@ const providerSelector = new Function(this, 'provider-selector', {
|
|
|
447
447
|
|
|
448
448
|
## Examples
|
|
449
449
|
|
|
450
|
-
|
|
450
|
+
We provide comprehensive examples in the [`examples/`](examples/) folder to help you get started quickly:
|
|
451
451
|
|
|
452
|
-
|
|
452
|
+
### Getting Started
|
|
453
|
+
- **[Simple CodeBuild](examples/typescript/simple-codebuild/)** - Basic setup with just a CodeBuild provider (also available in [Python](examples/python/simple-codebuild/))
|
|
454
|
+
|
|
455
|
+
### Provider Configuration
|
|
456
|
+
- **[Composite Provider](examples/typescript/composite-provider/)** - Fallback and weighted distribution strategies (also available in [Python](examples/python/composite-provider/))
|
|
457
|
+
- **[Provider Selector](examples/typescript/provider-selector/)** - Custom provider selection with Lambda function (also available in [Python](examples/python/provider-selector/))
|
|
458
|
+
- **[EC2 Windows Provider](examples/typescript/ec2-windows-provider/)** - EC2 configuration for Windows runners (also available in [Python](examples/python/ec2-windows-provider/))
|
|
459
|
+
|
|
460
|
+
### Compute & Performance
|
|
461
|
+
- **[Compute Options](examples/typescript/compute-options/)** - Configure CPU, memory, and instance types for different providers (also available in [Python](examples/python/compute-options/))
|
|
462
|
+
- **[Spot Instances](examples/typescript/spot-instances/)** - Use spot instances for cost savings across EC2, Fargate, and ECS (also available in [Python](examples/python/spot-instances/))
|
|
463
|
+
- **[Storage Options](examples/typescript/storage-options/)** - Custom EBS storage options for EC2 runners (also available in [Python](examples/python/storage-options/))
|
|
464
|
+
- **[ECS Scaling](examples/typescript/ecs-scaling/)** - Custom autoscaling group scaling policies for ECS providers (also available in [Python](examples/python/ecs-scaling/))
|
|
465
|
+
|
|
466
|
+
### Security & Access
|
|
467
|
+
- **[IAM Permissions](examples/typescript/iam-permissions/)** - Grant AWS IAM permissions to runners (also available in [Python](examples/python/iam-permissions/))
|
|
468
|
+
- **[Network Access](examples/typescript/network-access/)** - Configure network access with VPCs and security groups (also available in [Python](examples/python/network-access/))
|
|
469
|
+
- **[Access Control](examples/typescript/access-control/)** - Configure access control for webhook and setup functions (also available in [Python](examples/python/access-control/))
|
|
470
|
+
|
|
471
|
+
### Customization
|
|
472
|
+
- **[Add Software](examples/typescript/add-software/)** - Add custom software to runner images (also available in [Python](examples/python/add-software/))
|
|
473
|
+
|
|
474
|
+
### Enterprise & Monitoring
|
|
475
|
+
- **[GHES](examples/typescript/ghes/)** - Configure runners for GitHub Enterprise Server (also available in [Python](examples/python/ghes/))
|
|
476
|
+
- **[Monitoring](examples/typescript/monitoring/)** - Set up CloudWatch alarms and SNS notifications (also available in [Python](examples/python/monitoring/))
|
|
477
|
+
|
|
478
|
+
Each example is self-contained with its own dependencies and README. Start with the simple examples and work your way up to more advanced configurations.
|
|
479
|
+
|
|
480
|
+
Another good and very full example is the [integration test](test/default.integ.ts).
|
|
481
|
+
|
|
482
|
+
If you have more to share, please open a PR adding examples to the `examples` folder.
|
|
453
483
|
|
|
454
484
|
## Architecture
|
|
455
485
|
|
|
@@ -506,13 +536,13 @@ If you use and love this project, please consider contributing.
|
|
|
506
536
|
|
|
507
537
|
## Other Options
|
|
508
538
|
|
|
509
|
-
1. [
|
|
539
|
+
1. [github-aws-runners/terraform-aws-github-runner][3] if you're using Terraform
|
|
510
540
|
2. [actions/actions-runner-controller][4] if you're using Kubernetes
|
|
511
541
|
|
|
512
542
|
|
|
513
543
|
[1]: https://docs.github.com/en/actions/hosting-your-own-runners/about-self-hosted-runners
|
|
514
544
|
[2]: https://github.com/marketplace/actions/configure-aws-credentials-action-for-github-actions
|
|
515
|
-
[3]: https://github.com/
|
|
545
|
+
[3]: https://github.com/github-aws-runners/terraform-aws-github-runner
|
|
516
546
|
[4]: https://github.com/actions/actions-runner-controller
|
|
517
547
|
[5]: https://github.com/actions/runner
|
|
518
548
|
[6]: https://pypi.org/project/cloudsnorkel.cdk-github-runners
|
|
@@ -106,6 +106,17 @@ async function handler(event, context) {
|
|
|
106
106
|
await handleAmi(event, ssmValue);
|
|
107
107
|
break;
|
|
108
108
|
}
|
|
109
|
+
if (ami.startsWith("ssm:")) {
|
|
110
|
+
const ssmParam = ami.substring("ssm:".length);
|
|
111
|
+
console.log(`Checking SSM ${ssmParam}`);
|
|
112
|
+
const ssmValue = (await ssm.send(new import_client_ssm.GetParameterCommand({ Name: ssmParam }))).Parameter?.Value;
|
|
113
|
+
if (!ssmValue) {
|
|
114
|
+
await customResourceRespond(event, "FAILED", `${ami} has no value`, "ERROR", {});
|
|
115
|
+
break;
|
|
116
|
+
}
|
|
117
|
+
await handleAmi(event, ssmValue);
|
|
118
|
+
break;
|
|
119
|
+
}
|
|
109
120
|
if (ami.startsWith("lt-")) {
|
|
110
121
|
console.log(`Checking Launch Template ${ami}`);
|
|
111
122
|
const lts = await ec2.send(new import_client_ec2.DescribeLaunchTemplateVersionsCommand({ LaunchTemplateId: ami, Versions: ["$Latest"] }));
|
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.14.
|
|
62
|
+
LambdaAccess[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.LambdaAccess", version: "0.14.20" };
|
|
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.14.
|
|
46
|
+
RunnerImageBuilder[_a] = { fqn: "@cloudsnorkel/cdk-github-runners.RunnerImageBuilder", version: "0.14.20" };
|
|
47
47
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ltYWdlLWJ1aWxkZXJzL2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUEwQztBQUUxQywyREFBd0U7QUFDeEUsMkNBQTBEO0FBQzFELHFDQUFvSTtBQUNwSSw0Q0FBa0M7QUFFbEM7Ozs7OztHQU1HO0FBQ0gsTUFBc0Isa0JBQW1CLFNBQVEsK0JBQXNCO0lBQ3JFOztPQUVHO0lBQ0gsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUErQjtRQUN0RSxJQUFJLEtBQUssRUFBRSxVQUFVLElBQUksS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzdDLHlCQUFXLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsQ0FBQyxrSEFBa0gsQ0FBQyxDQUFDO1FBQ3ZKLENBQUM7UUFFRCxJQUFJLEtBQUssRUFBRSxXQUFXLEtBQUssK0JBQXNCLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDN0QsT0FBTyxJQUFJLHVDQUEyQixDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0QsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFdBQVcsS0FBSywrQkFBc0IsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQzNFLE9BQU8sSUFBSSxxREFBaUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFFRCxNQUFNLEVBQUUsR0FBRyxLQUFLLEVBQUUsRUFBRSxJQUFJLGNBQUUsQ0FBQyxZQUFZLENBQUM7UUFDeEMsSUFBSSxFQUFFLENBQUMsSUFBSSxDQUFDLGNBQUUsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLENBQUM7WUFDcEMsT0FBTyxJQUFJLHVDQUEyQixDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDM0QsQ0FBQzthQUFNLElBQUksRUFBRSxDQUFDLEVBQUUsQ0FBQyxjQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUM3QixPQUFPLElBQUkscURBQWlDLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNqRSxDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsMERBQTBELEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZGLENBQUM7SUFDSCxDQUFDOztBQXZCSCxnREF3QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBbm5vdGF0aW9ucyB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQXdzSW1hZ2VCdWlsZGVyUnVubmVySW1hZ2VCdWlsZGVyIH0gZnJvbSAnLi9hd3MtaW1hZ2UtYnVpbGRlcic7XG5pbXBvcnQgeyBDb2RlQnVpbGRSdW5uZXJJbWFnZUJ1aWxkZXIgfSBmcm9tICcuL2NvZGVidWlsZCc7XG5pbXBvcnQgeyBJQ29uZmlndXJhYmxlUnVubmVySW1hZ2VCdWlsZGVyLCBSdW5uZXJJbWFnZUJ1aWxkZXJCYXNlLCBSdW5uZXJJbWFnZUJ1aWxkZXJQcm9wcywgUnVubmVySW1hZ2VCdWlsZGVyVHlwZSB9IGZyb20gJy4vY29tbW9uJztcbmltcG9ydCB7IE9zIH0gZnJvbSAnLi4vcHJvdmlkZXJzJztcblxuLyoqXG4gKiBHaXRIdWIgUnVubmVyIGltYWdlIGJ1aWxkZXIuIEJ1aWxkcyBhIERvY2tlciBpbWFnZSBvciBBTUkgd2l0aCBHaXRIdWIgUnVubmVyIGFuZCBvdGhlciByZXF1aXJlbWVudHMgaW5zdGFsbGVkLlxuICpcbiAqIEltYWdlcyBjYW4gYmUgY3VzdG9taXplZCBiZWZvcmUgcGFzc2VkIGludG8gdGhlIHByb3ZpZGVyIGJ5IGFkZGluZyBvciByZW1vdmluZyBjb21wb25lbnRzIHRvIGJlIGluc3RhbGxlZC5cbiAqXG4gKiBJbWFnZXMgYXJlIHJlYnVpbHQgZXZlcnkgd2VlayBieSBkZWZhdWx0IHRvIGVuc3VyZSB0aGF0IHRoZSBsYXRlc3Qgc2VjdXJpdHkgcGF0Y2hlcyBhcmUgYXBwbGllZC5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFJ1bm5lckltYWdlQnVpbGRlciBleHRlbmRzIFJ1bm5lckltYWdlQnVpbGRlckJhc2Uge1xuICAvKipcbiAgICogQ3JlYXRlIGEgbmV3IGltYWdlIGJ1aWxkZXIgYmFzZWQgb24gdGhlIHByb3ZpZGVkIHByb3BlcnRpZXMuIFRoZSBpbXBsZW1lbnRhdGlvbiB3aWxsIGRpZmZlciBiYXNlZCBvbiB0aGUgT1MsIGFyY2hpdGVjdHVyZSwgYW5kIHJlcXVlc3RlZCBidWlsZGVyIHR5cGUuXG4gICAqL1xuICBzdGF0aWMgbmV3KHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogUnVubmVySW1hZ2VCdWlsZGVyUHJvcHMpOiBJQ29uZmlndXJhYmxlUnVubmVySW1hZ2VCdWlsZGVyIHtcbiAgICBpZiAocHJvcHM/LmNvbXBvbmVudHMgJiYgcHJvcHMucnVubmVyVmVyc2lvbikge1xuICAgICAgQW5ub3RhdGlvbnMub2Yoc2NvcGUpLmFkZFdhcm5pbmcoJ3J1bm5lclZlcnNpb24gaXMgaWdub3JlZCB3aGVuIGNvbXBvbmVudHMgYXJlIHNwZWNpZmllZC4gVGhlIHJ1bm5lciB2ZXJzaW9uIHdpbGwgYmUgZGV0ZXJtaW5lZCBieSB0aGUgY29tcG9uZW50cy4nKTtcbiAgICB9XG5cbiAgICBpZiAocHJvcHM/LmJ1aWxkZXJUeXBlID09PSBSdW5uZXJJbWFnZUJ1aWxkZXJUeXBlLkNPREVfQlVJTEQpIHtcbiAgICAgIHJldHVybiBuZXcgQ29kZUJ1aWxkUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSBpZiAocHJvcHM/LmJ1aWxkZXJUeXBlID09PSBSdW5uZXJJbWFnZUJ1aWxkZXJUeXBlLkFXU19JTUFHRV9CVUlMREVSKSB7XG4gICAgICByZXR1cm4gbmV3IEF3c0ltYWdlQnVpbGRlclJ1bm5lckltYWdlQnVpbGRlcihzY29wZSwgaWQsIHByb3BzKTtcbiAgICB9XG5cbiAgICBjb25zdCBvcyA9IHByb3BzPy5vcyA/PyBPcy5MSU5VWF9VQlVOVFU7XG4gICAgaWYgKG9zLmlzSW4oT3MuX0FMTF9MSU5VWF9WRVJTSU9OUykpIHtcbiAgICAgIHJldHVybiBuZXcgQ29kZUJ1aWxkUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSBpZiAob3MuaXMoT3MuV0lORE9XUykpIHtcbiAgICAgIHJldHVybiBuZXcgQXdzSW1hZ2VCdWlsZGVyUnVubmVySW1hZ2VCdWlsZGVyKHNjb3BlLCBpZCwgcHJvcHMpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVuYWJsZSB0byBmaW5kIHJ1bm5lciBpbWFnZSBidWlsZGVyIGltcGxlbWVudGF0aW9uIGZvciAke29zLm5hbWV9YCk7XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -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:
|
|
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):
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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.20" };
|
|
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.20" };
|
|
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"]}
|