aws-delivlib 14.13.37 → 14.14.0

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/CONTRIBUTING.md CHANGED
@@ -74,17 +74,18 @@ yarn test
74
74
  ```
75
75
 
76
76
  Besides this, there is a delivlib instance deployed to an AWS account (712950704752) that configures a delivlib pipeline for
77
- the package [aws-delivlib-sample](https://github.com/awslabs/aws-delivlib-sample). This instance can be used to test and
78
- validate your local changes. To do this,
77
+ the package [aws-delivlib-sample](https://github.com/awslabs/aws-delivlib-sample).
79
78
 
80
- 1. Build the package - `yarn compile`
81
- 2. Setup credentials to our AWS account: 712950704752
82
- 3. Execute `yarn integ:update`. This will update the delivlib instance and the command will halt at a user prompt.
79
+ You should use this code to validate more elaborate changes to the Delivlib code base. To do this,
80
+
81
+ 1. Setup credentials to our AWS account: 712950704752
82
+ 2. Execute `yarn integ:update`. This will update the delivlib instance.
83
83
 
84
84
  At this point, you will find the resources created by delivlib in the stack whose ARN is printed to the console. Wait for the
85
85
  deployment to complete, and are then free to test and verify that your changes had the intended effect.
86
86
 
87
- Once complete, continue following the instructions and prompts until the end.q
87
+ > NOTE: you might need to manually replicate the CDKlabs credentials to the publishing account. We don't do
88
+ > this often enough to make it worthwhile investing into automation for it.
88
89
 
89
90
  ## Releasing a New Version
90
91
 
@@ -17,3 +17,4 @@ echo "Installing rsync..."
17
17
  apt-get update > /dev/null && apt-get install -y rsync
18
18
 
19
19
  /bin/bash $SCRIPT_DIR/publish-docs.sh
20
+ /bin/bash $SCRIPT_DIR/update-ssm.sh
@@ -0,0 +1,24 @@
1
+ #!/bin/bash
2
+ # Write the current version and timestamp to SSM, if the current version is new
3
+ set -eu
4
+
5
+ if [[ "${SSM_PREFIX:-}" != "" ]]; then
6
+ if [[ "${FOR_REAL:-}" == "true" ]]; then
7
+ dry_aws="aws"
8
+ else
9
+ dry_aws="echo aws"
10
+ fi
11
+
12
+ build_manifest="${BUILD_MANIFEST:-"./build.json"}"
13
+ version="$(node -p "require('${build_manifest}').version")"
14
+
15
+ cur_version=$(aws ssm get-parameter --name "$SSM_PREFIX/version" --output text --query 'Parameter.Value' || echo '-missing-')
16
+
17
+ if [[ "$cur_version" != "$version" ]]; then
18
+ echo "📖 Writing version and timestamp to $SSM_PREFIX/{version,timestamp}"
19
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/version" --type "String" --value "$version" --overwrite
20
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/timestamp" --type "String" --value "$(date +%s)" --overwrite
21
+ else
22
+ echo "⚠️ Version already up-to-date."
23
+ fi
24
+ fi
@@ -85,3 +85,5 @@ else
85
85
  echo "Set FOR_REAL=true to do it!"
86
86
  echo "==========================================="
87
87
  fi
88
+
89
+ /bin/bash $SCRIPT_DIR/update-ssm.sh
@@ -0,0 +1,24 @@
1
+ #!/bin/bash
2
+ # Write the current version and timestamp to SSM, if the current version is new
3
+ set -eu
4
+
5
+ if [[ "${SSM_PREFIX:-}" != "" ]]; then
6
+ if [[ "${FOR_REAL:-}" == "true" ]]; then
7
+ dry_aws="aws"
8
+ else
9
+ dry_aws="echo aws"
10
+ fi
11
+
12
+ build_manifest="${BUILD_MANIFEST:-"./build.json"}"
13
+ version="$(node -p "require('${build_manifest}').version")"
14
+
15
+ cur_version=$(aws ssm get-parameter --name "$SSM_PREFIX/version" --output text --query 'Parameter.Value' || echo '-missing-')
16
+
17
+ if [[ "$cur_version" != "$version" ]]; then
18
+ echo "📖 Writing version and timestamp to $SSM_PREFIX/{version,timestamp}"
19
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/version" --type "String" --value "$version" --overwrite
20
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/timestamp" --type "String" --value "$(date +%s)" --overwrite
21
+ else
22
+ echo "⚠️ Version already up-to-date."
23
+ fi
24
+ fi
@@ -14,4 +14,6 @@ if [ ! -d "go" ]; then
14
14
  exit 0
15
15
  fi
16
16
 
17
- exec npx -p jsii-release jsii-release-golang go/
17
+ npx -p jsii-release jsii-release-golang go/
18
+
19
+ /bin/bash $SCRIPT_DIR/write-ssm.sh
@@ -0,0 +1,24 @@
1
+ #!/bin/bash
2
+ # Write the current version and timestamp to SSM, if the current version is new
3
+ set -eu
4
+
5
+ if [[ "${SSM_PREFIX:-}" != "" ]]; then
6
+ if [[ "${FOR_REAL:-}" == "true" ]]; then
7
+ dry_aws="aws"
8
+ else
9
+ dry_aws="echo aws"
10
+ fi
11
+
12
+ build_manifest="${BUILD_MANIFEST:-"./build.json"}"
13
+ version="$(node -p "require('${build_manifest}').version")"
14
+
15
+ cur_version=$(aws ssm get-parameter --name "$SSM_PREFIX/version" --output text --query 'Parameter.Value' || echo '-missing-')
16
+
17
+ if [[ "$cur_version" != "$version" ]]; then
18
+ echo "📖 Writing version and timestamp to $SSM_PREFIX/{version,timestamp}"
19
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/version" --type "String" --value "$version" --overwrite
20
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/timestamp" --type "String" --value "$(date +%s)" --overwrite
21
+ else
22
+ echo "⚠️ Version already up-to-date."
23
+ fi
24
+ fi
@@ -14,3 +14,5 @@ export MAVEN_PASSWORD=$(node -e "console.log(${credentials}.password);")
14
14
  chmod +x $SCRIPT_DIR/with-signing-key.sh
15
15
  chmod +x $SCRIPT_DIR/publish-mvn.sh
16
16
  $SCRIPT_DIR/with-signing-key.sh $SCRIPT_DIR/publish-mvn.sh
17
+
18
+ /bin/bash $SCRIPT_DIR/update-ssm.sh
@@ -0,0 +1,24 @@
1
+ #!/bin/bash
2
+ # Write the current version and timestamp to SSM, if the current version is new
3
+ set -eu
4
+
5
+ if [[ "${SSM_PREFIX:-}" != "" ]]; then
6
+ if [[ "${FOR_REAL:-}" == "true" ]]; then
7
+ dry_aws="aws"
8
+ else
9
+ dry_aws="echo aws"
10
+ fi
11
+
12
+ build_manifest="${BUILD_MANIFEST:-"./build.json"}"
13
+ version="$(node -p "require('${build_manifest}').version")"
14
+
15
+ cur_version=$(aws ssm get-parameter --name "$SSM_PREFIX/version" --output text --query 'Parameter.Value' || echo '-missing-')
16
+
17
+ if [[ "$cur_version" != "$version" ]]; then
18
+ echo "📖 Writing version and timestamp to $SSM_PREFIX/{version,timestamp}"
19
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/version" --type "String" --value "$version" --overwrite
20
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/timestamp" --type "String" --value "$(date +%s)" --overwrite
21
+ else
22
+ echo "⚠️ Version already up-to-date."
23
+ fi
24
+ fi
@@ -17,3 +17,4 @@ echo '//registry.npmjs.org/:_authToken=${NPM_TOKEN}' > ~/.npmrc
17
17
 
18
18
  # Call publishing script
19
19
  /bin/bash $SCRIPT_DIR/publish-npm.sh
20
+ /bin/bash $SCRIPT_DIR/update-ssm.sh
@@ -0,0 +1,24 @@
1
+ #!/bin/bash
2
+ # Write the current version and timestamp to SSM, if the current version is new
3
+ set -eu
4
+
5
+ if [[ "${SSM_PREFIX:-}" != "" ]]; then
6
+ if [[ "${FOR_REAL:-}" == "true" ]]; then
7
+ dry_aws="aws"
8
+ else
9
+ dry_aws="echo aws"
10
+ fi
11
+
12
+ build_manifest="${BUILD_MANIFEST:-"./build.json"}"
13
+ version="$(node -p "require('${build_manifest}').version")"
14
+
15
+ cur_version=$(aws ssm get-parameter --name "$SSM_PREFIX/version" --output text --query 'Parameter.Value' || echo '-missing-')
16
+
17
+ if [[ "$cur_version" != "$version" ]]; then
18
+ echo "📖 Writing version and timestamp to $SSM_PREFIX/{version,timestamp}"
19
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/version" --type "String" --value "$version" --overwrite
20
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/timestamp" --type "String" --value "$(date +%s)" --overwrite
21
+ else
22
+ echo "⚠️ Version already up-to-date."
23
+ fi
24
+ fi
@@ -114,5 +114,7 @@ if ! ${found}; then
114
114
  exit 1
115
115
  fi
116
116
 
117
+ /bin/bash $SCRIPT_DIR/update-ssm.sh
118
+
117
119
  echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
118
120
  echo "✅ All Done!"
@@ -0,0 +1,24 @@
1
+ #!/bin/bash
2
+ # Write the current version and timestamp to SSM, if the current version is new
3
+ set -eu
4
+
5
+ if [[ "${SSM_PREFIX:-}" != "" ]]; then
6
+ if [[ "${FOR_REAL:-}" == "true" ]]; then
7
+ dry_aws="aws"
8
+ else
9
+ dry_aws="echo aws"
10
+ fi
11
+
12
+ build_manifest="${BUILD_MANIFEST:-"./build.json"}"
13
+ version="$(node -p "require('${build_manifest}').version")"
14
+
15
+ cur_version=$(aws ssm get-parameter --name "$SSM_PREFIX/version" --output text --query 'Parameter.Value' || echo '-missing-')
16
+
17
+ if [[ "$cur_version" != "$version" ]]; then
18
+ echo "📖 Writing version and timestamp to $SSM_PREFIX/{version,timestamp}"
19
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/version" --type "String" --value "$version" --overwrite
20
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/timestamp" --type "String" --value "$(date +%s)" --overwrite
21
+ else
22
+ echo "⚠️ Version already up-to-date."
23
+ fi
24
+ fi
@@ -23,3 +23,5 @@ else
23
23
  echo "Set FOR_REAL=true to do it!"
24
24
  echo "==========================================="
25
25
  fi
26
+
27
+ /bin/bash $SCRIPT_DIR/update-ssm.sh
@@ -0,0 +1,24 @@
1
+ #!/bin/bash
2
+ # Write the current version and timestamp to SSM, if the current version is new
3
+ set -eu
4
+
5
+ if [[ "${SSM_PREFIX:-}" != "" ]]; then
6
+ if [[ "${FOR_REAL:-}" == "true" ]]; then
7
+ dry_aws="aws"
8
+ else
9
+ dry_aws="echo aws"
10
+ fi
11
+
12
+ build_manifest="${BUILD_MANIFEST:-"./build.json"}"
13
+ version="$(node -p "require('${build_manifest}').version")"
14
+
15
+ cur_version=$(aws ssm get-parameter --name "$SSM_PREFIX/version" --output text --query 'Parameter.Value' || echo '-missing-')
16
+
17
+ if [[ "$cur_version" != "$version" ]]; then
18
+ echo "📖 Writing version and timestamp to $SSM_PREFIX/{version,timestamp}"
19
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/version" --type "String" --value "$version" --overwrite
20
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/timestamp" --type "String" --value "$(date +%s)" --overwrite
21
+ else
22
+ echo "⚠️ Version already up-to-date."
23
+ fi
24
+ fi
@@ -28,12 +28,12 @@ if [[ "${idempotency_token:-}" != "" ]]; then
28
28
  echo "Idempotency token: $idempotency_token"
29
29
 
30
30
  # Must use 's3 cp' to try and read exact filename. 's3 ls' would match prefixes as well.
31
- aws s3 cp $BUCKET_URL/$idempotency_token - > /dev/null 2>&1 && {
31
+ if aws s3 cp $BUCKET_URL/$idempotency_token - > /dev/null 2>&1; then
32
32
  echo "Token found, stopping."
33
33
  exit 0
34
- } || {
34
+ else
35
35
  echo "Idempotency token not found, continuing."
36
- }
36
+ fi
37
37
  fi
38
38
 
39
39
  # Do the copy
@@ -55,4 +55,6 @@ else
55
55
  echo
56
56
  echo "Set FOR_REAL=true to do it!"
57
57
  echo "==========================================="
58
- fi
58
+ fi
59
+
60
+ /bin/bash $SCRIPT_DIR/update-ssm.sh
@@ -0,0 +1,24 @@
1
+ #!/bin/bash
2
+ # Write the current version and timestamp to SSM, if the current version is new
3
+ set -eu
4
+
5
+ if [[ "${SSM_PREFIX:-}" != "" ]]; then
6
+ if [[ "${FOR_REAL:-}" == "true" ]]; then
7
+ dry_aws="aws"
8
+ else
9
+ dry_aws="echo aws"
10
+ fi
11
+
12
+ build_manifest="${BUILD_MANIFEST:-"./build.json"}"
13
+ version="$(node -p "require('${build_manifest}').version")"
14
+
15
+ cur_version=$(aws ssm get-parameter --name "$SSM_PREFIX/version" --output text --query 'Parameter.Value' || echo '-missing-')
16
+
17
+ if [[ "$cur_version" != "$version" ]]; then
18
+ echo "📖 Writing version and timestamp to $SSM_PREFIX/{version,timestamp}"
19
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/version" --type "String" --value "$version" --overwrite
20
+ $dry_aws ssm put-parameter --name "$SSM_PREFIX/timestamp" --type "String" --value "$(date +%s)" --overwrite
21
+ else
22
+ echo "⚠️ Version already up-to-date."
23
+ fi
24
+ fi
@@ -50,6 +50,14 @@ export interface PublishToMavenProjectProps {
50
50
  * @default Latest superchain
51
51
  */
52
52
  readonly buildImage?: cbuild.IBuildImage;
53
+ /**
54
+ * The prefix under which to record the fact that the publish step executed
55
+ *
56
+ * This will write `<prefix>/version` and `<prefix>/timestamp` variables
57
+ *
58
+ * @default - no SSM parameters
59
+ */
60
+ ssmPrefix?: string;
53
61
  }
54
62
  /**
55
63
  * CodeBuild project that will publish all packages in a release bundle to Maven
@@ -88,6 +96,14 @@ export interface PublishToNpmProjectProps {
88
96
  * @default NpmAccess.PUBLIC
89
97
  */
90
98
  access?: NpmAccess;
99
+ /**
100
+ * The prefix under which to record the fact that the publish step executed
101
+ *
102
+ * This will write `<prefix>/version` and `<prefix>/timestamp` variables
103
+ *
104
+ * @default - no SSM parameters
105
+ */
106
+ ssmPrefix?: string;
91
107
  }
92
108
  /**
93
109
  * CodeBuild project that will publish all packages in a release bundle to NPM
@@ -121,6 +137,14 @@ export interface PublishToNuGetProjectProps {
121
137
  * @default Latest superchain
122
138
  */
123
139
  readonly buildImage?: cbuild.IBuildImage;
140
+ /**
141
+ * The prefix under which to record the fact that the publish step executed
142
+ *
143
+ * This will write `<prefix>/version` and `<prefix>/timestamp` variables
144
+ *
145
+ * @default - no SSM parameters
146
+ */
147
+ ssmPrefix?: string;
124
148
  }
125
149
  /**
126
150
  * CodeBuild project that will publish all packages in a release bundle to NuGet
@@ -152,6 +176,14 @@ export interface PublishDocsToGitHubProjectProps {
152
176
  * @default gh-pages
153
177
  */
154
178
  branch?: string;
179
+ /**
180
+ * The prefix under which to record the fact that the publish step executed
181
+ *
182
+ * This will write `<prefix>/version` and `<prefix>/timestamp` variables
183
+ *
184
+ * @default - no SSM parameters
185
+ */
186
+ ssmPrefix?: string;
155
187
  }
156
188
  /**
157
189
  * CodeBuild project that will publish all packages in a release bundle to NuGet
@@ -208,6 +240,14 @@ export interface PublishToGitHubProps {
208
240
  * @default true
209
241
  */
210
242
  signAdditionalArtifacts?: boolean;
243
+ /**
244
+ * The prefix under which to record the fact that the publish step executed
245
+ *
246
+ * This will write `<prefix>/version` and `<prefix>/timestamp` variables
247
+ *
248
+ * @default - no SSM parameters
249
+ */
250
+ ssmPrefix?: string;
211
251
  }
212
252
  export declare class PublishToGitHub extends Construct implements IPublisher {
213
253
  readonly role: iam.IRole;
@@ -247,6 +287,14 @@ export interface PublishToPyPiProps {
247
287
  * @default true
248
288
  */
249
289
  dryRun?: boolean;
290
+ /**
291
+ * The prefix under which to record the fact that the publish step executed
292
+ *
293
+ * This will write `<prefix>/version` and `<prefix>/timestamp` variables
294
+ *
295
+ * @default - no SSM parameters
296
+ */
297
+ ssmPrefix?: string;
250
298
  }
251
299
  export declare class PublishToPyPi extends Construct {
252
300
  readonly project: cbuild.Project;
@@ -297,6 +345,14 @@ export interface PublishToGolangProps {
297
345
  * @default "chore(release): $VERSION"
298
346
  */
299
347
  readonly gitCommitMessage?: string;
348
+ /**
349
+ * The prefix under which to record the fact that the publish step executed
350
+ *
351
+ * This will write `<prefix>/version` and `<prefix>/timestamp` variables
352
+ *
353
+ * @default - no SSM parameters
354
+ */
355
+ ssmPrefix?: string;
300
356
  }
301
357
  /**
302
358
  * Pushes a directory of golang modules to a GitHub repository.
package/lib/publishing.js CHANGED
@@ -56,18 +56,20 @@ class PublishToMavenProject extends constructs_1.Construct {
56
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-bullseye-slim-node18')),
57
57
  scriptDirectory: path.join(__dirname, 'publishing', 'maven'),
58
58
  entrypoint: 'publish.sh',
59
- environment: {
59
+ environment: (0, util_1.noUndefined)({
60
60
  STAGING_PROFILE_ID: props.stagingProfileId,
61
61
  SIGNING_KEY_ARN: props.signingKey.credential.secretArn,
62
62
  FOR_REAL: forReal,
63
63
  MAVEN_LOGIN_SECRET: props.mavenLoginSecret.secretArn,
64
64
  MAVEN_ENDPOINT: props.mavenEndpoint || 'https://oss.sonatype.org',
65
- },
65
+ SSM_PREFIX: props.ssmPrefix,
66
+ }),
66
67
  });
67
68
  if (shellable.role) {
68
69
  permissions.grantSecretRead(props.mavenLoginSecret, shellable.role);
69
70
  props.signingKey.grantRead(shellable.role);
70
71
  }
72
+ grantSsmPrefix(shellable.role, props.ssmPrefix);
71
73
  this.role = shellable.role;
72
74
  this.project = shellable.project;
73
75
  }
@@ -94,16 +96,18 @@ class PublishToNpmProject extends constructs_1.Construct {
94
96
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
95
97
  scriptDirectory: path.join(__dirname, 'publishing', 'npm'),
96
98
  entrypoint: 'publish.sh',
97
- environment: {
99
+ environment: (0, util_1.noUndefined)({
98
100
  FOR_REAL: forReal,
99
101
  NPM_TOKEN_SECRET: props.npmTokenSecret.secretArn,
100
102
  DISTTAG: props.distTag || '',
101
103
  ACCESS: access,
102
- },
104
+ SSM_PREFIX: props.ssmPrefix,
105
+ }),
103
106
  });
104
107
  if (shellable.role) {
105
108
  permissions.grantSecretRead(props.npmTokenSecret, shellable.role);
106
109
  }
110
+ grantSsmPrefix(shellable.role, props.ssmPrefix);
107
111
  this.role = shellable.role;
108
112
  this.project = shellable.project;
109
113
  }
@@ -136,6 +140,9 @@ class PublishToNuGetProject extends constructs_1.Construct {
136
140
  environment.NUGET_SECRET_REGION = aws_cdk_lib_1.Stack.of(this).region;
137
141
  }
138
142
  environment.NUGET_SECRET_ID = props.nugetApiKeySecret.secretArn;
143
+ if (props.ssmPrefix) {
144
+ environment.SSM_PREFIX = props.ssmPrefix;
145
+ }
139
146
  const shellable = new shellable_1.Shellable(this, 'Default', {
140
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-bullseye-slim-node18')),
141
148
  scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),
@@ -157,6 +164,7 @@ class PublishToNuGetProject extends constructs_1.Construct {
157
164
  props.codeSign.grantDecrypt(shellable.role);
158
165
  }
159
166
  }
167
+ grantSsmPrefix(shellable.role, props.ssmPrefix);
160
168
  this.role = shellable.role;
161
169
  this.project = shellable.project;
162
170
  }
@@ -181,7 +189,7 @@ class PublishDocsToGitHubProject extends constructs_1.Construct {
181
189
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
182
190
  scriptDirectory: path.join(__dirname, 'publishing', 'docs'),
183
191
  entrypoint: 'publish.sh',
184
- environment: {
192
+ environment: (0, util_1.noUndefined)({
185
193
  // Must be SSH because we use an SSH key to authenticate
186
194
  GITHUB_REPO: props.githubRepo.repositoryUrlSsh,
187
195
  GITHUB_PAGES_BRANCH: props.branch || 'gh-pages',
@@ -190,11 +198,13 @@ class PublishDocsToGitHubProject extends constructs_1.Construct {
190
198
  COMMIT_USERNAME: props.githubRepo.commitUsername,
191
199
  COMMIT_EMAIL: props.githubRepo.commitEmail,
192
200
  BUILD_MANIFEST: props.buildManifestFileName || './build.json',
193
- },
201
+ SSM_PREFIX: props.ssmPrefix,
202
+ }),
194
203
  });
195
204
  if (shellable.role) {
196
205
  permissions.grantSecretRead(props.githubRepo.sshKeySecret, shellable.role);
197
206
  }
207
+ grantSsmPrefix(shellable.role, props.ssmPrefix);
198
208
  this.role = shellable.role;
199
209
  this.project = shellable.project;
200
210
  }
@@ -232,6 +242,7 @@ class PublishToGitHub extends constructs_1.Construct {
232
242
  // Transmit the names of the secondary sources to the shell script (for easier iteration)
233
243
  SECONDARY_SOURCE_NAMES: props.additionalInputArtifacts ? props.additionalInputArtifacts.map(a => a.artifactName).join(' ') : undefined,
234
244
  SIGN_ADDITIONAL_ARTIFACTS: props.additionalInputArtifacts && props.signAdditionalArtifacts !== false ? 'true' : undefined,
245
+ SSM_PREFIX: props.ssmPrefix,
235
246
  }),
236
247
  environmentSecrets: {
237
248
  GITHUB_TOKEN: props.githubRepo.tokenSecretArn,
@@ -241,6 +252,7 @@ class PublishToGitHub extends constructs_1.Construct {
241
252
  if (shellable.role) {
242
253
  props.signingKey.grantRead(shellable.role);
243
254
  }
255
+ grantSsmPrefix(shellable.role, props.ssmPrefix);
244
256
  this.role = shellable.role;
245
257
  this.project = shellable.project;
246
258
  }
@@ -263,11 +275,11 @@ class PublishToS3 extends constructs_1.Construct {
263
275
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
264
276
  scriptDirectory: path.join(__dirname, 'publishing', 's3'),
265
277
  entrypoint: 'publish.sh',
266
- environment: {
278
+ environment: (0, util_1.noUndefined)({
267
279
  BUCKET_URL: `s3://${props.bucket.bucketName}`,
