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 +7 -6
- package/lib/publishing/docs/publish.sh +1 -0
- package/lib/publishing/docs/update-ssm.sh +24 -0
- package/lib/publishing/github/publish.sh +2 -0
- package/lib/publishing/github/update-ssm.sh +24 -0
- package/lib/publishing/golang/publish.sh +3 -1
- package/lib/publishing/golang/update-ssm.sh +24 -0
- package/lib/publishing/maven/publish.sh +2 -0
- package/lib/publishing/maven/update-ssm.sh +24 -0
- package/lib/publishing/npm/publish.sh +1 -0
- package/lib/publishing/npm/update-ssm.sh +24 -0
- package/lib/publishing/nuget/publish.sh +2 -0
- package/lib/publishing/nuget/update-ssm.sh +24 -0
- package/lib/publishing/pypi/publish.sh +2 -0
- package/lib/publishing/pypi/update-ssm.sh +24 -0
- package/lib/publishing/s3/publish.sh +6 -4
- package/lib/publishing/s3/update-ssm.sh +24 -0
- package/lib/publishing.d.ts +56 -0
- package/lib/publishing.js +47 -13
- package/lib/util.d.ts +2 -2
- package/lib/util.js +1 -1
- package/package.json +1 -1
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).
|
78
|
-
validate your local changes. To do this,
|
77
|
+
the package [aws-delivlib-sample](https://github.com/awslabs/aws-delivlib-sample).
|
79
78
|
|
80
|
-
|
81
|
-
|
82
|
-
|
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
|
-
|
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
|
|
@@ -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
|
@@ -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
|
@@ -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
|
@@ -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
|
@@ -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
|
@@ -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
|
@@ -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
|
package/lib/publishing.d.ts
CHANGED
@@ -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:
|
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,
|
105
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBaUM7QUFDakMsdUNBQXlCO0FBQ3pCLDJDQUE2QjtBQUk3Qjs7OztHQUlHO0FBQ0gsU0FBZ0IsaUJBQWlCLENBQUMsS0FBYSxFQUFFLFdBQW9CO0lBQ25FLGlEQUFpRDtJQUNqRCxJQUFJLFdBQVcsS0FBSyxTQUFTLEVBQUU7UUFDN0IsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUM3QyxDQUFDO0FBUEQsOENBT0M7QUFFRDs7Ozs7OztHQU9HO0FBQ0gsU0FBZ0IsbUJBQW1CLENBQUMsU0FBaUI7SUFDbkQsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN6QyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkQsTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNwQyxJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRTtRQUN0QixLQUFLLE1BQU0sSUFBSSxJQUFJLEVBQUUsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDOUQ7S0FDRjtTQUFNO1FBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7S0FDekM7SUFDRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDL0IsQ0FBQztBQVpELGtEQVlDO0FBRUQsU0FBZ0IsMEJBQTBCLENBQUMsR0FBMkMsRUFBRSxJQUEwQztJQUNoSSxJQUFJLENBQUMsR0FBRyxFQUFFO1FBQ1IsT0FBTyxTQUFTLENBQUM7S0FDbEI7SUFFRCxNQUFNLEdBQUcsR0FBdUQsRUFBRyxDQUFDO0lBQ3BFLEtBQUssTUFBTSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBQzlDLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRTtZQUN2QixHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUM7U0FDNUI7S0FDRjtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQVpELGdFQVlDO0FBRUQsU0FBZ0IsV0FBVyxDQUFtQixFQUFLO0lBQ2pELE1BQU0sR0FBRyxHQUFRLEVBQUUsQ0FBQztJQUNwQixLQUFLLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUN2QyxJQUFJLENBQUMsS0FBSyxTQUFTLEVBQUU7WUFDbkIsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNaO0tBQ0Y7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUFSRCxrQ0FRQztBQUVELFNBQWdCLFNBQVMsQ0FBTyxFQUFzQixFQUFFLEVBQWU7SUFDckUsTUFBTSxHQUFHLEdBQXVCLEVBQUUsQ0FBQztJQUNuQyxLQUFLLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRTtRQUN2QyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ2hCO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBTkQsOEJBTUM7QUFFRCxTQUFnQixPQUFPLENBQU8sRUFBTyxFQUFFLEVBQWlCO0lBQ3RELE1BQU0sR0FBRyxHQUFHLElBQUksS0FBSyxFQUFLLENBQUM7SUFDM0IsS0FBSyxNQUFNLENBQUMsSUFBSSxFQUFFLEVBQUU7UUFDbEIsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBQ3BCO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBTkQsMEJBTUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjcnlwdG8gZnJvbSAnY3J5cHRvJztcbmltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBhd3NfY29kZWJ1aWxkIGFzIGNidWlsZCB9IGZyb20gJ2F3cy1jZGstbGliJztcblxuXG4vKipcbiAqIERldGVybWluZXMgdGhlIFwiUnVuT3JkZXJcIiBwcm9wZXJ0eSBmb3IgdGhlIG5leHQgYWN0aW9uIHRvIGJlIGFkZGVkIHRvIGEgc3RhZ2UuXG4gKiBAcGFyYW0gaW5kZXggSW5kZXggb2YgbmV3IGFjdGlvblxuICogQHBhcmFtIGNvbmN1cnJlbmN5IFRoZSBjb25jdXJyZW5jeSBsaW1pdFxuICovXG5leHBvcnQgZnVuY3Rpb24gZGV0ZXJtaW5lUnVuT3JkZXIoaW5kZXg6IG51bWJlciwgY29uY3VycmVuY3k/OiBudW1iZXIpOiBudW1iZXIgfCB1bmRlZmluZWQge1xuICAvLyBubyBydW5PcmRlciBpZiB3ZSBhcmUgYXQgdW5saW1pdGVkIGNvbmN1cnJlbmN5XG4gIGlmIChjb25jdXJyZW5jeSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHJldHVybiBNYXRoLmZsb29yKGluZGV4IC8gY29uY3VycmVuY3kpICsgMTtcbn1cblxuLyoqXG4gKiBIYXNoZXMgdGhlIGNvbnRlbnRzIG9mIGEgZmlsZSBvciBkaXJlY3RvcnkuIElmIHRoZSBhcmd1bWVudCBpcyBhIGRpcmVjdG9yeSxcbiAqIGl0IGlzIGFzc3VtZWQgbm90IHRvIGNvbnRhaW4gc3ltbGlua3MgdGhhdCB3b3VsZCByZXN1bHQgaW4gYSBjeWNsaWMgdHJlZS5cbiAqXG4gKiBAcGFyYW0gZmlsZU9yRGlyIHRoZSBwYXRoIHRvIHRoZSBmaWxlIG9yIGRpcmVjdG9yeSB0aGF0IHNob3VsZCBiZSBoYXNoZWQuXG4gKlxuICogQHJldHVybnMgYSBTSEEyNTYgaGFzaCwgYmFzZS02NCBlbmNvZGVkLlxuICovXG5leHBvcnQgZnVuY3Rpb24gaGFzaEZpbGVPckRpcmVjdG9yeShmaWxlT3JEaXI6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IGhhc2ggPSBjcnlwdG8uY3JlYXRlSGFzaCgnU0hBMjU2Jyk7XG4gIGhhc2gudXBkYXRlKHBhdGguYmFzZW5hbWUoZmlsZU9yRGlyKSkudXBkYXRlKCdcXDAnKTtcbiAgY29uc3Qgc3RhdCA9IGZzLnN0YXRTeW5jKGZpbGVPckRpcik7XG4gIGlmIChzdGF0LmlzRGlyZWN0b3J5KCkpIHtcbiAgICBmb3IgKGNvbnN0IGl0ZW0gb2YgZnMucmVhZGRpclN5bmMoZmlsZU9yRGlyKS5zb3J0KCkpIHtcbiAgICAgIGhhc2gudXBkYXRlKGhhc2hGaWxlT3JEaXJlY3RvcnkocGF0aC5qb2luKGZpbGVPckRpciwgaXRlbSkpKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgaGFzaC51cGRhdGUoZnMucmVhZEZpbGVTeW5jKGZpbGVPckRpcikpO1xuICB9XG4gIHJldHVybiBoYXNoLmRpZ2VzdCgnYmFzZTY0Jyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJFbnZpcm9ubWVudFZhcmlhYmxlcyhlbnY/OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB8IHVuZGVmaW5lZCB9LCB0eXBlPzogY2J1aWxkLkJ1aWxkRW52aXJvbm1lbnRWYXJpYWJsZVR5cGUpIHtcbiAgaWYgKCFlbnYpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3Qgb3V0OiB7IFtrZXk6IHN0cmluZ106IGNidWlsZC5CdWlsZEVudmlyb25tZW50VmFyaWFibGUgfSA9IHsgfTtcbiAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoZW52KSkge1xuICAgIGlmICh2YWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBvdXRba2V5XSA9IHsgdmFsdWUsIHR5cGUgfTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIG91dDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG5vVW5kZWZpbmVkPFQgZXh0ZW5kcyBvYmplY3Q+KHhzOiBUKToge1trIGluIGtleW9mIFRdOiBOb25OdWxsYWJsZTxUW2tdPn0ge1xuICBjb25zdCByZXQ6IGFueSA9IHt9O1xuICBmb3IgKGNvbnN0IFtrLCB2XSBvZiBPYmplY3QuZW50cmllcyh4cykpIHtcbiAgICBpZiAodiAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXRba10gPSB2O1xuICAgIH1cbiAgfVxuICByZXR1cm4gcmV0O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwVmFsdWVzPFQsIFU+KHhzOiB7W2tleTogc3RyaW5nXTogVH0sIGZuOiAoeDogVCkgPT4gVSk6IHtba2V5OiBzdHJpbmddOiBVfSB7XG4gIGNvbnN0IHJldDoge1trZXk6IHN0cmluZ106IFV9ID0ge307XG4gIGZvciAoY29uc3QgW2ssIHZdIG9mIE9iamVjdC5lbnRyaWVzKHhzKSkge1xuICAgIHJldFtrXSA9IGZuKHYpO1xuICB9XG4gIHJldHVybiByZXQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmbGF0TWFwPFQsIFU+KHhzOiBUW10sIGZuOiAoeDogVCkgPT4gVVtdKTogVVtdIHtcbiAgY29uc3QgcmV0ID0gbmV3IEFycmF5PFU+KCk7XG4gIGZvciAoY29uc3QgeCBvZiB4cykge1xuICAgIHJldC5wdXNoKC4uLmZuKHgpKTtcbiAgfVxuICByZXR1cm4gcmV0O1xufVxuIl19
|