token-injectable-docker-builder 1.0.1 → 1.0.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 CHANGED
@@ -4056,6 +4056,6 @@
4056
4056
  "symbolId": "src/index:TokenInjectableDockerBuilderProps"
4057
4057
  }
4058
4058
  },
4059
- "version": "1.0.1",
4060
- "fingerprint": "bAw/kr8wy+8DBOatIsJQcEwY7gqDQMe9vQ1zuXwtsxU="
4059
+ "version": "1.0.2",
4060
+ "fingerprint": "M3quRv4OiP/T3iZnoD3jgdXJh/dwc6KeZAqX8Q5/p4U="
4061
4061
  }
package/lib/index.js CHANGED
@@ -151,5 +151,5 @@ class TokenInjectableDockerBuilder extends constructs_1.Construct {
151
151
  }
152
152
  exports.TokenInjectableDockerBuilder = TokenInjectableDockerBuilder;
153
153
  _a = JSII_RTTI_SYMBOL_1;
154
- TokenInjectableDockerBuilder[_a] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilder", version: "1.0.1" };
154
+ TokenInjectableDockerBuilder[_a] = { fqn: "token-injectable-docker-builder.TokenInjectableDockerBuilder", version: "1.0.2" };
155
155
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { CustomResource, Stack, Duration } from 'aws-cdk-lib';\nimport { Project, Source, LinuxBuildImage, BuildSpec } from 'aws-cdk-lib/aws-codebuild';\nimport { Repository } from 'aws-cdk-lib/aws-ecr';\nimport { ContainerImage } from 'aws-cdk-lib/aws-ecs';\nimport { PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { Runtime, Code, DockerImageCode, Function } from 'aws-cdk-lib/aws-lambda';\nimport { Asset } from 'aws-cdk-lib/aws-s3-assets';\nimport { Provider } from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\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` flags.\n   * @example\n   * {\n   *   TOKEN: 'my-secret-token',\n   *   ENV: 'production'\n   * }\n   */\n  readonly buildArgs?: { [key: string]: string };\n}\n\n\n/**\n * A CDK construct to build and push Docker images to an ECR repository using CodeBuild and Lambda custom resources.\n *\n * @example\n * const dockerBuilder = new TokenInjectableDockerBuilder(this, 'DockerBuilder', {\n *   path: './docker',\n *   buildArgs: {\n *     TOKEN: 'my-secret-token',\n *     ENV: 'production'\n *   },\n * });\n *\n * const containerImage = dockerBuilder.getContainerImage();\n */\nexport class TokenInjectableDockerBuilder extends Construct {\n  public readonly containerImage: ContainerImage;\n  public readonly dockerImageCode: DockerImageCode;\n  private readonly ecrRepository: Repository;\n\n  /**\n   * Creates a new `TokenInjectableDockerBuilder` instance.\n   *\n   * @param scope The parent construct/stack.\n   * @param id The unique ID of the construct.\n   * @param props Configuration properties for the construct.\n   */\n  constructor(scope: Construct, id: string, props: TokenInjectableDockerBuilderProps) {\n    super(scope, id);\n\n    const { path: sourcePath, buildArgs } = props; // Default to linux/amd64\n\n    // Create an ECR repository\n    this.ecrRepository = new Repository(this, 'ECRRepository');\n\n    // Package the source code as an asset\n    const sourceAsset = new Asset(this, 'SourceAsset', {\n      path: sourcePath, // Path to the Dockerfile or source code\n    });\n\n    // Transform buildArgs into a string of --build-arg KEY=VALUE\n    const buildArgsString = buildArgs\n      ? Object.entries(buildArgs)\n        .map(([key, value]) => `--build-arg ${key}=${value}`)\n        .join(' ')\n      : '';\n\n    // Pass the buildArgsString and platform as environment variables\n    const environmentVariables: { [name: string]: { value: string } } = {\n      ECR_REPO_URI: { value: this.ecrRepository.repositoryUri },\n      BUILD_ARGS: { value: buildArgsString },\n    };\n\n    // Create a CodeBuild project\n    const codeBuildProject = new Project(this, 'UICodeBuildProject', {\n      source: Source.s3({\n        bucket: sourceAsset.bucket,\n        path: sourceAsset.s3ObjectKey,\n      }),\n      environment: {\n        buildImage: LinuxBuildImage.STANDARD_7_0,\n        privileged: true, // Required for Docker builds\n      },\n      environmentVariables: environmentVariables,\n      buildSpec: BuildSpec.fromObject({\n        version: '0.2',\n        phases: {\n          pre_build: {\n            commands: [\n              'echo \"Retrieving AWS Account ID...\"',\n              'export ACCOUNT_ID=$(aws sts get-caller-identity --query Account --output text)',\n              'echo \"Logging in to 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 Build phase: Building the Docker image...',\n              'docker build $BUILD_ARGS -t $ECR_REPO_URI:latest $CODEBUILD_SRC_DIR',\n            ],\n          },\n          post_build: {\n            commands: [\n              'echo Post-build phase: Pushing the Docker image...',\n              'docker push $ECR_REPO_URI:latest',\n            ],\n          },\n        },\n      }),\n    });\n\n    // Grant permissions to interact with ECR\n    this.ecrRepository.grantPullPush(codeBuildProject);\n\n    codeBuildProject.role!.addToPrincipalPolicy(\n      new PolicyStatement({\n        actions: ['ecr:GetAuthorizationToken'],\n        resources: ['*'],\n      }),\n    );\n\n    // Grant permissions to CodeBuild for CloudWatch Logs\n    codeBuildProject.role!.addToPrincipalPolicy(\n      new PolicyStatement({\n        actions: ['logs:PutLogEvents', 'logs:CreateLogGroup', 'logs:CreateLogStream'],\n        resources: [`arn:aws:logs:${Stack.of(this).region}:${Stack.of(this).account}:*`],\n      }),\n    );\n\n    // Create Node.js Lambda function for onEvent\n    const onEventHandlerFunction = new Function(this, 'OnEventHandlerFunction', {\n      runtime: Runtime.NODEJS_LATEST, // Use Node.js runtime\n      code: Code.fromAsset('.'), // Path to handler code\n      handler: 'onEvent.handler', // Entry point (adjust as needed)\n      timeout: Duration.minutes(15),\n    });\n\n    onEventHandlerFunction.addToRolePolicy(\n      new PolicyStatement({\n        actions: ['codebuild:StartBuild'],\n        resources: [codeBuildProject.projectArn], // Restrict to specific project\n      }),\n    );\n\n    // Create Node.js Lambda function for isComplete\n    const isCompleteHandlerFunction = new Function(this, 'IsCompleteHandlerFunction', {\n      runtime: Runtime.NODEJS_LATEST,\n      code: Code.fromAsset('.'), // Path to handler code\n      handler: 'isComplete.handler', // Entry point (adjust as needed)\n      timeout: Duration.minutes(15),\n    });\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    // Create a custom resource provider\n    const provider = new Provider(this, 'CustomResourceProvider', {\n      onEventHandler: onEventHandlerFunction,\n      isCompleteHandler: isCompleteHandlerFunction,\n      queryInterval: Duration.seconds(30),\n    });\n\n    // Define the custom resource\n    const buildTriggerResource = new CustomResource(this, 'BuildTriggerResource', {\n      serviceToken: provider.serviceToken,\n      properties: {\n        ProjectName: codeBuildProject.projectName,\n        Trigger: crypto.randomUUID(),\n      },\n    });\n\n    buildTriggerResource.node.addDependency(codeBuildProject);\n    this.containerImage = ContainerImage.fromEcrRepository(this.ecrRepository);\n    this.dockerImageCode = DockerImageCode.fromEcr(this.ecrRepository);\n  }\n}\n"]}
package/package.json CHANGED
@@ -93,7 +93,7 @@
93
93
  "publishConfig": {
94
94
  "access": "public"
95
95
  },
96
- "version": "1.0.1",
96
+ "version": "1.0.2",
97
97
  "jest": {
98
98
  "coverageProvider": "v8",
99
99
  "testMatch": [
package/src/index.ts DELETED
@@ -1,197 +0,0 @@
1
- import { CustomResource, Stack, Duration } from 'aws-cdk-lib';
2
- import { Project, Source, LinuxBuildImage, BuildSpec } from 'aws-cdk-lib/aws-codebuild';
3
- import { Repository } from 'aws-cdk-lib/aws-ecr';
4
- import { ContainerImage } from 'aws-cdk-lib/aws-ecs';
5
- import { PolicyStatement } from 'aws-cdk-lib/aws-iam';
6
- import { Runtime, Code, DockerImageCode, Function } from 'aws-cdk-lib/aws-lambda';
7
- import { Asset } from 'aws-cdk-lib/aws-s3-assets';
8
- import { Provider } from 'aws-cdk-lib/custom-resources';
9
- import { Construct } from 'constructs';
10
-
11
- /**
12
- * Properties for the `TokenInjectableDockerBuilder` construct.
13
- */
14
- export interface TokenInjectableDockerBuilderProps {
15
- /**
16
- * The path to the directory containing the Dockerfile or source code.
17
- */
18
- readonly path: string;
19
-
20
- /**
21
- * Build arguments to pass to the Docker build process.
22
- * These are transformed into `--build-arg` flags.
23
- * @example
24
- * {
25
- * TOKEN: 'my-secret-token',
26
- * ENV: 'production'
27
- * }
28
- */
29
- readonly buildArgs?: { [key: string]: string };
30
- }
31
-
32
-
33
- /**
34
- * A CDK construct to build and push Docker images to an ECR repository using CodeBuild and Lambda custom resources.
35
- *
36
- * @example
37
- * const dockerBuilder = new TokenInjectableDockerBuilder(this, 'DockerBuilder', {
38
- * path: './docker',
39
- * buildArgs: {
40
- * TOKEN: 'my-secret-token',
41
- * ENV: 'production'
42
- * },
43
- * });
44
- *
45
- * const containerImage = dockerBuilder.getContainerImage();
46
- */
47
- export class TokenInjectableDockerBuilder extends Construct {
48
- public readonly containerImage: ContainerImage;
49
- public readonly dockerImageCode: DockerImageCode;
50
- private readonly ecrRepository: Repository;
51
-
52
- /**
53
- * Creates a new `TokenInjectableDockerBuilder` instance.
54
- *
55
- * @param scope The parent construct/stack.
56
- * @param id The unique ID of the construct.
57
- * @param props Configuration properties for the construct.
58
- */
59
- constructor(scope: Construct, id: string, props: TokenInjectableDockerBuilderProps) {
60
- super(scope, id);
61
-
62
- const { path: sourcePath, buildArgs } = props; // Default to linux/amd64
63
-
64
- // Create an ECR repository
65
- this.ecrRepository = new Repository(this, 'ECRRepository');
66
-
67
- // Package the source code as an asset
68
- const sourceAsset = new Asset(this, 'SourceAsset', {
69
- path: sourcePath, // Path to the Dockerfile or source code
70
- });
71
-
72
- // Transform buildArgs into a string of --build-arg KEY=VALUE
73
- const buildArgsString = buildArgs
74
- ? Object.entries(buildArgs)
75
- .map(([key, value]) => `--build-arg ${key}=${value}`)
76
- .join(' ')
77
- : '';
78
-
79
- // Pass the buildArgsString and platform as environment variables
80
- const environmentVariables: { [name: string]: { value: string } } = {
81
- ECR_REPO_URI: { value: this.ecrRepository.repositoryUri },
82
- BUILD_ARGS: { value: buildArgsString },
83
- };
84
-
85
- // Create a CodeBuild project
86
- const codeBuildProject = new Project(this, 'UICodeBuildProject', {
87
- source: Source.s3({
88
- bucket: sourceAsset.bucket,
89
- path: sourceAsset.s3ObjectKey,
90
- }),
91
- environment: {
92
- buildImage: LinuxBuildImage.STANDARD_7_0,
93
- privileged: true, // Required for Docker builds
94
- },
95
- environmentVariables: environmentVariables,
96
- buildSpec: BuildSpec.fromObject({
97
- version: '0.2',
98
- phases: {
99
- pre_build: {
100
- commands: [
101
- 'echo "Retrieving AWS Account ID..."',
102
- 'export ACCOUNT_ID=$(aws sts get-caller-identity --query Account --output text)',
103
- 'echo "Logging in to Amazon ECR..."',
104
- 'aws ecr get-login-password --region $AWS_DEFAULT_REGION | docker login --username AWS --password-stdin $ACCOUNT_ID.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com',
105
- ],
106
- },
107
- build: {
108
- commands: [
109
- 'echo Build phase: Building the Docker image...',
110
- 'docker build $BUILD_ARGS -t $ECR_REPO_URI:latest $CODEBUILD_SRC_DIR',
111
- ],
112
- },
113
- post_build: {
114
- commands: [
115
- 'echo Post-build phase: Pushing the Docker image...',
116
- 'docker push $ECR_REPO_URI:latest',
117
- ],
118
- },
119
- },
120
- }),
121
- });
122
-
123
- // Grant permissions to interact with ECR
124
- this.ecrRepository.grantPullPush(codeBuildProject);
125
-
126
- codeBuildProject.role!.addToPrincipalPolicy(
127
- new PolicyStatement({
128
- actions: ['ecr:GetAuthorizationToken'],
129
- resources: ['*'],
130
- }),
131
- );
132
-
133
- // Grant permissions to CodeBuild for CloudWatch Logs
134
- codeBuildProject.role!.addToPrincipalPolicy(
135
- new PolicyStatement({
136
- actions: ['logs:PutLogEvents', 'logs:CreateLogGroup', 'logs:CreateLogStream'],
137
- resources: [`arn:aws:logs:${Stack.of(this).region}:${Stack.of(this).account}:*`],
138
- }),
139
- );
140
-
141
- // Create Node.js Lambda function for onEvent
142
- const onEventHandlerFunction = new Function(this, 'OnEventHandlerFunction', {
143
- runtime: Runtime.NODEJS_LATEST, // Use Node.js runtime
144
- code: Code.fromAsset('.'), // Path to handler code
145
- handler: 'onEvent.handler', // Entry point (adjust as needed)
146
- timeout: Duration.minutes(15),
147
- });
148
-
149
- onEventHandlerFunction.addToRolePolicy(
150
- new PolicyStatement({
151
- actions: ['codebuild:StartBuild'],
152
- resources: [codeBuildProject.projectArn], // Restrict to specific project
153
- }),
154
- );
155
-
156
- // Create Node.js Lambda function for isComplete
157
- const isCompleteHandlerFunction = new Function(this, 'IsCompleteHandlerFunction', {
158
- runtime: Runtime.NODEJS_LATEST,
159
- code: Code.fromAsset('.'), // Path to handler code
160
- handler: 'isComplete.handler', // Entry point (adjust as needed)
161
- timeout: Duration.minutes(15),
162
- });
163
-
164
- isCompleteHandlerFunction.addToRolePolicy(
165
- new PolicyStatement({
166
- actions: [
167
- 'codebuild:BatchGetBuilds',
168
- 'codebuild:ListBuildsForProject',
169
- 'logs:GetLogEvents',
170
- 'logs:DescribeLogStreams',
171
- 'logs:DescribeLogGroups',
172
- ],
173
- resources: ['*'],
174
- }),
175
- );
176
-
177
- // Create a custom resource provider
178
- const provider = new Provider(this, 'CustomResourceProvider', {
179
- onEventHandler: onEventHandlerFunction,
180
- isCompleteHandler: isCompleteHandlerFunction,
181
- queryInterval: Duration.seconds(30),
182
- });
183
-
184
- // Define the custom resource
185
- const buildTriggerResource = new CustomResource(this, 'BuildTriggerResource', {
186
- serviceToken: provider.serviceToken,
187
- properties: {
188
- ProjectName: codeBuildProject.projectName,
189
- Trigger: crypto.randomUUID(),
190
- },
191
- });
192
-
193
- buildTriggerResource.node.addDependency(codeBuildProject);
194
- this.containerImage = ContainerImage.fromEcrRepository(this.ecrRepository);
195
- this.dockerImageCode = DockerImageCode.fromEcr(this.ecrRepository);
196
- }
197
- }
File without changes
File without changes