268
280
  CHANGELOG: props.public ? 'true' : 'false',
269
281
  FOR_REAL: forReal,
270
- },
282
+ }),
271
283
  });
272
284
  // Allow script to write to bucket
273
285
  if (shellable.role) {
@@ -294,14 +306,16 @@ class PublishToPyPi extends constructs_1.Construct {
294
306
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
295
307
  scriptDirectory: path.join(__dirname, 'publishing', 'pypi'),
296
308
  entrypoint: 'publish.sh',
297
- environment: {
309
+ environment: (0, util_1.noUndefined)({
298
310
  FOR_REAL: forReal,
299
311
  PYPI_CREDENTIALS_SECRET_ID: props.loginSecret.secretArn,
300
- },
312
+ SSM_PREFIX: props.ssmPrefix,
313
+ }),
301
314
  });
302
315
  if (shellable.role) {
303
316
  permissions.grantSecretRead(props.loginSecret, shellable.role);
304
317
  }
318
+ grantSsmPrefix(shellable.role, props.ssmPrefix);
305
319
  this.role = shellable.role;
306
320
  this.project = shellable.project;
307
321
  }
@@ -327,7 +341,7 @@ class PublishToGolang extends constructs_1.Construct {
327
341
  platform: new shellable_1.LinuxPlatform(aws_cdk_lib_1.aws_codebuild.LinuxBuildImage.STANDARD_7_0),
328
342
  scriptDirectory: path.join(__dirname, 'publishing', 'golang'),
329
343
  entrypoint: 'publish.sh',
330
- environment: {
344
+ environment: (0, util_1.noUndefined)({
331
345
  DRYRUN: dryRun ? 'true' : undefined,
332
346
  GITHUB_TOKEN_SECRET: props.githubTokenSecret.secretArn,
333
347
  VERSION: props.version,
@@ -335,11 +349,13 @@ class PublishToGolang extends constructs_1.Construct {
335
349
  GIT_USER_NAME: props.gitUserName,
336
350
  GIT_USER_EMAIL: props.gitUserEmail,
337
351
  GIT_COMMIT_MESSAGE: props.gitCommitMessage,
338
- },
352
+ SSM_PREFIX: props.ssmPrefix,
353
+ }),
339
354
  });
