aws-delivlib 14.14.18 → 14.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/lib/build-env.js CHANGED
@@ -2,12 +2,13 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.createBuildEnvironment = void 0;
4
4
  const aws_cdk_lib_1 = require("aws-cdk-lib");
5
+ const constants_1 = require("./constants");
5
6
  function createBuildEnvironment(props) {
6
7
  const environment = {
7
8
  computeType: props.computeType || aws_cdk_lib_1.aws_codebuild.ComputeType.SMALL,
8
9
  privileged: props.privileged,
9
10
  environmentVariables: renderEnvironmentVariables({ ...props.environment, ...props.env }),
10
- buildImage: props.buildImage || aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bullseye-slim-node18'),
11
+ buildImage: props.buildImage || aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry(constants_1.DEFAULT_SUPERCHAIN_IMAGE),
11
12
  };
12
13
  return environment;
13
14
  }
@@ -22,4 +23,4 @@ function renderEnvironmentVariables(env) {
22
23
  }
23
24
  return out;
24
25
  }
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtZW52LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYnVpbGQtZW52LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUFzRDtBQVd0RCxTQUFnQixzQkFBc0IsQ0FBQyxLQUE0QjtJQUNqRSxNQUFNLFdBQVcsR0FBNEI7UUFDM0MsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXLElBQUksMkJBQU0sQ0FBQyxXQUFXLENBQUMsS0FBSztRQUMxRCxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7UUFDNUIsb0JBQW9CLEVBQUUsMEJBQTBCLENBQUMsRUFBRSxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsR0FBRyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDeEYsVUFBVSxFQUFFLEtBQUssQ0FBQyxVQUFVLElBQUksMkJBQU0sQ0FBQyxlQUFlLENBQUMsa0JBQWtCLENBQUMsdURBQXVELENBQUM7S0FDbkksQ0FBQztJQUVGLE9BQU8sV0FBVyxDQUFDO0FBQ3JCLENBQUM7QUFURCx3REFTQztBQUVELFNBQVMsMEJBQTBCLENBQUMsR0FBK0I7SUFDakUsSUFBSSxDQUFDLEdBQUcsRUFBRTtRQUNSLE9BQU8sU0FBUyxDQUFDO0tBQ2xCO0lBRUQsTUFBTSxHQUFHLEdBQXVELEVBQUcsQ0FBQztJQUNwRSxLQUFLLE1BQU0sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUM5QyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsQ0FBQztLQUN0QjtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGF3c19jb2RlYnVpbGQgYXMgY2J1aWxkIH0gZnJvbSAnYXdzLWNkay1saWInO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJ1aWxkRW52aXJvbm1lbnRQcm9wcyB7XG4gIGNvbXB1dGVUeXBlPzogY2J1aWxkLkNvbXB1dGVUeXBlO1xuICBwcml2aWxlZ2VkPzogYm9vbGVhbjtcbiAgLyoqIEBkZXByZWNhdGVkICovXG4gIGVudj86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG4gIGVudmlyb25tZW50PzogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfTtcbiAgYnVpbGRJbWFnZT86IGNidWlsZC5JQnVpbGRJbWFnZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUJ1aWxkRW52aXJvbm1lbnQocHJvcHM6IEJ1aWxkRW52aXJvbm1lbnRQcm9wcykge1xuICBjb25zdCBlbnZpcm9ubWVudDogY2J1aWxkLkJ1aWxkRW52aXJvbm1lbnQgPSB7XG4gICAgY29tcHV0ZVR5cGU6IHByb3BzLmNvbXB1dGVUeXBlIHx8IGNidWlsZC5Db21wdXRlVHlwZS5TTUFMTCxcbiAgICBwcml2aWxlZ2VkOiBwcm9wcy5wcml2aWxlZ2VkLFxuICAgIGVudmlyb25tZW50VmFyaWFibGVzOiByZW5kZXJFbnZpcm9ubWVudFZhcmlhYmxlcyh7IC4uLnByb3BzLmVudmlyb25tZW50LCAuLi5wcm9wcy5lbnYgfSksXG4gICAgYnVpbGRJbWFnZTogcHJvcHMuYnVpbGRJbWFnZSB8fCBjYnVpbGQuTGludXhCdWlsZEltYWdlLmZyb21Eb2NrZXJSZWdpc3RyeSgncHVibGljLmVjci5hd3MvanNpaS9zdXBlcmNoYWluOjEtYnVsbHNleWUtc2xpbS1ub2RlMTgnKSxcbiAgfTtcblxuICByZXR1cm4gZW52aXJvbm1lbnQ7XG59XG5cbmZ1bmN0aW9uIHJlbmRlckVudmlyb25tZW50VmFyaWFibGVzKGVudj86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0pIHtcbiAgaWYgKCFlbnYpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3Qgb3V0OiB7IFtrZXk6IHN0cmluZ106IGNidWlsZC5CdWlsZEVudmlyb25tZW50VmFyaWFibGUgfSA9IHsgfTtcbiAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoZW52KSkge1xuICAgIG91dFtrZXldID0geyB2YWx1ZSB9O1xuICB9XG4gIHJldHVybiBvdXQ7XG59XG4iXX0=
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtZW52LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYnVpbGQtZW52LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUFzRDtBQUN0RCwyQ0FBdUQ7QUFXdkQsU0FBZ0Isc0JBQXNCLENBQUMsS0FBNEI7SUFDakUsTUFBTSxXQUFXLEdBQTRCO1FBQzNDLFdBQVcsRUFBRSxLQUFLLENBQUMsV0FBVyxJQUFJLDJCQUFNLENBQUMsV0FBVyxDQUFDLEtBQUs7UUFDMUQsVUFBVSxFQUFFLEtBQUssQ0FBQyxVQUFVO1FBQzVCLG9CQUFvQixFQUFFLDBCQUEwQixDQUFDLEVBQUUsR0FBRyxLQUFLLENBQUMsV0FBVyxFQUFFLEdBQUcsS0FBSyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ3hGLFVBQVUsRUFBRSxLQUFLLENBQUMsVUFBVSxJQUFJLDJCQUFNLENBQUMsZUFBZSxDQUFDLGtCQUFrQixDQUFDLG9DQUF3QixDQUFDO0tBQ3BHLENBQUM7SUFFRixPQUFPLFdBQVcsQ0FBQztBQUNyQixDQUFDO0FBVEQsd0RBU0M7QUFFRCxTQUFTLDBCQUEwQixDQUFDLEdBQStCO0lBQ2pFLElBQUksQ0FBQyxHQUFHLEVBQUU7UUFDUixPQUFPLFNBQVMsQ0FBQztLQUNsQjtJQUVELE1BQU0sR0FBRyxHQUF1RCxFQUFHLENBQUM7SUFDcEUsS0FBSyxNQUFNLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxJQUFJLE1BQU0sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUU7UUFDOUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLENBQUM7S0FDdEI7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhd3NfY29kZWJ1aWxkIGFzIGNidWlsZCB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IERFRkFVTFRfU1VQRVJDSEFJTl9JTUFHRSB9IGZyb20gJy4vY29uc3RhbnRzJztcblxuZXhwb3J0IGludGVyZmFjZSBCdWlsZEVudmlyb25tZW50UHJvcHMge1xuICBjb21wdXRlVHlwZT86IGNidWlsZC5Db21wdXRlVHlwZTtcbiAgcHJpdmlsZWdlZD86IGJvb2xlYW47XG4gIC8qKiBAZGVwcmVjYXRlZCAqL1xuICBlbnY/OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9O1xuICBlbnZpcm9ubWVudD86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG4gIGJ1aWxkSW1hZ2U/OiBjYnVpbGQuSUJ1aWxkSW1hZ2U7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVCdWlsZEVudmlyb25tZW50KHByb3BzOiBCdWlsZEVudmlyb25tZW50UHJvcHMpIHtcbiAgY29uc3QgZW52aXJvbm1lbnQ6IGNidWlsZC5CdWlsZEVudmlyb25tZW50ID0ge1xuICAgIGNvbXB1dGVUeXBlOiBwcm9wcy5jb21wdXRlVHlwZSB8fCBjYnVpbGQuQ29tcHV0ZVR5cGUuU01BTEwsXG4gICAgcHJpdmlsZWdlZDogcHJvcHMucHJpdmlsZWdlZCxcbiAgICBlbnZpcm9ubWVudFZhcmlhYmxlczogcmVuZGVyRW52aXJvbm1lbnRWYXJpYWJsZXMoeyAuLi5wcm9wcy5lbnZpcm9ubWVudCwgLi4ucHJvcHMuZW52IH0pLFxuICAgIGJ1aWxkSW1hZ2U6IHByb3BzLmJ1aWxkSW1hZ2UgfHwgY2J1aWxkLkxpbnV4QnVpbGRJbWFnZS5mcm9tRG9ja2VyUmVnaXN0cnkoREVGQVVMVF9TVVBFUkNIQUlOX0lNQUdFKSxcbiAgfTtcblxuICByZXR1cm4gZW52aXJvbm1lbnQ7XG59XG5cbmZ1bmN0aW9uIHJlbmRlckVudmlyb25tZW50VmFyaWFibGVzKGVudj86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0pIHtcbiAgaWYgKCFlbnYpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3Qgb3V0OiB7IFtrZXk6IHN0cmluZ106IGNidWlsZC5CdWlsZEVudmlyb25tZW50VmFyaWFibGUgfSA9IHsgfTtcbiAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoZW52KSkge1xuICAgIG91dFtrZXldID0geyB2YWx1ZSB9O1xuICB9XG4gIHJldHVybiBvdXQ7XG59XG4iXX0=
@@ -0,0 +1,4 @@
1
+ /**
2
+ * The default superchain image that will be used all across delivlib if no override is supplied.
3
+ */
4
+ export declare const DEFAULT_SUPERCHAIN_IMAGE = "public.ecr.aws/jsii/superchain:1-bookworm-slim-node22";
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DEFAULT_SUPERCHAIN_IMAGE = void 0;
4
+ /**
5
+ * The default superchain image that will be used all across delivlib if no override is supplied.
6
+ */
7
+ exports.DEFAULT_SUPERCHAIN_IMAGE = 'public.ecr.aws/jsii/superchain:1-bookworm-slim-node22';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ1UsUUFBQSx3QkFBd0IsR0FBRyx1REFBdUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhlIGRlZmF1bHQgc3VwZXJjaGFpbiBpbWFnZSB0aGF0IHdpbGwgYmUgdXNlZCBhbGwgYWNyb3NzIGRlbGl2bGliIGlmIG5vIG92ZXJyaWRlIGlzIHN1cHBsaWVkLlxuICovXG5leHBvcnQgY29uc3QgREVGQVVMVF9TVVBFUkNIQUlOX0lNQUdFID0gJ3B1YmxpYy5lY3IuYXdzL2pzaWkvc3VwZXJjaGFpbjoxLWJvb2t3b3JtLXNsaW0tbm9kZTIyJzsiXX0=
package/lib/pipeline.d.ts CHANGED
@@ -167,6 +167,7 @@ export declare class Pipeline extends Construct {
167
167
  private readonly buildEnvironment;
168
168
  private readonly buildSpec?;
169
169
  private firstPublishStageName?;
170
+ private readonly descrPipelineName;
170
171
  constructor(parent: Construct, name: string, props: PipelineProps);
171
172
  /**
172
173
  * Signing output artifact
package/lib/pipeline.js CHANGED
@@ -48,7 +48,7 @@ const FAILURE_METRIC_NAME = 'Failures';
48
48
  */
49
49
  class Pipeline extends constructs_1.Construct {
50
50
  constructor(parent, name, props) {
51
- var _a;
51
+ var _a, _b;
52
52
  super(parent, name);
53
53
  this.stages = {};
54
54
  this.concurrency = props.concurrency;
@@ -58,6 +58,9 @@ class Pipeline extends constructs_1.Construct {
58
58
  pipelineName: props.pipelineName,
59
59
  restartExecutionOnUpdate: props.restartExecutionOnUpdate === undefined ? true : props.restartExecutionOnUpdate,
60
60
  });
61
+ // We will use the pipeline name if given, but we can't use the Ref if not given
62
+ // because that would create cyclic references. Fall back to construct path if anonymous.
63
+ this.descrPipelineName = (_a = props.pipelineName) !== null && _a !== void 0 ? _a : this.node.path;
61
64
  this.branch = props.branch || 'master';
62
65
  this.sourceArtifact = props.repo.createSourceStage(this.pipeline, this.branch);
63
66
  this.buildEnvironment = (0, build_env_1.createBuildEnvironment)(props);
@@ -67,10 +70,11 @@ class Pipeline extends constructs_1.Construct {
67
70
  buildProjectName = `${props.pipelineName}-Build`;
68
71
  }
69
72
  this.buildProject = new aws_cdk_lib_1.aws_codebuild.PipelineProject(this, 'BuildProject', {
73
+ description: `Pipeline ${this.descrPipelineName}: build step`,
70
74
  projectName: buildProjectName,
71
75
  environment: this.buildEnvironment,
72
76
  buildSpec: this.buildSpec,
73
- timeout: (_a = props.buildTimeout) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.Duration.hours(8),
77
+ timeout: (_b = props.buildTimeout) !== null && _b !== void 0 ? _b : aws_cdk_lib_1.Duration.hours(8),
74
78
  ssmSessionPermissions: true,
75
79
  });
76
80
  this.buildRole = this.buildProject.role;
@@ -188,43 +192,57 @@ class Pipeline extends constructs_1.Construct {
188
192
  }), options);
189
193
  }
190
194
  publishToNpm(options) {
195
+ var _a;
191
196
  this.addPublish(new publishing.PublishToNpmProject(this, 'Npm', {
197
+ description: (_a = options.description) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: publish to NPM`,
192
198
  dryRun: this.dryRun,
193
199
  ...options,
194
200
  }), options);
195
201
  }
196
202
  publishToMaven(options) {
203
+ var _a;
197
204
  this.addPublish(new publishing.PublishToMavenProject(this, 'Maven', {
205
+ description: (_a = options.description) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: publish to Maven`,
198
206
  dryRun: this.dryRun,
199
207
  ...options,
200
208
  }), options);
201
209
  }
202
210
  publishToNuGet(options) {
211
+ var _a;
203
212
  this.addPublish(new publishing.PublishToNuGetProject(this, 'NuGet', {
213
+ description: (_a = options.description) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: publish to NuGet`,
204
214
  dryRun: this.dryRun,
205
215
  ...options,
206
216
  }), options);
207
217
  }
208
218
  publishToGitHubPages(options) {
219
+ var _a;
209
220
  this.addPublish(new publishing.PublishDocsToGitHubProject(this, 'GitHubPages', {
221
+ description: (_a = options.description) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: publish to GitHub Pages`,
210
222
  dryRun: this.dryRun,
211
223
  ...options,
212
224
  }), options);
213
225
  }
214
226
  publishToGitHub(options) {
227
+ var _a;
215
228
  this.addPublish(new publishing.PublishToGitHub(this, 'GitHub', {
229
+ description: (_a = options.description) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: publish to GitHub`,
216
230
  dryRun: this.dryRun,
217
231
  ...options,
218
232
  }), options);
219
233
  }
220
234
  publishToPyPI(options) {
235
+ var _a;
221
236
  this.addPublish(new publishing.PublishToPyPi(this, 'PyPI', {
237
+ description: (_a = options.description) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: publish to PyPI`,
222
238
  dryRun: this.dryRun,
223
239
  ...options,
224
240
  }), options);
225
241
  }
