aws-delivlib 14.3.65 → 14.4.1

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/.gitattributes CHANGED
@@ -1,4 +1,4 @@
1
- # ~~ Generated by projen. To modify, edit .projenrc.js and run "npx projen".
1
+ # ~~ Generated by projen. To modify, edit .projenrc.ts and run "npx projen".
2
2
 
3
3
  *.snap linguist-generated
4
4
  /.eslintrc.json linguist-generated
package/.projenrc.ts ADDED
@@ -0,0 +1,130 @@
1
+ import { typescript } from 'projen';
2
+
3
+ const project = new typescript.TypeScriptProject({
4
+ name: 'aws-delivlib',
5
+ projenrcTs: true,
6
+ description: 'A fabulous library for defining continuous pipelines for building, testing and releasing code libraries.',
7
+ repository: 'https://github.com/cdklabs/aws-delivlib.git',
8
+ defaultReleaseBranch: 'main',
9
+ authorName: 'Amazon Web Services',
10
+ authorUrl: 'https://aws.amazon.com',
11
+ minNodeVersion: '16.14.0',
12
+ keywords: [
13
+ 'aws-cdk',
14
+ 'continuous-delivery',
15
+ 'continuous-integration',
16
+ 'ci-cd',
17
+ ],
18
+ deps: ['changelog-parser'],
19
+ depsUpgradeOptions: {
20
+ exclude: ['aws-cdk-lib', 'constructs'],
21
+ },
22
+ devDeps: [
23
+ '@types/aws-lambda',
24
+ '@types/fs-extra',
25
+ '@types/tar',
26
+ '@types/adm-zip',
27
+ '@types/follow-redirects',
28
+ 'aws-cdk',
29
+ 'jest-create-mock-instance',
30
+ 'constructs',
31
+ 'aws-cdk-lib',
32
+ 'standard-version',
33
+ 'ts-jest',
34
+ 'typescript',
35
+ 'aws-sdk',
36
+ 'aws-sdk-mock',
37
+ 'node-ical@0.15.1', // need to pin due to https://github.com/axios/axios/issues/5101
38
+ 'rrule',
39
+ 'esbuild',
40
+ 'fs-extra',
41
+ 'tar',
42
+ 'adm-zip',
43
+ 'JSONStream',
44
+ 'follow-redirects',
45
+ 'minipass@3.2.1', // temporary (hopefully) workaround for https://github.com/DefinitelyTyped/DefinitelyTyped/discussions/60901
46
+ ],
47
+ peerDeps: [
48
+ 'constructs',
49
+ 'aws-cdk-lib',
50
+ ],
51
+ srcdir: 'lib',
52
+ testdir: 'lib/__tests__',
53
+
54
+ pullRequestTemplate: false,
55
+ autoApproveOptions: {
56
+ allowedUsernames: ['cdklabs-automation'],
57
+ secret: 'GITHUB_TOKEN',
58
+ },
59
+ autoApproveUpgrades: true,
60
+ releaseToNpm: true,
61
+ });
62
+
63
+ // trick projen so that it doesn't override the version in package.json
64
+ project.tasks.addEnvironment('RELEASE', '1');
65
+
66
+ project.gitignore.exclude('cdk.out');
67
+ project.gitignore.exclude('pipeline/*.js');
68
+ project.gitignore.exclude('pipeline/*.d.ts');
69
+ project.setScript('cdk', 'npx cdk');
70
+
71
+ const integDiff = project.addTask('integ:diff');
72
+ integDiff.exec('/bin/bash ./lib/__tests__/run-test.sh');
73
+
74
+ const integUpdate = project.addTask('integ:update');
75
+ integUpdate.exec('/bin/bash ./lib/__tests__/run-test.sh update');
76
+
77
+ // Need to run with UTC TZ, or else node-ical does very wrong things with timestamps and fails tests...
78
+ project.testTask.env('TZ', 'UTC');
79
+ project.testTask.spawn(integDiff);
80
+
81
+ // Run yarn install in the github publisher directory
82
+ const buildGithubPublisher = project.addTask('build:publishing/github');
83
+ buildGithubPublisher.exec('yarn install --frozen-lockfile', { cwd: 'lib/publishing/github' });
84
+ buildGithubPublisher.exec('yarn tsc --build', { cwd: 'lib/publishing/github' });
85
+ project.compileTask.prependSpawn(buildGithubPublisher);
86
+ // Exclude the publisher from the root tsconfig, but add a reference to it
87
+ project.tsconfig?.addExclude('lib/publishing/github');
88
+ project.tsconfig?.file.addOverride('references', [{ path: 'lib/publishing/github' }]);
89
+
90
+ const compileCustomResourceHandlers = project.addTask('compile:custom-resource-handlers');
91
+ compileCustomResourceHandlers.exec('/bin/bash ./build-custom-resource-handlers.sh');
92
+
93
+ project.compileTask.prependSpawn(compileCustomResourceHandlers);
94
+
95
+ project.gitignore.include('lib/package-integrity/handler/JSONStream.d.ts');
96
+ const bundlePackageIntegrity = project.addTask('bundle:package-integrity', {
97
+ description: 'Bundle the package integrity script',
98
+ exec: [
99
+ 'esbuild',
100
+ '--bundle',
101
+ 'lib/package-integrity/handler/validate.js',
102
+ '--target="node14"',
103
+ '--platform="node"',
104
+ '--outfile="lib/package-integrity/handler/validate.bundle.js"',
105
+ '--sourcemap=inline',
106
+ ].join(' '),
107
+ });
108
+
109
+ project.compileTask.spawn(bundlePackageIntegrity);
110
+
111
+ // The npmignore file includes original source files, which is undesirable.
112
+ project.npmignore?.exclude(
113
+ '/lib/**/*.ts',
114
+ );
115
+ project.npmignore?.include(
116
+ '/lib/**/*.d.ts',
117
+ '/lib/**/node_modules/**',
118
+ );
119
+ // Also includes other undesirable assets.
120
+ project.npmignore?.exclude(
121
+ '/lib/__tests__/',
122
+ 'tsconfig.json',
123
+ 'tsconfig.dev.json',
124
+ 'tsconfig.tsbuildinfo',
125
+ '/build-*.sh',
126
+ 'cdk.out/',
127
+ 'cdk.json',
128
+ );
129
+
130
+ project.synth();
package/lib/auto-build.js CHANGED
@@ -17,6 +17,7 @@ class AutoBuild extends constructs_1.Construct {
17
17
  buildSpec: props.buildSpec,
18
18
  ssmSessionPermissions: true,
19
19
  });