340
355
  if (shellable.role) {
341
356
  permissions.grantSecretRead(props.githubTokenSecret, shellable.role);
342
357
  }
358
+ grantSsmPrefix(shellable.role, props.ssmPrefix);
343
359
  this.role = shellable.role;
344
360
  this.project = shellable.project;
345
361
  }
@@ -353,4 +369,22 @@ class PublishToGolang extends constructs_1.Construct {
353
369
  }
354
370
  }
355
371
  exports.PublishToGolang = PublishToGolang;
356
- //# 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/**\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-bullseye-slim-node18')),\n      scriptDirectory: path.join(__dirname, 'publishing', 'maven'),\n      entrypoint: 'publish.sh',\n      environment: {\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      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.mavenLoginSecret, shellable.role);\n      props.signingKey.grantRead(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 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/**\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: {\n        FOR_REAL: forReal,\n        NPM_TOKEN_SECRET: props.npmTokenSecret.secretArn,\n        DISTTAG: props.distTag || '',\n        ACCESS: access,\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.npmTokenSecret, 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 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/**\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\n    const shellable = new Shellable(this, 'Default', {\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry('public.ecr.aws/jsii/superchain:1-bullseye-slim-node18')),\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    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/**\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: {\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      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubRepo.sshKeySecret, 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 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\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      }),\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    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: {\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\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: {\n        FOR_REAL: forReal,\n        PYPI_CREDENTIALS_SECRET_ID: props.loginSecret.secretArn,\n      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.loginSecret, 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\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/**\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: {\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      },\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubTokenSecret, 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"]}
372
+ function grantSsmPrefix(role, ssmPrefix) {
373
+ if (ssmPrefix) {
374
+ if (!ssmPrefix.startsWith('/')) {
375
+ throw new Error(`SSM prefix should start with '/', got: ${ssmPrefix}`);
376
+ }
377
+ if (ssmPrefix.endsWith('/')) {
378
+ throw new Error(`SSM prefix must not end with '/', got: ${ssmPrefix}`);
379
+ }
380
+ role === null || role === void 0 ? void 0 : role.addToPrincipalPolicy(new aws_cdk_lib_1.aws_iam.PolicyStatement({
381
+ actions: ['ssm:PutParameter', 'ssm:GetParameter'],
382
+ resources: [aws_cdk_lib_1.Stack.of(role).formatArn({
383
+ service: 'ssm',
384
+ resource: 'parameter',
385
+ resourceName: `${ssmPrefix.slice(1)}/*`,
386
+ })],
387
+ }));
388
+ }
389
+ }
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-bullseye-slim-node18')),\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-bullseye-slim-node18')),\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}"]}
package/lib/util.d.ts CHANGED
@@ -19,8 +19,8 @@ export declare function renderEnvironmentVariables(env?: {
19
19
  }, type?: cbuild.BuildEnvironmentVariableType): {
20
20
  [key: string]: cbuild.BuildEnvironmentVariable;
21
21
  } | undefined;
