token-injectable-docker-builder 1.12.1 → 1.12.2
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 +4 -4
- package/API.md +74 -2
- package/lib/index.js +2 -2
- package/package.json +7 -7
package/.jsii
CHANGED
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
},
|
|
9
9
|
"dependencies": {
|
|
10
10
|
"aws-cdk-lib": "^2.238.0",
|
|
11
|
-
"constructs": "^10.
|
|
11
|
+
"constructs": "^10.5.1"
|
|
12
12
|
},
|
|
13
13
|
"dependencyClosure": {
|
|
14
14
|
"@aws-cdk/asset-awscli-v1": {
|
|
@@ -8498,7 +8498,7 @@
|
|
|
8498
8498
|
"stability": "stable"
|
|
8499
8499
|
},
|
|
8500
8500
|
"homepage": "https://github.com/AlexTech314/TokenInjectableDockerBuilder.git",
|
|
8501
|
-
"jsiiVersion": "5.9.
|
|
8501
|
+
"jsiiVersion": "5.9.34 (build 8773a22)",
|
|
8502
8502
|
"keywords": [
|
|
8503
8503
|
"aws",
|
|
8504
8504
|
"aws-cdk",
|
|
@@ -9167,6 +9167,6 @@
|
|
|
9167
9167
|
"symbolId": "src/index:TokenInjectableDockerBuilderProviderProps"
|
|
9168
9168
|
}
|
|
9169
9169
|
},
|
|
9170
|
-
"version": "1.12.
|
|
9171
|
-
"fingerprint": "
|
|
9170
|
+
"version": "1.12.2",
|
|
9171
|
+
"fingerprint": "aVymQvfAo3DJtR28MDa++5wnoZNMwtzq54FCzqs3J3U="
|
|
9172
9172
|
}
|
package/API.md
CHANGED
|
@@ -51,6 +51,7 @@ Configuration for building and pushing the Docker image.
|
|
|
51
51
|
| **Name** | **Description** |
|
|
52
52
|
| --- | --- |
|
|
53
53
|
| <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilder.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
54
|
+
| <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilder.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
54
55
|
|
|
55
56
|
---
|
|
56
57
|
|
|
@@ -62,6 +63,27 @@ public toString(): string
|
|
|
62
63
|
|
|
63
64
|
Returns a string representation of this construct.
|
|
64
65
|
|
|
66
|
+
##### `with` <a name="with" id="token-injectable-docker-builder.TokenInjectableDockerBuilder.with"></a>
|
|
67
|
+
|
|
68
|
+
```typescript
|
|
69
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
Applies one or more mixins to this construct.
|
|
73
|
+
|
|
74
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
75
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
76
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
77
|
+
constructs.
|
|
78
|
+
|
|
79
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="token-injectable-docker-builder.TokenInjectableDockerBuilder.with.parameter.mixins"></a>
|
|
80
|
+
|
|
81
|
+
- *Type:* ...constructs.IMixin[]
|
|
82
|
+
|
|
83
|
+
The mixins to apply.
|
|
84
|
+
|
|
85
|
+
---
|
|
86
|
+
|
|
65
87
|
#### Static Functions <a name="Static Functions" id="Static Functions"></a>
|
|
66
88
|
|
|
67
89
|
| **Name** | **Description** |
|
|
@@ -70,7 +92,7 @@ Returns a string representation of this construct.
|
|
|
70
92
|
|
|
71
93
|
---
|
|
72
94
|
|
|
73
|
-
#####
|
|
95
|
+
##### `isConstruct` <a name="isConstruct" id="token-injectable-docker-builder.TokenInjectableDockerBuilder.isConstruct"></a>
|
|
74
96
|
|
|
75
97
|
```typescript
|
|
76
98
|
import { TokenInjectableDockerBuilder } from 'token-injectable-docker-builder'
|
|
@@ -80,6 +102,20 @@ TokenInjectableDockerBuilder.isConstruct(x: any)
|
|
|
80
102
|
|
|
81
103
|
Checks if `x` is a construct.
|
|
82
104
|
|
|
105
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
106
|
+
instances, even when the construct library is symlinked.
|
|
107
|
+
|
|
108
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
109
|
+
disk are seen as independent, completely different libraries. As a
|
|
110
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
111
|
+
is seen as a different class, and an instance of one class will not test as
|
|
112
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
113
|
+
like this, but users may manually symlink construct libraries together or
|
|
114
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
115
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
116
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
117
|
+
this type-testing method instead.
|
|
118
|
+
|
|
83
119
|
###### `x`<sup>Required</sup> <a name="x" id="token-injectable-docker-builder.TokenInjectableDockerBuilder.isConstruct.parameter.x"></a>
|
|
84
120
|
|
|
85
121
|
- *Type:* any
|
|
@@ -148,6 +184,7 @@ shared Lambdas have permission to start builds and read logs.
|
|
|
148
184
|
| **Name** | **Description** |
|
|
149
185
|
| --- | --- |
|
|
150
186
|
| <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProvider.toString">toString</a></code> | Returns a string representation of this construct. |
|
|
187
|
+
| <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProvider.with">with</a></code> | Applies one or more mixins to this construct. |
|
|
151
188
|
| <code><a href="#token-injectable-docker-builder.TokenInjectableDockerBuilderProvider.registerProject">registerProject</a></code> | Grant the shared Lambdas permission to start builds for a specific CodeBuild project and pull/push to its ECR repository. |
|
|
152
189
|
|
|
153
190
|
---
|
|
@@ -160,6 +197,27 @@ public toString(): string
|
|
|
160
197
|
|
|
161
198
|
Returns a string representation of this construct.
|
|
162
199
|
|
|
200
|
+
##### `with` <a name="with" id="token-injectable-docker-builder.TokenInjectableDockerBuilderProvider.with"></a>
|
|
201
|
+
|
|
202
|
+
```typescript
|
|
203
|
+
public with(mixins: ...IMixin[]): IConstruct
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
Applies one or more mixins to this construct.
|
|
207
|
+
|
|
208
|
+
Mixins are applied in order. The list of constructs is captured at the
|
|
209
|
+
start of the call, so constructs added by a mixin will not be visited.
|
|
210
|
+
Use multiple `with()` calls if subsequent mixins should apply to added
|
|
211
|
+
constructs.
|
|
212
|
+
|
|
213
|
+
###### `mixins`<sup>Required</sup> <a name="mixins" id="token-injectable-docker-builder.TokenInjectableDockerBuilderProvider.with.parameter.mixins"></a>
|
|
214
|
+
|
|
215
|
+
- *Type:* ...constructs.IMixin[]
|
|
216
|
+
|
|
217
|
+
The mixins to apply.
|
|
218
|
+
|
|
219
|
+
---
|
|
220
|
+
|
|
163
221
|
##### `registerProject` <a name="registerProject" id="token-injectable-docker-builder.TokenInjectableDockerBuilderProvider.registerProject"></a>
|
|
164
222
|
|
|
165
223
|
```typescript
|
|
@@ -195,7 +253,7 @@ Grant the shared Lambdas permission to start builds for a specific CodeBuild pro
|
|
|
195
253
|
|
|
196
254
|
---
|
|
197
255
|
|
|
198
|
-
#####
|
|
256
|
+
##### `isConstruct` <a name="isConstruct" id="token-injectable-docker-builder.TokenInjectableDockerBuilderProvider.isConstruct"></a>
|
|
199
257
|
|
|
200
258
|
```typescript
|
|
201
259
|
import { TokenInjectableDockerBuilderProvider } from 'token-injectable-docker-builder'
|
|
@@ -205,6 +263,20 @@ TokenInjectableDockerBuilderProvider.isConstruct(x: any)
|
|
|
205
263
|
|
|
206
264
|
Checks if `x` is a construct.
|
|
207
265
|
|
|
266
|
+
Use this method instead of `instanceof` to properly detect `Construct`
|
|
267
|
+
instances, even when the construct library is symlinked.
|
|
268
|
+
|
|
269
|
+
Explanation: in JavaScript, multiple copies of the `constructs` library on
|
|
270
|
+
disk are seen as independent, completely different libraries. As a
|
|
271
|
+
consequence, the class `Construct` in each copy of the `constructs` library
|
|
272
|
+
is seen as a different class, and an instance of one class will not test as
|
|
273
|
+
`instanceof` the other class. `npm install` will not create installations
|
|
274
|
+
like this, but users may manually symlink construct libraries together or
|
|
275
|
+
use a monorepo tool: in those cases, multiple copies of the `constructs`
|
|
276
|
+
library can be accidentally installed, and `instanceof` will behave
|
|
277
|
+
unpredictably. It is safest to avoid using `instanceof`, and using
|
|
278
|
+
this type-testing method instead.
|
|
279
|
+
|
|
208
280
|
###### `x`<sup>Required</sup> <a name="x" id="token-injectable-docker-builder.TokenInjectableDockerBuilderProvider.isConstruct.parameter.x"></a>
|
|
209
281
|
|
|
210
282
|
- *Type:* any
|
package/lib/index.js
CHANGED
|
@@ -95,7 +95,7 @@ class TokenInjectableDockerBuilderProvider extends constructs_1.Construct {
|
|
|
95
95
|
}
|
|
96
96
|
exports.TokenInjectableDockerBuilderProvider = TokenInjectableDockerBuilderProvider;
|
|
97
97
|
_a = JSII_RTTI_SYMBOL_1;
|
|
98
|
-
TokenInjectableDockerBuilderProvider[_a] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilderProvider", version: "1.12.
|
|
98
|
+
TokenInjectableDockerBuilderProvider[_a] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilderProvider", version: "1.12.2" };
|
|
99
99
|
/**
|
|
100
100
|
* A CDK construct to build and push Docker images to an ECR repository using
|
|
101
101
|
* CodeBuild and Lambda custom resources, **then** retrieve the final image tag
|
|
@@ -382,5 +382,5 @@ class TokenInjectableDockerBuilder extends constructs_1.Construct {
|
|
|
382
382
|
}
|
|
383
383
|
exports.TokenInjectableDockerBuilder = TokenInjectableDockerBuilder;
|
|
384
384
|
_b = JSII_RTTI_SYMBOL_1;
|
|
385
|
-
TokenInjectableDockerBuilder[_b] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilder", version: "1.12.
|
|
385
|
+
TokenInjectableDockerBuilder[_b] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilder", version: "1.12.2" };
|
|
386
386
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import * as crypto from 'crypto';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nimport { CustomResource, Duration, Stack } from 'aws-cdk-lib';\nimport { Project, Source, LinuxBuildImage, LinuxArmBuildImage, BuildSpec } from 'aws-cdk-lib/aws-codebuild';\nimport { IVpc, ISecurityGroup, SubnetSelection } from 'aws-cdk-lib/aws-ec2';\nimport { Repository, RepositoryEncryption, TagStatus } from 'aws-cdk-lib/aws-ecr';\nimport { ContainerImage } from 'aws-cdk-lib/aws-ecs';\nimport { PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { Key } from 'aws-cdk-lib/aws-kms';\nimport { Runtime, Code, DockerImageCode, Function } from 'aws-cdk-lib/aws-lambda';\nimport { ILogGroup } from 'aws-cdk-lib/aws-logs';\nimport { Asset } from 'aws-cdk-lib/aws-s3-assets';\nimport { Provider } from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\n\nconst PROVIDER_SINGLETON_ID = 'TokenInjectableDockerBuilderProvider';\n\n/**\n * Options for creating a `TokenInjectableDockerBuilderProvider`.\n */\nexport interface TokenInjectableDockerBuilderProviderProps {\n  /**\n   * How often the provider polls for build completion.\n   *\n   * @default Duration.seconds(30)\n   */\n  readonly queryInterval?: Duration;\n}\n\n/**\n * Shared provider for `TokenInjectableDockerBuilder` instances.\n *\n * Creates the onEvent and isComplete Lambda functions once per stack.\n * Each builder instance registers its CodeBuild project ARN so the\n * shared Lambdas have permission to start builds and read logs.\n */\nexport class TokenInjectableDockerBuilderProvider extends Construct {\n  /**\n   * Get or create the singleton provider for this stack.\n   * All `TokenInjectableDockerBuilder` instances in the same stack\n   * share a single pair of Lambda functions.\n   */\n  public static getOrCreate(scope: Construct, props?: TokenInjectableDockerBuilderProviderProps): TokenInjectableDockerBuilderProvider {\n    const stack = Stack.of(scope);\n    const existing = stack.node.tryFindChild(PROVIDER_SINGLETON_ID) as TokenInjectableDockerBuilderProvider | undefined;\n    if (existing) return existing;\n    return new TokenInjectableDockerBuilderProvider(stack, PROVIDER_SINGLETON_ID, props);\n  }\n\n  /** The service token used by CustomResource instances. */\n  public readonly serviceToken: string;\n\n  private readonly onEventHandlerFunction: Function;\n  private readonly isCompleteHandlerFunction: Function;\n\n  private constructor(scope: Construct, id: string, props?: TokenInjectableDockerBuilderProviderProps) {\n    super(scope, id);\n\n    this.onEventHandlerFunction = new Function(this, 'OnEventHandler', {\n      runtime: Runtime.NODEJS_22_X,\n      code: Code.fromAsset(path.resolve(__dirname, '../onEvent')),\n      handler: 'onEvent.handler',\n      timeout: Duration.minutes(15),\n    });\n    this.onEventHandlerFunction.addToRolePolicy(\n      new PolicyStatement({\n        actions: [\n          'logs:CreateLogGroup',\n          'logs:PutRetentionPolicy',\n          'logs:DeleteLogGroup',\n        ],\n        resources: ['arn:aws:logs:*:*:log-group:/docker-builder/*'],\n      }),\n    );\n\n    this.isCompleteHandlerFunction = new Function(this, 'IsCompleteHandler', {\n      runtime: Runtime.NODEJS_22_X,\n      code: Code.fromAsset(path.resolve(__dirname, '../isComplete')),\n      handler: 'isComplete.handler',\n      timeout: Duration.minutes(15),\n    });\n    this.isCompleteHandlerFunction.addToRolePolicy(\n      new PolicyStatement({\n        actions: [\n          'codebuild:BatchGetBuilds',\n          'codebuild:ListBuildsForProject',\n          'logs:GetLogEvents',\n          'logs:DescribeLogStreams',\n          'logs:DescribeLogGroups',\n        ],\n        resources: ['*'],\n      }),\n    );\n\n    const provider = new Provider(this, 'Provider', {\n      onEventHandler: this.onEventHandlerFunction,\n      isCompleteHandler: this.isCompleteHandlerFunction,\n      queryInterval: props?.queryInterval ?? Duration.seconds(30),\n    });\n\n    this.serviceToken = provider.serviceToken;\n  }\n\n  /**\n   * Grant the shared Lambdas permission to start builds for a specific\n   * CodeBuild project and pull/push to its ECR repository.\n   */\n  public registerProject(project: Project, ecrRepo: Repository, encryptionKey?: Key): void {\n    this.onEventHandlerFunction.addToRolePolicy(\n      new PolicyStatement({\n        actions: ['codebuild:StartBuild'],\n        resources: [project.projectArn],\n      }),\n    );\n    ecrRepo.grantPullPush(this.onEventHandlerFunction);\n    ecrRepo.grantPullPush(this.isCompleteHandlerFunction);\n\n    if (encryptionKey) {\n      encryptionKey.grantEncryptDecrypt(this.onEventHandlerFunction);\n      encryptionKey.grantEncryptDecrypt(this.isCompleteHandlerFunction);\n    }\n  }\n}\n\n/**\n * Properties for the `TokenInjectableDockerBuilder` construct.\n */\nexport interface TokenInjectableDockerBuilderProps {\n  /**\n   * The path to the directory containing the Dockerfile or source code.\n   */\n  readonly path: string;\n\n  /**\n   * Build arguments to pass to the Docker build process.\n   * These are transformed into `--build-arg KEY=VALUE` flags.\n   * @example\n   * {\n   *   TOKEN: 'my-secret-token',\n   *   ENV: 'production'\n   * }\n   */\n  readonly buildArgs?: { [key: string]: string };\n\n  /**\n   * The ARN of the AWS Secrets Manager secret containing Docker login credentials.\n   * This secret should store a JSON object with the following structure:\n   * ```json\n   * {\n   *   \"username\": \"my-docker-username\",\n   *   \"password\": \"my-docker-password\"\n   * }\n   * ```\n   * If not provided (or not needed), the construct will skip Docker Hub login.\n   *\n   * **Note**: The secret must be in the same region as the stack.\n   *\n   * @example 'arn:aws:secretsmanager:us-east-1:123456789012:secret:DockerLoginSecret'\n   */\n  readonly dockerLoginSecretArn?: string;\n\n  /**\n   * The VPC in which the CodeBuild project will be deployed.\n   * If provided, the CodeBuild project will be launched within the specified VPC.\n   *\n   * @default - No VPC is attached, and the CodeBuild project will use public internet.\n   */\n  readonly vpc?: IVpc;\n\n  /**\n   * The security groups to attach to the CodeBuild project.\n   * These define the network access rules for the CodeBuild project.\n   *\n   * @default - No security groups are attached.\n   */\n  readonly securityGroups?: ISecurityGroup[];\n\n  /**\n   * The subnet selection to specify which subnets to use within the VPC.\n   * Allows the user to select private, public, or isolated subnets.\n   *\n   * @default - All subnets in the VPC are used.\n   */\n  readonly subnetSelection?: SubnetSelection;\n\n  /**\n   * Custom commands to run during the install phase of CodeBuild.\n   *\n   * **Example**:\n   * ```ts\n   * installCommands: [\n   *   'echo \"Updating package lists...\"',\n   *   'apt-get update -y',\n   *   'echo \"Installing required packages...\"',\n   *   'apt-get install -y curl dnsutils',\n   * ],\n   * ```\n   * @default - No additional install commands.\n   */\n  readonly installCommands?: string[];\n\n  /**\n   * Custom commands to run during the pre_build phase of CodeBuild.\n   *\n   * **Example**:\n   * ```ts\n   * preBuildCommands: [\n   *   'echo \"Fetching configuration from private API...\"',\n   *   'curl -o config.json https://api.example.com/config',\n   * ],\n   * ```\n   * @default - No additional pre-build commands.\n   */\n  readonly preBuildCommands?: string[];\n\n  /**\n   * Whether to enable KMS encryption for the ECR repository.\n   * If `true`, a KMS key will be created for encrypting ECR images.\n   * If `false`, the repository will use AES-256 encryption.\n   *\n   * @default - false\n   */\n  readonly kmsEncryption?: boolean;\n\n  /**\n   * The query interval for checking if the CodeBuild project has completed.\n   * This determines how frequently the custom resource polls for build completion.\n   *\n   * @default - Duration.seconds(30)\n   */\n  readonly completenessQueryInterval?: Duration;\n\n  /**\n   * A list of file paths in the Docker directory to exclude from build.\n   * Will use paths in .dockerignore file if present.\n   *\n   * @default - No file path exclusions\n   */\n  readonly exclude?: string[];\n\n  /**\n   * The name of the Dockerfile to use for the build.\n   * Passed as `--file` to `docker build`.\n   *\n   * @example 'Dockerfile.production'\n   * @default 'Dockerfile'\n   */\n  readonly file?: string;\n\n  /**\n   * When `true`, disables Docker layer caching. Every build runs from scratch.\n   * Use for debugging, corrupted cache, or major dependency changes.\n   *\n   * @default false\n   */\n  readonly cacheDisabled?: boolean;\n\n  /**\n   * CloudWatch log group for CodeBuild build logs.\n   * When provided with a RETAIN removal policy, build logs survive rollbacks\n   * and stack deletion for debugging.\n   *\n   * @default - CodeBuild default logging (logs are deleted on rollback)\n   */\n  readonly buildLogGroup?: ILogGroup;\n\n  /**\n   * Target platform for the Docker image.\n   *\n   * When set to `'linux/arm64'`, the construct uses a native ARM/Graviton\n   * CodeBuild instance for fast builds without emulation.\n   *\n   * @default 'linux/amd64'\n   */\n  readonly platform?: 'linux/amd64' | 'linux/arm64';\n\n  /**\n   * Shared provider for the custom resource Lambdas.\n   * Use `TokenInjectableDockerBuilderProvider.getOrCreate(this)` to create\n   * a singleton that is shared across all builders in the same stack.\n   *\n   * When omitted, each builder creates its own Lambdas (original behavior).\n   *\n   * @default - A new provider is created per builder instance\n   */\n  readonly provider?: TokenInjectableDockerBuilderProvider;\n\n  /**\n   * ECR pull-through cache repository prefixes to grant pull access to.\n   * Use when your Dockerfile references base images from ECR pull-through\n   * cache (e.g. docker-hub/library/node:20-slim, ghcr/org/image:tag).\n   * The CodeBuild role will be granted ecr:BatchGetImage, ecr:GetDownloadUrlForLayer,\n   * and ecr:BatchCheckLayerAvailability on repositories matching each prefix.\n   *\n   * @example ['docker-hub', 'ghcr']\n   * @default - No pull-through cache access\n   */\n  readonly ecrPullThroughCachePrefixes?: string[];\n\n  /**\n   * When `true`, creates a CloudWatch log group outside of CloudFormation\n   * (`/docker-builder/<projectName>`) and directs CodeBuild output there.\n   * Because the log group is managed imperatively (not by CloudFormation),\n   * it survives stack rollbacks and preserves full build logs for debugging.\n   * A 7-day retention policy is applied so old logs auto-expire.\n   *\n   * Set to `false` after debugging to delete the log group and clean up.\n   *\n   * @default false\n   */\n  readonly retainBuildLogs?: boolean;\n}\n\n/**\n * A CDK construct to build and push Docker images to an ECR repository using\n * CodeBuild and Lambda custom resources, **then** retrieve the final image tag\n * so that ECS/Lambda references use the exact digest.\n */\nexport class TokenInjectableDockerBuilder extends Construct {\n  /**\n   * The ECR repository that stores the resulting Docker image.\n   */\n  private readonly ecrRepository: Repository;\n\n  /**\n   * An ECS-compatible container image referencing the tag\n   * of the built Docker image.\n   */\n  public readonly containerImage: ContainerImage;\n\n  /**\n   * A Lambda-compatible DockerImageCode referencing the tag\n   * of the built Docker image.\n   */\n  public readonly dockerImageCode: DockerImageCode;\n\n  /**\n   * Creates a new `TokenInjectableDockerBuilder`.\n   *\n   * @param scope The scope in which to define this construct.\n   * @param id The scoped construct ID.\n   * @param props Configuration for building and pushing the Docker image.\n   */\n  constructor(scope: Construct, id: string, props: TokenInjectableDockerBuilderProps) {\n    super(scope, id);\n\n    const {\n      path: sourcePath,\n      buildArgs,\n      dockerLoginSecretArn,\n      vpc,\n      securityGroups,\n      subnetSelection,\n      installCommands,\n      preBuildCommands,\n      kmsEncryption = false,\n      completenessQueryInterval,\n      exclude,\n      file: dockerFile,\n      cacheDisabled = false,\n      buildLogGroup: buildLogGroupProp,\n      platform = 'linux/amd64',\n      provider: sharedProvider,\n      ecrPullThroughCachePrefixes,\n      retainBuildLogs = false,\n    } = props;\n\n    // Generate an ephemeral tag for CodeBuild\n    const imageTag = crypto.randomUUID();\n\n    // Optionally define a KMS key for ECR encryption if requested\n    let encryptionKey: Key | undefined;\n    if (kmsEncryption) {\n      encryptionKey = new Key(this, 'EcrEncryptionKey', {\n        enableKeyRotation: true,\n      });\n    }\n\n    // Create an ECR repository (optionally with KMS encryption)\n    this.ecrRepository = new Repository(this, 'ECRRepository', {\n      lifecycleRules: [\n        {\n          rulePriority: 1,\n          description: 'Remove untagged images after 1 day',\n          tagStatus: TagStatus.UNTAGGED,\n          maxImageAge: Duration.days(1),\n        },\n      ],\n      encryption: kmsEncryption ? RepositoryEncryption.KMS : RepositoryEncryption.AES_256,\n      encryptionKey: kmsEncryption ? encryptionKey : undefined,\n      imageScanOnPush: true,\n    });\n\n    let effectiveExclude = exclude;\n    if (!effectiveExclude) {\n      const dockerignorePath = path.join(sourcePath, '.dockerignore');\n      if (fs.existsSync(dockerignorePath)) {\n        const fileContent = fs.readFileSync(dockerignorePath, 'utf8');\n        effectiveExclude = fileContent\n          .split('\\n')\n          .map((line: string) => line.trim())\n          .filter((line: string) => line.length > 0 && !line.startsWith('#'));\n      }\n    }\n\n    // Ensure the target Dockerfile is never excluded (handles globs like \"Dockerfile*\")\n    const dockerFileName = dockerFile ?? 'Dockerfile';\n    if (effectiveExclude) {\n      effectiveExclude = effectiveExclude.filter((pattern: string) => {\n        const escaped = pattern.replace(/[.+^${}()|[\\]\\\\]/g, '\\\\$&');\n        const regex = new RegExp(`^${escaped.replace(/\\*/g, '.*').replace(/\\?/g, '.')}$`, 'i');\n        return !regex.test(dockerFileName);\n      });\n    }\n\n    // Wrap the source folder as an S3 asset for CodeBuild to use\n    const sourceAsset = new Asset(this, 'SourceAsset', {\n      path: sourcePath,\n      exclude: effectiveExclude,\n    });\n\n    // Convert buildArgs to a CLI-friendly string\n    const buildArgsString = buildArgs\n      ? Object.entries(buildArgs)\n        .map(([k, v]) => `--build-arg ${k}=${v}`)\n        .join(' ')\n      : '';\n\n    const dockerFileFlag = dockerFile ? `-f $CODEBUILD_SRC_DIR/${dockerFile}` : '';\n\n    // Optional DockerHub login, if a secret ARN is provided\n    const dockerLoginCommands = dockerLoginSecretArn\n      ? [\n        'echo \"Retrieving Docker credentials...\"',\n        'apt-get update -y && apt-get install -y jq',\n        `DOCKER_USERNAME=$(aws secretsmanager get-secret-value --secret-id ${dockerLoginSecretArn} --query SecretString --output text | jq -r .username)`,\n        `DOCKER_PASSWORD=$(aws secretsmanager get-secret-value --secret-id ${dockerLoginSecretArn} --query SecretString --output text | jq -r .password)`,\n        'echo \"Logging in to Docker Hub...\"',\n        'echo $DOCKER_PASSWORD | docker login --username $DOCKER_USERNAME --password-stdin',\n      ]\n      : ['echo \"No Docker credentials. Skipping Docker Hub login.\"'];\n\n    const buildxInstallCommands = cacheDisabled\n      ? []\n      : [\n        'echo \"Setting up Docker buildx for ECR layer cache...\"',\n        'docker buildx create --driver docker-container --name ecr-cache-builder --use 2>/dev/null || docker buildx use ecr-cache-builder',\n      ];\n\n    const platformFlag = `--platform ${platform}`;\n\n    // --provenance=false --sbom=false: Docker Buildx v0.10+ adds attestations by default,\n    // producing OCI image indexes that AWS Lambda does not support. Disable them for Lambda/ECS compatibility.\n    const buildCommand = cacheDisabled\n      ? `docker build ${platformFlag} ${dockerFileFlag} ${buildArgsString} -t $ECR_REPO_URI:${imageTag} $CODEBUILD_SRC_DIR`\n      : `docker buildx build --push ${platformFlag} --provenance=false --sbom=false --cache-from type=registry,ref=$ECR_REPO_URI:cache --cache-to type=registry,ref=$ECR_REPO_URI:cache,mode=max,image-manifest=true ${dockerFileFlag} ${buildArgsString} -t $ECR_REPO_URI:${imageTag} $CODEBUILD_SRC_DIR`;\n\n    const buildSpecObj = {\n      version: '0.2',\n      phases: {\n        install: {\n          commands: [\n            'echo \"Beginning install phase...\"',\n            ...(installCommands ?? []),\n            ...buildxInstallCommands,\n          ],\n        },\n        pre_build: {\n          commands: [\n            ...(preBuildCommands ?? []),\n            ...dockerLoginCommands,\n            'echo \"Retrieving AWS Account ID...\"',\n            'export ACCOUNT_ID=$(aws sts get-caller-identity --query Account --output text)',\n            'echo \"Logging into Amazon ECR...\"',\n            'aws ecr get-login-password --region $AWS_DEFAULT_REGION | docker login --username AWS --password-stdin $ACCOUNT_ID.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com',\n          ],\n        },\n        build: {\n          commands: [\n            `echo \"Building Docker image with tag ${imageTag}...\"`,\n            buildCommand,\n          ],\n        },\n        ...(cacheDisabled && {\n          post_build: {\n            commands: [\n              `echo \"Pushing Docker image with tag ${imageTag}...\"`,\n              `docker push $ECR_REPO_URI:${imageTag}`,\n            ],\n          },\n        }),\n      },\n    };\n\n    const isArm = platform === 'linux/arm64';\n    const codeBuildImage = isArm\n      ? LinuxArmBuildImage.AMAZON_LINUX_2_STANDARD_3_0\n      : LinuxBuildImage.STANDARD_7_0;\n\n    // Create the CodeBuild project\n    const codeBuildProject = new Project(this, 'CodeBuildProject', {\n      source: Source.s3({\n        bucket: sourceAsset.bucket,\n        path: sourceAsset.s3ObjectKey,\n      }),\n      environment: {\n        buildImage: codeBuildImage,\n        privileged: true,\n      },\n      environmentVariables: {\n        ECR_REPO_URI: { value: this.ecrRepository.repositoryUri },\n      },\n      buildSpec: BuildSpec.fromObject(buildSpecObj),\n      ...(buildLogGroupProp && {\n        logging: {\n          cloudWatch: {\n            logGroup: buildLogGroupProp,\n          },\n        },\n      }),\n      vpc,\n      securityGroups,\n      subnetSelection,\n    });\n\n    // Grant CodeBuild permission to write to the retained build logs group\n    if (retainBuildLogs) {\n      const stack = Stack.of(this);\n      codeBuildProject.addToRolePolicy(\n        new PolicyStatement({\n          actions: [\n            'logs:CreateLogGroup',\n            'logs:CreateLogStream',\n            'logs:PutLogEvents',\n          ],\n          resources: [\n            `arn:aws:logs:${stack.region}:${stack.account}:log-group:/docker-builder/${codeBuildProject.projectName}`,\n            `arn:aws:logs:${stack.region}:${stack.account}:log-group:/docker-builder/${codeBuildProject.projectName}:*`,\n          ],\n        }),\n      );\n    }\n\n    // Grant CodeBuild the ability to interact with ECR\n    this.ecrRepository.grantPullPush(codeBuildProject);\n    codeBuildProject.addToRolePolicy(\n      new PolicyStatement({\n        actions: [\n          'ecr:GetAuthorizationToken',\n          'ecr:GetDownloadUrlForLayer',\n          'ecr:BatchCheckLayerAvailability',\n          'ecr:BatchGetImage',\n        ],\n        resources: ['*'],\n      }),\n    );\n    if (ecrPullThroughCachePrefixes && ecrPullThroughCachePrefixes.length > 0) {\n      const stack = Stack.of(this);\n      codeBuildProject.addToRolePolicy(\n        new PolicyStatement({\n          actions: [\n            'ecr:BatchGetImage',\n            'ecr:GetDownloadUrlForLayer',\n            'ecr:BatchCheckLayerAvailability',\n            'ecr:BatchImportUpstreamImage',\n            'ecr:CreateRepository',\n          ],\n          resources: ecrPullThroughCachePrefixes.map(\n            (prefix) => `arn:aws:ecr:${stack.region}:${stack.account}:repository/${prefix}/*`,\n          ),\n        }),\n      );\n    }\n    if (dockerLoginSecretArn) {\n      codeBuildProject.addToRolePolicy(\n        new PolicyStatement({\n          actions: ['secretsmanager:GetSecretValue'],\n          resources: [dockerLoginSecretArn],\n        }),\n      );\n    }\n\n    // Conditionally grant KMS encrypt/decrypt if a key is used\n    if (encryptionKey) {\n      encryptionKey.grantEncryptDecrypt(codeBuildProject.role!);\n    }\n\n    // Resolve the service token: shared provider or per-instance Lambdas\n    let serviceToken: string;\n    if (sharedProvider) {\n      sharedProvider.registerProject(codeBuildProject, this.ecrRepository, encryptionKey);\n      serviceToken = sharedProvider.serviceToken;\n    } else {\n      const onEventHandlerFunction = new Function(this, 'OnEventHandlerFunction', {\n        runtime: Runtime.NODEJS_22_X,\n        code: Code.fromAsset(path.resolve(__dirname, '../onEvent')),\n        handler: 'onEvent.handler',\n        timeout: Duration.minutes(15),\n      });\n      onEventHandlerFunction.addToRolePolicy(\n        new PolicyStatement({\n          actions: ['codebuild:StartBuild'],\n          resources: [codeBuildProject.projectArn],\n        }),\n      );\n      onEventHandlerFunction.addToRolePolicy(\n        new PolicyStatement({\n          actions: [\n            'logs:CreateLogGroup',\n            'logs:PutRetentionPolicy',\n            'logs:DeleteLogGroup',\n          ],\n          resources: ['arn:aws:logs:*:*:log-group:/docker-builder/*'],\n        }),\n      );\n\n      const isCompleteHandlerFunction = new Function(this, 'IsCompleteHandlerFunction', {\n        runtime: Runtime.NODEJS_22_X,\n        code: Code.fromAsset(path.resolve(__dirname, '../isComplete')),\n        environment: {\n          IMAGE_TAG: imageTag,\n        },\n        handler: 'isComplete.handler',\n        timeout: Duration.minutes(15),\n      });\n      isCompleteHandlerFunction.addToRolePolicy(\n        new PolicyStatement({\n          actions: [\n            'codebuild:BatchGetBuilds',\n            'codebuild:ListBuildsForProject',\n            'logs:GetLogEvents',\n            'logs:DescribeLogStreams',\n            'logs:DescribeLogGroups',\n          ],\n          resources: ['*'],\n        }),\n      );\n\n      if (encryptionKey) {\n        encryptionKey.grantEncryptDecrypt(onEventHandlerFunction);\n        encryptionKey.grantEncryptDecrypt(isCompleteHandlerFunction);\n      }\n      this.ecrRepository.grantPullPush(onEventHandlerFunction);\n      this.ecrRepository.grantPullPush(isCompleteHandlerFunction);\n\n      const provider = new Provider(this, 'CustomResourceProvider', {\n        onEventHandler: onEventHandlerFunction,\n        isCompleteHandler: isCompleteHandlerFunction,\n        queryInterval: completenessQueryInterval ?? Duration.seconds(30),\n      });\n      serviceToken = provider.serviceToken;\n    }\n\n    // Custom Resource that triggers the CodeBuild and waits for completion\n    const buildTriggerResource = new CustomResource(this, 'BuildTriggerResource', {\n      serviceToken,\n      properties: {\n        ProjectName: codeBuildProject.projectName,\n        ImageTag: imageTag,\n        Trigger: sourceAsset.assetHash,\n        RetainBuildLogs: retainBuildLogs ? 'true' : 'false',\n      },\n    });\n    buildTriggerResource.node.addDependency(codeBuildProject);\n\n    // Retrieve the final Docker image tag from Data.ImageTag\n    const imageTagRef = buildTriggerResource.getAttString('ImageTag');\n    this.containerImage = ContainerImage.fromEcrRepository(this.ecrRepository, imageTagRef);\n    this.dockerImageCode = DockerImageCode.fromEcr(this.ecrRepository, {\n      tagOrDigest: imageTagRef,\n    });\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -42,30 +42,30 @@
|
|
|
42
42
|
"devDependencies": {
|
|
43
43
|
"@stylistic/eslint-plugin": "^2",
|
|
44
44
|
"@types/jest": "^29.5.14",
|
|
45
|
-
"@types/node": "^22.19.
|
|
45
|
+
"@types/node": "^22.19.15",
|
|
46
46
|
"@typescript-eslint/eslint-plugin": "^8",
|
|
47
47
|
"@typescript-eslint/parser": "^8",
|
|
48
48
|
"aws-cdk-lib": "2.238.0",
|
|
49
49
|
"commit-and-tag-version": "^12",
|
|
50
|
-
"constructs": "10.
|
|
50
|
+
"constructs": "10.5.1",
|
|
51
51
|
"eslint": "^9",
|
|
52
52
|
"eslint-import-resolver-typescript": "^3.10.1",
|
|
53
53
|
"eslint-plugin-import": "^2.32.0",
|
|
54
54
|
"jest": "^29.7.0",
|
|
55
55
|
"jest-junit": "^16",
|
|
56
56
|
"jsii": "~5.9.27",
|
|
57
|
-
"jsii-diff": "^1.
|
|
57
|
+
"jsii-diff": "^1.127.0",
|
|
58
58
|
"jsii-docgen": "^10.11.0",
|
|
59
|
-
"jsii-pacmak": "^1.
|
|
59
|
+
"jsii-pacmak": "^1.127.0",
|
|
60
60
|
"jsii-rosetta": "~5.9.27",
|
|
61
|
-
"projen": "^0.99.
|
|
61
|
+
"projen": "^0.99.25",
|
|
62
62
|
"ts-jest": "^29.4.6",
|
|
63
63
|
"ts-node": "^10.9.2",
|
|
64
64
|
"typescript": "^5.9.3"
|
|
65
65
|
},
|
|
66
66
|
"peerDependencies": {
|
|
67
67
|
"aws-cdk-lib": "^2.238.0",
|
|
68
|
-
"constructs": "^10.
|
|
68
|
+
"constructs": "^10.5.1"
|
|
69
69
|
},
|
|
70
70
|
"keywords": [
|
|
71
71
|
"aws",
|
|
@@ -98,7 +98,7 @@
|
|
|
98
98
|
"publishConfig": {
|
|
99
99
|
"access": "public"
|
|
100
100
|
},
|
|
101
|
-
"version": "1.12.
|
|
101
|
+
"version": "1.12.2",
|
|
102
102
|
"jest": {
|
|
103
103
|
"coverageProvider": "v8",
|
|
104
104
|
"testMatch": [
|