20
+ this.project.role.addManagedPolicy(aws_cdk_lib_1.aws_iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonElasticContainerRegistryPublicReadOnly'));
20
21
  const publicLogs = props.publicLogs !== undefined ? props.publicLogs : false;
21
22
  const githubToken = props.repo.tokenSecretArn ? aws_cdk_lib_1.SecretValue.secretsManager(props.repo.tokenSecretArn) : undefined;
22
23
  if (publicLogs) {
@@ -36,4 +37,4 @@ class AutoBuild extends constructs_1.Construct {
36
37
  }
37
38
  }
38
39
  exports.AutoBuild = AutoBuild;
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0by1idWlsZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImF1dG8tYnVpbGQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkNBSXFCO0FBQ3JCLDJDQUF1QztBQUN2QywyQ0FBNEU7QUEwRjVFLE1BQWEsU0FBVSxTQUFRLHNCQUFTO0lBT3RDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBcUI7O1FBQzdELEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLDJCQUFTLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDcEQsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXO1lBQzlCLFdBQVcsRUFBRSwwQkFBMEIsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUM5RCxNQUFNLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsTUFBQSxLQUFLLENBQUMsT0FBTyxtQ0FBSSxJQUFJLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3JILFdBQVcsRUFBRSxJQUFBLGtDQUFzQixFQUFDLE1BQUEsS0FBSyxDQUFDLFdBQVcsbUNBQUksRUFBRSxDQUFDO1lBQzVELEtBQUssRUFBRSxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQVc7WUFDN0IsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTO1lBQzFCLHFCQUFxQixFQUFFLElBQUk7U0FDNUIsQ0FBQyxDQUFDO1FBRUgsTUFBTSxVQUFVLEdBQUcsS0FBSyxDQUFDLFVBQVUsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztRQUM3RSxNQUFNLFdBQVcsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMseUJBQVcsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1FBRWxILElBQUksVUFBVSxFQUFFO1lBQ2QsSUFBSSxxQkFBVSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsd0JBQXdCLEVBQUU7Z0JBQzVELFFBQVEsRUFBRTtvQkFDUixhQUFhLEVBQUUsa0ZBQWtGO29CQUNqRyxlQUFlLEVBQUUsT0FBTztpQkFDekI7Z0JBQ0QsVUFBVSxFQUFFO29CQUNWLG9CQUFvQixFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVztvQkFDOUMsc0JBQXNCLEVBQUUsQ0FBQyxNQUFBLEtBQUssQ0FBQyw2QkFBNkIsbUNBQUksSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFO29CQUNoRixnQkFBZ0IsRUFBRSxDQUFDLE1BQUEsS0FBSyxDQUFDLG1CQUFtQixtQ0FBSSxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUU7b0JBQ2hFLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxFQUFFLGdCQUFnQixFQUFFLFdBQVcsQ0FBQyxZQUFZLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTO2lCQUM5RTthQUNGLENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQztDQUNGO0FBdENELDhCQXNDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIFNlY3JldFZhbHVlLFxuICBhd3NfY29kZWJ1aWxkIGFzIGNvZGVidWlsZCxcbiAgYXdzX3NhbSBhcyBzZXJ2ZXJsZXNzLFxufSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEJ1aWxkRW52aXJvbm1lbnRQcm9wcywgY3JlYXRlQnVpbGRFbnZpcm9ubWVudCB9IGZyb20gJy4vYnVpbGQtZW52JztcbmltcG9ydCB7IElSZXBvIH0gZnJvbSAnLi9yZXBvJztcblxuZXhwb3J0IGludGVyZmFjZSBBdXRvQnVpbGRPcHRpb25zIHtcbiAgLyoqXG4gICAqIEJ1aWxkIGVudmlyb25tZW50LlxuICAgKiBAZGVmYXVsdCAtIHNlZSBkZWZhdWx0cyBpbiBgQnVpbGRFbnZpcm9ubWVudFByb3BzYFxuICAgKi9cbiAgcmVhZG9ubHkgZW52aXJvbm1lbnQ/OiBCdWlsZEVudmlyb25tZW50UHJvcHM7XG5cbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBDb2RlQnVpbGQgcHJvamVjdC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBhIG5hbWUgd2lsbCBiZSBnZW5lcmF0ZWQgYnkgQ2xvdWRGb3JtYXRpb24uXG4gICAqL1xuICByZWFkb25seSBwcm9qZWN0TmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogTWFrZSBidWlsZCBsb2dzIHB1YmxpYyBhbmQgcHVibGlzaGVzIGEgbGluayB0byBHaXRIdWIgUFIgZGlzY3Vzc2lvbi5cbiAgICpcbiAgICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vamxob29kL2dpdGh1Yi1jb2RlYnVpbGQtbG9nc1xuICAgKlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgcHVibGljTG9ncz86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIENvbmZpZ3VyZSB0aGUgcHJvamVjdCB0byByZXNwb25kIHRvIHdlYmhvb2tzLlxuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICByZWFkb25seSB3ZWJob29rPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogV2hldGhlciB0byBwdWJsaXNoIGEgbGluayB0byBidWlsZCBsb2dzIHdoZW4gYnVpbGQgaXMgc3VjY2Vzc2Z1bC5cbiAgICpcbiAgICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vamxob29kL2dpdGh1Yi1jb2RlYnVpbGQtbG9ncyNhcHAtcGFyYW1ldGVyc1xuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICByZWFkb25seSBwdWJsaWNMb2dzT25TdWNjZXNzPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogV2hldGhlciB0byBkZWxldGUgcHJldmlvdXNseSBwdWJsaXNoZWQgbGlua3MgdG8gYnVpbGQgbG9nc1xuICAgKiBiZWZvcmUgcG9zdGluZyBhIG5ldyBvbmUuXG4gICAqXG4gICAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2psaG9vZC9naXRodWItY29kZWJ1aWxkLWxvZ3MjYXBwLXBhcmFtZXRlcnNcbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgcmVhZG9ubHkgZGVsZXRlUHJldmlvdXNQdWJsaWNMb2dzTGlua3M/OiBib29sZWFuO1xuXG4gIC8qIHRzbGludDpkaXNhYmxlOm1heC1saW5lLWxlbmd0aCAqL1xuICAvKipcbiAgICogQnVpbGQgc3BlYyBmaWxlIHRvIHVzZSBmb3IgQXV0b0J1aWxkXG4gICAqXG4gICAqIEBkZWZhdWx0IEBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtY29kZWJ1aWxkLXByb2plY3Qtc291cmNlLmh0bWwjY2ZuLWNvZGVidWlsZC1wcm9qZWN0LXNvdXJjZS1idWlsZHNwZWNcbiAgICovXG4gIHJlYWRvbmx5IGJ1aWxkU3BlYz86IGNvZGVidWlsZC5CdWlsZFNwZWM7XG4gIC8qIHRzbGludDplbmFibGU6bWF4LWxpbmUtbGVuZ3RoICovXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXV0b0J1aWxkUHJvcHMgZXh0ZW5kcyBBdXRvQnVpbGRPcHRpb25zIHtcbiAgLyoqXG4gICAqIFRoZSByZXBvc2l0b3J5IHRvIG1vbml0b3IuXG4gICAqXG4gICAqIE11c3QgYmUgYSBHaXRIdWIgcmVwb3NpdG9yeSBmb3IgYHB1YmxpY0xvZ3NgIHRvIGhhdmUgYW55IGVmZmVjdC5cbiAgICovXG4gIHJlYWRvbmx5IHJlcG86IElSZXBvO1xuXG4gIC8qKlxuICAgKiBUaGUgc3BlY2lmaWMgYnJhbmNoIHRvIGJlIGNvbnNpZGVyZWQgZm9yIGF1dG8tYnVpbGRzLlxuICAgKlxuICAgKiBTcGVjaWZ5IGF0IG1vc3Qgb25lIG9mIGBicmFuY2hgIGFuZCBgYnJhbmNoZXNgLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIGFueSAmIGFsbCBicmFuY2hlcy5cbiAgICogQGRlcHJlY2F0ZWQgVXNlIGBicmFuY2hlc2AgaW5zdGVhZC5cbiAgICovXG4gIHJlYWRvbmx5IGJyYW5jaD86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHNwZWNpZmljIGJyYW5jaCB0byBiZSBjb25zaWRlcmVkIGZvciBhdXRvLWJ1aWxkcy5cbiAgICpcbiAgICogU3BlY2lmeSBhdCBtb3N0IG9uZSBvZiBgYnJhbmNoYCBhbmQgYGJyYW5jaGVzYC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBhbnkgJiBhbGwgYnJhbmNoZXMuXG4gICAqL1xuICByZWFkb25seSBicmFuY2hlcz86IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgY2xhc3MgQXV0b0J1aWxkIGV4dGVuZHMgQ29uc3RydWN0IHtcblxuICAvKipcbiAgICogVGhlIHVuZGVybHlpbmcgYENvZGVCdWlsZGAgcHJvamVjdC5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBwcm9qZWN0OiBjb2RlYnVpbGQuUHJvamVjdDtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogQXV0b0J1aWxkUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5wcm9qZWN0ID0gbmV3IGNvZGVidWlsZC5Qcm9qZWN0KHRoaXMsICdQcm9qZWN0Jywge1xuICAgICAgcHJvamVjdE5hbWU6IHByb3BzLnByb2plY3ROYW1lLFxuICAgICAgZGVzY3JpcHRpb246IGBBdXRvbWF0aWMgUFIgYnVpbGQgZm9yICR7cHJvcHMucmVwby5kZXNjcmliZSgpfWAsXG4gICAgICBzb3VyY2U6IHByb3BzLnJlcG8uY3JlYXRlQnVpbGRTb3VyY2UodGhpcywgcHJvcHMud2ViaG9vayA/PyB0cnVlLCB7IGJyYW5jaDogcHJvcHMuYnJhbmNoLCBicmFuY2hlczogcHJvcHMuYnJhbmNoZXMgfSksXG4gICAgICBlbnZpcm9ubWVudDogY3JlYXRlQnVpbGRFbnZpcm9ubWVudChwcm9wcy5lbnZpcm9ubWVudCA/PyB7fSksXG4gICAgICBiYWRnZTogcHJvcHMucmVwby5hbGxvd3NCYWRnZSxcbiAgICAgIGJ1aWxkU3BlYzogcHJvcHMuYnVpbGRTcGVjLFxuICAgICAgc3NtU2Vzc2lvblBlcm1pc3Npb25zOiB0cnVlLFxuICAgIH0pO1xuXG4gICAgY29uc3QgcHVibGljTG9ncyA9IHByb3BzLnB1YmxpY0xvZ3MgIT09IHVuZGVmaW5lZCA/IHByb3BzLnB1YmxpY0xvZ3MgOiBmYWxzZTtcbiAgICBjb25zdCBnaXRodWJUb2tlbiA9IHByb3BzLnJlcG8udG9rZW5TZWNyZXRBcm4gPyBTZWNyZXRWYWx1ZS5zZWNyZXRzTWFuYWdlcihwcm9wcy5yZXBvLnRva2VuU2VjcmV0QXJuKSA6IHVuZGVmaW5lZDtcblxuICAgIGlmIChwdWJsaWNMb2dzKSB7XG4gICAgICBuZXcgc2VydmVybGVzcy5DZm5BcHBsaWNhdGlvbih0aGlzLCAnR2l0SHViQ29kZUJ1aWxkTG9nc1NBUicsIHtcbiAgICAgICAgbG9jYXRpb246IHtcbiAgICAgICAgICBhcHBsaWNhdGlvbklkOiAnYXJuOmF3czpzZXJ2ZXJsZXNzcmVwbzp1cy1lYXN0LTE6Mjc3MTg3NzA5NjE1OmFwcGxpY2F0aW9ucy9naXRodWItY29kZWJ1aWxkLWxvZ3MnLFxuICAgICAgICAgIHNlbWFudGljVmVyc2lvbjogJzEuNC4wJyxcbiAgICAgICAgfSxcbiAgICAgICAgcGFyYW1ldGVyczoge1xuICAgICAgICAgIENvZGVCdWlsZFByb2plY3ROYW1lOiB0aGlzLnByb2plY3QucHJvamVjdE5hbWUsXG4gICAgICAgICAgRGVsZXRlUHJldmlvdXNDb21tZW50czogKHByb3BzLmRlbGV0ZVByZXZpb3VzUHVibGljTG9nc0xpbmtzID8/IHRydWUpLnRvU3RyaW5nKCksXG4gICAgICAgICAgQ29tbWVudE9uU3VjY2VzczogKHByb3BzLnB1YmxpY0xvZ3NPblN1Y2Nlc3MgPz8gdHJ1ZSkudG9TdHJpbmcoKSxcbiAgICAgICAgICAuLi5naXRodWJUb2tlbiA/IHsgR2l0SHViT0F1dGhUb2tlbjogZ2l0aHViVG9rZW4udW5zYWZlVW53cmFwKCkgfSA6IHVuZGVmaW5lZCxcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxufVxuIl19
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0by1idWlsZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImF1dG8tYnVpbGQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkNBS3FCO0FBQ3JCLDJDQUF1QztBQUN2QywyQ0FBNEU7QUEwRjVFLE1BQWEsU0FBVSxTQUFRLHNCQUFTO0lBT3RDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBcUI7O1FBQzdELEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLDJCQUFTLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDcEQsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXO1lBQzlCLFdBQVcsRUFBRSwwQkFBMEIsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUM5RCxNQUFNLEVBQUUsS0FBSyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsTUFBQSxLQUFLLENBQUMsT0FBTyxtQ0FBSSxJQUFJLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3JILFdBQVcsRUFBRSxJQUFBLGtDQUFzQixFQUFDLE1BQUEsS0FBSyxDQUFDLFdBQVcsbUNBQUksRUFBRSxDQUFDO1lBQzVELEtBQUssRUFBRSxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQVc7WUFDN0IsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTO1lBQzFCLHFCQUFxQixFQUFFLElBQUk7U0FDNUIsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFLLENBQUMsZ0JBQWdCLENBQUMscUJBQUcsQ0FBQyxhQUFhLENBQUMsd0JBQXdCLENBQUMsOENBQThDLENBQUMsQ0FBQyxDQUFDO1FBRWhJLE1BQU0sVUFBVSxHQUFHLEtBQUssQ0FBQyxVQUFVLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDN0UsTUFBTSxXQUFXLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLHlCQUFXLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztRQUVsSCxJQUFJLFVBQVUsRUFBRTtZQUNkLElBQUkscUJBQVUsQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLHdCQUF3QixFQUFFO2dCQUM1RCxRQUFRLEVBQUU7b0JBQ1IsYUFBYSxFQUFFLGtGQUFrRjtvQkFDakcsZUFBZSxFQUFFLE9BQU87aUJBQ3pCO2dCQUNELFVBQVUsRUFBRTtvQkFDVixvQkFBb0IsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVc7b0JBQzlDLHNCQUFzQixFQUFFLENBQUMsTUFBQSxLQUFLLENBQUMsNkJBQTZCLG1DQUFJLElBQUksQ0FBQyxDQUFDLFFBQVEsRUFBRTtvQkFDaEYsZ0JBQWdCLEVBQUUsQ0FBQyxNQUFBLEtBQUssQ0FBQyxtQkFBbUIsbUNBQUksSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFO29CQUNoRSxHQUFHLFdBQVcsQ0FBQyxDQUFDLENBQUMsRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLENBQUMsWUFBWSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUztpQkFDOUU7YUFDRixDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7Q0FDRjtBQXZDRCw4QkF1Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBTZWNyZXRWYWx1ZSxcbiAgYXdzX2NvZGVidWlsZCBhcyBjb2RlYnVpbGQsXG4gIGF3c19pYW0gYXMgaWFtLFxuICBhd3Nfc2FtIGFzIHNlcnZlcmxlc3MsXG59IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQnVpbGRFbnZpcm9ubWVudFByb3BzLCBjcmVhdGVCdWlsZEVudmlyb25tZW50IH0gZnJvbSAnLi9idWlsZC1lbnYnO1xuaW1wb3J0IHsgSVJlcG8gfSBmcm9tICcuL3JlcG8nO1xuXG5leHBvcnQgaW50ZXJmYWNlIEF1dG9CdWlsZE9wdGlvbnMge1xuICAvKipcbiAgICogQnVpbGQgZW52aXJvbm1lbnQuXG4gICAqIEBkZWZhdWx0IC0gc2VlIGRlZmF1bHRzIGluIGBCdWlsZEVudmlyb25tZW50UHJvcHNgXG4gICAqL1xuICByZWFkb25seSBlbnZpcm9ubWVudD86IEJ1aWxkRW52aXJvbm1lbnRQcm9wcztcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIENvZGVCdWlsZCBwcm9qZWN0LlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIGEgbmFtZSB3aWxsIGJlIGdlbmVyYXRlZCBieSBDbG91ZEZvcm1hdGlvbi5cbiAgICovXG4gIHJlYWRvbmx5IHByb2plY3ROYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBNYWtlIGJ1aWxkIGxvZ3MgcHVibGljIGFuZCBwdWJsaXNoZXMgYSBsaW5rIHRvIEdpdEh1YiBQUiBkaXNjdXNzaW9uLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9qbGhvb2QvZ2l0aHViLWNvZGVidWlsZC1sb2dzXG4gICAqXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICByZWFkb25seSBwdWJsaWNMb2dzPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogQ29uZmlndXJlIHRoZSBwcm9qZWN0IHRvIHJlc3BvbmQgdG8gd2ViaG9va3MuXG4gICAqXG4gICAqIEBkZWZhdWx0IHRydWVcbiAgICovXG4gIHJlYWRvbmx5IHdlYmhvb2s/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIHB1Ymxpc2ggYSBsaW5rIHRvIGJ1aWxkIGxvZ3Mgd2hlbiBidWlsZCBpcyBzdWNjZXNzZnVsLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9qbGhvb2QvZ2l0aHViLWNvZGVidWlsZC1sb2dzI2FwcC1wYXJhbWV0ZXJzXG4gICAqXG4gICAqIEBkZWZhdWx0IHRydWVcbiAgICovXG4gIHJlYWRvbmx5IHB1YmxpY0xvZ3NPblN1Y2Nlc3M/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIGRlbGV0ZSBwcmV2aW91c2x5IHB1Ymxpc2hlZCBsaW5rcyB0byBidWlsZCBsb2dzXG4gICAqIGJlZm9yZSBwb3N0aW5nIGEgbmV3IG9uZS5cbiAgICpcbiAgICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vamxob29kL2dpdGh1Yi1jb2RlYnVpbGQtbG9ncyNhcHAtcGFyYW1ldGVyc1xuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICByZWFkb25seSBkZWxldGVQcmV2aW91c1B1YmxpY0xvZ3NMaW5rcz86IGJvb2xlYW47XG5cbiAgLyogdHNsaW50OmRpc2FibGU6bWF4LWxpbmUtbGVuZ3RoICovXG4gIC8qKlxuICAgKiBCdWlsZCBzcGVjIGZpbGUgdG8gdXNlIGZvciBBdXRvQnVpbGRcbiAgICpcbiAgICogQGRlZmF1bHQgQHNlZSBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcHJvcGVydGllcy1jb2RlYnVpbGQtcHJvamVjdC1zb3VyY2UuaHRtbCNjZm4tY29kZWJ1aWxkLXByb2plY3Qtc291cmNlLWJ1aWxkc3BlY1xuICAgKi9cbiAgcmVhZG9ubHkgYnVpbGRTcGVjPzogY29kZWJ1aWxkLkJ1aWxkU3BlYztcbiAgLyogdHNsaW50OmVuYWJsZTptYXgtbGluZS1sZW5ndGggKi9cbn1cblxuZXhwb3J0IGludGVyZmFjZSBBdXRvQnVpbGRQcm9wcyBleHRlbmRzIEF1dG9CdWlsZE9wdGlvbnMge1xuICAvKipcbiAgICogVGhlIHJlcG9zaXRvcnkgdG8gbW9uaXRvci5cbiAgICpcbiAgICogTXVzdCBiZSBhIEdpdEh1YiByZXBvc2l0b3J5IGZvciBgcHVibGljTG9nc2AgdG8gaGF2ZSBhbnkgZWZmZWN0LlxuICAgKi9cbiAgcmVhZG9ubHkgcmVwbzogSVJlcG87XG5cbiAgLyoqXG4gICAqIFRoZSBzcGVjaWZpYyBicmFuY2ggdG8gYmUgY29uc2lkZXJlZCBmb3IgYXV0by1idWlsZHMuXG4gICAqXG4gICAqIFNwZWNpZnkgYXQgbW9zdCBvbmUgb2YgYGJyYW5jaGAgYW5kIGBicmFuY2hlc2AuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gYW55ICYgYWxsIGJyYW5jaGVzLlxuICAgKiBAZGVwcmVjYXRlZCBVc2UgYGJyYW5jaGVzYCBpbnN0ZWFkLlxuICAgKi9cbiAgcmVhZG9ubHkgYnJhbmNoPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgc3BlY2lmaWMgYnJhbmNoIHRvIGJlIGNvbnNpZGVyZWQgZm9yIGF1dG8tYnVpbGRzLlxuICAgKlxuICAgKiBTcGVjaWZ5IGF0IG1vc3Qgb25lIG9mIGBicmFuY2hgIGFuZCBgYnJhbmNoZXNgLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIGFueSAmIGFsbCBicmFuY2hlcy5cbiAgICovXG4gIHJlYWRvbmx5IGJyYW5jaGVzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBjbGFzcyBBdXRvQnVpbGQgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuXG4gIC8qKlxuICAgKiBUaGUgdW5kZXJseWluZyBgQ29kZUJ1aWxkYCBwcm9qZWN0LlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHByb2plY3Q6IGNvZGVidWlsZC5Qcm9qZWN0O1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBBdXRvQnVpbGRQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICB0aGlzLnByb2plY3QgPSBuZXcgY29kZWJ1aWxkLlByb2plY3QodGhpcywgJ1Byb2plY3QnLCB7XG4gICAgICBwcm9qZWN0TmFtZTogcHJvcHMucHJvamVjdE5hbWUsXG4gICAgICBkZXNjcmlwdGlvbjogYEF1dG9tYXRpYyBQUiBidWlsZCBmb3IgJHtwcm9wcy5yZXBvLmRlc2NyaWJlKCl9YCxcbiAgICAgIHNvdXJjZTogcHJvcHMucmVwby5jcmVhdGVCdWlsZFNvdXJjZSh0aGlzLCBwcm9wcy53ZWJob29rID8/IHRydWUsIHsgYnJhbmNoOiBwcm9wcy5icmFuY2gsIGJyYW5jaGVzOiBwcm9wcy5icmFuY2hlcyB9KSxcbiAgICAgIGVudmlyb25tZW50OiBjcmVhdGVCdWlsZEVudmlyb25tZW50KHByb3BzLmVudmlyb25tZW50ID8/IHt9KSxcbiAgICAgIGJhZGdlOiBwcm9wcy5yZXBvLmFsbG93c0JhZGdlLFxuICAgICAgYnVpbGRTcGVjOiBwcm9wcy5idWlsZFNwZWMsXG4gICAgICBzc21TZXNzaW9uUGVybWlzc2lvbnM6IHRydWUsXG4gICAgfSk7XG4gICAgdGhpcy5wcm9qZWN0LnJvbGUhLmFkZE1hbmFnZWRQb2xpY3koaWFtLk1hbmFnZWRQb2xpY3kuZnJvbUF3c01hbmFnZWRQb2xpY3lOYW1lKCdBbWF6b25FbGFzdGljQ29udGFpbmVyUmVnaXN0cnlQdWJsaWNSZWFkT25seScpKTtcblxuICAgIGNvbnN0IHB1YmxpY0xvZ3MgPSBwcm9wcy5wdWJsaWNMb2dzICE9PSB1bmRlZmluZWQgPyBwcm9wcy5wdWJsaWNMb2dzIDogZmFsc2U7XG4gICAgY29uc3QgZ2l0aHViVG9rZW4gPSBwcm9wcy5yZXBvLnRva2VuU2VjcmV0QXJuID8gU2VjcmV0VmFsdWUuc2VjcmV0c01hbmFnZXIocHJvcHMucmVwby50b2tlblNlY3JldEFybikgOiB1bmRlZmluZWQ7XG5cbiAgICBpZiAocHVibGljTG9ncykge1xuICAgICAgbmV3IHNlcnZlcmxlc3MuQ2ZuQXBwbGljYXRpb24odGhpcywgJ0dpdEh1YkNvZGVCdWlsZExvZ3NTQVInLCB7XG4gICAgICAgIGxvY2F0aW9uOiB7XG4gICAgICAgICAgYXBwbGljYXRpb25JZDogJ2Fybjphd3M6c2VydmVybGVzc3JlcG86dXMtZWFzdC0xOjI3NzE4NzcwOTYxNTphcHBsaWNhdGlvbnMvZ2l0aHViLWNvZGVidWlsZC1sb2dzJyxcbiAgICAgICAgICBzZW1hbnRpY1ZlcnNpb246ICcxLjQuMCcsXG4gICAgICAgIH0sXG4gICAgICAgIHBhcmFtZXRlcnM6IHtcbiAgICAgICAgICBDb2RlQnVpbGRQcm9qZWN0TmFtZTogdGhpcy5wcm9qZWN0LnByb2plY3ROYW1lLFxuICAgICAgICAgIERlbGV0ZVByZXZpb3VzQ29tbWVudHM6IChwcm9wcy5kZWxldGVQcmV2aW91c1B1YmxpY0xvZ3NMaW5rcyA/PyB0cnVlKS50b1N0cmluZygpLFxuICAgICAgICAgIENvbW1lbnRPblN1Y2Nlc3M6IChwcm9wcy5wdWJsaWNMb2dzT25TdWNjZXNzID8/IHRydWUpLnRvU3RyaW5nKCksXG4gICAgICAgICAgLi4uZ2l0aHViVG9rZW4gPyB7IEdpdEh1Yk9BdXRoVG9rZW46IGdpdGh1YlRva2VuLnVuc2FmZVVud3JhcCgpIH0gOiB1bmRlZmluZWQsXG4gICAgICAgIH0sXG4gICAgICB9KTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
package/lib/build-env.js CHANGED
@@ -7,7 +7,7 @@ function createBuildEnvironment(props) {
7
7
  computeType: props.computeType || aws_cdk_lib_1.aws_codebuild.ComputeType.SMALL,
8
8
  privileged: props.privileged,
9
9
  environmentVariables: renderEnvironmentVariables({ ...props.environment, ...props.env }),
10
- buildImage: props.buildImage || aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry('jsii/superchain:1-buster-slim'),
10
+ buildImage: props.buildImage || aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-buster-slim-node18'),
11
11
  };
12
12
  return environment;
13
13
  }