226
242
  publishToS3(id, options) {
243
+ var _a;
227
244
  this.addPublish(new publishing.PublishToS3(this, id, {
245
+ description: (_a = options.description) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: publish to S3 (${options.bucket.bucketName})`,
228
246
  dryRun: this.dryRun,
229
247
  ...options,
230
248
  }), options);
@@ -233,7 +251,9 @@ class Pipeline extends constructs_1.Construct {
233
251
  * Publish Golang code from `go` directory in build artifact to a GitHub repository.
234
252
  */
235
253
  publishToGolang(options) {
254
+ var _a;
236
255
  this.addPublish(new publishing.PublishToGolang(this, 'Golang', {
256
+ description: (_a = options.description) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: publish Golang`,
237
257
  dryRun: this.dryRun,
238
258
  ...options,
239
259
  }));
@@ -257,20 +277,21 @@ class Pipeline extends constructs_1.Construct {
257
277
  * @param options Options for auto bump (see AutoMergeBackPipelineOptions for description of defaults)
258
278
  */
259
279
  autoMergeBack(options) {
260
- var _a;
280
+ var _a, _b;
261
281
  if (!repo_1.WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {
262
282
  throw new Error('"repo" must be a WritableGitHubRepo in order to enable auto-merge-back');
263
283
  }
264
284
  const mergeBack = new pull_request_1.AutoMergeBack(this, 'MergeBack', {
265
285
  repo: this.repo,
266
286
  ...options,
287
+ projectDescription: (_a = options === null || options === void 0 ? void 0 : options.projectDescription) !== null && _a !== void 0 ? _a : `Pipeline ${this.descrPipelineName}: merge-back step`,
267
288
  });
268
289
  if (options === null || options === void 0 ? void 0 : options.stage) {
269
290
  const afterStage = this.getStage(options.stage.after);
270
291
  if (!afterStage) {
271
292
  throw new Error(`'options.stage.after' must be configured to an existing stage: ${options.stage.after}`);
272
293
  }
273
- const stage = this.getOrCreateStage((_a = options.stage.name) !== null && _a !== void 0 ? _a : 'MergeBack', { justAfter: afterStage });
294
+ const stage = this.getOrCreateStage((_b = options.stage.name) !== null && _b !== void 0 ? _b : 'MergeBack', { justAfter: afterStage });
274
295
  stage.addAction(new aws_cdk_lib_1.aws_codepipeline_actions.CodeBuildAction({
275
296
  actionName: 'CreateMergeBackPullRequest',
276
297
  project: mergeBack.pr.project,
@@ -366,4 +387,4 @@ class Pipeline extends constructs_1.Construct {
366
387
  }
367
388
  }
368
389
  exports.Pipeline = Pipeline;
369
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Duration,\n  aws_cloudwatch as cloudwatch,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_events as events,\n  aws_events_targets as events_targets,\n  aws_iam as iam, aws_s3 as s3,\n  aws_sns as sns,\n  aws_sns_subscriptions as sns_subs,\n} from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\n\nimport { AutoBuild, AutoBuildOptions } from './auto-build';\nimport { createBuildEnvironment } from './build-env';\nimport { Canary, CanaryProps } from './canary';\nimport { ChangeController } from './change-controller';\nimport { ChimeNotifier } from './chime-notifier';\nimport { PipelineWatcher } from './pipeline-watcher';\nimport * as publishing from './publishing';\nimport { AutoBump, AutoMergeBack, AutoBumpProps } from './pull-request';\nimport { AutoMergeBackPipelineOptions } from './pull-request/merge-back';\nimport { IRepo, WritableGitHubRepo } from './repo';\nimport { Shellable, ShellableProps } from './shellable';\nimport * as signing from './signing';\nimport { determineRunOrder, flatMap } from './util';\n\nconst PUBLISH_STAGE_NAME = 'Publish';\nconst SIGNING_STAGE_NAME = 'Sign';\nconst TEST_STAGE_NAME = 'Test';\nconst METRIC_NAMESPACE = 'CDK/Delivlib';\nconst FAILURE_METRIC_NAME = 'Failures';\n\nexport interface PipelineProps {\n  /**\n   * The source repository to build (e.g. GitHubRepo).\n   */\n  readonly repo: IRepo;\n\n  /**\n   * A display name for this pipeline.\n   */\n  readonly title?: string;\n\n  /**\n   * A physical name for this pipeline.\n   * @default - a new name will be generated.\n   */\n  readonly pipelineName?: string;\n\n  /**\n   * Branch to build.\n   * @default master\n   */\n  readonly branch?: string;\n\n  /**\n   * Email to send failure notifications.\n   * @default - No email notifications\n   */\n  readonly notificationEmail?: string;\n\n  /**\n   * The image used for the builds.\n   *\n   * @default jsii/superchain (see docs)\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The name of the CodeBuild project that will be part of this pipeline.\n   * @default - `${pipelineName}-Build`, if `pipelineName` property is specified; automatically generated, otherwise.\n   */\n  readonly buildProjectName?: string;\n\n  /**\n   * The type of compute to use for this build.\n   * See the {@link ComputeType} enum for the possible values.\n   *\n   * @default taken from {@link #buildImage#defaultComputeType}\n   */\n  readonly computeType?: cbuild.ComputeType;\n\n  /**\n   * Indicates how the project builds Docker images. Specify true to enable\n   * running the Docker daemon inside a Docker container. This value must be\n   * set to true only if this build project will be used to build Docker\n   * images, and the specified build environment image is not one provided by\n   * AWS CodeBuild with Docker support. Otherwise, all associated builds that\n   * attempt to interact with the Docker daemon will fail.\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Environment variables to pass to build\n   */\n  readonly environment?: { [key: string]: string };\n\n  /**\n   * Optional buildspec, as an alternative to a buildspec.yml file\n   */\n  readonly buildSpec?: cbuild.BuildSpec;\n\n  /**\n   * Indicates whether to re-run the pipeline after you've updated it.\n   * @default true\n   */\n  readonly restartExecutionOnUpdate?: boolean;\n\n  /**\n   * Indicates the concurrency limit test and publish stages.\n   *\n   * For example, if this value is 2, then only two actions will execute concurrently.\n   * If this value is 1, the pipeline will not have any concurrent execution.\n   *\n   * @default - no limit\n   */\n  readonly concurrency?: number;\n\n  /**\n   * Set the default dryRun for all publishing steps\n   *\n   * (Can still be changed when adding a step).\n   *\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Automatically build commits that are pushed to this repository, including PR builds on github.\n   *\n   * @default false\n   */\n  readonly autoBuild?: boolean;\n\n  /**\n   * Options for auto-build\n   *\n   * @default - 'autoBuildOptions.publicLogs' will be set to its default. 'autoBuildOptions.buildspec' will be configured to match with the\n   * 'buildSpec' property.\n   */\n  readonly autoBuildOptions?: AutoBuildOptions;\n\n  /**\n   * Post a notification to the given Chime webhooks if the pipeline fails\n   * @default - no Chime notifications on pipeline failure\n   * @deprecated - use `notifyOnFailure()` instead in combination with `PipelineNotification.chime()`.\n   */\n  readonly chimeFailureWebhooks?: string[];\n\n  /**\n   * The Chime message to post\n   *\n   * @default - A default message\n   */\n  readonly chimeMessage?: string;\n\n  /**\n   * Build timeout\n   *\n   * How long the build can take at maximum (before failing with an error).\n   *\n   * @default - Duration.hours(8)\n   */\n  readonly buildTimeout?: Duration;\n}\n\nexport interface PipelineNotificationBindOptions {\n  readonly pipeline: Pipeline;\n}\n\nexport interface IPipelineNotification {\n  bind(pipeline: PipelineNotificationBindOptions): void;\n}\n\n/**\n * Options for configuring an auto bump for this pipeline.\n */\nexport interface AutoBumpOptions extends Omit<AutoBumpProps, 'repo'> {\n}\n\n/**\n * Defines a delivlib CI/CD pipeline.\n */\nexport class Pipeline extends Construct {\n  public buildRole?: iam.IRole;\n  public readonly failureAlarm: cloudwatch.Alarm;\n  public readonly buildOutput: cpipeline.Artifact;\n  public readonly sourceArtifact: cpipeline.Artifact;\n\n  /**\n   * The primary CodeBuild project of this pipeline.\n   */\n  public readonly buildProject: cbuild.IProject;\n\n  /**\n   * The auto build project. undefined if 'autoBuild' is disabled for this pipeline.\n   */\n  public readonly autoBuildProject?: cbuild.Project;\n\n  /*\n   * The underlying CodePipeline Pipeline object that models this pipeline.\n   */\n  public readonly pipeline: cpipeline.Pipeline;\n  private readonly branch: string;\n  private readonly notify?: sns.Topic;\n  private defaultArtifact: cpipeline.Artifact;\n  private stages: { [name: string]: cpipeline.IStage } = { };\n  private _signingOutput?: cpipeline.Artifact;\n\n  private readonly concurrency?: number;\n  private readonly repo: IRepo;\n  private readonly dryRun: boolean;\n  private readonly buildEnvironment: cbuild.BuildEnvironment;\n  private readonly buildSpec?: cbuild.BuildSpec;\n  private firstPublishStageName?: string;\n\n  constructor(parent: Construct, name: string, props: PipelineProps) {\n    super(parent, name);\n\n    this.concurrency = props.concurrency;\n    this.repo = props.repo;\n    this.dryRun = !!props.dryRun;\n\n    this.pipeline = new cpipeline.Pipeline(this, 'BuildPipeline', {\n      pipelineName: props.pipelineName,\n      restartExecutionOnUpdate: props.restartExecutionOnUpdate === undefined ? true : props.restartExecutionOnUpdate,\n    });\n\n    this.branch = props.branch || 'master';\n    this.sourceArtifact = props.repo.createSourceStage(this.pipeline, this.branch);\n\n    this.buildEnvironment = createBuildEnvironment(props);\n    this.buildSpec = props.buildSpec;\n\n    let buildProjectName = props.buildProjectName;\n    if (buildProjectName === undefined && props.pipelineName !== undefined) {\n      buildProjectName = `${props.pipelineName}-Build`;\n    }\n    this.buildProject = new cbuild.PipelineProject(this, 'BuildProject', {\n      projectName: buildProjectName,\n      environment: this.buildEnvironment,\n      buildSpec: this.buildSpec,\n      timeout: props.buildTimeout ?? Duration.hours(8),\n      ssmSessionPermissions: true,\n    });\n\n    this.buildRole = this.buildProject.role;\n    this.buildRole!.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonElasticContainerRegistryPublicReadOnly'));\n\n    const buildStage = this.getOrCreateStage('Build');\n    const buildOutput = new cpipeline.Artifact();\n    buildStage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: 'Build',\n      project: this.buildProject,\n      input: this.sourceArtifact,\n      outputs: [buildOutput],\n    }));\n    this.buildOutput = buildOutput;\n    this.defaultArtifact = buildOutput;\n\n    if (props.notificationEmail) {\n      this.notify = new sns.Topic(this, 'NotificationsTopic');\n      this.notify.addSubscription(new sns_subs.EmailSubscription(props.notificationEmail));\n    }\n\n    // add a failure alarm for the entire pipeline.\n    this.failureAlarm = this.addFailureAlarm(props.title);\n\n    // emit an SNS notification every time build fails.\n    this.addBuildFailureNotification(this.buildProject, `${props.title} build failed`);\n\n    // Also emit to Chime webhooks if configured\n    if (props.chimeFailureWebhooks) {\n      new ChimeNotifier(this, 'ChimeNotifier', {\n        pipeline: this.pipeline,\n        message: props.chimeMessage,\n        webhookUrls: props.chimeFailureWebhooks,\n      });\n    }\n\n    if (props.autoBuild) {\n      this.autoBuildProject = this.autoBuild(props.autoBuildOptions).project;\n    }\n  }\n\n  /**\n   * Signing output artifact\n   */\n  public get signingOutput() {\n    return this._signingOutput;\n  }\n\n  public notifyOnFailure(notification: IPipelineNotification) {\n    notification.bind({\n      pipeline: this,\n    });\n  }\n\n  /**\n   * Add an action to run a shell script to the pipeline\n   *\n   * @return The Shellable and the Action added to the pipeline.\n   */\n  public addShellable(stageName: string, id: string, options: AddShellableOptions): {\n    shellable: Shellable; action: cpipeline_actions.CodeBuildAction;} {\n    const stage = this.getOrCreateStage(stageName);\n\n    const sh = new Shellable(this, id, options);\n    const action = sh.addToPipeline(\n      stage,\n      options.actionName || `Action${id}`,\n      options.inputArtifact || this.defaultArtifact,\n      this.determineRunOrderForNewAction(stage));\n\n    if (options.failureNotification) {\n      this.addBuildFailureNotification(sh.project, options.failureNotification);\n    }\n\n    return { shellable: sh, action };\n  }\n\n  public addTest(id: string, props: ShellableProps): {shellable: Shellable; action: cpipeline_actions.CodeBuildAction} {\n    return this.addShellable(TEST_STAGE_NAME, id, {\n      actionName: `Test${id}`,\n      failureNotification: `Test ${id} failed`,\n      ...props,\n    });\n  }\n\n  /**\n   * Convenience/discovery method that defines a canary test in your account.\n   * @param id the construct id\n   * @param props canary options\n   */\n  public addCanary(id: string, props: CanaryProps) {\n    return new Canary(this, `Canary${id}`, props);\n  }\n\n  public addPublish(publisher: IPublisher, options: AddPublishOptions = {}) {\n    const publishStageName = options.stageName ?? PUBLISH_STAGE_NAME;\n    if (!this.firstPublishStageName) {\n      this.firstPublishStageName = publishStageName;\n    }\n    const stage = this.getOrCreateStage(publishStageName);\n\n    publisher.addToPipeline(stage, `${publisher.node.id}Publish`, {\n      inputArtifact: options.inputArtifact || this.defaultArtifact,\n      runOrder: this.determineRunOrderForNewAction(stage),\n    });\n  }\n\n  /**\n   * Adds a change control policy to block transitions into the publish stage during certain time windows.\n   * @param options the options to configure the change control policy.\n   */\n  public addChangeControl(options: AddChangeControlOptions = { }): ChangeController {\n    const publishStage = this.getStage(this.firstPublishStageName ?? PUBLISH_STAGE_NAME);\n    if (!publishStage) {\n      throw new Error(`This pipeline does not have a ${PUBLISH_STAGE_NAME} stage yet. Add one first.`);\n    }\n\n    return new ChangeController(this, 'ChangeController', {\n      ...options,\n      pipelineStage: publishStage,\n    });\n  }\n\n  public addSigning(signer: signing.ISigner, options: signing.AddSigningOptions = {}) {\n    const signingStageName = options.stageName ?? SIGNING_STAGE_NAME;\n    const stage = this.getOrCreateStage(signingStageName);\n\n    this._signingOutput = signer.addToPipeline(stage, `${signer.node.id}Sign`, {\n      inputArtifact: options.inputArtifact || this.defaultArtifact,\n      runOrder: this.determineRunOrderForNewAction(stage),\n    });\n    this.defaultArtifact = this._signingOutput;\n  }\n\n  public signNuGetWithSigner(options: signing.SignNuGetWithSignerProps & signing.AddSigningOptions) {\n    this.addSigning(new signing.SignNuGetWithSigner(this, 'NuGetSigning', {\n      ...options,\n    }), options);\n  }\n\n  public publishToNpm(options: publishing.PublishToNpmProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToNpmProject(this, 'Npm', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToMaven(options: publishing.PublishToMavenProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToMavenProject(this, 'Maven', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToNuGet(options: publishing.PublishToNuGetProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToNuGetProject(this, 'NuGet', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToGitHubPages(options: publishing.PublishDocsToGitHubProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishDocsToGitHubProject(this, 'GitHubPages', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToGitHub(options: publishing.PublishToGitHubProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToGitHub(this, 'GitHub', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToPyPI(options: publishing.PublishToPyPiProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToPyPi(this, 'PyPI', {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToS3(id: string, options: publishing.PublishToS3Props & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToS3(this, id, {\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  /**\n   * Publish Golang code from `go` directory in build artifact to a GitHub repository.\n   */\n  public publishToGolang(options: publishing.PublishToGolangProps) {\n    this.addPublish(new publishing.PublishToGolang(this, 'Golang', {\n      dryRun: this.dryRun,\n      ...options,\n    }));\n  }\n\n  /**\n   * Enables automatic bumps for the source repo.\n   * @param options Options for auto bump (see AutoBumpOptions for description of defaults)\n   */\n  public autoBump(options?: AutoBumpOptions): AutoBump {\n    if (!WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {\n      throw new Error('\"repo\" must be a WritableGitHubRepo in order to enable auto-bump');\n    }\n\n    const autoBump = new AutoBump(this, 'AutoBump', {\n      repo: this.repo,\n      ...options,\n    });\n\n    return autoBump;\n  }\n\n  /**\n   * Enables automatic merge backs for the source repo.\n   * @param options Options for auto bump (see AutoMergeBackPipelineOptions for description of defaults)\n   */\n  public autoMergeBack(options?: AutoMergeBackPipelineOptions) {\n    if (!WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {\n      throw new Error('\"repo\" must be a WritableGitHubRepo in order to enable auto-merge-back');\n    }\n\n    const mergeBack = new AutoMergeBack(this, 'MergeBack', {\n      repo: this.repo,\n      ...options,\n    });\n\n    if (options?.stage) {\n\n      const afterStage = this.getStage(options.stage.after);\n\n      if (!afterStage) {\n        throw new Error(`'options.stage.after' must be configured to an existing stage: ${options.stage.after}`);\n      }\n\n      const stage = this.getOrCreateStage(options.stage.name ?? 'MergeBack', { justAfter: afterStage });\n      stage.addAction(new cpipeline_actions.CodeBuildAction({\n        actionName: 'CreateMergeBackPullRequest',\n        project: mergeBack.pr.project,\n        input: this.sourceArtifact,\n      }));\n    }\n  }\n\n  /**\n   * Enables automatic builds of pull requests in the Github repository and posts the\n   * results back as a comment with a public link to the build logs.\n   */\n  public autoBuild(options: AutoBuildOptions = { }): AutoBuild {\n    return new AutoBuild(this, 'AutoBuild', {\n      environment: this.buildEnvironment,\n      repo: this.repo,\n      buildSpec: options.buildSpec || this.buildSpec,\n      ...options,\n    });\n  }\n\n  /**\n   * The metric that tracks pipeline failures.\n   */\n  public metricFailures(options: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: METRIC_NAMESPACE,\n      metricName: FAILURE_METRIC_NAME,\n      dimensionsMap: {\n        Pipeline: this.pipeline.pipelineName,\n      },\n      statistic: 'Sum',\n      ...options,\n    });\n  }\n\n  /**\n   * The metrics that track failure of each action within the pipeline.\n   */\n  public metricActionFailures(options: cloudwatch.MetricOptions): cloudwatch.Metric[] {\n    return flatMap(this.pipeline.stages, stage => stage.actions.map(action => {\n      return new cloudwatch.Metric({\n        namespace: METRIC_NAMESPACE,\n        metricName: FAILURE_METRIC_NAME,\n        dimensionsMap: {\n          Pipeline: this.pipeline.pipelineName,\n          Action: action.actionProperties.actionName,\n        },\n        statistic: 'Sum',\n        ...options,\n      });\n    }));\n  }\n\n  public addManualApprovalToStage(stageName: string, props?: cpipeline_actions.ManualApprovalActionProps) {\n    const stage = this.getOrCreateStage(stageName);\n    stage.addAction(new cpipeline_actions.ManualApprovalAction(props ?? {\n      actionName: 'ManualApprovalAction',\n    }));\n  }\n\n  private addFailureAlarm(title?: string): cloudwatch.Alarm {\n    return new PipelineWatcher(this, 'PipelineWatcher', {\n      pipeline: this.pipeline,\n      metricNamespace: METRIC_NAMESPACE,\n      failureMetricName: FAILURE_METRIC_NAME,\n      title,\n    }).alarm;\n  }\n\n  private addBuildFailureNotification(buildProject: cbuild.IProject, message: string) {\n    if (!this.notify) {\n      return;\n    }\n\n    buildProject.onBuildFailed('OnBuildFailed').addTarget(new events_targets.SnsTopic(this.notify, {\n      message: events.RuleTargetInput.fromText(message),\n    }));\n  }\n\n  /**\n   * @returns the stage or undefined if the stage doesn't exist\n   */\n  private getStage(stageName: string): cpipeline.IStage | undefined {\n    return this.stages[stageName];\n  }\n\n  private getOrCreateStage(stageName: string, placement?: cpipeline.StagePlacement): cpipeline.IStage {\n    // otherwise, group all actions so they run concurrently.\n    let stage = this.getStage(stageName);\n    if (!stage) {\n      stage = this.pipeline.addStage({\n        stageName,\n        placement,\n      });\n      this.stages[stageName] = stage;\n    }\n    return stage;\n  }\n\n  private determineRunOrderForNewAction(stage: cpipeline.IStage): number | undefined {\n    return determineRunOrder(stage.actions.length, this.concurrency);\n  }\n}\n\nexport interface IPublisher extends IConstruct {\n  addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void;\n}\n\nexport interface AddToPipelineOptions {\n  inputArtifact?: cpipeline.Artifact;\n  runOrder?: number;\n}\n\nexport interface AddChangeControlOptions {\n  /**\n   * The bucket in which the ChangeControl iCal document will be stored.\n   *\n   * @default a new bucket will be provisioned.\n   */\n  changeControlBucket?: s3.IBucket;\n\n  /**\n   * The key in which the iCal fille will be stored.\n   *\n   * @default 'change-control.ical'\n   */\n  changeControlObjectKey?: string;\n\n  /**\n   * Schedule to run the change controller on\n   *\n   * @default rate(15 minutes)\n   */\n  scheduleExpression?: string;\n}\n\nexport interface AddPublishOptions {\n  /**\n   * The input artifact to use\n   *\n   * @default Signing output artifact when a signing stage is added to the\n   * pipeline via `addSigning` or `signNuGetWithSigner`. Otherwise, the default\n   * will be the build output artifact.\n   */\n  inputArtifact?: cpipeline.Artifact;\n\n  /**\n   * Stage name to add publishing job to\n   *\n   * By default, this will be the stage name `'Publish'`, but if you want to\n   * separate out the publishing actions into different stages (in order to\n   * block/unblock them separately for example) you can change this.\n   *\n   * Stages appear in the pipeline in the order they are referenced for\n   * the first time.\n   *\n   * @default \"Publish\"\n   */\n  readonly stageName?: string;\n}\n\nexport interface AddShellableOptions extends ShellableProps {\n  /**\n   * String to use as action name\n   *\n   * @default Id\n   */\n  actionName?: string;\n\n  /**\n   * Message to use as failure notification\n   *\n   * @default No notification\n   */\n  failureNotification?: string;\n\n  /**\n   * The input artifact to use\n   *\n   * @default Signing output artifact when a signing stage is added to the\n   * pipeline via `addSigning` or `signNuGetWithSigner`. Otherwise, the default\n   * will be the build output artifact.\n   */\n  inputArtifact?: cpipeline.Artifact;\n}\n"]}
390
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Duration,\n  aws_cloudwatch as cloudwatch,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_events as events,\n  aws_events_targets as events_targets,\n  aws_iam as iam, aws_s3 as s3,\n  aws_sns as sns,\n  aws_sns_subscriptions as sns_subs,\n} from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\n\nimport { AutoBuild, AutoBuildOptions } from './auto-build';\nimport { createBuildEnvironment } from './build-env';\nimport { Canary, CanaryProps } from './canary';\nimport { ChangeController } from './change-controller';\nimport { ChimeNotifier } from './chime-notifier';\nimport { PipelineWatcher } from './pipeline-watcher';\nimport * as publishing from './publishing';\nimport { AutoBump, AutoMergeBack, AutoBumpProps } from './pull-request';\nimport { AutoMergeBackPipelineOptions } from './pull-request/merge-back';\nimport { IRepo, WritableGitHubRepo } from './repo';\nimport { Shellable, ShellableProps } from './shellable';\nimport * as signing from './signing';\nimport { determineRunOrder, flatMap } from './util';\n\nconst PUBLISH_STAGE_NAME = 'Publish';\nconst SIGNING_STAGE_NAME = 'Sign';\nconst TEST_STAGE_NAME = 'Test';\nconst METRIC_NAMESPACE = 'CDK/Delivlib';\nconst FAILURE_METRIC_NAME = 'Failures';\n\nexport interface PipelineProps {\n  /**\n   * The source repository to build (e.g. GitHubRepo).\n   */\n  readonly repo: IRepo;\n\n  /**\n   * A display name for this pipeline.\n   */\n  readonly title?: string;\n\n  /**\n   * A physical name for this pipeline.\n   * @default - a new name will be generated.\n   */\n  readonly pipelineName?: string;\n\n  /**\n   * Branch to build.\n   * @default master\n   */\n  readonly branch?: string;\n\n  /**\n   * Email to send failure notifications.\n   * @default - No email notifications\n   */\n  readonly notificationEmail?: string;\n\n  /**\n   * The image used for the builds.\n   *\n   * @default jsii/superchain (see docs)\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The name of the CodeBuild project that will be part of this pipeline.\n   * @default - `${pipelineName}-Build`, if `pipelineName` property is specified; automatically generated, otherwise.\n   */\n  readonly buildProjectName?: string;\n\n  /**\n   * The type of compute to use for this build.\n   * See the {@link ComputeType} enum for the possible values.\n   *\n   * @default taken from {@link #buildImage#defaultComputeType}\n   */\n  readonly computeType?: cbuild.ComputeType;\n\n  /**\n   * Indicates how the project builds Docker images. Specify true to enable\n   * running the Docker daemon inside a Docker container. This value must be\n   * set to true only if this build project will be used to build Docker\n   * images, and the specified build environment image is not one provided by\n   * AWS CodeBuild with Docker support. Otherwise, all associated builds that\n   * attempt to interact with the Docker daemon will fail.\n   *\n   * @default false\n   */\n  readonly privileged?: boolean;\n\n  /**\n   * Environment variables to pass to build\n   */\n  readonly environment?: { [key: string]: string };\n\n  /**\n   * Optional buildspec, as an alternative to a buildspec.yml file\n   */\n  readonly buildSpec?: cbuild.BuildSpec;\n\n  /**\n   * Indicates whether to re-run the pipeline after you've updated it.\n   * @default true\n   */\n  readonly restartExecutionOnUpdate?: boolean;\n\n  /**\n   * Indicates the concurrency limit test and publish stages.\n   *\n   * For example, if this value is 2, then only two actions will execute concurrently.\n   * If this value is 1, the pipeline will not have any concurrent execution.\n   *\n   * @default - no limit\n   */\n  readonly concurrency?: number;\n\n  /**\n   * Set the default dryRun for all publishing steps\n   *\n   * (Can still be changed when adding a step).\n   *\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Automatically build commits that are pushed to this repository, including PR builds on github.\n   *\n   * @default false\n   */\n  readonly autoBuild?: boolean;\n\n  /**\n   * Options for auto-build\n   *\n   * @default - 'autoBuildOptions.publicLogs' will be set to its default. 'autoBuildOptions.buildspec' will be configured to match with the\n   * 'buildSpec' property.\n   */\n  readonly autoBuildOptions?: AutoBuildOptions;\n\n  /**\n   * Post a notification to the given Chime webhooks if the pipeline fails\n   * @default - no Chime notifications on pipeline failure\n   * @deprecated - use `notifyOnFailure()` instead in combination with `PipelineNotification.chime()`.\n   */\n  readonly chimeFailureWebhooks?: string[];\n\n  /**\n   * The Chime message to post\n   *\n   * @default - A default message\n   */\n  readonly chimeMessage?: string;\n\n  /**\n   * Build timeout\n   *\n   * How long the build can take at maximum (before failing with an error).\n   *\n   * @default - Duration.hours(8)\n   */\n  readonly buildTimeout?: Duration;\n}\n\nexport interface PipelineNotificationBindOptions {\n  readonly pipeline: Pipeline;\n}\n\nexport interface IPipelineNotification {\n  bind(pipeline: PipelineNotificationBindOptions): void;\n}\n\n/**\n * Options for configuring an auto bump for this pipeline.\n */\nexport interface AutoBumpOptions extends Omit<AutoBumpProps, 'repo'> {\n}\n\n/**\n * Defines a delivlib CI/CD pipeline.\n */\nexport class Pipeline extends Construct {\n  public buildRole?: iam.IRole;\n  public readonly failureAlarm: cloudwatch.Alarm;\n  public readonly buildOutput: cpipeline.Artifact;\n  public readonly sourceArtifact: cpipeline.Artifact;\n\n  /**\n   * The primary CodeBuild project of this pipeline.\n   */\n  public readonly buildProject: cbuild.IProject;\n\n  /**\n   * The auto build project. undefined if 'autoBuild' is disabled for this pipeline.\n   */\n  public readonly autoBuildProject?: cbuild.Project;\n\n  /*\n   * The underlying CodePipeline Pipeline object that models this pipeline.\n   */\n  public readonly pipeline: cpipeline.Pipeline;\n  private readonly branch: string;\n  private readonly notify?: sns.Topic;\n  private defaultArtifact: cpipeline.Artifact;\n  private stages: { [name: string]: cpipeline.IStage } = { };\n  private _signingOutput?: cpipeline.Artifact;\n\n  private readonly concurrency?: number;\n  private readonly repo: IRepo;\n  private readonly dryRun: boolean;\n  private readonly buildEnvironment: cbuild.BuildEnvironment;\n  private readonly buildSpec?: cbuild.BuildSpec;\n  private firstPublishStageName?: string;\n  private readonly descrPipelineName: string;\n\n  constructor(parent: Construct, name: string, props: PipelineProps) {\n    super(parent, name);\n\n    this.concurrency = props.concurrency;\n    this.repo = props.repo;\n    this.dryRun = !!props.dryRun;\n\n    this.pipeline = new cpipeline.Pipeline(this, 'BuildPipeline', {\n      pipelineName: props.pipelineName,\n      restartExecutionOnUpdate: props.restartExecutionOnUpdate === undefined ? true : props.restartExecutionOnUpdate,\n    });\n    // We will use the pipeline name if given, but we can't use the Ref if not given\n    // because that would create cyclic references. Fall back to construct path if anonymous.\n    this.descrPipelineName = props.pipelineName ?? this.node.path;\n\n    this.branch = props.branch || 'master';\n    this.sourceArtifact = props.repo.createSourceStage(this.pipeline, this.branch);\n\n    this.buildEnvironment = createBuildEnvironment(props);\n    this.buildSpec = props.buildSpec;\n\n    let buildProjectName = props.buildProjectName;\n    if (buildProjectName === undefined && props.pipelineName !== undefined) {\n      buildProjectName = `${props.pipelineName}-Build`;\n    }\n    this.buildProject = new cbuild.PipelineProject(this, 'BuildProject', {\n      description: `Pipeline ${this.descrPipelineName}: build step`,\n      projectName: buildProjectName,\n      environment: this.buildEnvironment,\n      buildSpec: this.buildSpec,\n      timeout: props.buildTimeout ?? Duration.hours(8),\n      ssmSessionPermissions: true,\n    });\n\n    this.buildRole = this.buildProject.role;\n    this.buildRole!.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonElasticContainerRegistryPublicReadOnly'));\n\n    const buildStage = this.getOrCreateStage('Build');\n    const buildOutput = new cpipeline.Artifact();\n    buildStage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: 'Build',\n      project: this.buildProject,\n      input: this.sourceArtifact,\n      outputs: [buildOutput],\n    }));\n    this.buildOutput = buildOutput;\n    this.defaultArtifact = buildOutput;\n\n    if (props.notificationEmail) {\n      this.notify = new sns.Topic(this, 'NotificationsTopic');\n      this.notify.addSubscription(new sns_subs.EmailSubscription(props.notificationEmail));\n    }\n\n    // add a failure alarm for the entire pipeline.\n    this.failureAlarm = this.addFailureAlarm(props.title);\n\n    // emit an SNS notification every time build fails.\n    this.addBuildFailureNotification(this.buildProject, `${props.title} build failed`);\n\n    // Also emit to Chime webhooks if configured\n    if (props.chimeFailureWebhooks) {\n      new ChimeNotifier(this, 'ChimeNotifier', {\n        pipeline: this.pipeline,\n        message: props.chimeMessage,\n        webhookUrls: props.chimeFailureWebhooks,\n      });\n    }\n\n    if (props.autoBuild) {\n      this.autoBuildProject = this.autoBuild(props.autoBuildOptions).project;\n    }\n  }\n\n  /**\n   * Signing output artifact\n   */\n  public get signingOutput() {\n    return this._signingOutput;\n  }\n\n  public notifyOnFailure(notification: IPipelineNotification) {\n    notification.bind({\n      pipeline: this,\n    });\n  }\n\n  /**\n   * Add an action to run a shell script to the pipeline\n   *\n   * @return The Shellable and the Action added to the pipeline.\n   */\n  public addShellable(stageName: string, id: string, options: AddShellableOptions): {\n    shellable: Shellable; action: cpipeline_actions.CodeBuildAction;} {\n    const stage = this.getOrCreateStage(stageName);\n\n    const sh = new Shellable(this, id, options);\n    const action = sh.addToPipeline(\n      stage,\n      options.actionName || `Action${id}`,\n      options.inputArtifact || this.defaultArtifact,\n      this.determineRunOrderForNewAction(stage));\n\n    if (options.failureNotification) {\n      this.addBuildFailureNotification(sh.project, options.failureNotification);\n    }\n\n    return { shellable: sh, action };\n  }\n\n  public addTest(id: string, props: ShellableProps): {shellable: Shellable; action: cpipeline_actions.CodeBuildAction} {\n    return this.addShellable(TEST_STAGE_NAME, id, {\n      actionName: `Test${id}`,\n      failureNotification: `Test ${id} failed`,\n      ...props,\n    });\n  }\n\n  /**\n   * Convenience/discovery method that defines a canary test in your account.\n   * @param id the construct id\n   * @param props canary options\n   */\n  public addCanary(id: string, props: CanaryProps) {\n    return new Canary(this, `Canary${id}`, props);\n  }\n\n  public addPublish(publisher: IPublisher, options: AddPublishOptions = {}) {\n    const publishStageName = options.stageName ?? PUBLISH_STAGE_NAME;\n    if (!this.firstPublishStageName) {\n      this.firstPublishStageName = publishStageName;\n    }\n    const stage = this.getOrCreateStage(publishStageName);\n\n    publisher.addToPipeline(stage, `${publisher.node.id}Publish`, {\n      inputArtifact: options.inputArtifact || this.defaultArtifact,\n      runOrder: this.determineRunOrderForNewAction(stage),\n    });\n  }\n\n  /**\n   * Adds a change control policy to block transitions into the publish stage during certain time windows.\n   * @param options the options to configure the change control policy.\n   */\n  public addChangeControl(options: AddChangeControlOptions = { }): ChangeController {\n    const publishStage = this.getStage(this.firstPublishStageName ?? PUBLISH_STAGE_NAME);\n    if (!publishStage) {\n      throw new Error(`This pipeline does not have a ${PUBLISH_STAGE_NAME} stage yet. Add one first.`);\n    }\n\n    return new ChangeController(this, 'ChangeController', {\n      ...options,\n      pipelineStage: publishStage,\n    });\n  }\n\n  public addSigning(signer: signing.ISigner, options: signing.AddSigningOptions = {}) {\n    const signingStageName = options.stageName ?? SIGNING_STAGE_NAME;\n    const stage = this.getOrCreateStage(signingStageName);\n\n    this._signingOutput = signer.addToPipeline(stage, `${signer.node.id}Sign`, {\n      inputArtifact: options.inputArtifact || this.defaultArtifact,\n      runOrder: this.determineRunOrderForNewAction(stage),\n    });\n    this.defaultArtifact = this._signingOutput;\n  }\n\n  public signNuGetWithSigner(options: signing.SignNuGetWithSignerProps & signing.AddSigningOptions) {\n    this.addSigning(new signing.SignNuGetWithSigner(this, 'NuGetSigning', {\n      ...options,\n    }), options);\n  }\n\n  public publishToNpm(options: publishing.PublishToNpmProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToNpmProject(this, 'Npm', {\n      description: options.description ?? `Pipeline ${this.descrPipelineName}: publish to NPM`,\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToMaven(options: publishing.PublishToMavenProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToMavenProject(this, 'Maven', {\n      description: options.description ?? `Pipeline ${this.descrPipelineName}: publish to Maven`,\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToNuGet(options: publishing.PublishToNuGetProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToNuGetProject(this, 'NuGet', {\n      description: options.description ?? `Pipeline ${this.descrPipelineName}: publish to NuGet`,\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToGitHubPages(options: publishing.PublishDocsToGitHubProjectProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishDocsToGitHubProject(this, 'GitHubPages', {\n      description: options.description ?? `Pipeline ${this.descrPipelineName}: publish to GitHub Pages`,\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToGitHub(options: publishing.PublishToGitHubProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToGitHub(this, 'GitHub', {\n      description: options.description ?? `Pipeline ${this.descrPipelineName}: publish to GitHub`,\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToPyPI(options: publishing.PublishToPyPiProps & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToPyPi(this, 'PyPI', {\n      description: options.description ?? `Pipeline ${this.descrPipelineName}: publish to PyPI`,\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  public publishToS3(id: string, options: publishing.PublishToS3Props & AddPublishOptions) {\n    this.addPublish(new publishing.PublishToS3(this, id, {\n      description: options.description ?? `Pipeline ${this.descrPipelineName}: publish to S3 (${options.bucket.bucketName})`,\n      dryRun: this.dryRun,\n      ...options,\n    }), options);\n  }\n\n  /**\n   * Publish Golang code from `go` directory in build artifact to a GitHub repository.\n   */\n  public publishToGolang(options: publishing.PublishToGolangProps) {\n    this.addPublish(new publishing.PublishToGolang(this, 'Golang', {\n      description: options.description ?? `Pipeline ${this.descrPipelineName}: publish Golang`,\n      dryRun: this.dryRun,\n      ...options,\n    }));\n  }\n\n  /**\n   * Enables automatic bumps for the source repo.\n   * @param options Options for auto bump (see AutoBumpOptions for description of defaults)\n   */\n  public autoBump(options?: AutoBumpOptions): AutoBump {\n    if (!WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {\n      throw new Error('\"repo\" must be a WritableGitHubRepo in order to enable auto-bump');\n    }\n\n    const autoBump = new AutoBump(this, 'AutoBump', {\n      repo: this.repo,\n      ...options,\n    });\n\n    return autoBump;\n  }\n\n  /**\n   * Enables automatic merge backs for the source repo.\n   * @param options Options for auto bump (see AutoMergeBackPipelineOptions for description of defaults)\n   */\n  public autoMergeBack(options?: AutoMergeBackPipelineOptions) {\n    if (!WritableGitHubRepo.isWritableGitHubRepo(this.repo)) {\n      throw new Error('\"repo\" must be a WritableGitHubRepo in order to enable auto-merge-back');\n    }\n\n    const mergeBack = new AutoMergeBack(this, 'MergeBack', {\n      repo: this.repo,\n      ...options,\n      projectDescription: options?.projectDescription ?? `Pipeline ${this.descrPipelineName}: merge-back step`,\n    });\n\n    if (options?.stage) {\n\n      const afterStage = this.getStage(options.stage.after);\n\n      if (!afterStage) {\n        throw new Error(`'options.stage.after' must be configured to an existing stage: ${options.stage.after}`);\n      }\n\n      const stage = this.getOrCreateStage(options.stage.name ?? 'MergeBack', { justAfter: afterStage });\n      stage.addAction(new cpipeline_actions.CodeBuildAction({\n        actionName: 'CreateMergeBackPullRequest',\n        project: mergeBack.pr.project,\n        input: this.sourceArtifact,\n      }));\n    }\n  }\n\n  /**\n   * Enables automatic builds of pull requests in the Github repository and posts the\n   * results back as a comment with a public link to the build logs.\n   */\n  public autoBuild(options: AutoBuildOptions = { }): AutoBuild {\n    return new AutoBuild(this, 'AutoBuild', {\n      environment: this.buildEnvironment,\n      repo: this.repo,\n      buildSpec: options.buildSpec || this.buildSpec,\n      ...options,\n    });\n  }\n\n  /**\n   * The metric that tracks pipeline failures.\n   */\n  public metricFailures(options: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: METRIC_NAMESPACE,\n      metricName: FAILURE_METRIC_NAME,\n      dimensionsMap: {\n        Pipeline: this.pipeline.pipelineName,\n      },\n      statistic: 'Sum',\n      ...options,\n    });\n  }\n\n  /**\n   * The metrics that track failure of each action within the pipeline.\n   */\n  public metricActionFailures(options: cloudwatch.MetricOptions): cloudwatch.Metric[] {\n    return flatMap(this.pipeline.stages, stage => stage.actions.map(action => {\n      return new cloudwatch.Metric({\n        namespace: METRIC_NAMESPACE,\n        metricName: FAILURE_METRIC_NAME,\n        dimensionsMap: {\n          Pipeline: this.pipeline.pipelineName,\n          Action: action.actionProperties.actionName,\n        },\n        statistic: 'Sum',\n        ...options,\n      });\n    }));\n  }\n\n  public addManualApprovalToStage(stageName: string, props?: cpipeline_actions.ManualApprovalActionProps) {\n    const stage = this.getOrCreateStage(stageName);\n    stage.addAction(new cpipeline_actions.ManualApprovalAction(props ?? {\n      actionName: 'ManualApprovalAction',\n    }));\n  }\n\n  private addFailureAlarm(title?: string): cloudwatch.Alarm {\n    return new PipelineWatcher(this, 'PipelineWatcher', {\n      pipeline: this.pipeline,\n      metricNamespace: METRIC_NAMESPACE,\n      failureMetricName: FAILURE_METRIC_NAME,\n      title,\n    }).alarm;\n  }\n\n  private addBuildFailureNotification(buildProject: cbuild.IProject, message: string) {\n    if (!this.notify) {\n      return;\n    }\n\n    buildProject.onBuildFailed('OnBuildFailed').addTarget(new events_targets.SnsTopic(this.notify, {\n      message: events.RuleTargetInput.fromText(message),\n    }));\n  }\n\n  /**\n   * @returns the stage or undefined if the stage doesn't exist\n   */\n  private getStage(stageName: string): cpipeline.IStage | undefined {\n    return this.stages[stageName];\n  }\n\n  private getOrCreateStage(stageName: string, placement?: cpipeline.StagePlacement): cpipeline.IStage {\n    // otherwise, group all actions so they run concurrently.\n    let stage = this.getStage(stageName);\n    if (!stage) {\n      stage = this.pipeline.addStage({\n        stageName,\n        placement,\n      });\n      this.stages[stageName] = stage;\n    }\n    return stage;\n  }\n\n  private determineRunOrderForNewAction(stage: cpipeline.IStage): number | undefined {\n    return determineRunOrder(stage.actions.length, this.concurrency);\n  }\n}\n\nexport interface IPublisher extends IConstruct {\n  addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void;\n}\n\nexport interface AddToPipelineOptions {\n  inputArtifact?: cpipeline.Artifact;\n  runOrder?: number;\n}\n\nexport interface AddChangeControlOptions {\n  /**\n   * The bucket in which the ChangeControl iCal document will be stored.\n   *\n   * @default a new bucket will be provisioned.\n   */\n  changeControlBucket?: s3.IBucket;\n\n  /**\n   * The key in which the iCal fille will be stored.\n   *\n   * @default 'change-control.ical'\n   */\n  changeControlObjectKey?: string;\n\n  /**\n   * Schedule to run the change controller on\n   *\n   * @default rate(15 minutes)\n   */\n  scheduleExpression?: string;\n}\n\nexport interface AddPublishOptions {\n  /**\n   * The input artifact to use\n   *\n   * @default Signing output artifact when a signing stage is added to the\n   * pipeline via `addSigning` or `signNuGetWithSigner`. Otherwise, the default\n   * will be the build output artifact.\n   */\n  inputArtifact?: cpipeline.Artifact;\n\n  /**\n   * Stage name to add publishing job to\n   *\n   * By default, this will be the stage name `'Publish'`, but if you want to\n   * separate out the publishing actions into different stages (in order to\n   * block/unblock them separately for example) you can change this.\n   *\n   * Stages appear in the pipeline in the order they are referenced for\n   * the first time.\n   *\n   * @default \"Publish\"\n   */\n  readonly stageName?: string;\n}\n\nexport interface AddShellableOptions extends ShellableProps {\n  /**\n   * String to use as action name\n   *\n   * @default Id\n   */\n  actionName?: string;\n\n  /**\n   * Message to use as failure notification\n   *\n   * @default No notification\n   */\n  failureNotification?: string;\n\n  /**\n   * The input artifact to use\n   *\n   * @default Signing output artifact when a signing stage is added to the\n   * pipeline via `addSigning` or `signNuGetWithSigner`. Otherwise, the default\n   * will be the build output artifact.\n   */\n  inputArtifact?: cpipeline.Artifact;\n}\n"]}
@@ -51,7 +51,7 @@
51
51
  "@types/btoa-lite@^1.0.0": "https://registry.yarnpkg.com/@types/btoa-lite/-/btoa-lite-1.0.2.tgz#82bb6aab00abf7cff3ca2825abe010c0cd536ae5",
52
52
  "@types/changelog-parser@^2.8.1": "https://registry.yarnpkg.com/@types/changelog-parser/-/changelog-parser-2.8.4.tgz#45d70417e742ac3bc6bef3786aa453e1f1d63ecc",
53
53
  "@types/jsonwebtoken@^9.0.0": "https://registry.yarnpkg.com/@types/jsonwebtoken/-/jsonwebtoken-9.0.7.tgz#e49b96c2b29356ed462e9708fc73b833014727d2",
54
- "@types/node@*": "https://registry.yarnpkg.com/@types/node/-/node-22.10.1.tgz#41ffeee127b8975a05f8c4f83fb89bcb2987d766",
54
+ "@types/node@*": "https://registry.yarnpkg.com/@types/node/-/node-22.10.2.tgz#a485426e6d1fdafc7b0d4c7b24e2c78182ddabb9",
55
55
  "@types/node@^14": "https://registry.yarnpkg.com/@types/node/-/node-14.18.63.tgz#1788fa8da838dbb5f9ea994b834278205db6ca2b",
56
56
  "aggregate-error@^3.1.0": "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a",
57
57
  "before-after-hook@^2.2.0": "https://registry.yarnpkg.com/before-after-hook/-/before-after-hook-2.2.3.tgz#c51e809c81a4e354084422b9b26bad88249c517c",
@@ -8,8 +8,8 @@ This package contains type definitions for node (https://nodejs.org/).
8
8
  Files were exported from https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node.
9
9
 
10
10
  ### Additional Details
11
- * Last updated: Thu, 28 Nov 2024 06:02:26 GMT
11
+ * Last updated: Wed, 11 Dec 2024 09:35:14 GMT
12
12
  * Dependencies: [undici-types](https://npmjs.com/package/undici-types)
13
13
 
14
14
  # Credits
15
- These definitions were written by [Microsoft TypeScript](https://github.com/Microsoft), [Alberto Schiabel](https://github.com/jkomyno), [Alvis HT Tang](https://github.com/alvis), [Andrew Makarov](https://github.com/r3nya), [Benjamin Toueg](https://github.com/btoueg), [Chigozirim C.](https://github.com/smac89), [David Junger](https://github.com/touffy), [Deividas Bakanas](https://github.com/DeividasBakanas), [Eugene Y. Q. Shen](https://github.com/eyqs), [Hannes Magnusson](https://github.com/Hannes-Magnusson-CK), [Huw](https://github.com/hoo29), [Kelvin Jin](https://github.com/kjin), [Klaus Meinhardt](https://github.com/ajafff), [Lishude](https://github.com/islishude), [Mariusz Wiktorczyk](https://github.com/mwiktorczyk), [Mohsen Azimi](https://github.com/mohsen1), [Nikita Galkin](https://github.com/galkin), [Parambir Singh](https://github.com/parambirs), [Sebastian Silbermann](https://github.com/eps1lon), [Thomas den Hollander](https://github.com/ThomasdenH), [Wilco Bakker](https://github.com/WilcoBakker), [wwwy3y3](https://github.com/wwwy3y3), [Samuel Ainsworth](https://github.com/samuela), [Kyle Uehlein](https://github.com/kuehlein), [Thanik Bhongbhibhat](https://github.com/bhongy), [Marcin Kopacz](https://github.com/chyzwar), [Trivikram Kamat](https://github.com/trivikr), [Junxiao Shi](https://github.com/yoursunny), [Ilia Baryshnikov](https://github.com/qwelias), [ExE Boss](https://github.com/ExE-Boss), [Piotr Błażejewicz](https://github.com/peterblazejewicz), [Anna Henningsen](https://github.com/addaleax), [Victor Perin](https://github.com/victorperin), [Yongsheng Zhang](https://github.com/ZYSzys), [NodeJS Contributors](https://github.com/NodeJS), [Linus Unnebäck](https://github.com/LinusU), [wafuwafu13](https://github.com/wafuwafu13), [Matteo Collina](https://github.com/mcollina), and [Dmitry Semigradsky](https://github.com/Semigradsky).
15
+ These definitions were written by [Microsoft TypeScript](https://github.com/Microsoft), [Alberto Schiabel](https://github.com/jkomyno), [Alvis HT Tang](https://github.com/alvis), [Andrew Makarov](https://github.com/r3nya), [Benjamin Toueg](https://github.com/btoueg), [Chigozirim C.](https://github.com/smac89), [David Junger](https://github.com/touffy), [Deividas Bakanas](https://github.com/DeividasBakanas), [Eugene Y. Q. Shen](https://github.com/eyqs), [Hannes Magnusson](https://github.com/Hannes-Magnusson-CK), [Huw](https://github.com/hoo29), [Kelvin Jin](https://github.com/kjin), [Klaus Meinhardt](https://github.com/ajafff), [Lishude](https://github.com/islishude), [Mariusz Wiktorczyk](https://github.com/mwiktorczyk), [Mohsen Azimi](https://github.com/mohsen1), [Nikita Galkin](https://github.com/galkin), [Parambir Singh](https://github.com/parambirs), [Sebastian Silbermann](https://github.com/eps1lon), [Thomas den Hollander](https://github.com/ThomasdenH), [Wilco Bakker](https://github.com/WilcoBakker), [wwwy3y3](https://github.com/wwwy3y3), [Samuel Ainsworth](https://github.com/samuela), [Kyle Uehlein](https://github.com/kuehlein), [Thanik Bhongbhibhat](https://github.com/bhongy), [Marcin Kopacz](https://github.com/chyzwar), [Trivikram Kamat](https://github.com/trivikr), [Junxiao Shi](https://github.com/yoursunny), [Ilia Baryshnikov](https://github.com/qwelias), [ExE Boss](https://github.com/ExE-Boss), [Piotr Błażejewicz](https://github.com/peterblazejewicz), [Anna Henningsen](https://github.com/addaleax), [Victor Perin](https://github.com/victorperin), [NodeJS Contributors](https://github.com/NodeJS), [Linus Unnebäck](https://github.com/LinusU), [wafuwafu13](https://github.com/wafuwafu13), [Matteo Collina](https://github.com/mcollina), and [Dmitry Semigradsky](https://github.com/Semigradsky).
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@types/node",
3
- "version": "22.10.1",
3
+ "version": "22.10.2",
4
4
  "description": "TypeScript definitions for node",
5
5
  "homepage": "https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node",
6
6
  "license": "MIT",
@@ -170,11 +170,6 @@
170
170
  "githubUsername": "victorperin",
171
171
  "url": "https://github.com/victorperin"
172
172
  },
173
- {
174
- "name": "Yongsheng Zhang",
175
- "githubUsername": "ZYSzys",
176
- "url": "https://github.com/ZYSzys"
177
- },
178
173
  {
179
174
  "name": "NodeJS Contributors",
180
175
  "githubUsername": "NodeJS",
@@ -220,6 +215,6 @@
220
215
  "undici-types": "~6.20.0"
221
216
  },
222
217
  "peerDependencies": {},
223
- "typesPublisherContentHash": "3701fe96f56663784f5ca896f95c630cfe62583f01bf6ce5e7a4e52c4d15e944",
218
+ "typesPublisherContentHash": "1c1003be2fa8d4f16936ac129ec72142249d4a14af58831bef4147ca7035833b",
224
219
  "typeScriptVersion": "5.0"
225
220
  }
@@ -58,6 +58,12 @@ export interface PublishToMavenProjectProps {
58
58
  * @default - no SSM parameters
59
59
  */
60
60
  ssmPrefix?: string;
61
+ /**
62
+ * Description for the CodeBuild project
63
+ *
64
+ * @default - No description
65
+ */
66
+ description?: string;
61
67
  }
62
68
  /**
63
69
  * CodeBuild project that will publish all packages in a release bundle to Maven
@@ -104,6 +110,12 @@ export interface PublishToNpmProjectProps {
104
110
  * @default - no SSM parameters
105
111
  */
106
112
  ssmPrefix?: string;
113
+ /**
114
+ * Description for the CodeBuild project
115
+ *
116
+ * @default - No description
117
+ */
118
+ description?: string;
107
119
  }
108
120
  /**
109
121
  * CodeBuild project that will publish all packages in a release bundle to NPM
@@ -145,6 +157,12 @@ export interface PublishToNuGetProjectProps {
145
157
  * @default - no SSM parameters
146
158
  */
147
159
  ssmPrefix?: string;
160
+ /**
161
+ * Description for the CodeBuild project
162
+ *
163
+ * @default - No description
164
+ */
165
+ description?: string;
148
166
  }
149
167
  /**
150
168
  * CodeBuild project that will publish all packages in a release bundle to NuGet
@@ -184,6 +202,12 @@ export interface PublishDocsToGitHubProjectProps {
184
202
  * @default - no SSM parameters
185
203
  */
186
204
  ssmPrefix?: string;
205
+ /**
206
+ * Description for the CodeBuild project
207
+ *
208
+ * @default - No description
209
+ */
210
+ description?: string;
187
211
  }
188
212
  /**
189
213
  * CodeBuild project that will publish all packages in a release bundle to NuGet
@@ -248,6 +272,12 @@ export interface PublishToGitHubProps {
248
272
  * @default - no SSM parameters
249
273
  */
250
274
  ssmPrefix?: string;
275
+ /**
276
+ * Description for the CodeBuild project
277
+ *
278
+ * @default - No description
279
+ */
280
+ description?: string;
251
281
  }
252
282
  export declare class PublishToGitHub extends Construct implements IPublisher {
253
283
  readonly role: iam.IRole;
@@ -269,6 +299,12 @@ export interface PublishToS3Props {
269
299
  * @default true
270
300
  */
271
301
  dryRun?: boolean;
302
+ /**
303
+ * Description for the CodeBuild project
304
+ *
305
+ * @default - No description
306
+ */
307
+ description?: string;
272
308
  }
273
309
  export declare class PublishToS3 extends Construct implements IPublisher {
274
310
  readonly role?: iam.IRole;
@@ -295,6 +331,12 @@ export interface PublishToPyPiProps {
295
331
  * @default - no SSM parameters
296
332
  */
297
333
  ssmPrefix?: string;
334
+ /**
335
+ * Description for the CodeBuild project
336
+ *
337
+ * @default - No description
338
+ */
339
+ description?: string;
298
340
  }
299
341
  export declare class PublishToPyPi extends Construct {
300
342
  readonly project: cbuild.Project;
@@ -353,6 +395,12 @@ export interface PublishToGolangProps {
353
395
  * @default - no SSM parameters
354
396
  */
355
397
  ssmPrefix?: string;
398
+ /**
399
+ * Description for the CodeBuild project
400
+ *
401
+ * @default - No description
402
+ */
403
+ description?: string;
356
404
  }
357
405
  /**
358
406
  * Pushes a directory of golang modules to a GitHub repository.
package/lib/publishing.js CHANGED
@@ -27,6 +27,7 @@ exports.PublishToGolang = exports.PublishToPyPi = exports.PublishToS3 = exports.
27
27
  const path = __importStar(require("path"));
28
28
  const aws_cdk_lib_1 = require("aws-cdk-lib");
29
29
  const constructs_1 = require("constructs");
30
+ const constants_1 = require("./constants");
30
31
  const permissions = __importStar(require("./permissions"));
31
32
  const shellable_1 = require("./shellable");
32
33
  const util_1 = require("./util");
@@ -53,7 +54,8 @@ class PublishToMavenProject extends constructs_1.Construct {
53
54
  super(parent, id);
54
55
  const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();
55
56
  const shellable = new shellable_1.Shellable(this, 'Default', {
56
- platform: new shellable_1.LinuxPlatform((_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bookworm-slim-node20')),
57
+ description: props.description,
58
+ platform: new shellable_1.LinuxPlatform((_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry(constants_1.DEFAULT_SUPERCHAIN_IMAGE)),
57
59
  scriptDirectory: path.join(__dirname, 'publishing', 'maven'),
58
60
  entrypoint: 'publish.sh',
59
61
  environment: (0, util_1.noUndefined)({
@@ -93,6 +95,7 @@ class PublishToNpmProject extends constructs_1.Construct {
93
95
  const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();
94
96
  const access = (_a = props.access) !== null && _a !== void 0 ? _a : NpmAccess.PUBLIC;
95
97
  const shellable = new shellable_1.Shellable(this, 'Default', {
98
+ description: props.description,
96
99
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
97
100
  scriptDirectory: path.join(__dirname, 'publishing', 'npm'),
98
101
  entrypoint: 'publish.sh',
@@ -144,7 +147,8 @@ class PublishToNuGetProject extends constructs_1.Construct {
144
147
  environment.SSM_PREFIX = props.ssmPrefix;
145
148
  }
146
149
  const shellable = new shellable_1.Shellable(this, 'Default', {
147
- platform: new shellable_1.LinuxPlatform((_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bookworm-slim-node20')),
150
+ description: props.description,
151
+ platform: new shellable_1.LinuxPlatform((_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry(constants_1.DEFAULT_SUPERCHAIN_IMAGE)),
148
152
  scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),
149
153
  entrypoint: 'publish.sh',
150
154
  environment,
@@ -186,6 +190,7 @@ class PublishDocsToGitHubProject extends constructs_1.Construct {
186
190
  super(parent, id);
187
191
  const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();
188
192
  const shellable = new shellable_1.Shellable(this, 'Default', {
193
+ description: props.description,
189
194
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
190
195
  scriptDirectory: path.join(__dirname, 'publishing', 'docs'),
191
196
  entrypoint: 'publish.sh',
@@ -228,6 +233,7 @@ class PublishToGitHub extends constructs_1.Construct {
228
233
  throw new Error('both `releaseNotesFileName` and `changelogFileName` cannot be specified; use one or the other');
229
234
  }
230
235
  const shellable = new shellable_1.Shellable(this, 'Default', {
236
+ description: props.description,
231
237
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
232
238
  scriptDirectory: path.join(__dirname, 'publishing', 'github'),
233
239
  entrypoint: 'publish.sh',
@@ -272,6 +278,7 @@ class PublishToS3 extends constructs_1.Construct {
272
278
  super(scope, id);
273
279
  const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();
274
280
  const shellable = new shellable_1.Shellable(this, 'Default', {
281
+ description: props.description,
275
282
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
276
283
  scriptDirectory: path.join(__dirname, 'publishing', 's3'),
277
284
  entrypoint: 'publish.sh',
@@ -303,6 +310,7 @@ class PublishToPyPi extends constructs_1.Construct {
303
310
  super(scope, id);
304
311
  const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();
305
312
  const shellable = new shellable_1.Shellable(this, 'Default', {
313
+ description: props.description,
306
314
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
307
315
  scriptDirectory: path.join(__dirname, 'publishing', 'pypi'),
308
316
  entrypoint: 'publish.sh',
@@ -338,6 +346,7 @@ class PublishToGolang extends constructs_1.Construct {
338
346
  super(scope, id);
339
347
  const dryRun = (_a = props.dryRun) !== null && _a !== void 0 ? _a : false;
340
348
  const shellable = new shellable_1.Shellable(this, 'Default', {
349
+ description: props.description,
341
350
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
342
351
  scriptDirectory: path.join(__dirname, 'publishing', 'golang'),
343
352
  entrypoint: 'publish.sh',
@@ -387,4 +396,4 @@ function grantSsmPrefix(role, ssmPrefix) {
387
396
  }));
388
397
  }
389
398
  }
390
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["publishing.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Stack,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_iam as iam,\n  aws_s3 as s3,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ICodeSigningCertificate } from './code-signing';\nimport { OpenPGPKeyPair } from './open-pgp-key-pair';\nimport * as permissions from './permissions';\nimport { AddToPipelineOptions, IPublisher } from './pipeline';\nimport { WritableGitHubRepo } from './repo';\nimport { LinuxPlatform, Shellable } from './shellable';\nimport { noUndefined } from './util';\n\n/**\n * Type of access permissions to request from npmjs.\n */\nexport enum NpmAccess {\n  /**\n   * No access restriction. Note that unscoped packages must always be public.\n   */\n  PUBLIC = 'public',\n\n  /**\n   * Limit access to whitelisted npmjs users.\n   */\n  RESTRICTED = 'restricted',\n}\n\nexport interface PublishToMavenProjectProps {\n  /**\n   * The signing key itself\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The ID of the sonatype staging profile (e.g. \"68a05363083174\").\n   */\n  stagingProfileId: string;\n\n  /**\n   * Identifier of the secret that contains the Maven login\n   */\n  mavenLoginSecret: permissions.ExternalSecret;\n\n  /**\n   * If true (default) performs a dry-run only instead of actually publishing.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The Maven publishing endpoint to be used.\n   *\n   * @default \"https://oss.sonatype.org\"\n   */\n  mavenEndpoint?: string;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have Maven preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to Maven\n */\nexport class PublishToMavenProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToMavenProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bookworm-slim-node20')),\n      scriptDirectory: path.join(__dirname, 'publishing', 'maven'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        STAGING_PROFILE_ID: props.stagingProfileId,\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        FOR_REAL: forReal,\n        MAVEN_LOGIN_SECRET: props.mavenLoginSecret.secretArn,\n        MAVEN_ENDPOINT: props.mavenEndpoint || 'https://oss.sonatype.org',\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.mavenLoginSecret, shellable.role);\n      props.signingKey.grantRead(shellable.role);\n    }\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNpmProjectProps {\n  /**\n   * Identifier of the secret that contains the NPM token\n   */\n  npmTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * npm dist-tag to use when publishing artifacts.\n   *\n   * @default - npm default behavior (\"latest\" unless dist tag is specified in package.json)\n   */\n  distTag?: string;\n\n  /**\n   * npm --access public|restricted\n   *\n   * See https://docs.npmjs.com/cli-commands/publish#:~:text=Tells%20the\n   *\n   * Tells the registry whether this package should be published as public or restricted.\n   * Only applies to scoped packages, which default to restricted.\n   * If you don’t have a paid account, you must publish with --access public to publish scoped packages.\n   *\n   * @default NpmAccess.PUBLIC\n   */\n  access?: NpmAccess;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NPM\n */\nexport class PublishToNpmProject extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNpmProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const access = props.access ?? NpmAccess.PUBLIC;\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'npm'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        FOR_REAL: forReal,\n        NPM_TOKEN_SECRET: props.npmTokenSecret.secretArn,\n        DISTTAG: props.distTag || '',\n        ACCESS: access,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.npmTokenSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNuGetProjectProps {\n  /**\n   * The SecretsManager secret which stores the Nuget API key.\n   */\n  nugetApiKeySecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * A code signing certificate to use to sign assemblies.\n   * @default No signing\n   */\n  codeSign?: ICodeSigningCertificate;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have NuGet preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishToNuGetProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNuGetProjectProps) {\n    super(parent, id);\n\n    const environment: { [key: string]: string } = {};\n\n    environment.FOR_REAL = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    if (props.nugetApiKeySecret.assumeRoleArn) {\n      environment.NUGET_ROLE_ARN = props.nugetApiKeySecret.assumeRoleArn;\n    }\n\n    if (props.nugetApiKeySecret.region) {\n      environment.NUGET_SECRET_REGION = props.nugetApiKeySecret.region;\n    } else {\n      environment.NUGET_SECRET_REGION = Stack.of(this).region;\n    }\n\n    environment.NUGET_SECRET_ID = props.nugetApiKeySecret.secretArn;\n    if (props.ssmPrefix) {\n      environment.SSM_PREFIX = props.ssmPrefix;\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bookworm-slim-node20')),\n      scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),\n      entrypoint: 'publish.sh',\n      environment,\n    });\n\n    if (props.codeSign) {\n      environment.CODE_SIGNING_SECRET_ID = props.codeSign.credential.secretArn;\n      environment.CODE_SIGNING_PARAMETER_NAME = props.codeSign.principal.parameterName;\n    }\n\n    if (shellable.role) {\n      if (props.nugetApiKeySecret.assumeRoleArn) {\n        permissions.grantAssumeRole(props.nugetApiKeySecret.assumeRoleArn, shellable.role);\n      } else {\n        permissions.grantSecretRead(props.nugetApiKeySecret, shellable.role);\n      }\n\n      if (props.codeSign) {\n        props.codeSign.grantDecrypt(shellable.role);\n      }\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishDocsToGitHubProjectProps {\n  /**\n   * The repository to publish to\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * GitHub Pages branch to push to.\n   * @default gh-pages\n   */\n  branch?: string;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishDocsToGitHubProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishDocsToGitHubProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'docs'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        // Must be SSH because we use an SSH key to authenticate\n        GITHUB_REPO: props.githubRepo.repositoryUrlSsh,\n        GITHUB_PAGES_BRANCH: props.branch || 'gh-pages',\n        SSH_KEY_SECRET: props.githubRepo.sshKeySecret.secretArn,\n        FOR_REAL: forReal,\n        COMMIT_USERNAME: props.githubRepo.commitUsername,\n        COMMIT_EMAIL: props.githubRepo.commitEmail,\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubRepo.sshKeySecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToGitHubProps {\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The repository to create a release in.\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * The signign key to use to create a GPG signature of the artifact.\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * The name of the changelog markdown file, used to create release notes.\n   * Relative to the artifacts root.\n   * @default \"./CHANGELOG.md\"\n   */\n  changelogFileName?: string;\n\n  /**\n   * The name of the release notes file, containing the completed release notes\n   * for the current release.\n   * Relative to the artifacts root.\n   * NOTE - If this value is set and points to a valid file, the file in its entirety\n   * will be read and used for the release notes. The value of `changelogFileName` will\n   * be ignored.\n   * @default \"./RELEASE_NOTES.md\"\n   */\n  releaseNotesFileName?: string;\n\n  /**\n   * Additional input artifacts to publish binaries from to GitHub release\n   */\n  additionalInputArtifacts?: cpipeline.Artifact[];\n\n  /**\n   * Whether to sign the additional artifacts\n   *\n   * @default true\n   */\n  signAdditionalArtifacts?: boolean;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n}\n\nexport class PublishToGitHub extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n  private readonly additionalInputArtifacts?: cpipeline.Artifact[];\n\n  constructor(parent: Construct, id: string, props: PublishToGitHubProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n    this.additionalInputArtifacts = props.additionalInputArtifacts;\n\n    // The release notes, if set and a valid file, overrides any usages of the changelog.\n    if (props.changelogFileName && props.releaseNotesFileName) {\n      throw new Error('both `releaseNotesFileName` and `changelogFileName` cannot be specified; use one or the other');\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'github'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        CHANGELOG: props.changelogFileName || './CHANGELOG.md',\n        RELEASE_NOTES: props.releaseNotesFileName || './RELEASE_NOTES.md',\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        GITHUB_OWNER: props.githubRepo.owner,\n        GITHUB_REPO: props.githubRepo.repo,\n        FOR_REAL: forReal,\n        // Transmit the names of the secondary sources to the shell script (for easier iteration)\n        SECONDARY_SOURCE_NAMES: props.additionalInputArtifacts ? props.additionalInputArtifacts.map(a => a.artifactName).join(' ') : undefined,\n        SIGN_ADDITIONAL_ARTIFACTS: props.additionalInputArtifacts && props.signAdditionalArtifacts !== false ? 'true' : undefined,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n      environmentSecrets: {\n        GITHUB_TOKEN: props.githubRepo.tokenSecretArn,\n      },\n    });\n\n    // allow script to read the signing key\n    if (shellable.role) {\n      props.signingKey.grantRead(shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      extraInputs: this.additionalInputArtifacts,\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToS3Props {\n  bucket: s3.IBucket;\n\n  /**\n   * Make files publicly readable\n   *\n   * @default false\n   */\n  public?: boolean;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n}\n\nexport class PublishToS3 extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(scope: Construct, id: string, props: PublishToS3Props) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 's3'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUCKET_URL: `s3://${props.bucket.bucketName}`,\n        CHANGELOG: props.public ? 'true' : 'false',\n        FOR_REAL: forReal,\n      }),\n    });\n\n    // Allow script to write to bucket\n    if (shellable.role) {\n      props.bucket.grantReadWrite(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToPyPiProps {\n  /**\n   * Identifier of the secret that contains the PyPI credentials under\n   * \"username\" and \"password\" keys.\n   */\n  loginSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n}\n\nexport class PublishToPyPi extends Construct {\n\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToPyPiProps) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'pypi'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        FOR_REAL: forReal,\n        PYPI_CREDENTIALS_SECRET_ID: props.loginSecret.secretArn,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.loginSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\n/**\n * Props for Go publishing.\n */\nexport interface PublishToGolangProps {\n  /**\n   * Identifier of the secret that contains the GitHub personal access token\n   * used to push the go code to the github repository defined by it's name.\n   *\n   * @see https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token\n   */\n  readonly githubTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * Username to perform the commit with.\n   */\n  readonly gitUserName: string;\n\n  /**\n   * Email to perform the commit with.\n   */\n  readonly gitUserEmail: string;\n\n  /**\n   * Set to \"true\" for a dry run.\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Module version.\n   *\n   * @default - Defaults to the value in the 'version' file of the module\n   * directory. Fails if it doesn't exist.\n   */\n  readonly version?: string;\n\n  /**\n   * Branch to push to.\n   *\n   * @default \"main\"\n   */\n  readonly gitBranch?: string;\n\n  /**\n   * The commit message.\n   *\n   * @default \"chore(release): $VERSION\"\n   */\n  readonly gitCommitMessage?: string;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n}\n\n/**\n * Pushes a directory of golang modules to a GitHub repository.\n */\nexport class PublishToGolang extends Construct {\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToGolangProps) {\n    super(scope, id);\n\n    const dryRun = props.dryRun ?? false;\n\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'golang'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        DRYRUN: dryRun ? 'true' : undefined,\n        GITHUB_TOKEN_SECRET: props.githubTokenSecret.secretArn,\n        VERSION: props.version,\n        GIT_BRANCH: props.gitBranch,\n        GIT_USER_NAME: props.gitUserName,\n        GIT_USER_EMAIL: props.gitUserEmail,\n        GIT_COMMIT_MESSAGE: props.gitCommitMessage,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubTokenSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nfunction grantSsmPrefix(role: iam.IRole, ssmPrefix?: string) {\n  if (ssmPrefix) {\n    if (!ssmPrefix.startsWith('/')) {\n      throw new Error(`SSM prefix should start with '/', got: ${ssmPrefix}`);\n    }\n    if (ssmPrefix.endsWith('/')) {\n      throw new Error(`SSM prefix must not end with '/', got: ${ssmPrefix}`);\n    }\n\n    role?.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['ssm:PutParameter', 'ssm:GetParameter'],\n      resources: [Stack.of(role).formatArn({\n        service: 'ssm',\n        resource: 'parameter',\n        resourceName: `${ssmPrefix.slice(1)}/*`,\n      })],\n    }));\n  }\n}"]}
399
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["publishing.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Stack,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_iam as iam,\n  aws_s3 as s3,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ICodeSigningCertificate } from './code-signing';\nimport { DEFAULT_SUPERCHAIN_IMAGE } from './constants';\nimport { OpenPGPKeyPair } from './open-pgp-key-pair';\nimport * as permissions from './permissions';\nimport { AddToPipelineOptions, IPublisher } from './pipeline';\nimport { WritableGitHubRepo } from './repo';\nimport { LinuxPlatform, Shellable } from './shellable';\nimport { noUndefined } from './util';\n\n/**\n * Type of access permissions to request from npmjs.\n */\nexport enum NpmAccess {\n  /**\n   * No access restriction. Note that unscoped packages must always be public.\n   */\n  PUBLIC = 'public',\n\n  /**\n   * Limit access to whitelisted npmjs users.\n   */\n  RESTRICTED = 'restricted',\n}\n\nexport interface PublishToMavenProjectProps {\n  /**\n   * The signing key itself\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The ID of the sonatype staging profile (e.g. \"68a05363083174\").\n   */\n  stagingProfileId: string;\n\n  /**\n   * Identifier of the secret that contains the Maven login\n   */\n  mavenLoginSecret: permissions.ExternalSecret;\n\n  /**\n   * If true (default) performs a dry-run only instead of actually publishing.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The Maven publishing endpoint to be used.\n   *\n   * @default \"https://oss.sonatype.org\"\n   */\n  mavenEndpoint?: string;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have Maven preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to Maven\n */\nexport class PublishToMavenProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToMavenProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry(DEFAULT_SUPERCHAIN_IMAGE)),\n      scriptDirectory: path.join(__dirname, 'publishing', 'maven'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        STAGING_PROFILE_ID: props.stagingProfileId,\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        FOR_REAL: forReal,\n        MAVEN_LOGIN_SECRET: props.mavenLoginSecret.secretArn,\n        MAVEN_ENDPOINT: props.mavenEndpoint || 'https://oss.sonatype.org',\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.mavenLoginSecret, shellable.role);\n      props.signingKey.grantRead(shellable.role);\n    }\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNpmProjectProps {\n  /**\n   * Identifier of the secret that contains the NPM token\n   */\n  npmTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * npm dist-tag to use when publishing artifacts.\n   *\n   * @default - npm default behavior (\"latest\" unless dist tag is specified in package.json)\n   */\n  distTag?: string;\n\n  /**\n   * npm --access public|restricted\n   *\n   * See https://docs.npmjs.com/cli-commands/publish#:~:text=Tells%20the\n   *\n   * Tells the registry whether this package should be published as public or restricted.\n   * Only applies to scoped packages, which default to restricted.\n   * If you don’t have a paid account, you must publish with --access public to publish scoped packages.\n   *\n   * @default NpmAccess.PUBLIC\n   */\n  access?: NpmAccess;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NPM\n */\nexport class PublishToNpmProject extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNpmProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const access = props.access ?? NpmAccess.PUBLIC;\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'npm'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        FOR_REAL: forReal,\n        NPM_TOKEN_SECRET: props.npmTokenSecret.secretArn,\n        DISTTAG: props.distTag || '',\n        ACCESS: access,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.npmTokenSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNuGetProjectProps {\n  /**\n   * The SecretsManager secret which stores the Nuget API key.\n   */\n  nugetApiKeySecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * A code signing certificate to use to sign assemblies.\n   * @default No signing\n   */\n  codeSign?: ICodeSigningCertificate;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have NuGet preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishToNuGetProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNuGetProjectProps) {\n    super(parent, id);\n\n    const environment: { [key: string]: string } = {};\n\n    environment.FOR_REAL = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    if (props.nugetApiKeySecret.assumeRoleArn) {\n      environment.NUGET_ROLE_ARN = props.nugetApiKeySecret.assumeRoleArn;\n    }\n\n    if (props.nugetApiKeySecret.region) {\n      environment.NUGET_SECRET_REGION = props.nugetApiKeySecret.region;\n    } else {\n      environment.NUGET_SECRET_REGION = Stack.of(this).region;\n    }\n\n    environment.NUGET_SECRET_ID = props.nugetApiKeySecret.secretArn;\n    if (props.ssmPrefix) {\n      environment.SSM_PREFIX = props.ssmPrefix;\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry(DEFAULT_SUPERCHAIN_IMAGE)),\n      scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),\n      entrypoint: 'publish.sh',\n      environment,\n    });\n\n    if (props.codeSign) {\n      environment.CODE_SIGNING_SECRET_ID = props.codeSign.credential.secretArn;\n      environment.CODE_SIGNING_PARAMETER_NAME = props.codeSign.principal.parameterName;\n    }\n\n    if (shellable.role) {\n      if (props.nugetApiKeySecret.assumeRoleArn) {\n        permissions.grantAssumeRole(props.nugetApiKeySecret.assumeRoleArn, shellable.role);\n      } else {\n        permissions.grantSecretRead(props.nugetApiKeySecret, shellable.role);\n      }\n\n      if (props.codeSign) {\n        props.codeSign.grantDecrypt(shellable.role);\n      }\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishDocsToGitHubProjectProps {\n  /**\n   * The repository to publish to\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * GitHub Pages branch to push to.\n   * @default gh-pages\n   */\n  branch?: string;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishDocsToGitHubProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishDocsToGitHubProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'docs'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        // Must be SSH because we use an SSH key to authenticate\n        GITHUB_REPO: props.githubRepo.repositoryUrlSsh,\n        GITHUB_PAGES_BRANCH: props.branch || 'gh-pages',\n        SSH_KEY_SECRET: props.githubRepo.sshKeySecret.secretArn,\n        FOR_REAL: forReal,\n        COMMIT_USERNAME: props.githubRepo.commitUsername,\n        COMMIT_EMAIL: props.githubRepo.commitEmail,\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubRepo.sshKeySecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToGitHubProps {\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The repository to create a release in.\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * The signign key to use to create a GPG signature of the artifact.\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * The name of the changelog markdown file, used to create release notes.\n   * Relative to the artifacts root.\n   * @default \"./CHANGELOG.md\"\n   */\n  changelogFileName?: string;\n\n  /**\n   * The name of the release notes file, containing the completed release notes\n   * for the current release.\n   * Relative to the artifacts root.\n   * NOTE - If this value is set and points to a valid file, the file in its entirety\n   * will be read and used for the release notes. The value of `changelogFileName` will\n   * be ignored.\n   * @default \"./RELEASE_NOTES.md\"\n   */\n  releaseNotesFileName?: string;\n\n  /**\n   * Additional input artifacts to publish binaries from to GitHub release\n   */\n  additionalInputArtifacts?: cpipeline.Artifact[];\n\n  /**\n   * Whether to sign the additional artifacts\n   *\n   * @default true\n   */\n  signAdditionalArtifacts?: boolean;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToGitHub extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n  private readonly additionalInputArtifacts?: cpipeline.Artifact[];\n\n  constructor(parent: Construct, id: string, props: PublishToGitHubProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n    this.additionalInputArtifacts = props.additionalInputArtifacts;\n\n    // The release notes, if set and a valid file, overrides any usages of the changelog.\n    if (props.changelogFileName && props.releaseNotesFileName) {\n      throw new Error('both `releaseNotesFileName` and `changelogFileName` cannot be specified; use one or the other');\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'github'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        CHANGELOG: props.changelogFileName || './CHANGELOG.md',\n        RELEASE_NOTES: props.releaseNotesFileName || './RELEASE_NOTES.md',\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        GITHUB_OWNER: props.githubRepo.owner,\n        GITHUB_REPO: props.githubRepo.repo,\n        FOR_REAL: forReal,\n        // Transmit the names of the secondary sources to the shell script (for easier iteration)\n        SECONDARY_SOURCE_NAMES: props.additionalInputArtifacts ? props.additionalInputArtifacts.map(a => a.artifactName).join(' ') : undefined,\n        SIGN_ADDITIONAL_ARTIFACTS: props.additionalInputArtifacts && props.signAdditionalArtifacts !== false ? 'true' : undefined,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n      environmentSecrets: {\n        GITHUB_TOKEN: props.githubRepo.tokenSecretArn,\n      },\n    });\n\n    // allow script to read the signing key\n    if (shellable.role) {\n      props.signingKey.grantRead(shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      extraInputs: this.additionalInputArtifacts,\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToS3Props {\n  bucket: s3.IBucket;\n\n  /**\n   * Make files publicly readable\n   *\n   * @default false\n   */\n  public?: boolean;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToS3 extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(scope: Construct, id: string, props: PublishToS3Props) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 's3'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUCKET_URL: `s3://${props.bucket.bucketName}`,\n        CHANGELOG: props.public ? 'true' : 'false',\n        FOR_REAL: forReal,\n      }),\n    });\n\n    // Allow script to write to bucket\n    if (shellable.role) {\n      props.bucket.grantReadWrite(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToPyPiProps {\n  /**\n   * Identifier of the secret that contains the PyPI credentials under\n   * \"username\" and \"password\" keys.\n   */\n  loginSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToPyPi extends Construct {\n\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToPyPiProps) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'pypi'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        FOR_REAL: forReal,\n        PYPI_CREDENTIALS_SECRET_ID: props.loginSecret.secretArn,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.loginSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\n/**\n * Props for Go publishing.\n */\nexport interface PublishToGolangProps {\n  /**\n   * Identifier of the secret that contains the GitHub personal access token\n   * used to push the go code to the github repository defined by it's name.\n   *\n   * @see https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token\n   */\n  readonly githubTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * Username to perform the commit with.\n   */\n  readonly gitUserName: string;\n\n  /**\n   * Email to perform the commit with.\n   */\n  readonly gitUserEmail: string;\n\n  /**\n   * Set to \"true\" for a dry run.\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Module version.\n   *\n   * @default - Defaults to the value in the 'version' file of the module\n   * directory. Fails if it doesn't exist.\n   */\n  readonly version?: string;\n\n  /**\n   * Branch to push to.\n   *\n   * @default \"main\"\n   */\n  readonly gitBranch?: string;\n\n  /**\n   * The commit message.\n   *\n   * @default \"chore(release): $VERSION\"\n   */\n  readonly gitCommitMessage?: string;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * Pushes a directory of golang modules to a GitHub repository.\n */\nexport class PublishToGolang extends Construct {\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToGolangProps) {\n    super(scope, id);\n\n    const dryRun = props.dryRun ?? false;\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'golang'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        DRYRUN: dryRun ? 'true' : undefined,\n        GITHUB_TOKEN_SECRET: props.githubTokenSecret.secretArn,\n        VERSION: props.version,\n        GIT_BRANCH: props.gitBranch,\n        GIT_USER_NAME: props.gitUserName,\n        GIT_USER_EMAIL: props.gitUserEmail,\n        GIT_COMMIT_MESSAGE: props.gitCommitMessage,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubTokenSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nfunction grantSsmPrefix(role: iam.IRole, ssmPrefix?: string) {\n  if (ssmPrefix) {\n    if (!ssmPrefix.startsWith('/')) {\n      throw new Error(`SSM prefix should start with '/', got: ${ssmPrefix}`);\n    }\n    if (ssmPrefix.endsWith('/')) {\n      throw new Error(`SSM prefix must not end with '/', got: ${ssmPrefix}`);\n    }\n\n    role?.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['ssm:PutParameter', 'ssm:GetParameter'],\n      resources: [Stack.of(role).formatArn({\n        service: 'ssm',\n        resource: 'parameter',\n        resourceName: `${ssmPrefix.slice(1)}/*`,\n      })],\n    }));\n  }\n}"]}
@@ -70,6 +70,12 @@ export interface AutoMergeBackOptions extends pr.AutoPullRequestOptions {
70
70
  * @default - no condition
71
71
  */
72
72
  condition?: string;
73
+ /**
74
+ * Description for the CodeBuild project
75
+ *
76
+ * @default - No description
77
+ */
78
+ projectDescription?: string;
73
79
  }
74
80
  export interface AutoMergeBackPipelineOptions extends AutoMergeBackOptions {
75
81
  /**
@@ -50,4 +50,4 @@ class AutoMergeBack extends constructs_1.Construct {
50
50
  }
51
51
  }
52
52
  exports.AutoMergeBack = AutoMergeBack;
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtYmFjay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm1lcmdlLWJhY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBdUM7QUFDdkMseUNBQTJCO0FBb0czQixNQUFhLGFBQWMsU0FBUSxzQkFBUztJQU8xQyxZQUFZLE1BQWlCLEVBQUUsRUFBVSxFQUFFLEtBQXlCOztRQUNsRSxLQUFLLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWxCLE1BQU0sY0FBYyxHQUFHLE1BQUEsS0FBSyxDQUFDLGNBQWMsbUNBQUksY0FBYyxDQUFDO1FBQzlELE1BQU0sUUFBUSxHQUFHLE1BQUEsTUFBQSxLQUFLLENBQUMsSUFBSSwwQ0FBRSxJQUFJLG1DQUFJLHFCQUFxQixDQUFDO1FBQzNELE1BQU0sS0FBSyxHQUFHLE1BQUEsS0FBSyxDQUFDLEtBQUssbUNBQUksNkJBQTZCLENBQUM7UUFDM0QsTUFBTSxJQUFJLEdBQUcsTUFBQSxLQUFLLENBQUMsSUFBSSxtQ0FBSSxzQ0FBc0MsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLFNBQVMsUUFBUSxnQkFBZ0IsQ0FBQztRQUV0SSxJQUFJLENBQUMsRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsZUFBZSxFQUFFO1lBQ3RELEdBQUcsS0FBSztZQUNSLElBQUk7WUFDSixLQUFLO1lBQ0wsSUFBSSxFQUFFO2dCQUNKLElBQUksRUFBRSxRQUFRO2dCQUNkLE1BQU0sRUFBRSxNQUFBLEtBQUssQ0FBQyxJQUFJLDBDQUFFLE1BQU07YUFDM0I7WUFDRCxPQUFPLEVBQUU7Z0JBQ1AsR0FBRyxLQUFLLENBQUMsT0FBTztnQkFDaEIsT0FBTyxFQUFFLGNBQWM7YUFDeEI7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUE3QkQsc0NBNkJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgKiBhcyBwciBmcm9tICcuL3ByJztcbmltcG9ydCB7IFdyaXRhYmxlR2l0SHViUmVwbyB9IGZyb20gJy4uL3JlcG8nO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGNvbmZpZ3VyaW5nIHRoZSBoZWFkIGJyYW5jaCBvZiB0aGUgYnVtcCBQUi5cbiAqIChUaGUgYnJhbmNoIHRoZSBQUiB3aWxsIGJlIG1lcmdlZCBmcm9tKVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEF1dG9NZXJnZUJhY2tIZWFkIHtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgYnJhbmNoLiBXaWxsIGJlIGNyZWF0ZWQgaWYgaXQgZG9lc24ndCBleGlzdC5cbiAgICogJFZFUlNJT04gd2lsbCBiZSBzdWJzdGl0dXRlZCBieSB0aGUgY3VycmVudCB2ZXJzaW9uIChvYnRhaW5lZCBieSBleGVjdXRpbmcgYHZlcnNpb25Db21tYW5kYCkuXG4gICAqXG4gICAqIEBkZWZhdWx0ICdtZXJnZS1iYWNrLyRWRVJTSU9OJ1xuICAgKi9cbiAgcmVhZG9ubHkgbmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogQHNlZSAnc291cmNlJyBwcm9wZXJ0eSBpbiBBdXRvUHVsbFJlcXVlc3QuSGVhZFxuICAgKi9cbiAgcmVhZG9ubHkgc291cmNlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1lcmdlQmFja1N0YWdlIHtcblxuICAvKipcbiAgICogV2hpY2ggc3RhZ2Ugc2hvdWxkIHRoZSBtZXJnZSBiYWNrIGJlIHBhcnQgb2YuIChDcmVhdGVkIGlmIG1pc3NpbmcpXG4gICAqXG4gICAqIEBkZWZhdWx0ICdNZXJnZUJhY2snXG4gICAqL1xuICByZWFkb25seSBuYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgc3RhZ2UgdGhhdCB0aGUgbWVyZ2UgYmFjayBzdGFnZSBzaG91bGQgZ28gYWZ0ZXIgb2YuIChNdXN0IGV4aXN0KVxuICAgKi9cbiAgcmVhZG9ubHkgYWZ0ZXI6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBdXRvTWVyZ2VCYWNrT3B0aW9ucyBleHRlbmRzIHByLkF1dG9QdWxsUmVxdWVzdE9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIGNvbW1hbmQgdG8gZGV0ZXJtaW5lIHRoZSBjdXJyZW50IHZlcnNpb24uXG4gICAqXG4gICAqIEBkZWZhdWx0ICdnaXQgZGVzY3JpYmUnXG4gICAqL1xuICB2ZXJzaW9uQ29tbWFuZD86IHN0cmluZztcblxuICAvKipcbiAgICogVGl0bGUgb2YgdGhlIFBSLlxuICAgKlxuICAgKiAkVkVSU0lPTiB3aWxsIGJlIHN1YnN0aXR1dGVkIGJ5IHRoZSBjdXJyZW50IHZlcnNpb24gKG9idGFpbmVkIGJ5IGV4ZWN1dGluZyBgdmVyc2lvbkNvbW1hbmRgKS5cbiAgICpcbiAgICogQGRlZmF1bHQgJ2Nob3JlKHJlbGVhc2UpOiBtZXJnZSBiYWNrICRWRVJTSU9OJ1xuICAgKi9cbiAgdGl0bGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEJvZHkgb2YgdGhlIFBSLlxuICAgKlxuICAgKiBAZGVmYXVsdCAnU2VlIFtDSEFOR0VMT0ddKGh0dHBzOi8vZ2l0aHViLmNvbS8ke3Byb3BzLnJlcG8ub3duZXJ9LyR7cHJvcHMucmVwby5yZXBvfS9ibG9iLyR7aGVhZH0vQ0hBTkdFTE9HLm1kKSdcbiAgICogKExpbmsgdG8gdGhlIENIQU5HRUxPRyBmaWxlIG9mIHRoZSBoZWFkIGJyYW5jaClcbiAgICovXG4gIGJvZHk/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEhlYWQgYnJhbmNoIG9mIHRoZSBQUi5cbiAgICpcbiAgICogJFZFUlNJT04gd2lsbCBiZSBzdWJzdGl0dXRlZCBieSB0aGUgY3VycmVudCB2ZXJzaW9uIChvYnRhaW5lZCBieSBleGVjdXRpbmcgYHZlcnNpb25Db21tYW5kYCkuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gV2lsbCBiZSBjcmVhdGVkIGZyb20gcmVsZWFzZSBhbmQgbmFtZWQgJ21lcmdlLWJhY2svJFZFUlNJT04nXG4gICAqL1xuICBoZWFkPzogQXV0b01lcmdlQmFja0hlYWQ7XG5cbiAgLyoqXG4gICAqIFRoZSBleGl0IGNvZGUgb2YgdGhpcyBjb21tYW5kIGRldGVybWluZXMgd2hldGhlciBvciBub3QgdG8gcHJvY2VlZCB3aXRoIHRoZVxuICAgKiBQUiBjcmVhdGlvbi4gSWYgY29uZmlndXJlZCwgdGhpcyBjb21tYW5kIGlzIHRoZSBmaXJzdCBvbmUgdG8gcnVuLCBhbmQgaWYgaXQgZmFpbHMsIGFsbFxuICAgKiBvdGhlciBjb21tYW5kcyB3aWxsIGJlIHNraXBwZWQuXG4gICAqXG4gICAqIFRoaXMgY29tbWFuZCBpcyB0aGUgZmlyc3QgdG8gZXhlY3V0ZSwgYW5kIHNob3VsZCBub3QgYXNzdW1lIGFueSBwcmUtZXhpc3Rpbmcgc3RhdGUuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gbm8gY29uZGl0aW9uXG4gICAqL1xuICBjb25kaXRpb24/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXV0b01lcmdlQmFja1BpcGVsaW5lT3B0aW9ucyBleHRlbmRzIEF1dG9NZXJnZUJhY2tPcHRpb25zIHtcbiAgLyoqXG4gICAqIFNwZWNpZnkgc3RhZ2Ugb3B0aW9ucyB0byBjcmVhdGUgdGhlIG1lcmdlIGJhY2sgaW5zaWRlIGEgc3RhZ2Ugb2YgdGhlIHBpcGVsaW5lLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIFRoZSBDb2RlQnVpbGQgcHJvamVjdCB3aWxsIGJlIGNyZWF0ZWQgaW5kZXBkZW50IG9mIGFueSBzdGFnZS5cbiAgICovXG4gIHJlYWRvbmx5IHN0YWdlPzogTWVyZ2VCYWNrU3RhZ2U7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXV0b01lcmdlQmFja1Byb3BzIGV4dGVuZHMgQXV0b01lcmdlQmFja09wdGlvbnMge1xuICAvKipcbiAgICogVGhlIHJlcG9zaXRvcnkgdG8gYnVtcC5cbiAgICovXG4gIHJlcG86IFdyaXRhYmxlR2l0SHViUmVwbztcbn1cblxuZXhwb3J0IGNsYXNzIEF1dG9NZXJnZUJhY2sgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuXG4gIC8qKlxuICAgKiBUaGUgdW5kZXJseWluZyBBdXRvUHVsbFJlcXVlc3QgY29uc3RydWN0LlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHByOiBwci5BdXRvUHVsbFJlcXVlc3Q7XG5cbiAgY29uc3RydWN0b3IocGFyZW50OiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBBdXRvTWVyZ2VCYWNrUHJvcHMpIHtcbiAgICBzdXBlcihwYXJlbnQsIGlkKTtcblxuICAgIGNvbnN0IHZlcnNpb25Db21tYW5kID0gcHJvcHMudmVyc2lvbkNvbW1hbmQgPz8gJ2dpdCBkZXNjcmliZSc7XG4gICAgY29uc3QgaGVhZE5hbWUgPSBwcm9wcy5oZWFkPy5uYW1lID8/ICdtZXJnZS1iYWNrLyRWRVJTSU9OJztcbiAgICBjb25zdCB0aXRsZSA9IHByb3BzLnRpdGxlID8/ICdjaG9yZShtZXJnZS1iYWNrKTogJFZFUlNJT04nO1xuICAgIGNvbnN0IGJvZHkgPSBwcm9wcy5ib2R5ID8/IGBTZWUgW0NIQU5HRUxPR10oaHR0cHM6Ly9naXRodWIuY29tLyR7cHJvcHMucmVwby5vd25lcn0vJHtwcm9wcy5yZXBvLnJlcG99L2Jsb2IvJHtoZWFkTmFtZX0vQ0hBTkdFTE9HLm1kKWA7XG5cbiAgICB0aGlzLnByID0gbmV3IHByLkF1dG9QdWxsUmVxdWVzdCh0aGlzLCAnQXV0b01lcmdlQmFjaycsIHtcbiAgICAgIC4uLnByb3BzLFxuICAgICAgYm9keSxcbiAgICAgIHRpdGxlLFxuICAgICAgaGVhZDoge1xuICAgICAgICBuYW1lOiBoZWFkTmFtZSxcbiAgICAgICAgc291cmNlOiBwcm9wcy5oZWFkPy5zb3VyY2UsXG4gICAgICB9LFxuICAgICAgZXhwb3J0czoge1xuICAgICAgICAuLi5wcm9wcy5leHBvcnRzLFxuICAgICAgICBWRVJTSU9OOiB2ZXJzaW9uQ29tbWFuZCxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtYmFjay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIm1lcmdlLWJhY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBdUM7QUFDdkMseUNBQTJCO0FBMkczQixNQUFhLGFBQWMsU0FBUSxzQkFBUztJQU8xQyxZQUFZLE1BQWlCLEVBQUUsRUFBVSxFQUFFLEtBQXlCOztRQUNsRSxLQUFLLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWxCLE1BQU0sY0FBYyxHQUFHLE1BQUEsS0FBSyxDQUFDLGNBQWMsbUNBQUksY0FBYyxDQUFDO1FBQzlELE1BQU0sUUFBUSxHQUFHLE1BQUEsTUFBQSxLQUFLLENBQUMsSUFBSSwwQ0FBRSxJQUFJLG1DQUFJLHFCQUFxQixDQUFDO1FBQzNELE1BQU0sS0FBSyxHQUFHLE1BQUEsS0FBSyxDQUFDLEtBQUssbUNBQUksNkJBQTZCLENBQUM7UUFDM0QsTUFBTSxJQUFJLEdBQUcsTUFBQSxLQUFLLENBQUMsSUFBSSxtQ0FBSSxzQ0FBc0MsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLFNBQVMsUUFBUSxnQkFBZ0IsQ0FBQztRQUV0SSxJQUFJLENBQUMsRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsZUFBZSxFQUFFO1lBQ3RELEdBQUcsS0FBSztZQUNSLElBQUk7WUFDSixLQUFLO1lBQ0wsSUFBSSxFQUFFO2dCQUNKLElBQUksRUFBRSxRQUFRO2dCQUNkLE1BQU0sRUFBRSxNQUFBLEtBQUssQ0FBQyxJQUFJLDBDQUFFLE1BQU07YUFDM0I7WUFDRCxPQUFPLEVBQUU7Z0JBQ1AsR0FBRyxLQUFLLENBQUMsT0FBTztnQkFDaEIsT0FBTyxFQUFFLGNBQWM7YUFDeEI7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUE3QkQsc0NBNkJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgKiBhcyBwciBmcm9tICcuL3ByJztcbmltcG9ydCB7IFdyaXRhYmxlR2l0SHViUmVwbyB9IGZyb20gJy4uL3JlcG8nO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGNvbmZpZ3VyaW5nIHRoZSBoZWFkIGJyYW5jaCBvZiB0aGUgYnVtcCBQUi5cbiAqIChUaGUgYnJhbmNoIHRoZSBQUiB3aWxsIGJlIG1lcmdlZCBmcm9tKVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEF1dG9NZXJnZUJhY2tIZWFkIHtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgYnJhbmNoLiBXaWxsIGJlIGNyZWF0ZWQgaWYgaXQgZG9lc24ndCBleGlzdC5cbiAgICogJFZFUlNJT04gd2lsbCBiZSBzdWJzdGl0dXRlZCBieSB0aGUgY3VycmVudCB2ZXJzaW9uIChvYnRhaW5lZCBieSBleGVjdXRpbmcgYHZlcnNpb25Db21tYW5kYCkuXG4gICAqXG4gICAqIEBkZWZhdWx0ICdtZXJnZS1iYWNrLyRWRVJTSU9OJ1xuICAgKi9cbiAgcmVhZG9ubHkgbmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogQHNlZSAnc291cmNlJyBwcm9wZXJ0eSBpbiBBdXRvUHVsbFJlcXVlc3QuSGVhZFxuICAgKi9cbiAgcmVhZG9ubHkgc291cmNlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1lcmdlQmFja1N0YWdlIHtcblxuICAvKipcbiAgICogV2hpY2ggc3RhZ2Ugc2hvdWxkIHRoZSBtZXJnZSBiYWNrIGJlIHBhcnQgb2YuIChDcmVhdGVkIGlmIG1pc3NpbmcpXG4gICAqXG4gICAqIEBkZWZhdWx0ICdNZXJnZUJhY2snXG4gICAqL1xuICByZWFkb25seSBuYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgc3RhZ2UgdGhhdCB0aGUgbWVyZ2UgYmFjayBzdGFnZSBzaG91bGQgZ28gYWZ0ZXIgb2YuIChNdXN0IGV4aXN0KVxuICAgKi9cbiAgcmVhZG9ubHkgYWZ0ZXI6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBdXRvTWVyZ2VCYWNrT3B0aW9ucyBleHRlbmRzIHByLkF1dG9QdWxsUmVxdWVzdE9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIGNvbW1hbmQgdG8gZGV0ZXJtaW5lIHRoZSBjdXJyZW50IHZlcnNpb24uXG4gICAqXG4gICAqIEBkZWZhdWx0ICdnaXQgZGVzY3JpYmUnXG4gICAqL1xuICB2ZXJzaW9uQ29tbWFuZD86IHN0cmluZztcblxuICAvKipcbiAgICogVGl0bGUgb2YgdGhlIFBSLlxuICAgKlxuICAgKiAkVkVSU0lPTiB3aWxsIGJlIHN1YnN0aXR1dGVkIGJ5IHRoZSBjdXJyZW50IHZlcnNpb24gKG9idGFpbmVkIGJ5IGV4ZWN1dGluZyBgdmVyc2lvbkNvbW1hbmRgKS5cbiAgICpcbiAgICogQGRlZmF1bHQgJ2Nob3JlKHJlbGVhc2UpOiBtZXJnZSBiYWNrICRWRVJTSU9OJ1xuICAgKi9cbiAgdGl0bGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEJvZHkgb2YgdGhlIFBSLlxuICAgKlxuICAgKiBAZGVmYXVsdCAnU2VlIFtDSEFOR0VMT0ddKGh0dHBzOi8vZ2l0aHViLmNvbS8ke3Byb3BzLnJlcG8ub3duZXJ9LyR7cHJvcHMucmVwby5yZXBvfS9ibG9iLyR7aGVhZH0vQ0hBTkdFTE9HLm1kKSdcbiAgICogKExpbmsgdG8gdGhlIENIQU5HRUxPRyBmaWxlIG9mIHRoZSBoZWFkIGJyYW5jaClcbiAgICovXG4gIGJvZHk/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEhlYWQgYnJhbmNoIG9mIHRoZSBQUi5cbiAgICpcbiAgICogJFZFUlNJT04gd2lsbCBiZSBzdWJzdGl0dXRlZCBieSB0aGUgY3VycmVudCB2ZXJzaW9uIChvYnRhaW5lZCBieSBleGVjdXRpbmcgYHZlcnNpb25Db21tYW5kYCkuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gV2lsbCBiZSBjcmVhdGVkIGZyb20gcmVsZWFzZSBhbmQgbmFtZWQgJ21lcmdlLWJhY2svJFZFUlNJT04nXG4gICAqL1xuICBoZWFkPzogQXV0b01lcmdlQmFja0hlYWQ7XG5cbiAgLyoqXG4gICAqIFRoZSBleGl0IGNvZGUgb2YgdGhpcyBjb21tYW5kIGRldGVybWluZXMgd2hldGhlciBvciBub3QgdG8gcHJvY2VlZCB3aXRoIHRoZVxuICAgKiBQUiBjcmVhdGlvbi4gSWYgY29uZmlndXJlZCwgdGhpcyBjb21tYW5kIGlzIHRoZSBmaXJzdCBvbmUgdG8gcnVuLCBhbmQgaWYgaXQgZmFpbHMsIGFsbFxuICAgKiBvdGhlciBjb21tYW5kcyB3aWxsIGJlIHNraXBwZWQuXG4gICAqXG4gICAqIFRoaXMgY29tbWFuZCBpcyB0aGUgZmlyc3QgdG8gZXhlY3V0ZSwgYW5kIHNob3VsZCBub3QgYXNzdW1lIGFueSBwcmUtZXhpc3Rpbmcgc3RhdGUuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gbm8gY29uZGl0aW9uXG4gICAqL1xuICBjb25kaXRpb24/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIERlc2NyaXB0aW9uIGZvciB0aGUgQ29kZUJ1aWxkIHByb2plY3RcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBkZXNjcmlwdGlvblxuICAgKi9cbiAgcHJvamVjdERlc2NyaXB0aW9uPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEF1dG9NZXJnZUJhY2tQaXBlbGluZU9wdGlvbnMgZXh0ZW5kcyBBdXRvTWVyZ2VCYWNrT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBTcGVjaWZ5IHN0YWdlIG9wdGlvbnMgdG8gY3JlYXRlIHRoZSBtZXJnZSBiYWNrIGluc2lkZSBhIHN0YWdlIG9mIHRoZSBwaXBlbGluZS5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBUaGUgQ29kZUJ1aWxkIHByb2plY3Qgd2lsbCBiZSBjcmVhdGVkIGluZGVwZGVudCBvZiBhbnkgc3RhZ2UuXG4gICAqL1xuICByZWFkb25seSBzdGFnZT86IE1lcmdlQmFja1N0YWdlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEF1dG9NZXJnZUJhY2tQcm9wcyBleHRlbmRzIEF1dG9NZXJnZUJhY2tPcHRpb25zIHtcbiAgLyoqXG4gICAqIFRoZSByZXBvc2l0b3J5IHRvIGJ1bXAuXG4gICAqL1xuICByZXBvOiBXcml0YWJsZUdpdEh1YlJlcG87XG59XG5cbmV4cG9ydCBjbGFzcyBBdXRvTWVyZ2VCYWNrIGV4dGVuZHMgQ29uc3RydWN0IHtcblxuICAvKipcbiAgICogVGhlIHVuZGVybHlpbmcgQXV0b1B1bGxSZXF1ZXN0IGNvbnN0cnVjdC5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBwcjogcHIuQXV0b1B1bGxSZXF1ZXN0O1xuXG4gIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogQXV0b01lcmdlQmFja1Byb3BzKSB7XG4gICAgc3VwZXIocGFyZW50LCBpZCk7XG5cbiAgICBjb25zdCB2ZXJzaW9uQ29tbWFuZCA9IHByb3BzLnZlcnNpb25Db21tYW5kID8/ICdnaXQgZGVzY3JpYmUnO1xuICAgIGNvbnN0IGhlYWROYW1lID0gcHJvcHMuaGVhZD8ubmFtZSA/PyAnbWVyZ2UtYmFjay8kVkVSU0lPTic7XG4gICAgY29uc3QgdGl0bGUgPSBwcm9wcy50aXRsZSA/PyAnY2hvcmUobWVyZ2UtYmFjayk6ICRWRVJTSU9OJztcbiAgICBjb25zdCBib2R5ID0gcHJvcHMuYm9keSA/PyBgU2VlIFtDSEFOR0VMT0ddKGh0dHBzOi8vZ2l0aHViLmNvbS8ke3Byb3BzLnJlcG8ub3duZXJ9LyR7cHJvcHMucmVwby5yZXBvfS9ibG9iLyR7aGVhZE5hbWV9L0NIQU5HRUxPRy5tZClgO1xuXG4gICAgdGhpcy5wciA9IG5ldyBwci5BdXRvUHVsbFJlcXVlc3QodGhpcywgJ0F1dG9NZXJnZUJhY2snLCB7XG4gICAgICAuLi5wcm9wcyxcbiAgICAgIGJvZHksXG4gICAgICB0aXRsZSxcbiAgICAgIGhlYWQ6IHtcbiAgICAgICAgbmFtZTogaGVhZE5hbWUsXG4gICAgICAgIHNvdXJjZTogcHJvcHMuaGVhZD8uc291cmNlLFxuICAgICAgfSxcbiAgICAgIGV4cG9ydHM6IHtcbiAgICAgICAgLi4ucHJvcHMuZXhwb3J0cyxcbiAgICAgICAgVkVSU0lPTjogdmVyc2lvbkNvbW1hbmQsXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -38,6 +38,14 @@ export interface EcrMirrorProps {
38
38
  * Credentials to signing into Dockerhub.
39
39
  */
40
40
  readonly dockerHubCredentials: DockerHubCredentials;
41
+ /**
42
+ * The image used to run the mirror step itself.
43
+ *
44
+ * Prefer to supply the image yourself here.
45
+ *
46
+ * @default - Some superchain image that may grow outdated.
47
+ */
48
+ readonly buildImage?: codebuild.IBuildImage;
41
49
  /**
42
50
  * Sync job runs on a schedule.
43
51
  * Throws an error if neither this nor `autoStart` are specified.
@@ -3,12 +3,14 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.EcrMirrorAspect = exports.EcrMirror = void 0;
4
4
  const aws_cdk_lib_1 = require("aws-cdk-lib");
5
5
  const constructs_1 = require("constructs");
6
+ const constants_1 = require("../constants");
6
7
  /**
7
8
  * Synchronize images from DockerHub to an ECR registry in the AWS account.
8
9
  * This is particularly useful to workaround DockerHub's throttling on pulls and use ECR instead.
9
10
  */
10
11
  class EcrMirror extends constructs_1.Construct {
11
12
  constructor(scope, id, props) {
13
+ var _a;
12
14
  super(scope, id);
13
15
  this._repos = new Map();
14
16
  this._repoTagsSeen = new Set();
@@ -24,10 +26,14 @@ class EcrMirror extends constructs_1.Construct {
24
26
  };
25
27
  const username = codeBuildSecretValue(props.dockerHubCredentials.usernameKey, props.dockerHubCredentials);
26
28
  const password = codeBuildSecretValue(props.dockerHubCredentials.passwordKey, props.dockerHubCredentials);
29
+ if (!props.buildImage) {
30
+ aws_cdk_lib_1.Annotations.of(this).addWarningV2('aws-delivlib:EcrMirror.missingBuildImage', 'Prefer supplying an explicit build image to relying on the default superchain.');
31
+ }
27
32
  this.project = new aws_cdk_lib_1.aws_codebuild.Project(this, 'EcrPushImages', {
33
+ description: aws_cdk_lib_1.Lazy.string({ produce: () => `Synchronize ${props.sources.length} images from DockerHub to local ECR` }),
28
34
  environment: {
29
35
  privileged: true,
30
- buildImage: aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bullseye-slim-node18'),
36
+ buildImage: (_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry(constants_1.DEFAULT_SUPERCHAIN_IMAGE),
31
37
  },
32
38
  environmentVariables: {
33
39
  // DockerHub credentials to avoid throttling
@@ -109,6 +115,7 @@ class EcrMirror extends constructs_1.Construct {
109
115
  }
110
116
  if (props.schedule) {
111
117
  new aws_cdk_lib_1.aws_events.Rule(this, 'ScheduledTrigger', {
118
+ description: 'Trigger ECR mirror job',
112
119
  schedule: props.schedule,
113
120
  targets: [new aws_cdk_lib_1.aws_events_targets.CodeBuildProject(this.project)],
114
121
  });
@@ -163,4 +170,4 @@ class EcrMirrorAspect {
163
170
  }
164
171
  }
165
172
  exports.EcrMirrorAspect = EcrMirrorAspect;
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecr-mirror.js","sourceRoot":"","sources":["ecr-mirror.ts"],"names":[],"mappings":";;;AAAA,6CAUqB;AACrB,2CAAmD;AA+DnD;;;GAGG;AACH,MAAa,SAAU,SAAQ,sBAAS;IAOtC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAqB;QAC7D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QANF,WAAM,GAAgC,IAAI,GAAG,EAAE,CAAC;QAChD,kBAAa,GAAG,IAAI,GAAG,EAAU,CAAC;QAOjD,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE;YACvC,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;SAClE;QAED,MAAM,WAAW,GAAG,GAAG,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,OAAO,YAAY,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,MAAM,gBAAgB,CAAC;QACjG,MAAM,QAAQ,GAAa,EAAE,CAAC;QAC9B,MAAM,MAAM,GAAG,IAAI,KAAK,EAAkB,CAAC;QAE3C,MAAM,oBAAoB,GAAG,CAAC,GAAW,EAAE,IAA0B,EAAE,EAAE;;YACvE,OAAO,GAAG,KAAK,CAAC,oBAAoB,CAAC,MAAM,CAAC,UAAU,IAAI,GAAG,IAAI,MAAA,IAAI,CAAC,YAAY,mCAAI,YAAY,EAAE,CAAC;QACvG,CAAC,CAAC;QAEF,MAAM,QAAQ,GAAG,oBAAoB,CAAC,KAAK,CAAC,oBAAoB,CAAC,WAAW,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC;QAC1G,MAAM,QAAQ,GAAG,oBAAoB,CAAC,KAAK,CAAC,oBAAoB,CAAC,WAAW,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC;QAE1G,IAAI,CAAC,OAAO,GAAG,IAAI,2BAAS,CAAC,OAAO,CAAC,IAAI,EAAE,eAAe,EAAE;YAC1D,WAAW,EAAE;gBACX,UAAU,EAAE,IAAI;gBAChB,UAAU,EAAE,2BAAS,CAAC,eAAe,CAAC,kBAAkB,CAAC,uDAAuD,CAAC;aAClH;YACD,oBAAoB,EAAE;gBACpB,4CAA4C;gBAC5C,kBAAkB,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,2BAAS,CAAC,4BAA4B,CAAC,eAAe,EAAE;gBACrG,kBAAkB,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,2BAAS,CAAC,4BAA4B,CAAC,eAAe,EAAE;aACtG;YACD,SAAS,EAAE,2BAAS,CAAC,SAAS,CAAC,UAAU,CAAC,kBAAI,CAAC,GAAG,CAAC;gBACjD,OAAO,EAAE,GAAG,EAAE;oBACZ,OAAO;wBACL,OAAO,EAAE,KAAK;wBACd,MAAM,EAAE;4BACN,KAAK,EAAE;gCACL,QAAQ,EAAE;oCAER,0BAA0B;oCAC1B,kHAAkH;oCAClH,gEAAgE;oCAEhE,+CAA+C;oCAC/C,gEAAgE;oCAEhE,oCAAoC;oCACpC,6EAA6E,WAAW,EAAE;oCAE1F,uEAAuE;oCACvE,oHAAoH;oCAEpH,GAAG,QAAQ;iCACZ;6BACF;yBACF;qBACF,CAAC;gBACJ,CAAC;aACF,CAAC,CAAC;YACH,qBAAqB,EAAE,IAAI;SAC5B,CAAC,CAAC;QAEH,mDAAmD;QACnD,IAAI,CAAC,OAAO,CAAC,IAAK,CAAC,gBAAgB,CAAC,qBAAG,CAAC,aAAa,CAAC,wBAAwB,CAAC,8CAA8C,CAAC,CAAC,CAAC;QAEhI,wDAAwD;QACxD,yFAAyF;QACzF,KAAK,CAAC,oBAAoB,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAE1D,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,OAAO,EAAE;YACjC,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC;gBACxB,KAAK,EAAE,IAAI;gBACX,WAAW;gBACX,OAAO,EAAE,IAAI,CAAC,OAAO;aACtB,CAAC,CAAC;YACH,QAAQ,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;YAElC,MAAM,OAAO,GAAG,GAAG,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,GAAG,EAAE,CAAC;YACzD,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;gBACnC,MAAM,IAAI,KAAK,CAAC,uCAAuC,MAAM,CAAC,cAAc,cAAc,MAAM,CAAC,GAAG,mBAAmB,CAAC,CAAC;aAC1H;YACD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAEhC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;YAE7C,MAAM,WAAW,GAAG,GAAG,WAAW,IAAI,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,GAAG,EAAE,CAAC;YAC5E,QAAQ,CAAC,IAAI,CAAC,eAAe,WAAW,EAAE,CAAC,CAAC;YAE5C,2DAA2D;YAC3D,kCAAkC;YAClC,QAAQ,CAAC,IAAI,CAAC,kCAAkC,CAAC,CAAC;SACnD;QAED,sEAAsE;QACtE,KAAK,CAAC,oBAAoB,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAE1D,qBAAG,CAAC,kBAAkB,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC/C,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QAE7D,iEAAiE;QACjE,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QAE/C,IAAI,KAAK,CAAC,SAAS,EAAE;YACnB,IAAI,8BAAE,CAAC,iBAAiB,CAAC,IAAI,EAAE,gBAAgB,EAAE;gBAC/C,mBAAmB,EAAE,KAAK;gBAC1B,MAAM,EAAE,8BAAE,CAAC,uBAAuB,CAAC,YAAY,CAAC,EAAE,SAAS,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;gBACzF,QAAQ,EAAE;oBACR,MAAM,EAAE,YAAY;oBACpB,OAAO,EAAE,WAAW;oBACpB,UAAU,EAAE;wBACV,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW;wBACrC,sCAAsC;wBACtC,gBAAgB,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,EAAE;qBAClC;oBACD,kBAAkB,EAAE,8BAAE,CAAC,kBAAkB,CAAC,EAAE,CAAC,sBAAsB,CAAC;oBAEpE,oFAAoF;oBACpF,WAAW,EAAE,CAAC,UAAU,CAAC;iBAC1B;aACF,CAAC,CAAC;SACJ;QAED,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,IAAI,wBAAM,CAAC,IAAI,CAAC,IAAI,EAAE,kBAAkB,EAAE;gBACxC,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,OAAO,EAAE,CAAC,IAAI,gCAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aACtD,CAAC,CAAC;SACJ;IACH,CAAC;IAEO,gBAAgB,CAAC,iBAAyB;QAChD,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,EAAE;YACtC,OAAO;SACR;QAED,MAAM,UAAU,GAAG,IAAI,qBAAG,CAAC,UAAU,CAAC,IAAI,EAAE,OAAO,iBAAiB,EAAE,EAAE;YACtE,cAAc,EAAE,iBAAiB;SAClC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,iBAAiB,EAAE,UAAU,CAAC,CAAC;IACjD,CAAC;IAED;;;;OAIG;IACI,aAAa,CAAC,cAAsB;QACzC,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACzC,CAAC;CACF;AAzJD,8BAyJC;AAAA,CAAC;AAEF;;;GAGG;AACH,MAAa,eAAe;IAC1B,YAA6B,MAAiB;QAAjB,WAAM,GAAN,MAAM,CAAW;IAAG,CAAC;IAE3C,KAAK,CAAC,SAAqB;QAChC,IAAI,SAAS,YAAY,2BAAS,CAAC,OAAO,EAAE;YAC1C,MAAM,UAAU,GAAG,SAAS,CAAC,IAAI,CAAC,YAAoC,CAAC;YACvE,IAAI,CAAC,mBAAK,CAAC,YAAY,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE;gBAC/C,MAAM,GAAG,GAAG,UAAU,CAAC,WAAuD,CAAC;gBAC/E,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC1C,MAAM,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACpC,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;gBACzD,IAAI,WAAW,EAAE;oBACf,UAAU,CAAC,WAAW,GAAG;wBACvB,GAAG,GAAG;wBACN,KAAK,EAAE,2BAAS,CAAC,eAAe,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,OAAO;qBAC7E,CAAC;oBACF,WAAW,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;oBACjC,qBAAG,CAAC,kBAAkB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;iBAC7C;aACF;SACF;IACH,CAAC;CACF;AAtBD,0CAsBC","sourcesContent":["import {\n  IAspect, Lazy, Stack, Token,\n  aws_ecr as ecr,\n  aws_codebuild as codebuild,\n  aws_events as events,\n  aws_events_targets as targets,\n  aws_iam as iam,\n  aws_s3_assets as s3Assets,\n  aws_secretsmanager as sm,\n  custom_resources as cr,\n} from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\nimport { MirrorSource } from './mirror-source';\n\n/**\n * Authentication details for DockerHub.\n *\n * @see https://docs.aws.amazon.com/codebuild/latest/userguide/build-spec-ref.html#build-spec.env.secrets-manager\n */\nexport interface DockerHubCredentials {\n\n  /**\n   * The secret that contains the username and password for Dockerhub\n   */\n  readonly secret: sm.ISecret;\n\n  /**\n   * The secret key that contains the username in the specified secret.\n   */\n  readonly usernameKey: string;\n\n  /**\n   * The secret key that contains the password in the specified secret.\n   */\n  readonly passwordKey: string;\n\n  /**\n   * Version stage of the secret.\n   *\n   * @default 'AWSCURRENT'\n   */\n  readonly versionStage?: string;\n}\n\n/**\n * Properties to initialize EcrRegistrySync\n */\nexport interface EcrMirrorProps {\n  /**\n   * The list of images to keep sync'ed.\n   */\n  readonly sources: MirrorSource[];\n\n  /**\n   * Credentials to signing into Dockerhub.\n   */\n  readonly dockerHubCredentials: DockerHubCredentials;\n\n  /**\n   * Sync job runs on a schedule.\n   * Throws an error if neither this nor `autoStart` are specified.\n   * @default - does not run on schedule\n   */\n  readonly schedule?: events.Schedule;\n\n  /**\n   * Start the sync job immediately after the deployment.\n   * This injects a custom resource that is executed as part of the deployment.\n   * Throws an error if neither this nor `schedule` are specified.\n   * @default false\n   */\n  readonly autoStart?: boolean;\n}\n\n/**\n * Synchronize images from DockerHub to an ECR registry in the AWS account.\n * This is particularly useful to workaround DockerHub's throttling on pulls and use ECR instead.\n */\nexport class EcrMirror extends Construct {\n\n  private readonly _repos: Map<string, ecr.Repository> = new Map();\n  private readonly _repoTagsSeen = new Set<string>();\n\n  public readonly project: codebuild.Project;\n\n  constructor(scope: Construct, id: string, props: EcrMirrorProps) {\n    super(scope, id);\n\n    if (!props.schedule && !props.autoStart) {\n      throw new Error('Either schedule or autoStart must be provided');\n    }\n\n    const ecrRegistry = `${Stack.of(scope).account}.dkr.ecr.${Stack.of(scope).region}.amazonaws.com`;\n    const commands: string[] = [];\n    const assets = new Array<s3Assets.Asset>();\n\n    const codeBuildSecretValue = (key: string, auth: DockerHubCredentials) => {\n      return `${props.dockerHubCredentials.secret.secretName}:${key}:${auth.versionStage ?? 'AWSCURRENT'}`;\n    };\n\n    const username = codeBuildSecretValue(props.dockerHubCredentials.usernameKey, props.dockerHubCredentials);\n    const password = codeBuildSecretValue(props.dockerHubCredentials.passwordKey, props.dockerHubCredentials);\n\n    this.project = new codebuild.Project(this, 'EcrPushImages', {\n      environment: {\n        privileged: true,\n        buildImage: codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bullseye-slim-node18'),\n      },\n      environmentVariables: {\n        // DockerHub credentials to avoid throttling\n        DOCKERHUB_USERNAME: { value: username, type: codebuild.BuildEnvironmentVariableType.SECRETS_MANAGER },\n        DOCKERHUB_PASSWORD: { value: password, type: codebuild.BuildEnvironmentVariableType.SECRETS_MANAGER },\n      },\n      buildSpec: codebuild.BuildSpec.fromObject(Lazy.any({\n        produce: () => {\n          return {\n            version: '0.2',\n            phases: {\n              build: {\n                commands: [\n\n                  // start the docker daemon\n                  'nohup /usr/bin/dockerd --host=unix:///var/run/docker.sock --host=tcp://127.0.0.1:2375 --storage-driver=overlay2&',\n                  'timeout 15 sh -c \"until docker info; do echo .; sleep 1; done\"',\n\n                  // login to dockerhub so we won't get throttled\n                  'docker login -u ${DOCKERHUB_USERNAME} -p ${DOCKERHUB_PASSWORD}',\n\n                  // login to ecr so we can push to it\n                  `aws ecr get-login-password | docker login --username AWS --password-stdin ${ecrRegistry}`,\n\n                  // login to ecr-public so we can pull from it with improved rate limits\n                  'aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aws',\n\n                  ...commands,\n                ],\n              },\n            },\n          };\n        },\n      })),\n      ssmSessionPermissions: true,\n    });\n\n    // Ensure the runner has PULL access to ECR-Public.\n    this.project.role!.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonElasticContainerRegistryPublicReadOnly'));\n\n    // Give the project access to the Docker Hub credentials\n    // Required for access to private images and to avoid throttling of unauthorized requests\n    props.dockerHubCredentials.secret.grantRead(this.project);\n\n    for (const image of props.sources) {\n      const result = image.bind({\n        scope: this,\n        ecrRegistry,\n        syncJob: this.project,\n      });\n      commands.push(...result.commands);\n\n      const repoTag = `${result.repositoryName}:${result.tag}`;\n      if (this._repoTagsSeen.has(repoTag)) {\n        throw new Error(`Mirror source with repository name [${result.repositoryName}] and tag [${result.tag}] already exists.`);\n      }\n      this._repoTagsSeen.add(repoTag);\n\n      this.createMirrorRepo(result.repositoryName);\n\n      const ecrImageUri = `${ecrRegistry}/${result.repositoryName}:${result.tag}`;\n      commands.push(`docker push ${ecrImageUri}`);\n\n      // clean after each push so that we don't fillup disk space\n      // possibly failing the next pull.\n      commands.push('docker image prune --all --force');\n    }\n\n    // CodeBuild needs to read the secret to resolve environment variables\n    props.dockerHubCredentials.secret.grantRead(this.project);\n\n    ecr.AuthorizationToken.grantRead(this.project);\n    this._repos.forEach((r, _) => r.grantPullPush(this.project));\n\n    // this project needs to download the assets so it can build them\n    assets.forEach(a => a.grantRead(this.project));\n\n    if (props.autoStart) {\n      new cr.AwsCustomResource(this, 'BuildExecution', {\n        installLatestAwsSdk: false,\n        policy: cr.AwsCustomResourcePolicy.fromSdkCalls({ resources: [this.project.projectArn] }),\n        onUpdate: {\n          action: 'startBuild',\n          service: 'CodeBuild',\n          parameters: {\n            projectName: this.project.projectName,\n            // to tigger the build on every update\n            idempotencyToken: `${Date.now()}`,\n          },\n          physicalResourceId: cr.PhysicalResourceId.of('EcrRegistryExecution'),\n\n          // need since the default reponse if greater than the 4k limit for custom resources.\n          outputPaths: ['build.id'],\n        },\n      });\n    }\n\n    if (props.schedule) {\n      new events.Rule(this, 'ScheduledTrigger', {\n        schedule: props.schedule,\n        targets: [new targets.CodeBuildProject(this.project)],\n      });\n    }\n  }\n\n  private createMirrorRepo(ecrRepositoryName: string) {\n    if (this._repos.get(ecrRepositoryName)) {\n      return;\n    }\n\n    const repository = new ecr.Repository(this, `Repo${ecrRepositoryName}`, {\n      repositoryName: ecrRepositoryName,\n    });\n    this._repos.set(ecrRepositoryName, repository);\n  }\n\n  /**\n   * Get the target ECR repository for the given repository name and tag.\n   * @param repositoryName The ECR repository with this name\n   * @param tag the tag for the repository, defaults to 'latest'\n   */\n  public ecrRepository(repositoryName: string): ecr.IRepository | undefined {\n    return this._repos.get(repositoryName);\n  }\n};\n\n/**\n * An aspect that walks through the construct tree and replaces CodeBuild jobs with Docker images\n * with ECR equivalents found in the EcrMirror.\n */\nexport class EcrMirrorAspect implements IAspect {\n  constructor(private readonly mirror: EcrMirror) {}\n\n  public visit(construct: IConstruct) {\n    if (construct instanceof codebuild.Project) {\n      const cfnproject = construct.node.defaultChild as codebuild.CfnProject;\n      if (!Token.isUnresolved(cfnproject.environment)) {\n        const env = cfnproject.environment as codebuild.CfnProject.EnvironmentProperty;\n        const imageName = env.image.split(':')[0];\n        const tag = env.image.split(':')[1];\n        const replacement = this.mirror.ecrRepository(imageName);\n        if (replacement) {\n          cfnproject.environment = {\n            ...env,\n            image: codebuild.LinuxBuildImage.fromEcrRepository(replacement, tag).imageId,\n          };\n          replacement.grantPull(construct);\n          ecr.AuthorizationToken.grantRead(construct);\n        }\n      }\n    }\n  }\n}\n"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecr-mirror.js","sourceRoot":"","sources":["ecr-mirror.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  IAspect, Lazy, Stack, Token,\n  aws_ecr as ecr,\n  aws_codebuild as codebuild,\n  aws_events as events,\n  aws_events_targets as targets,\n  aws_iam as iam,\n  aws_s3_assets as s3Assets,\n  aws_secretsmanager as sm,\n  custom_resources as cr,\n  Annotations,\n} from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\nimport { MirrorSource } from './mirror-source';\nimport { DEFAULT_SUPERCHAIN_IMAGE } from '../constants';\n\n/**\n * Authentication details for DockerHub.\n *\n * @see https://docs.aws.amazon.com/codebuild/latest/userguide/build-spec-ref.html#build-spec.env.secrets-manager\n */\nexport interface DockerHubCredentials {\n\n  /**\n   * The secret that contains the username and password for Dockerhub\n   */\n  readonly secret: sm.ISecret;\n\n  /**\n   * The secret key that contains the username in the specified secret.\n   */\n  readonly usernameKey: string;\n\n  /**\n   * The secret key that contains the password in the specified secret.\n   */\n  readonly passwordKey: string;\n\n  /**\n   * Version stage of the secret.\n   *\n   * @default 'AWSCURRENT'\n   */\n  readonly versionStage?: string;\n}\n\n/**\n * Properties to initialize EcrRegistrySync\n */\nexport interface EcrMirrorProps {\n  /**\n   * The list of images to keep sync'ed.\n   */\n  readonly sources: MirrorSource[];\n\n  /**\n   * Credentials to signing into Dockerhub.\n   */\n  readonly dockerHubCredentials: DockerHubCredentials;\n\n  /**\n   * The image used to run the mirror step itself.\n   *\n   * Prefer to supply the image yourself here.\n   *\n   * @default - Some superchain image that may grow outdated.\n   */\n  readonly buildImage?: codebuild.IBuildImage;\n\n  /**\n   * Sync job runs on a schedule.\n   * Throws an error if neither this nor `autoStart` are specified.\n   * @default - does not run on schedule\n   */\n  readonly schedule?: events.Schedule;\n\n  /**\n   * Start the sync job immediately after the deployment.\n   * This injects a custom resource that is executed as part of the deployment.\n   * Throws an error if neither this nor `schedule` are specified.\n   * @default false\n   */\n  readonly autoStart?: boolean;\n}\n\n/**\n * Synchronize images from DockerHub to an ECR registry in the AWS account.\n * This is particularly useful to workaround DockerHub's throttling on pulls and use ECR instead.\n */\nexport class EcrMirror extends Construct {\n\n  private readonly _repos: Map<string, ecr.Repository> = new Map();\n  private readonly _repoTagsSeen = new Set<string>();\n\n  public readonly project: codebuild.Project;\n\n  constructor(scope: Construct, id: string, props: EcrMirrorProps) {\n    super(scope, id);\n\n    if (!props.schedule && !props.autoStart) {\n      throw new Error('Either schedule or autoStart must be provided');\n    }\n\n    const ecrRegistry = `${Stack.of(scope).account}.dkr.ecr.${Stack.of(scope).region}.amazonaws.com`;\n    const commands: string[] = [];\n    const assets = new Array<s3Assets.Asset>();\n\n    const codeBuildSecretValue = (key: string, auth: DockerHubCredentials) => {\n      return `${props.dockerHubCredentials.secret.secretName}:${key}:${auth.versionStage ?? 'AWSCURRENT'}`;\n    };\n\n    const username = codeBuildSecretValue(props.dockerHubCredentials.usernameKey, props.dockerHubCredentials);\n    const password = codeBuildSecretValue(props.dockerHubCredentials.passwordKey, props.dockerHubCredentials);\n\n    if (!props.buildImage) {\n      Annotations.of(this).addWarningV2('aws-delivlib:EcrMirror.missingBuildImage', 'Prefer supplying an explicit build image to relying on the default superchain.');\n    }\n\n    this.project = new codebuild.Project(this, 'EcrPushImages', {\n      description: Lazy.string({ produce: () => `Synchronize ${props.sources.length} images from DockerHub to local ECR` }),\n      environment: {\n        privileged: true,\n        buildImage: props.buildImage ?? codebuild.LinuxBuildImage.fromDockerRegistry(DEFAULT_SUPERCHAIN_IMAGE),\n      },\n      environmentVariables: {\n        // DockerHub credentials to avoid throttling\n        DOCKERHUB_USERNAME: { value: username, type: codebuild.BuildEnvironmentVariableType.SECRETS_MANAGER },\n        DOCKERHUB_PASSWORD: { value: password, type: codebuild.BuildEnvironmentVariableType.SECRETS_MANAGER },\n      },\n      buildSpec: codebuild.BuildSpec.fromObject(Lazy.any({\n        produce: () => {\n          return {\n            version: '0.2',\n            phases: {\n              build: {\n                commands: [\n\n                  // start the docker daemon\n                  'nohup /usr/bin/dockerd --host=unix:///var/run/docker.sock --host=tcp://127.0.0.1:2375 --storage-driver=overlay2&',\n                  'timeout 15 sh -c \"until docker info; do echo .; sleep 1; done\"',\n\n                  // login to dockerhub so we won't get throttled\n                  'docker login -u ${DOCKERHUB_USERNAME} -p ${DOCKERHUB_PASSWORD}',\n\n                  // login to ecr so we can push to it\n                  `aws ecr get-login-password | docker login --username AWS --password-stdin ${ecrRegistry}`,\n\n                  // login to ecr-public so we can pull from it with improved rate limits\n                  'aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aws',\n\n                  ...commands,\n                ],\n              },\n            },\n          };\n        },\n      })),\n      ssmSessionPermissions: true,\n    });\n\n    // Ensure the runner has PULL access to ECR-Public.\n    this.project.role!.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonElasticContainerRegistryPublicReadOnly'));\n\n    // Give the project access to the Docker Hub credentials\n    // Required for access to private images and to avoid throttling of unauthorized requests\n    props.dockerHubCredentials.secret.grantRead(this.project);\n\n    for (const image of props.sources) {\n      const result = image.bind({\n        scope: this,\n        ecrRegistry,\n        syncJob: this.project,\n      });\n      commands.push(...result.commands);\n\n      const repoTag = `${result.repositoryName}:${result.tag}`;\n      if (this._repoTagsSeen.has(repoTag)) {\n        throw new Error(`Mirror source with repository name [${result.repositoryName}] and tag [${result.tag}] already exists.`);\n      }\n      this._repoTagsSeen.add(repoTag);\n\n      this.createMirrorRepo(result.repositoryName);\n\n      const ecrImageUri = `${ecrRegistry}/${result.repositoryName}:${result.tag}`;\n      commands.push(`docker push ${ecrImageUri}`);\n\n      // clean after each push so that we don't fillup disk space\n      // possibly failing the next pull.\n      commands.push('docker image prune --all --force');\n    }\n\n    // CodeBuild needs to read the secret to resolve environment variables\n    props.dockerHubCredentials.secret.grantRead(this.project);\n\n    ecr.AuthorizationToken.grantRead(this.project);\n    this._repos.forEach((r, _) => r.grantPullPush(this.project));\n\n    // this project needs to download the assets so it can build them\n    assets.forEach(a => a.grantRead(this.project));\n\n    if (props.autoStart) {\n      new cr.AwsCustomResource(this, 'BuildExecution', {\n        installLatestAwsSdk: false,\n        policy: cr.AwsCustomResourcePolicy.fromSdkCalls({ resources: [this.project.projectArn] }),\n        onUpdate: {\n          action: 'startBuild',\n          service: 'CodeBuild',\n          parameters: {\n            projectName: this.project.projectName,\n            // to tigger the build on every update\n            idempotencyToken: `${Date.now()}`,\n          },\n          physicalResourceId: cr.PhysicalResourceId.of('EcrRegistryExecution'),\n\n          // need since the default reponse if greater than the 4k limit for custom resources.\n          outputPaths: ['build.id'],\n        },\n      });\n    }\n\n    if (props.schedule) {\n      new events.Rule(this, 'ScheduledTrigger', {\n        description: 'Trigger ECR mirror job',\n        schedule: props.schedule,\n        targets: [new targets.CodeBuildProject(this.project)],\n      });\n    }\n  }\n\n  private createMirrorRepo(ecrRepositoryName: string) {\n    if (this._repos.get(ecrRepositoryName)) {\n      return;\n    }\n\n    const repository = new ecr.Repository(this, `Repo${ecrRepositoryName}`, {\n      repositoryName: ecrRepositoryName,\n    });\n    this._repos.set(ecrRepositoryName, repository);\n  }\n\n  /**\n   * Get the target ECR repository for the given repository name and tag.\n   * @param repositoryName The ECR repository with this name\n   * @param tag the tag for the repository, defaults to 'latest'\n   */\n  public ecrRepository(repositoryName: string): ecr.IRepository | undefined {\n    return this._repos.get(repositoryName);\n  }\n};\n\n/**\n * An aspect that walks through the construct tree and replaces CodeBuild jobs with Docker images\n * with ECR equivalents found in the EcrMirror.\n */\nexport class EcrMirrorAspect implements IAspect {\n  constructor(private readonly mirror: EcrMirror) {}\n\n  public visit(construct: IConstruct) {\n    if (construct instanceof codebuild.Project) {\n      const cfnproject = construct.node.defaultChild as codebuild.CfnProject;\n      if (!Token.isUnresolved(cfnproject.environment)) {\n        const env = cfnproject.environment as codebuild.CfnProject.EnvironmentProperty;\n        const imageName = env.image.split(':')[0];\n        const tag = env.image.split(':')[1];\n        const replacement = this.mirror.ecrRepository(imageName);\n        if (replacement) {\n          cfnproject.environment = {\n            ...env,\n            image: codebuild.LinuxBuildImage.fromEcrRepository(replacement, tag).imageId,\n          };\n          replacement.grantPull(construct);\n          ecr.AuthorizationToken.grantRead(construct);\n        }\n      }\n    }\n  }\n}\n"]}
package/lib/signing.js CHANGED
@@ -30,6 +30,7 @@ const aws_codepipeline_1 = require("aws-cdk-lib/aws-codepipeline");
30
30
  const aws_codepipeline_actions_1 = require("aws-cdk-lib/aws-codepipeline-actions");
31
31
  const constructs_1 = require("constructs");
32
32
  const build_spec_1 = require("./build-spec");
33
+ const constants_1 = require("./constants");
33
34
  const shellable_1 = require("./shellable");
34
35
  class SignNuGetWithSigner extends constructs_1.Construct {
35
36
  constructor(scope, id, props) {
@@ -47,7 +48,7 @@ class SignNuGetWithSigner extends constructs_1.Construct {
47
48
  environment.SIGNER_PROFILE_OWNER = props.signerProfileOwner;
48
49
  }
49
50
  const shellable = new shellable_1.Shellable(this, 'Default', {
50
- platform: new shellable_1.LinuxPlatform((_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_codebuild_1.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bullseye-slim-node18')),
51
+ platform: new shellable_1.LinuxPlatform((_a = props.buildImage) !== null && _a !== void 0 ? _a : aws_codebuild_1.LinuxBuildImage.fromDockerRegistry(constants_1.DEFAULT_SUPERCHAIN_IMAGE)),
51
52
  scriptDirectory: path.join(__dirname, 'signing', 'nuget'),
52
53
  entrypoint: 'sign.sh',
53
54
  serviceRole: props.serviceRole,
@@ -77,4 +78,4 @@ class SignNuGetWithSigner extends constructs_1.Construct {
77
78
  }
78
79
  }
79
80
  exports.SignNuGetWithSigner = SignNuGetWithSigner;
80
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpZ25pbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBNkI7QUFDN0IsNkRBQWtGO0FBQ2xGLG1FQUFnRTtBQUNoRSxtRkFBdUU7QUFJdkUsMkNBQW1EO0FBQ25ELDZDQUF5QztBQUV6QywyQ0FBdUQ7QUFzRXZELE1BQWEsbUJBQW9CLFNBQVEsc0JBQVM7SUFJaEQsWUFBbUIsS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBK0I7O1FBQzlFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsTUFBTSxXQUFXLEdBQThCO1lBQzdDLG1CQUFtQixFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsVUFBVTtZQUNuRCxrQkFBa0IsRUFBRSxLQUFLLENBQUMsYUFBYSxDQUFDLFdBQVc7WUFDbkQsZUFBZSxFQUFFLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBTztTQUMxQyxDQUFDO1FBRUYsSUFBSSxLQUFLLENBQUMsaUJBQWlCLEVBQUU7WUFDM0IsV0FBVyxDQUFDLG1CQUFtQixHQUFHLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQztTQUMzRDtRQUVELElBQUksS0FBSyxDQUFDLGtCQUFrQixFQUFFO1lBQzVCLFdBQVcsQ0FBQyxvQkFBb0IsR0FBRyxLQUFLLENBQUMsa0JBQWtCLENBQUM7U0FDN0Q7UUFFRCxNQUFNLFNBQVMsR0FBRyxJQUFJLHFCQUFTLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRTtZQUMvQyxRQUFRLEVBQUUsSUFBSSx5QkFBYSxDQUFDLE1BQUEsS0FBSyxDQUFDLFVBQVUsbUNBQUksK0JBQWUsQ0FBQyxrQkFBa0IsQ0FBQyx1REFBdUQsQ0FBQyxDQUFDO1lBQzVJLGVBQWUsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxTQUFTLEVBQUUsT0FBTyxDQUFDO1lBQ3pELFVBQVUsRUFBRSxTQUFTO1lBQ3JCLFdBQVcsRUFBRSxLQUFLLENBQUMsV0FBVztZQUM5QixTQUFTLEVBQUUsc0JBQVMsQ0FBQyxPQUFPLENBQUM7Z0JBQzNCLE9BQU8sRUFBRSxLQUFLO2dCQUNkLFNBQVMsRUFBRTtvQkFDVCxLQUFLLEVBQUUsQ0FBQyxNQUFNLENBQUM7b0JBQ2YsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLEdBQUc7aUJBQ3hCO2FBQ0YsQ0FBQztZQUNGLFdBQVc7U0FDWixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxHQUFHLFNBQVMsQ0FBQyxJQUFJLENBQUM7UUFDM0IsSUFBSSxDQUFDLE9BQU8sR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDO0lBQ25DLENBQUM7SUFFTSxhQUFhLENBQUMsS0FBYSxFQUFFLEVBQVUsRUFBRSxPQUE2QjtRQUMzRSxNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsYUFBYSxJQUFJLElBQUksMkJBQVEsRUFBRSxDQUFDO1FBQzdELE1BQU0sYUFBYSxHQUFHLElBQUksMkJBQVEsRUFBRSxDQUFDO1FBRXJDLEtBQUssQ0FBQyxTQUFTLENBQUMsSUFBSSwwQ0FBZSxDQUFDO1lBQ2xDLFVBQVUsRUFBRSxFQUFFO1lBQ2QsS0FBSyxFQUFFLFlBQVk7WUFDbkIsUUFBUSxFQUFFLE9BQU8sQ0FBQyxRQUFRO1lBQzFCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixPQUFPLEVBQUUsQ0FBQyxhQUFhLENBQUM7U0FDekIsQ0FBQyxDQUFDLENBQUM7UUFFSixPQUFPLGFBQWEsQ0FBQztJQUN2QixDQUFDO0NBQ0Y7QUF0REQsa0RBc0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IElCdWlsZEltYWdlLCBMaW51eEJ1aWxkSW1hZ2UsIFByb2plY3QgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY29kZWJ1aWxkJztcbmltcG9ydCB7IEFydGlmYWN0LCBJU3RhZ2UgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY29kZXBpcGVsaW5lJztcbmltcG9ydCB7IENvZGVCdWlsZEFjdGlvbiB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jb2RlcGlwZWxpbmUtYWN0aW9ucyc7XG5pbXBvcnQgeyBJUm9sZSB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1pYW0nO1xuaW1wb3J0IHsgSUZ1bmN0aW9uIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWxhbWJkYSc7XG5pbXBvcnQgeyBJQnVja2V0IH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLXMzJztcbmltcG9ydCB7IENvbnN0cnVjdCwgSUNvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQnVpbGRTcGVjIH0gZnJvbSAnLi9idWlsZC1zcGVjJztcbmltcG9ydCB7IEFkZFRvUGlwZWxpbmVPcHRpb25zIH0gZnJvbSAnLi9waXBlbGluZSc7XG5pbXBvcnQgeyBMaW51eFBsYXRmb3JtLCBTaGVsbGFibGUgfSBmcm9tICcuL3NoZWxsYWJsZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVNpZ25lciBleHRlbmRzIElDb25zdHJ1Y3Qge1xuICBhZGRUb1BpcGVsaW5lKHN0YWdlOiBJU3RhZ2UsIGlkOiBzdHJpbmcsIG9wdGlvbnM6IEFkZFRvUGlwZWxpbmVPcHRpb25zKTogQXJ0aWZhY3Q7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWRkU2lnbmluZ09wdGlvbnMge1xuICAvKipcbiAgICogVGhlIGlucHV0IGFydGlmYWN0IHRvIHVzZVxuICAgKlxuICAgKiBAZGVmYXVsdCBCdWlsZCBvdXRwdXQgYXJ0aWZhY3RcbiAgICovXG4gIHJlYWRvbmx5IGlucHV0QXJ0aWZhY3Q/OiBBcnRpZmFjdDtcblxuICAvKipcbiAgICogU3RhZ2UgbmFtZSB0byBhZGQgc2lnbmluZyBqb2IgdG9cbiAgICpcbiAgICogQGRlZmF1bHQgXCJTaWduXCJcbiAgICovXG4gIHJlYWRvbmx5IHN0YWdlTmFtZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTaWduTnVHZXRXaXRoU2lnbmVyUHJvcHMge1xuICAvKipcbiAgICogQW4gUzMgYnVja2V0IHVzZWQgdG8gc3RvcmUgc2lnbmVkIGFuZCB1bnNpZ25lZCBETEwgZmlsZXNcbiAgICovXG4gIHJlYWRvbmx5IHNpZ25pbmdCdWNrZXQ6IElCdWNrZXQ7XG5cbiAgLyoqXG4gICAqIEEgTGFtYmRhIGZ1bmN0aW9uIHVzZWQgdG8gcGVyZm9ybSBzaWduaW5nIG9wZXJhdGlvbnMgd2l0aCBBV1MgU2lnbmVyXG4gICAqL1xuICByZWFkb25seSBzaWduaW5nTGFtYmRhOiBJRnVuY3Rpb247XG5cbiAgLyoqXG4gICAqIEEgcm9sZSB1c2VkIHByb3ZpZGUgYWNjZXNzIHRvIHRoZSBzaWduaW5nIGJ1Y2tldCBhbmQgc2lnbmluZyBsYW1iZGFcbiAgICovXG4gIHJlYWRvbmx5IGFjY2Vzc1JvbGU6IElSb2xlO1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgc2lnbmVyIHByb2ZpbGUgdG8gdXNlIGZvciBzaWduaW5nXG4gICAqXG4gICAqIEBkZWZhdWx0IG5vIHNpZ25pbmcgcHJvZmlsZSBuYW1lXG4gICAqL1xuICByZWFkb25seSBzaWduZXJQcm9maWxlTmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIG93bmVyIG9mIHRoZSBzaWduZXIgcHJvZmlsZSB0byB1c2UgZm9yIHNpZ25pbmdcbiAgICpcbiAgICogQGRlZmF1bHQgbm8gc2lnbmluZyBwcm9maWxlIG93bmVyXG4gICAqL1xuICByZWFkb25seSBzaWduZXJQcm9maWxlT3duZXI/OiBzdHJpbmc7XG5cbiAgLypcbiAgICogVGhlIHNlcnZpY2Ugcm9sZSB0aGF0IHdpbGwgYmUgdXNlZCB0byBhbGxvdyBDb2RlQnVpbGQgdG8gcGVyZm9ybSBvcGVyYXRpb25zXG4gICAqIG9uIHlvdXIgYmVoYWxmLlxuICAgKlxuICAgKiBAZGVmYXVsdCBBIHJvbGUgd2lsbCBiZSBjcmVhdGVkXG4gICAqL1xuICByZWFkb25seSBzZXJ2aWNlUm9sZT86IElSb2xlO1xuXG4gIC8qKlxuICAgKiBUaGUgYnVpbGQgaW1hZ2UgdG8gZG8gdGhlIHNpZ25pbmcgaW5cbiAgICpcbiAgICogTmVlZHMgdG8gaGF2ZSBOdUdldCBwcmVpbnN0YWxsZWQuXG4gICAqXG4gICAqIEBkZWZhdWx0IExhdGVzdCBzdXBlcmNoYWluXG4gICAqL1xuICByZWFkb25seSBidWlsZEltYWdlPzogSUJ1aWxkSW1hZ2U7XG59XG5cbmV4cG9ydCBjbGFzcyBTaWduTnVHZXRXaXRoU2lnbmVyIGV4dGVuZHMgQ29uc3RydWN0IGltcGxlbWVudHMgSVNpZ25lciB7XG4gIHB1YmxpYyByZWFkb25seSByb2xlOiBJUm9sZTtcbiAgcHVibGljIHJlYWRvbmx5IHByb2plY3Q6IFByb2plY3Q7XG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTaWduTnVHZXRXaXRoU2lnbmVyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgZW52aXJvbm1lbnQ6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0gPSB7XG4gICAgICBTSUdOSU5HX0JVQ0tFVF9OQU1FOiBwcm9wcy5zaWduaW5nQnVja2V0LmJ1Y2tldE5hbWUsXG4gICAgICBTSUdOSU5HX0xBTUJEQV9BUk46IHByb3BzLnNpZ25pbmdMYW1iZGEuZnVuY3Rpb25Bcm4sXG4gICAgICBBQ0NFU1NfUk9MRV9BUk46IHByb3BzLmFjY2Vzc1JvbGUucm9sZUFybixcbiAgICB9O1xuXG4gICAgaWYgKHByb3BzLnNpZ25lclByb2ZpbGVOYW1lKSB7XG4gICAgICBlbnZpcm9ubWVudC5TSUdORVJfUFJPRklMRV9OQU1FID0gcHJvcHMuc2lnbmVyUHJvZmlsZU5hbWU7XG4gICAgfVxuXG4gICAgaWYgKHByb3BzLnNpZ25lclByb2ZpbGVPd25lcikge1xuICAgICAgZW52aXJvbm1lbnQuU0lHTkVSX1BST0ZJTEVfT1dORVIgPSBwcm9wcy5zaWduZXJQcm9maWxlT3duZXI7XG4gICAgfVxuXG4gICAgY29uc3Qgc2hlbGxhYmxlID0gbmV3IFNoZWxsYWJsZSh0aGlzLCAnRGVmYXVsdCcsIHtcbiAgICAgIHBsYXRmb3JtOiBuZXcgTGludXhQbGF0Zm9ybShwcm9wcy5idWlsZEltYWdlID8/IExpbnV4QnVpbGRJbWFnZS5mcm9tRG9ja2VyUmVnaXN0cnkoJ3B1YmxpYy5lY3IuYXdzL2pzaWkvc3VwZXJjaGFpbjoxLWJ1bGxzZXllLXNsaW0tbm9kZTE4JykpLFxuICAgICAgc2NyaXB0RGlyZWN0b3J5OiBwYXRoLmpvaW4oX19kaXJuYW1lLCAnc2lnbmluZycsICdudWdldCcpLFxuICAgICAgZW50cnlwb2ludDogJ3NpZ24uc2gnLFxuICAgICAgc2VydmljZVJvbGU6IHByb3BzLnNlcnZpY2VSb2xlLFxuICAgICAgYnVpbGRTcGVjOiBCdWlsZFNwZWMubGl0ZXJhbCh7XG4gICAgICAgIHZlcnNpb246ICcwLjInLFxuICAgICAgICBhcnRpZmFjdHM6IHtcbiAgICAgICAgICBmaWxlczogWycqKi8qJ10sXG4gICAgICAgICAgWydiYXNlLWRpcmVjdG9yeSddOiAnLicsXG4gICAgICAgIH0sXG4gICAgICB9KSxcbiAgICAgIGVudmlyb25tZW50LFxuICAgIH0pO1xuXG4gICAgdGhpcy5yb2xlID0gc2hlbGxhYmxlLnJvbGU7XG4gICAgdGhpcy5wcm9qZWN0ID0gc2hlbGxhYmxlLnByb2plY3Q7XG4gIH1cblxuICBwdWJsaWMgYWRkVG9QaXBlbGluZShzdGFnZTogSVN0YWdlLCBpZDogc3RyaW5nLCBvcHRpb25zOiBBZGRUb1BpcGVsaW5lT3B0aW9ucykge1xuICAgIGNvbnN0IHNpZ25pbmdJbnB1dCA9IG9wdGlvbnMuaW5wdXRBcnRpZmFjdCB8fCBuZXcgQXJ0aWZhY3QoKTtcbiAgICBjb25zdCBzaWduaW5nT3V0cHV0ID0gbmV3IEFydGlmYWN0KCk7XG5cbiAgICBzdGFnZS5hZGRBY3Rpb24obmV3IENvZGVCdWlsZEFjdGlvbih7XG4gICAgICBhY3Rpb25OYW1lOiBpZCxcbiAgICAgIGlucHV0OiBzaWduaW5nSW5wdXQsXG4gICAgICBydW5PcmRlcjogb3B0aW9ucy5ydW5PcmRlcixcbiAgICAgIHByb2plY3Q6IHRoaXMucHJvamVjdCxcbiAgICAgIG91dHB1dHM6IFtzaWduaW5nT3V0cHV0XSxcbiAgICB9KSk7XG5cbiAgICByZXR1cm4gc2lnbmluZ091dHB1dDtcbiAgfVxufSJdfQ==
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNpZ25pbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBNkI7QUFDN0IsNkRBQWtGO0FBQ2xGLG1FQUFnRTtBQUNoRSxtRkFBdUU7QUFJdkUsMkNBQW1EO0FBQ25ELDZDQUF5QztBQUN6QywyQ0FBdUQ7QUFFdkQsMkNBQXVEO0FBc0V2RCxNQUFhLG1CQUFvQixTQUFRLHNCQUFTO0lBSWhELFlBQW1CLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQStCOztRQUM5RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sV0FBVyxHQUE4QjtZQUM3QyxtQkFBbUIsRUFBRSxLQUFLLENBQUMsYUFBYSxDQUFDLFVBQVU7WUFDbkQsa0JBQWtCLEVBQUUsS0FBSyxDQUFDLGFBQWEsQ0FBQyxXQUFXO1lBQ25ELGVBQWUsRUFBRSxLQUFLLENBQUMsVUFBVSxDQUFDLE9BQU87U0FDMUMsQ0FBQztRQUVGLElBQUksS0FBSyxDQUFDLGlCQUFpQixFQUFFO1lBQzNCLFdBQVcsQ0FBQyxtQkFBbUIsR0FBRyxLQUFLLENBQUMsaUJBQWlCLENBQUM7U0FDM0Q7UUFFRCxJQUFJLEtBQUssQ0FBQyxrQkFBa0IsRUFBRTtZQUM1QixXQUFXLENBQUMsb0JBQW9CLEdBQUcsS0FBSyxDQUFDLGtCQUFrQixDQUFDO1NBQzdEO1FBRUQsTUFBTSxTQUFTLEdBQUcsSUFBSSxxQkFBUyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDL0MsUUFBUSxFQUFFLElBQUkseUJBQWEsQ0FBQyxNQUFBLEtBQUssQ0FBQyxVQUFVLG1DQUFJLCtCQUFlLENBQUMsa0JBQWtCLENBQUMsb0NBQXdCLENBQUMsQ0FBQztZQUM3RyxlQUFlLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsU0FBUyxFQUFFLE9BQU8sQ0FBQztZQUN6RCxVQUFVLEVBQUUsU0FBUztZQUNyQixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsU0FBUyxFQUFFLHNCQUFTLENBQUMsT0FBTyxDQUFDO2dCQUMzQixPQUFPLEVBQUUsS0FBSztnQkFDZCxTQUFTLEVBQUU7b0JBQ1QsS0FBSyxFQUFFLENBQUMsTUFBTSxDQUFDO29CQUNmLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxHQUFHO2lCQUN4QjthQUNGLENBQUM7WUFDRixXQUFXO1NBQ1osQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLElBQUksR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDO1FBQzNCLElBQUksQ0FBQyxPQUFPLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FBQztJQUNuQyxDQUFDO0lBRU0sYUFBYSxDQUFDLEtBQWEsRUFBRSxFQUFVLEVBQUUsT0FBNkI7UUFDM0UsTUFBTSxZQUFZLEdBQUcsT0FBTyxDQUFDLGFBQWEsSUFBSSxJQUFJLDJCQUFRLEVBQUUsQ0FBQztRQUM3RCxNQUFNLGFBQWEsR0FBRyxJQUFJLDJCQUFRLEVBQUUsQ0FBQztRQUVyQyxLQUFLLENBQUMsU0FBUyxDQUFDLElBQUksMENBQWUsQ0FBQztZQUNsQyxVQUFVLEVBQUUsRUFBRTtZQUNkLEtBQUssRUFBRSxZQUFZO1lBQ25CLFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUTtZQUMxQixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87WUFDckIsT0FBTyxFQUFFLENBQUMsYUFBYSxDQUFDO1NBQ3pCLENBQUMsQ0FBQyxDQUFDO1FBRUosT0FBTyxhQUFhLENBQUM7SUFDdkIsQ0FBQztDQUNGO0FBdERELGtEQXNEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBJQnVpbGRJbWFnZSwgTGludXhCdWlsZEltYWdlLCBQcm9qZWN0IH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWNvZGVidWlsZCc7XG5pbXBvcnQgeyBBcnRpZmFjdCwgSVN0YWdlIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWNvZGVwaXBlbGluZSc7XG5pbXBvcnQgeyBDb2RlQnVpbGRBY3Rpb24gfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY29kZXBpcGVsaW5lLWFjdGlvbnMnO1xuaW1wb3J0IHsgSVJvbGUgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCB7IElGdW5jdGlvbiB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEnO1xuaW1wb3J0IHsgSUJ1Y2tldCB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1zMyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QsIElDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEJ1aWxkU3BlYyB9IGZyb20gJy4vYnVpbGQtc3BlYyc7XG5pbXBvcnQgeyBERUZBVUxUX1NVUEVSQ0hBSU5fSU1BR0UgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBBZGRUb1BpcGVsaW5lT3B0aW9ucyB9IGZyb20gJy4vcGlwZWxpbmUnO1xuaW1wb3J0IHsgTGludXhQbGF0Zm9ybSwgU2hlbGxhYmxlIH0gZnJvbSAnLi9zaGVsbGFibGUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElTaWduZXIgZXh0ZW5kcyBJQ29uc3RydWN0IHtcbiAgYWRkVG9QaXBlbGluZShzdGFnZTogSVN0YWdlLCBpZDogc3RyaW5nLCBvcHRpb25zOiBBZGRUb1BpcGVsaW5lT3B0aW9ucyk6IEFydGlmYWN0O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFkZFNpZ25pbmdPcHRpb25zIHtcbiAgLyoqXG4gICAqIFRoZSBpbnB1dCBhcnRpZmFjdCB0byB1c2VcbiAgICpcbiAgICogQGRlZmF1bHQgQnVpbGQgb3V0cHV0IGFydGlmYWN0XG4gICAqL1xuICByZWFkb25seSBpbnB1dEFydGlmYWN0PzogQXJ0aWZhY3Q7XG5cbiAgLyoqXG4gICAqIFN0YWdlIG5hbWUgdG8gYWRkIHNpZ25pbmcgam9iIHRvXG4gICAqXG4gICAqIEBkZWZhdWx0IFwiU2lnblwiXG4gICAqL1xuICByZWFkb25seSBzdGFnZU5hbWU/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2lnbk51R2V0V2l0aFNpZ25lclByb3BzIHtcbiAgLyoqXG4gICAqIEFuIFMzIGJ1Y2tldCB1c2VkIHRvIHN0b3JlIHNpZ25lZCBhbmQgdW5zaWduZWQgRExMIGZpbGVzXG4gICAqL1xuICByZWFkb25seSBzaWduaW5nQnVja2V0OiBJQnVja2V0O1xuXG4gIC8qKlxuICAgKiBBIExhbWJkYSBmdW5jdGlvbiB1c2VkIHRvIHBlcmZvcm0gc2lnbmluZyBvcGVyYXRpb25zIHdpdGggQVdTIFNpZ25lclxuICAgKi9cbiAgcmVhZG9ubHkgc2lnbmluZ0xhbWJkYTogSUZ1bmN0aW9uO1xuXG4gIC8qKlxuICAgKiBBIHJvbGUgdXNlZCBwcm92aWRlIGFjY2VzcyB0byB0aGUgc2lnbmluZyBidWNrZXQgYW5kIHNpZ25pbmcgbGFtYmRhXG4gICAqL1xuICByZWFkb25seSBhY2Nlc3NSb2xlOiBJUm9sZTtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIHNpZ25lciBwcm9maWxlIHRvIHVzZSBmb3Igc2lnbmluZ1xuICAgKlxuICAgKiBAZGVmYXVsdCBubyBzaWduaW5nIHByb2ZpbGUgbmFtZVxuICAgKi9cbiAgcmVhZG9ubHkgc2lnbmVyUHJvZmlsZU5hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBvd25lciBvZiB0aGUgc2lnbmVyIHByb2ZpbGUgdG8gdXNlIGZvciBzaWduaW5nXG4gICAqXG4gICAqIEBkZWZhdWx0IG5vIHNpZ25pbmcgcHJvZmlsZSBvd25lclxuICAgKi9cbiAgcmVhZG9ubHkgc2lnbmVyUHJvZmlsZU93bmVyPzogc3RyaW5nO1xuXG4gIC8qXG4gICAqIFRoZSBzZXJ2aWNlIHJvbGUgdGhhdCB3aWxsIGJlIHVzZWQgdG8gYWxsb3cgQ29kZUJ1aWxkIHRvIHBlcmZvcm0gb3BlcmF0aW9uc1xuICAgKiBvbiB5b3VyIGJlaGFsZi5cbiAgICpcbiAgICogQGRlZmF1bHQgQSByb2xlIHdpbGwgYmUgY3JlYXRlZFxuICAgKi9cbiAgcmVhZG9ubHkgc2VydmljZVJvbGU/OiBJUm9sZTtcblxuICAvKipcbiAgICogVGhlIGJ1aWxkIGltYWdlIHRvIGRvIHRoZSBzaWduaW5nIGluXG4gICAqXG4gICAqIE5lZWRzIHRvIGhhdmUgTnVHZXQgcHJlaW5zdGFsbGVkLlxuICAgKlxuICAgKiBAZGVmYXVsdCBMYXRlc3Qgc3VwZXJjaGFpblxuICAgKi9cbiAgcmVhZG9ubHkgYnVpbGRJbWFnZT86IElCdWlsZEltYWdlO1xufVxuXG5leHBvcnQgY2xhc3MgU2lnbk51R2V0V2l0aFNpZ25lciBleHRlbmRzIENvbnN0cnVjdCBpbXBsZW1lbnRzIElTaWduZXIge1xuICBwdWJsaWMgcmVhZG9ubHkgcm9sZTogSVJvbGU7XG4gIHB1YmxpYyByZWFkb25seSBwcm9qZWN0OiBQcm9qZWN0O1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU2lnbk51R2V0V2l0aFNpZ25lclByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGNvbnN0IGVudmlyb25tZW50OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9ID0ge1xuICAgICAgU0lHTklOR19CVUNLRVRfTkFNRTogcHJvcHMuc2lnbmluZ0J1Y2tldC5idWNrZXROYW1lLFxuICAgICAgU0lHTklOR19MQU1CREFfQVJOOiBwcm9wcy5zaWduaW5nTGFtYmRhLmZ1bmN0aW9uQXJuLFxuICAgICAgQUNDRVNTX1JPTEVfQVJOOiBwcm9wcy5hY2Nlc3NSb2xlLnJvbGVBcm4sXG4gICAgfTtcblxuICAgIGlmIChwcm9wcy5zaWduZXJQcm9maWxlTmFtZSkge1xuICAgICAgZW52aXJvbm1lbnQuU0lHTkVSX1BST0ZJTEVfTkFNRSA9IHByb3BzLnNpZ25lclByb2ZpbGVOYW1lO1xuICAgIH1cblxuICAgIGlmIChwcm9wcy5zaWduZXJQcm9maWxlT3duZXIpIHtcbiAgICAgIGVudmlyb25tZW50LlNJR05FUl9QUk9GSUxFX09XTkVSID0gcHJvcHMuc2lnbmVyUHJvZmlsZU93bmVyO1xuICAgIH1cblxuICAgIGNvbnN0IHNoZWxsYWJsZSA9IG5ldyBTaGVsbGFibGUodGhpcywgJ0RlZmF1bHQnLCB7XG4gICAgICBwbGF0Zm9ybTogbmV3IExpbnV4UGxhdGZvcm0ocHJvcHMuYnVpbGRJbWFnZSA/PyBMaW51eEJ1aWxkSW1hZ2UuZnJvbURvY2tlclJlZ2lzdHJ5KERFRkFVTFRfU1VQRVJDSEFJTl9JTUFHRSkpLFxuICAgICAgc2NyaXB0RGlyZWN0b3J5OiBwYXRoLmpvaW4oX19kaXJuYW1lLCAnc2lnbmluZycsICdudWdldCcpLFxuICAgICAgZW50cnlwb2ludDogJ3NpZ24uc2gnLFxuICAgICAgc2VydmljZVJvbGU6IHByb3BzLnNlcnZpY2VSb2xlLFxuICAgICAgYnVpbGRTcGVjOiBCdWlsZFNwZWMubGl0ZXJhbCh7XG4gICAgICAgIHZlcnNpb246ICcwLjInLFxuICAgICAgICBhcnRpZmFjdHM6IHtcbiAgICAgICAgICBmaWxlczogWycqKi8qJ10sXG4gICAgICAgICAgWydiYXNlLWRpcmVjdG9yeSddOiAnLicsXG4gICAgICAgIH0sXG4gICAgICB9KSxcbiAgICAgIGVudmlyb25tZW50LFxuICAgIH0pO1xuXG4gICAgdGhpcy5yb2xlID0gc2hlbGxhYmxlLnJvbGU7XG4gICAgdGhpcy5wcm9qZWN0ID0gc2hlbGxhYmxlLnByb2plY3Q7XG4gIH1cblxuICBwdWJsaWMgYWRkVG9QaXBlbGluZShzdGFnZTogSVN0YWdlLCBpZDogc3RyaW5nLCBvcHRpb25zOiBBZGRUb1BpcGVsaW5lT3B0aW9ucykge1xuICAgIGNvbnN0IHNpZ25pbmdJbnB1dCA9IG9wdGlvbnMuaW5wdXRBcnRpZmFjdCB8fCBuZXcgQXJ0aWZhY3QoKTtcbiAgICBjb25zdCBzaWduaW5nT3V0cHV0ID0gbmV3IEFydGlmYWN0KCk7XG5cbiAgICBzdGFnZS5hZGRBY3Rpb24obmV3IENvZGVCdWlsZEFjdGlvbih7XG4gICAgICBhY3Rpb25OYW1lOiBpZCxcbiAgICAgIGlucHV0OiBzaWduaW5nSW5wdXQsXG4gICAgICBydW5PcmRlcjogb3B0aW9ucy5ydW5PcmRlcixcbiAgICAgIHByb2plY3Q6IHRoaXMucHJvamVjdCxcbiAgICAgIG91dHB1dHM6IFtzaWduaW5nT3V0cHV0XSxcbiAgICB9KSk7XG5cbiAgICByZXR1cm4gc2lnbmluZ091dHB1dDtcbiAgfVxufSJdfQ==
package/package.json CHANGED
@@ -97,7 +97,7 @@
97
97
  "publishConfig": {
98
98
  "access": "public"
99
99
  },
100
- "version": "14.14.18",
100
+ "version": "14.14.20",
101
101
  "jest": {
102
102
  "coverageProvider": "v8",
103
103
  "testMatch": [