22
- export declare function noUndefined<T>(xs: Partial<T>): {
23
- [k in keyof T]: T[k];
22
+ export declare function noUndefined<T extends object>(xs: T): {
23
+ [k in keyof T]: NonNullable<T[k]>;
24
24
  };
25
25
  export declare function mapValues<T, U>(xs: {
26
26
  [key: string]: T;
package/lib/util.js CHANGED
@@ -102,4 +102,4 @@ function flatMap(xs, fn) {
102
102
  return ret;
103
103
  }
104
104
  exports.flatMap = flatMap;
105
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBaUM7QUFDakMsdUNBQXlCO0FBQ3pCLDJDQUE2QjtBQUk3Qjs7OztHQUlHO0FBQ0gsU0FBZ0IsaUJBQWlCLENBQUMsS0FBYSxFQUFFLFdBQW9CO0lBQ25FLGlEQUFpRDtJQUNqRCxJQUFJLFdBQVcsS0FBSyxTQUFTLEVBQUU7UUFDN0IsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUM3QyxDQUFDO0FBUEQsOENBT0M7QUFFRDs7Ozs7OztHQU9HO0FBQ0gsU0FBZ0IsbUJBQW1CLENBQUMsU0FBaUI7SUFDbkQsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN6QyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkQsTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNwQyxJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRTtRQUN0QixLQUFLLE1BQU0sSUFBSSxJQUFJLEVBQUUsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDOUQ7S0FDRjtTQUFNO1FBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7S0FDekM7SUFDRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDL0IsQ0FBQztBQVpELGtEQVlDO0FBRUQsU0FBZ0IsMEJBQTBCLENBQUMsR0FBMkMsRUFBRSxJQUEwQztJQUNoSSxJQUFJLENBQUMsR0FBRyxFQUFFO1FBQ1IsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxNQUFNLEdBQUcsR0FBdUQsRUFBRyxDQUFDO0lBQ3BFLEtBQUssTUFBTSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBQzlDLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRTtZQUN2QixHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUM7U0FDNUI7S0FDRjtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQVpELGdFQVlDO0FBRUQsU0FBZ0IsV0FBVyxDQUFJLEVBQWM7SUFDM0MsTUFBTSxHQUFHLEdBQVEsRUFBRSxDQUFDO0lBQ3BCLEtBQUssTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1FBQ3ZDLElBQUksQ0FBQyxLQUFLLFNBQVMsRUFBRTtZQUNuQixHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQ1o7S0FDRjtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQVJELGtDQVFDO0FBRUQsU0FBZ0IsU0FBUyxDQUFPLEVBQXNCLEVBQUUsRUFBZTtJQUNyRSxNQUFNLEdBQUcsR0FBdUIsRUFBRSxDQUFDO0lBQ25DLEtBQUssTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1FBQ3ZDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDaEI7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUFORCw4QkFNQztBQUVELFNBQWdCLE9BQU8sQ0FBTyxFQUFPLEVBQUUsRUFBaUI7SUFDdEQsTUFBTSxHQUFHLEdBQUcsSUFBSSxLQUFLLEVBQUssQ0FBQztJQUMzQixLQUFLLE1BQU0sQ0FBQyxJQUFJLEVBQUUsRUFBRTtRQUNsQixHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDcEI7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUFORCwwQkFNQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGNyeXB0byBmcm9tICdjcnlwdG8nO1xuaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IGF3c19jb2RlYnVpbGQgYXMgY2J1aWxkIH0gZnJvbSAnYXdzLWNkay1saWInO1xuXG5cbi8qKlxuICogRGV0ZXJtaW5lcyB0aGUgXCJSdW5PcmRlclwiIHByb3BlcnR5IGZvciB0aGUgbmV4dCBhY3Rpb24gdG8gYmUgYWRkZWQgdG8gYSBzdGFnZS5cbiAqIEBwYXJhbSBpbmRleCBJbmRleCBvZiBuZXcgYWN0aW9uXG4gKiBAcGFyYW0gY29uY3VycmVuY3kgVGhlIGNvbmN1cnJlbmN5IGxpbWl0XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZXRlcm1pbmVSdW5PcmRlcihpbmRleDogbnVtYmVyLCBjb25jdXJyZW5jeT86IG51bWJlcik6IG51bWJlciB8IHVuZGVmaW5lZCB7XG4gIC8vIG5vIHJ1bk9yZGVyIGlmIHdlIGFyZSBhdCB1bmxpbWl0ZWQgY29uY3VycmVuY3lcbiAgaWYgKGNvbmN1cnJlbmN5ID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgcmV0dXJuIE1hdGguZmxvb3IoaW5kZXggLyBjb25jdXJyZW5jeSkgKyAxO1xufVxuXG4vKipcbiAqIEhhc2hlcyB0aGUgY29udGVudHMgb2YgYSBmaWxlIG9yIGRpcmVjdG9yeS4gSWYgdGhlIGFyZ3VtZW50IGlzIGEgZGlyZWN0b3J5LFxuICogaXQgaXMgYXNzdW1lZCBub3QgdG8gY29udGFpbiBzeW1saW5rcyB0aGF0IHdvdWxkIHJlc3VsdCBpbiBhIGN5Y2xpYyB0cmVlLlxuICpcbiAqIEBwYXJhbSBmaWxlT3JEaXIgdGhlIHBhdGggdG8gdGhlIGZpbGUgb3IgZGlyZWN0b3J5IHRoYXQgc2hvdWxkIGJlIGhhc2hlZC5cbiAqXG4gKiBAcmV0dXJucyBhIFNIQTI1NiBoYXNoLCBiYXNlLTY0IGVuY29kZWQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBoYXNoRmlsZU9yRGlyZWN0b3J5KGZpbGVPckRpcjogc3RyaW5nKTogc3RyaW5nIHtcbiAgY29uc3QgaGFzaCA9IGNyeXB0by5jcmVhdGVIYXNoKCdTSEEyNTYnKTtcbiAgaGFzaC51cGRhdGUocGF0aC5iYXNlbmFtZShmaWxlT3JEaXIpKS51cGRhdGUoJ1xcMCcpO1xuICBjb25zdCBzdGF0ID0gZnMuc3RhdFN5bmMoZmlsZU9yRGlyKTtcbiAgaWYgKHN0YXQuaXNEaXJlY3RvcnkoKSkge1xuICAgIGZvciAoY29uc3QgaXRlbSBvZiBmcy5yZWFkZGlyU3luYyhmaWxlT3JEaXIpLnNvcnQoKSkge1xuICAgICAgaGFzaC51cGRhdGUoaGFzaEZpbGVPckRpcmVjdG9yeShwYXRoLmpvaW4oZmlsZU9yRGlyLCBpdGVtKSkpO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICBoYXNoLnVwZGF0ZShmcy5yZWFkRmlsZVN5bmMoZmlsZU9yRGlyKSk7XG4gIH1cbiAgcmV0dXJuIGhhc2guZGlnZXN0KCdiYXNlNjQnKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlbmRlckVudmlyb25tZW50VmFyaWFibGVzKGVudj86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIHwgdW5kZWZpbmVkIH0sIHR5cGU/OiBjYnVpbGQuQnVpbGRFbnZpcm9ubWVudFZhcmlhYmxlVHlwZSkge1xuICBpZiAoIWVudikge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBvdXQ6IHsgW2tleTogc3RyaW5nXTogY2J1aWxkLkJ1aWxkRW52aXJvbm1lbnRWYXJpYWJsZSB9ID0geyB9O1xuICBmb3IgKGNvbnN0IFtrZXksIHZhbHVlXSBvZiBPYmplY3QuZW50cmllcyhlbnYpKSB7XG4gICAgaWYgKHZhbHVlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIG91dFtrZXldID0geyB2YWx1ZSwgdHlwZSB9O1xuICAgIH1cbiAgfVxuICByZXR1cm4gb3V0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbm9VbmRlZmluZWQ8VD4oeHM6IFBhcnRpYWw8VD4pOiB7W2sgaW4ga2V5b2YgVF06IFRba119IHtcbiAgY29uc3QgcmV0OiBhbnkgPSB7fTtcbiAgZm9yIChjb25zdCBbaywgdl0gb2YgT2JqZWN0LmVudHJpZXMoeHMpKSB7XG4gICAgaWYgKHYgIT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0W2tdID0gdjtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHJldDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1hcFZhbHVlczxULCBVPih4czoge1trZXk6IHN0cmluZ106IFR9LCBmbjogKHg6IFQpID0+IFUpOiB7W2tleTogc3RyaW5nXTogVX0ge1xuICBjb25zdCByZXQ6IHtba2V5OiBzdHJpbmddOiBVfSA9IHt9O1xuICBmb3IgKGNvbnN0IFtrLCB2XSBvZiBPYmplY3QuZW50cmllcyh4cykpIHtcbiAgICByZXRba10gPSBmbih2KTtcbiAgfVxuICByZXR1cm4gcmV0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZmxhdE1hcDxULCBVPih4czogVFtdLCBmbjogKHg6IFQpID0+IFVbXSk6IFVbXSB7XG4gIGNvbnN0IHJldCA9IG5ldyBBcnJheTxVPigpO1xuICBmb3IgKGNvbnN0IHggb2YgeHMpIHtcbiAgICByZXQucHVzaCguLi5mbih4KSk7XG4gIH1cbiAgcmV0dXJuIHJldDtcbn1cbiJdfQ==
105
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBaUM7QUFDakMsdUNBQXlCO0FBQ3pCLDJDQUE2QjtBQUk3Qjs7OztHQUlHO0FBQ0gsU0FBZ0IsaUJBQWlCLENBQUMsS0FBYSxFQUFFLFdBQW9CO0lBQ25FLGlEQUFpRDtJQUNqRCxJQUFJLFdBQVcsS0FBSyxTQUFTLEVBQUU7UUFDN0IsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUM3QyxDQUFDO0FBUEQsOENBT0M7QUFFRDs7Ozs7OztHQU9HO0FBQ0gsU0FBZ0IsbUJBQW1CLENBQUMsU0FBaUI7SUFDbkQsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN6QyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkQsTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNwQyxJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRTtRQUN0QixLQUFLLE1BQU0sSUFBSSxJQUFJLEVBQUUsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDOUQ7S0FDRjtTQUFNO1FBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7S0FDekM7SUFDRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDL0IsQ0FBQztBQVpELGtEQVlDO0FBRUQsU0FBZ0IsMEJBQTBCLENBQUMsR0FBMkMsRUFBRSxJQUEwQztJQUNoSSxJQUFJLENBQUMsR0FBRyxFQUFFO1FBQ1IsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxNQUFNLEdBQUcsR0FBdUQsRUFBRyxDQUFDO0lBQ3BFLEtBQUssTUFBTSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBQzlDLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRTtZQUN2QixHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUM7U0FDNUI7S0FDRjtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQVpELGdFQVlDO0FBRUQsU0FBZ0IsV0FBVyxDQUFtQixFQUFLO0lBQ2pELE1BQU0sR0FBRyxHQUFRLEVBQUUsQ0FBQztJQUNwQixLQUFLLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUN2QyxJQUFJLENBQUMsS0FBSyxTQUFTLEVBQUU7WUFDbkIsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNaO0tBQ0Y7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUFSRCxrQ0FRQztBQUVELFNBQWdCLFNBQVMsQ0FBTyxFQUFzQixFQUFFLEVBQWU7SUFDckUsTUFBTSxHQUFHLEdBQXVCLEVBQUUsQ0FBQztJQUNuQyxLQUFLLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUN2QyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ2hCO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBTkQsOEJBTUM7QUFFRCxTQUFnQixPQUFPLENBQU8sRUFBTyxFQUFFLEVBQWlCO0lBQ3RELE1BQU0sR0FBRyxHQUFHLElBQUksS0FBSyxFQUFLLENBQUM7SUFDM0IsS0FBSyxNQUFNLENBQUMsSUFBSSxFQUFFLEVBQUU7UUFDbEIsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ3BCO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBTkQsMEJBTUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjcnlwdG8gZnJvbSAnY3J5cHRvJztcbmltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBhd3NfY29kZWJ1aWxkIGFzIGNidWlsZCB9IGZyb20gJ2F3cy1jZGstbGliJztcblxuXG4vKipcbiAqIERldGVybWluZXMgdGhlIFwiUnVuT3JkZXJcIiBwcm9wZXJ0eSBmb3IgdGhlIG5leHQgYWN0aW9uIHRvIGJlIGFkZGVkIHRvIGEgc3RhZ2UuXG4gKiBAcGFyYW0gaW5kZXggSW5kZXggb2YgbmV3IGFjdGlvblxuICogQHBhcmFtIGNvbmN1cnJlbmN5IFRoZSBjb25jdXJyZW5jeSBsaW1pdFxuICovXG5leHBvcnQgZnVuY3Rpb24gZGV0ZXJtaW5lUnVuT3JkZXIoaW5kZXg6IG51bWJlciwgY29uY3VycmVuY3k/OiBudW1iZXIpOiBudW1iZXIgfCB1bmRlZmluZWQge1xuICAvLyBubyBydW5PcmRlciBpZiB3ZSBhcmUgYXQgdW5saW1pdGVkIGNvbmN1cnJlbmN5XG4gIGlmIChjb25jdXJyZW5jeSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHJldHVybiBNYXRoLmZsb29yKGluZGV4IC8gY29uY3VycmVuY3kpICsgMTtcbn1cblxuLyoqXG4gKiBIYXNoZXMgdGhlIGNvbnRlbnRzIG9mIGEgZmlsZSBvciBkaXJlY3RvcnkuIElmIHRoZSBhcmd1bWVudCBpcyBhIGRpcmVjdG9yeSxcbiAqIGl0IGlzIGFzc3VtZWQgbm90IHRvIGNvbnRhaW4gc3ltbGlua3MgdGhhdCB3b3VsZCByZXN1bHQgaW4gYSBjeWNsaWMgdHJlZS5cbiAqXG4gKiBAcGFyYW0gZmlsZU9yRGlyIHRoZSBwYXRoIHRvIHRoZSBmaWxlIG9yIGRpcmVjdG9yeSB0aGF0IHNob3VsZCBiZSBoYXNoZWQuXG4gKlxuICogQHJldHVybnMgYSBTSEEyNTYgaGFzaCwgYmFzZS02NCBlbmNvZGVkLlxuICovXG5leHBvcnQgZnVuY3Rpb24gaGFzaEZpbGVPckRpcmVjdG9yeShmaWxlT3JEaXI6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IGhhc2ggPSBjcnlwdG8uY3JlYXRlSGFzaCgnU0hBMjU2Jyk7XG4gIGhhc2gudXBkYXRlKHBhdGguYmFzZW5hbWUoZmlsZU9yRGlyKSkudXBkYXRlKCdcXDAnKTtcbiAgY29uc3Qgc3RhdCA9IGZzLnN0YXRTeW5jKGZpbGVPckRpcik7XG4gIGlmIChzdGF0LmlzRGlyZWN0b3J5KCkpIHtcbiAgICBmb3IgKGNvbnN0IGl0ZW0gb2YgZnMucmVhZGRpclN5bmMoZmlsZU9yRGlyKS5zb3J0KCkpIHtcbiAgICAgIGhhc2gudXBkYXRlKGhhc2hGaWxlT3JEaXJlY3RvcnkocGF0aC5qb2luKGZpbGVPckRpciwgaXRlbSkpKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgaGFzaC51cGRhdGUoZnMucmVhZEZpbGVTeW5jKGZpbGVPckRpcikpO1xuICB9XG4gIHJldHVybiBoYXNoLmRpZ2VzdCgnYmFzZTY0Jyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJFbnZpcm9ubWVudFZhcmlhYmxlcyhlbnY/OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB8IHVuZGVmaW5lZCB9LCB0eXBlPzogY2J1aWxkLkJ1aWxkRW52aXJvbm1lbnRWYXJpYWJsZVR5cGUpIHtcbiAgaWYgKCFlbnYpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3Qgb3V0OiB7IFtrZXk6IHN0cmluZ106IGNidWlsZC5CdWlsZEVudmlyb25tZW50VmFyaWFibGUgfSA9IHsgfTtcbiAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoZW52KSkge1xuICAgIGlmICh2YWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBvdXRba2V5XSA9IHsgdmFsdWUsIHR5cGUgfTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIG91dDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG5vVW5kZWZpbmVkPFQgZXh0ZW5kcyBvYmplY3Q+KHhzOiBUKToge1trIGluIGtleW9mIFRdOiBOb25OdWxsYWJsZTxUW2tdPn0ge1xuICBjb25zdCByZXQ6IGFueSA9IHt9O1xuICBmb3IgKGNvbnN0IFtrLCB2XSBvZiBPYmplY3QuZW50cmllcyh4cykpIHtcbiAgICBpZiAodiAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXRba10gPSB2O1xuICAgIH1cbiAgfVxuICByZXR1cm4gcmV0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwVmFsdWVzPFQsIFU+KHhzOiB7W2tleTogc3RyaW5nXTogVH0sIGZuOiAoeDogVCkgPT4gVSk6IHtba2V5OiBzdHJpbmddOiBVfSB7XG4gIGNvbnN0IHJldDoge1trZXk6IHN0cmluZ106IFV9ID0ge307XG4gIGZvciAoY29uc3QgW2ssIHZdIG9mIE9iamVjdC5lbnRyaWVzKHhzKSkge1xuICAgIHJldFtrXSA9IGZuKHYpO1xuICB9XG4gIHJldHVybiByZXQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmbGF0TWFwPFQsIFU+KHhzOiBUW10sIGZuOiAoeDogVCkgPT4gVVtdKTogVVtdIHtcbiAgY29uc3QgcmV0ID0gbmV3IEFycmF5PFU+KCk7XG4gIGZvciAoY29uc3QgeCBvZiB4cykge1xuICAgIHJldC5wdXNoKC4uLmZuKHgpKTtcbiAgfVxuICByZXR1cm4gcmV0O1xufVxuIl19
package/package.json CHANGED
@@ -97,7 +97,7 @@
97
97
  "publishConfig": {
98
98
  "access": "public"
99
99
  },
100
- "version": "14.13.37",
100
+ "version": "14.14.0",
101
101
  "jest": {
102
102
  "coverageProvider": "v8",
103
103
  "testMatch": [