@@ -22,4 +22,4 @@ function renderEnvironmentVariables(env) {
22
22
  }
23
23
  return out;
24
24
  }
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtZW52LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYnVpbGQtZW52LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUFzRDtBQVd0RCxTQUFnQixzQkFBc0IsQ0FBQyxLQUE0QjtJQUNqRSxNQUFNLFdBQVcsR0FBNEI7UUFDM0MsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXLElBQUksMkJBQU0sQ0FBQyxXQUFXLENBQUMsS0FBSztRQUMxRCxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7UUFDNUIsb0JBQW9CLEVBQUUsMEJBQTBCLENBQUMsRUFBRSxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsR0FBRyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDeEYsVUFBVSxFQUFFLEtBQUssQ0FBQyxVQUFVLElBQUksMkJBQU0sQ0FBQyxlQUFlLENBQUMsa0JBQWtCLENBQUMsK0JBQStCLENBQUM7S0FDM0csQ0FBQztJQUVGLE9BQU8sV0FBVyxDQUFDO0FBQ3JCLENBQUM7QUFURCx3REFTQztBQUVELFNBQVMsMEJBQTBCLENBQUMsR0FBK0I7SUFDakUsSUFBSSxDQUFDLEdBQUcsRUFBRTtRQUNSLE9BQU8sU0FBUyxDQUFDO0tBQ2xCO0lBRUQsTUFBTSxHQUFHLEdBQXVELEVBQUcsQ0FBQztJQUNwRSxLQUFLLE1BQU0sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUM5QyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsQ0FBQztLQUN0QjtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGF3c19jb2RlYnVpbGQgYXMgY2J1aWxkIH0gZnJvbSAnYXdzLWNkay1saWInO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJ1aWxkRW52aXJvbm1lbnRQcm9wcyB7XG4gIGNvbXB1dGVUeXBlPzogY2J1aWxkLkNvbXB1dGVUeXBlO1xuICBwcml2aWxlZ2VkPzogYm9vbGVhbjtcbiAgLyoqIEBkZXByZWNhdGVkICovXG4gIGVudj86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG4gIGVudmlyb25tZW50PzogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfTtcbiAgYnVpbGRJbWFnZT86IGNidWlsZC5JQnVpbGRJbWFnZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUJ1aWxkRW52aXJvbm1lbnQocHJvcHM6IEJ1aWxkRW52aXJvbm1lbnRQcm9wcykge1xuICBjb25zdCBlbnZpcm9ubWVudDogY2J1aWxkLkJ1aWxkRW52aXJvbm1lbnQgPSB7XG4gICAgY29tcHV0ZVR5cGU6IHByb3BzLmNvbXB1dGVUeXBlIHx8IGNidWlsZC5Db21wdXRlVHlwZS5TTUFMTCxcbiAgICBwcml2aWxlZ2VkOiBwcm9wcy5wcml2aWxlZ2VkLFxuICAgIGVudmlyb25tZW50VmFyaWFibGVzOiByZW5kZXJFbnZpcm9ubWVudFZhcmlhYmxlcyh7IC4uLnByb3BzLmVudmlyb25tZW50LCAuLi5wcm9wcy5lbnYgfSksXG4gICAgYnVpbGRJbWFnZTogcHJvcHMuYnVpbGRJbWFnZSB8fCBjYnVpbGQuTGludXhCdWlsZEltYWdlLmZyb21Eb2NrZXJSZWdpc3RyeSgnanNpaS9zdXBlcmNoYWluOjEtYnVzdGVyLXNsaW0nKSxcbiAgfTtcblxuICByZXR1cm4gZW52aXJvbm1lbnQ7XG59XG5cbmZ1bmN0aW9uIHJlbmRlckVudmlyb25tZW50VmFyaWFibGVzKGVudj86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0pIHtcbiAgaWYgKCFlbnYpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3Qgb3V0OiB7IFtrZXk6IHN0cmluZ106IGNidWlsZC5CdWlsZEVudmlyb25tZW50VmFyaWFibGUgfSA9IHsgfTtcbiAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoZW52KSkge1xuICAgIG91dFtrZXldID0geyB2YWx1ZSB9O1xuICB9XG4gIHJldHVybiBvdXQ7XG59XG4iXX0=
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtZW52LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYnVpbGQtZW52LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUFzRDtBQVd0RCxTQUFnQixzQkFBc0IsQ0FBQyxLQUE0QjtJQUNqRSxNQUFNLFdBQVcsR0FBNEI7UUFDM0MsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXLElBQUksMkJBQU0sQ0FBQyxXQUFXLENBQUMsS0FBSztRQUMxRCxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7UUFDNUIsb0JBQW9CLEVBQUUsMEJBQTBCLENBQUMsRUFBRSxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsR0FBRyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDeEYsVUFBVSxFQUFFLEtBQUssQ0FBQyxVQUFVLElBQUksMkJBQU0sQ0FBQyxlQUFlLENBQUMsa0JBQWtCLENBQUMscURBQXFELENBQUM7S0FDakksQ0FBQztJQUVGLE9BQU8sV0FBVyxDQUFDO0FBQ3JCLENBQUM7QUFURCx3REFTQztBQUVELFNBQVMsMEJBQTBCLENBQUMsR0FBK0I7SUFDakUsSUFBSSxDQUFDLEdBQUcsRUFBRTtRQUNSLE9BQU8sU0FBUyxDQUFDO0tBQ2xCO0lBRUQsTUFBTSxHQUFHLEdBQXVELEVBQUcsQ0FBQztJQUNwRSxLQUFLLE1BQU0sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUM5QyxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsQ0FBQztLQUN0QjtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGF3c19jb2RlYnVpbGQgYXMgY2J1aWxkIH0gZnJvbSAnYXdzLWNkay1saWInO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJ1aWxkRW52aXJvbm1lbnRQcm9wcyB7XG4gIGNvbXB1dGVUeXBlPzogY2J1aWxkLkNvbXB1dGVUeXBlO1xuICBwcml2aWxlZ2VkPzogYm9vbGVhbjtcbiAgLyoqIEBkZXByZWNhdGVkICovXG4gIGVudj86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG4gIGVudmlyb25tZW50PzogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfTtcbiAgYnVpbGRJbWFnZT86IGNidWlsZC5JQnVpbGRJbWFnZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUJ1aWxkRW52aXJvbm1lbnQocHJvcHM6IEJ1aWxkRW52aXJvbm1lbnRQcm9wcykge1xuICBjb25zdCBlbnZpcm9ubWVudDogY2J1aWxkLkJ1aWxkRW52aXJvbm1lbnQgPSB7XG4gICAgY29tcHV0ZVR5cGU6IHByb3BzLmNvbXB1dGVUeXBlIHx8IGNidWlsZC5Db21wdXRlVHlwZS5TTUFMTCxcbiAgICBwcml2aWxlZ2VkOiBwcm9wcy5wcml2aWxlZ2VkLFxuICAgIGVudmlyb25tZW50VmFyaWFibGVzOiByZW5kZXJFbnZpcm9ubWVudFZhcmlhYmxlcyh7IC4uLnByb3BzLmVudmlyb25tZW50LCAuLi5wcm9wcy5lbnYgfSksXG4gICAgYnVpbGRJbWFnZTogcHJvcHMuYnVpbGRJbWFnZSB8fCBjYnVpbGQuTGludXhCdWlsZEltYWdlLmZyb21Eb2NrZXJSZWdpc3RyeSgncHVibGljLmVjci5hd3MvanNpaS9zdXBlcmNoYWluOjEtYnVzdGVyLXNsaW0tbm9kZTE4JyksXG4gIH07XG5cbiAgcmV0dXJuIGVudmlyb25tZW50O1xufVxuXG5mdW5jdGlvbiByZW5kZXJFbnZpcm9ubWVudFZhcmlhYmxlcyhlbnY/OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9KSB7XG4gIGlmICghZW52KSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IG91dDogeyBba2V5OiBzdHJpbmddOiBjYnVpbGQuQnVpbGRFbnZpcm9ubWVudFZhcmlhYmxlIH0gPSB7IH07XG4gIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIE9iamVjdC5lbnRyaWVzKGVudikpIHtcbiAgICBvdXRba2V5XSA9IHsgdmFsdWUgfTtcbiAgfVxuICByZXR1cm4gb3V0O1xufVxuIl19
package/lib/pipeline.js CHANGED
@@ -72,6 +72,7 @@ class Pipeline extends constructs_1.Construct {
72
72
  ssmSessionPermissions: true,
73
73
  });
74
74
  this.buildRole = this.buildProject.role;
75
+ this.buildRole.addManagedPolicy(aws_cdk_lib_1.aws_iam.ManagedPolicy.fromAwsManagedPolicyName('AmazonElasticContainerRegistryPublicReadOnly'));
75
76
  const buildStage = this.getOrCreateStage('Build');
76
77
  const buildOutput = new aws_cdk_lib_1.aws_codepipeline.Artifact();
77
78
  buildStage.addAction(new aws_cdk_lib_1.aws_codepipeline_actions.CodeBuildAction({
@@ -341,4 +342,4 @@ class Pipeline extends constructs_1.Construct {
341
342
  }
342
343
  }
343
344
  exports.Pipeline = Pipeline;
344
- //# 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 { determineRunOrder, flatMap } from './util';\n\nconst PUBLISH_STAGE_NAME = 'Publish';\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 stages: { [name: string]: cpipeline.IStage } = { };\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\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\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  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.buildOutput,\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.buildOutput,\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 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 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 Build output artifact\n   */\n  inputArtifact?: cpipeline.Artifact;\n}\n"]}
345
+ //# 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 { determineRunOrder, flatMap } from './util';\n\nconst PUBLISH_STAGE_NAME = 'Publish';\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 stages: { [name: string]: cpipeline.IStage } = { };\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\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  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.buildOutput,\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.buildOutput,\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 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 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 Build output artifact\n   */\n  inputArtifact?: cpipeline.Artifact;\n}\n"]}