aws-delivlib 15.0.4 → 15.0.5

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.
@@ -52,7 +52,7 @@
52
52
  "@types/changelog-parser@^2.8.1": "https://registry.yarnpkg.com/@types/changelog-parser/-/changelog-parser-2.8.4.tgz#45d70417e742ac3bc6bef3786aa453e1f1d63ecc",
53
53
  "@types/jsonwebtoken@^9.0.0": "https://registry.yarnpkg.com/@types/jsonwebtoken/-/jsonwebtoken-9.0.9.tgz#a4c3a446c0ebaaf467a58398382616f416345fb3",
54
54
  "@types/ms@*": "https://registry.yarnpkg.com/@types/ms/-/ms-2.1.0.tgz#052aa67a48eccc4309d7f0191b7e41434b90bb78",
55
- "@types/node@*": "https://registry.yarnpkg.com/@types/node/-/node-22.15.26.tgz#01ea4427edeaf205cd18ebdb93db2708d5301f05",
55
+ "@types/node@*": "https://registry.yarnpkg.com/@types/node/-/node-22.15.27.tgz#b99cd64129c4c85a69edca903af9b3aa72c3b4f7",
56
56
  "@types/node@^14": "https://registry.yarnpkg.com/@types/node/-/node-14.18.63.tgz#1788fa8da838dbb5f9ea994b834278205db6ca2b",
57
57
  "aggregate-error@^3.1.0": "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a",
58
58
  "before-after-hook@^2.2.0": "https://registry.yarnpkg.com/before-after-hook/-/before-after-hook-2.2.3.tgz#c51e809c81a4e354084422b9b26bad88249c517c",
@@ -8,7 +8,7 @@ This package contains type definitions for node (https://nodejs.org/).
8
8
  Files were exported from https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node.
9
9
 
10
10
  ### Additional Details
11
- * Last updated: Thu, 29 May 2025 23:02:21 GMT
11
+ * Last updated: Fri, 30 May 2025 05:02:50 GMT
12
12
  * Dependencies: [undici-types](https://npmjs.com/package/undici-types)
13
13
 
14
14
  # Credits
@@ -266,11 +266,6 @@ declare global {
266
266
 
267
267
  // Global DOM types
268
268
 
269
- function structuredClone<T>(
270
- value: T,
271
- transfer?: { transfer: ReadonlyArray<import("worker_threads").TransferListItem> },
272
- ): T;
273
-
274
269
  interface DOMException extends _DOMException {}
275
270
  var DOMException: typeof globalThis extends { onmessage: any; DOMException: infer T } ? T
276
271
  : NodeDOMExceptionConstructor;
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@types/node",
3
- "version": "22.15.26",
3
+ "version": "22.15.27",
4
4
  "description": "TypeScript definitions for node",
5
5
  "homepage": "https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node",
6
6
  "license": "MIT",
@@ -220,6 +220,6 @@
220
220
  "undici-types": "~6.21.0"
221
221
  },
222
222
  "peerDependencies": {},
223
- "typesPublisherContentHash": "396d40f2ce0ddd8afa08e7ce4e4629ae9b67d6c511d0f44b0d0e511763140857",
223
+ "typesPublisherContentHash": "b9177cabc8a459c3570f9577c085dbfdc96e40f78ed41af33c674c3696a4e277",
224
224
  "typeScriptVersion": "5.1"
225
225
  }
@@ -52,14 +52,13 @@
52
52
  * @see [source](https://github.com/nodejs/node/blob/v22.x/lib/worker_threads.js)
53
53
  */
54
54
  declare module "worker_threads" {
55
- import { Blob } from "node:buffer";
56
55
  import { Context } from "node:vm";
57
56
  import { EventEmitter } from "node:events";
58
57
  import { EventLoopUtilityFunction } from "node:perf_hooks";
59
58
  import { FileHandle } from "node:fs/promises";
60
59
  import { Readable, Writable } from "node:stream";
60
+ import { ReadableStream, TransformStream, WritableStream } from "node:stream/web";
61
61
  import { URL } from "node:url";
62
- import { X509Certificate } from "node:crypto";
63
62
  const isInternalThread: boolean;
64
63
  const isMainThread: boolean;
65
64
  const parentPort: null | MessagePort;
@@ -89,7 +88,17 @@ declare module "worker_threads" {
89
88
  interface WorkerPerformance {
90
89
  eventLoopUtilization: EventLoopUtilityFunction;
91
90
  }
92
- type TransferListItem = ArrayBuffer | MessagePort | FileHandle | X509Certificate | Blob;
91
+ type Transferable =
92
+ | ArrayBuffer
93
+ | MessagePort
94
+ | AbortSignal
95
+ | FileHandle
96
+ | ReadableStream
97
+ | WritableStream
98
+ | TransformStream;
99
+ /** @deprecated Use `import { Transferable } from "node:worker_threads"` instead. */
100
+ // TODO: remove in a future major @types/node version.
101
+ type TransferListItem = Transferable;
93
102
  /**
94
103
  * Instances of the `worker.MessagePort` class represent one end of an
95
104
  * asynchronous, two-way communications channel. It can be used to transfer
@@ -174,7 +183,7 @@ declare module "worker_threads" {
174
183
  * behind this API, see the `serialization API of the node:v8 module`.
175
184
  * @since v10.5.0
176
185
  */
177
- postMessage(value: any, transferList?: readonly TransferListItem[]): void;
186
+ postMessage(value: any, transferList?: readonly Transferable[]): void;
178
187
  /**
179
188
  * Opposite of `unref()`. Calling `ref()` on a previously `unref()`ed port does _not_ let the program exit if it's the only active handle left (the default
180
189
  * behavior). If the port is `ref()`ed, calling `ref()` again has no effect.
@@ -261,7 +270,7 @@ declare module "worker_threads" {
261
270
  /**
262
271
  * Additional data to send in the first worker message.
263
272
  */
264
- transferList?: TransferListItem[] | undefined;
273
+ transferList?: Transferable[] | undefined;
265
274
  /**
266
275
  * @default true
267
276
  */
@@ -409,7 +418,7 @@ declare module "worker_threads" {
409
418
  * See `port.postMessage()` for more details.
410
419
  * @since v10.5.0
411
420
  */
412
- postMessage(value: any, transferList?: readonly TransferListItem[]): void;
421
+ postMessage(value: any, transferList?: readonly Transferable[]): void;
413
422
  /**
414
423
  * Sends a value to another worker, identified by its thread ID.
415
424
  * @param threadId The target thread ID. If the thread ID is invalid, a `ERR_WORKER_MESSAGING_FAILED` error will be thrown.
@@ -425,7 +434,7 @@ declare module "worker_threads" {
425
434
  postMessageToThread(
426
435
  threadId: number,
427
436
  value: any,
428
- transferList: readonly TransferListItem[],
437
+ transferList: readonly Transferable[],
429
438
  timeout?: number,
430
439
  ): Promise<void>;
431
440
  /**
@@ -709,6 +718,10 @@ declare module "worker_threads" {
709
718
  MessagePort as _MessagePort,
710
719
  } from "worker_threads";
711
720
  global {
721
+ function structuredClone<T>(
722
+ value: T,
723
+ options?: { transfer?: Transferable[] },
724
+ ): T;
712
725
  /**
713
726
  * `BroadcastChannel` class is a global reference for `import { BroadcastChannel } from 'worker_threads'`
714
727
  * https://nodejs.org/api/globals.html#broadcastchannel
@@ -5,6 +5,11 @@ echo "Sources:"
5
5
  ls
6
6
  echo ----------------------------------------
7
7
 
8
+ if [[ ! -d ./java ]]; then
9
+ echo "❌ No JARS to publish: 'java/' directory is missing."
10
+ exit 1
11
+ fi
12
+
8
13
  echo "Getting credentials..."
9
14
  credentials=$(aws secretsmanager get-secret-value --secret-id ${MAVEN_LOGIN_SECRET} --output=text --query=SecretString)
10
15
 
@@ -12,7 +17,6 @@ export MAVEN_USERNAME=$(node -e "console.log(${credentials}.username);")
12
17
  export MAVEN_PASSWORD=$(node -e "console.log(${credentials}.password);")
13
18
 
14
19
  chmod +x $SCRIPT_DIR/with-signing-key.sh
15
- chmod +x $SCRIPT_DIR/publish-mvn.sh
16
- $SCRIPT_DIR/with-signing-key.sh $SCRIPT_DIR/publish-mvn.sh
20
+ $SCRIPT_DIR/with-signing-key.sh npx -p publib@latest publib-maven ./java
17
21
 
18
22
  /bin/bash $SCRIPT_DIR/update-ssm.sh
@@ -6,15 +6,12 @@
6
6
  # 'true' or 'false'. If $KEY_AVAILABLE is 'true', the following
7
7
  # variables will be set as well:
8
8
  #
9
- # $KEY_ID
10
- # $KEY_PASSPHRASE
11
- # $GPG_PASSPHRASE_FROM_STDIN
9
+ # $MAVEN_GPG_PRIVATE_KEY
10
+ # $MAVEN_GPG_PRIVATE_KEY_PASSPHRASE
12
11
  #
13
- # The environment variable KEY_PASSPHRASE will be set to
14
- # the key's passphrase, to pass in like so:
12
+ # These will be used by `publib-maven`.
15
13
  #
16
- # echo $KEY_PASSPHRASE | gpg ${GPG_PASSPHRASE_FROM_STDIN} \
17
- # ...other gpg arguments...
14
+ # See <https://github.com/cdklabs/publib?tab=readme-ov-file#maven>.
18
15
  set -euo pipefail
19
16
 
20
17
  if [[ "${1:-}" == "" ]]; then
@@ -39,31 +36,9 @@ else
39
36
  node -e "console.log(JSON.parse(require('fs').readFileSync('$tmpdir/secret.txt', { encoding: 'utf-8' })).$1)"
40
37
  }
41
38
 
42
- export KEY_PASSPHRASE=$(value-from-secret Passphrase)
43
-
44
- # GnuPG will occasionally bail out with "gpg: <whatever> failed: Inappropriate ioctl for device", the following attempts to fix
45
- export GPG_TTY=$(tty)
46
- export GNUPGHOME=$tmpdir
47
-
48
- echo "Importing key..." >&2
49
- gpg --allow-secret-key-import \
50
- --batch --yes --no-tty \
51
- --import <(value-from-secret PrivateKey)
52
-
53
- export KEY_ID=$(gpg --list-keys --with-colons | grep pub | cut -d: -f5)
54
-
55
- # Prepare environment variables with flags to GPG
56
- # --passphrase-fd 0 \
57
- # ${EXTRA_GPG_OPTS} \
58
- GPG_PASSPHRASE_FROM_STDIN="--passphrase-fd 0"
59
- if [[ "$(uname)" == "Darwin" ]]; then
60
- # On Mac, we must pass this to disable a prompt for
61
- # passphrase, but option is not recognized on Linux.
62
- GPG_PASSPHRASE_FROM_STDIN="${GPG_PASSPHRASE_FROM_STDIN} --pinentry-mode loopback"
63
- fi
64
- export GPG_PASSPHRASE_FROM_STDIN
65
-
66
39
  export KEY_AVAILABLE=true
40
+ export MAVEN_GPG_PRIVATE_KEY=$(value-from-secret Passphrase)
41
+ export MAVEN_GPG_PRIVATE_KEY_PASSPHRASE=$(value-from-secret Passphrase)
67
42
  fi
68
43
 
69
44
  # Execute remaining commands
@@ -42,6 +42,20 @@ export interface PublishToMavenProjectProps {
42
42
  * @default "https://oss.sonatype.org"
43
43
  */
44
44
  mavenEndpoint?: string;
45
+ /**
46
+ * The server ID
47
+ *
48
+ * The only sensible value here is `central-ossrh`, which will use the new
49
+ * publishing endpoint that is mandatory starting June 30th.
50
+ *
51
+ * Any other value can `central-ossrh` will cause the underlying publishing
52
+ * library `publib` to assume publishing to a custom Nexus server, but this
53
+ * action currently doesn't have a way of specifying that Nexus server's
54
+ * endpoint.
55
+ *
56
+ * @default - Use legacy OSSRH server
57
+ */
58
+ serverId?: string;
45
59
  /**
46
60
  * The build image to do the publishing in
47
61
  *
package/lib/publishing.js CHANGED
@@ -63,6 +63,7 @@ class PublishToMavenProject extends constructs_1.Construct {
63
63
  FOR_REAL: forReal,
64
64
  MAVEN_LOGIN_SECRET: props.mavenLoginSecret.secretArn,
65
65
  MAVEN_ENDPOINT: props.mavenEndpoint || 'https://oss.sonatype.org',
66
+ MAVEN_SERVER_ID: props.serverId,
66
67
  SSM_PREFIX: props.ssmPrefix,
67
68
  }),
68
69
  });
@@ -392,4 +393,4 @@ function grantSsmPrefix(role, ssmPrefix) {
392
393
  }));
393
394
  }
394
395
  }
395
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["publishing.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport {\n  Stack,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_iam as iam,\n  aws_s3 as s3,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ICodeSigningCertificate } from './code-signing';\nimport { DEFAULT_SUPERCHAIN_IMAGE } from './constants';\nimport { OpenPGPKeyPair } from './open-pgp-key-pair';\nimport * as permissions from './permissions';\nimport { AddToPipelineOptions, IPublisher } from './pipeline';\nimport { WritableGitHubRepo } from './repo';\nimport { LinuxPlatform, Shellable } from './shellable';\nimport { noUndefined } from './util';\n\n/**\n * Type of access permissions to request from npmjs.\n */\nexport enum NpmAccess {\n  /**\n   * No access restriction. Note that unscoped packages must always be public.\n   */\n  PUBLIC = 'public',\n\n  /**\n   * Limit access to whitelisted npmjs users.\n   */\n  RESTRICTED = 'restricted',\n}\n\nexport interface PublishToMavenProjectProps {\n  /**\n   * The signing key itself\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The ID of the sonatype staging profile (e.g. \"68a05363083174\").\n   */\n  stagingProfileId: string;\n\n  /**\n   * Identifier of the secret that contains the Maven login\n   */\n  mavenLoginSecret: permissions.ExternalSecret;\n\n  /**\n   * If true (default) performs a dry-run only instead of actually publishing.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The Maven publishing endpoint to be used.\n   *\n   * @default \"https://oss.sonatype.org\"\n   */\n  mavenEndpoint?: string;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have Maven preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to Maven\n */\nexport class PublishToMavenProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToMavenProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry(DEFAULT_SUPERCHAIN_IMAGE)),\n      scriptDirectory: path.join(__dirname, 'publishing', 'maven'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        STAGING_PROFILE_ID: props.stagingProfileId,\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        FOR_REAL: forReal,\n        MAVEN_LOGIN_SECRET: props.mavenLoginSecret.secretArn,\n        MAVEN_ENDPOINT: props.mavenEndpoint || 'https://oss.sonatype.org',\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.mavenLoginSecret, shellable.role);\n      props.signingKey.grantRead(shellable.role);\n    }\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNpmProjectProps {\n  /**\n   * Identifier of the secret that contains the NPM token\n   */\n  npmTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * npm dist-tag to use when publishing artifacts.\n   *\n   * @default - npm default behavior (\"latest\" unless dist tag is specified in package.json)\n   */\n  distTag?: string;\n\n  /**\n   * npm --access public|restricted\n   *\n   * See https://docs.npmjs.com/cli-commands/publish#:~:text=Tells%20the\n   *\n   * Tells the registry whether this package should be published as public or restricted.\n   * Only applies to scoped packages, which default to restricted.\n   * If you don’t have a paid account, you must publish with --access public to publish scoped packages.\n   *\n   * @default NpmAccess.PUBLIC\n   */\n  access?: NpmAccess;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NPM\n */\nexport class PublishToNpmProject extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNpmProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const access = props.access ?? NpmAccess.PUBLIC;\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'npm'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        FOR_REAL: forReal,\n        NPM_TOKEN_SECRET: props.npmTokenSecret.secretArn,\n        DISTTAG: props.distTag || '',\n        ACCESS: access,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.npmTokenSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNuGetProjectProps {\n  /**\n   * The SecretsManager secret which stores the Nuget API key.\n   */\n  nugetApiKeySecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * A code signing certificate to use to sign assemblies.\n   * @default No signing\n   */\n  codeSign?: ICodeSigningCertificate;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have NuGet preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishToNuGetProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNuGetProjectProps) {\n    super(parent, id);\n\n    const environment: { [key: string]: string } = {};\n\n    environment.FOR_REAL = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    if (props.nugetApiKeySecret.assumeRoleArn) {\n      environment.NUGET_ROLE_ARN = props.nugetApiKeySecret.assumeRoleArn;\n    }\n\n    if (props.nugetApiKeySecret.region) {\n      environment.NUGET_SECRET_REGION = props.nugetApiKeySecret.region;\n    } else {\n      environment.NUGET_SECRET_REGION = Stack.of(this).region;\n    }\n\n    environment.NUGET_SECRET_ID = props.nugetApiKeySecret.secretArn;\n    if (props.ssmPrefix) {\n      environment.SSM_PREFIX = props.ssmPrefix;\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry(DEFAULT_SUPERCHAIN_IMAGE)),\n      scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),\n      entrypoint: 'publish.sh',\n      environment,\n    });\n\n    if (props.codeSign) {\n      environment.CODE_SIGNING_SECRET_ID = props.codeSign.credential.secretArn;\n      environment.CODE_SIGNING_PARAMETER_NAME = props.codeSign.principal.parameterName;\n    }\n\n    if (shellable.role) {\n      if (props.nugetApiKeySecret.assumeRoleArn) {\n        permissions.grantAssumeRole(props.nugetApiKeySecret.assumeRoleArn, shellable.role);\n      } else {\n        permissions.grantSecretRead(props.nugetApiKeySecret, shellable.role);\n      }\n\n      if (props.codeSign) {\n        props.codeSign.grantDecrypt(shellable.role);\n      }\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishDocsToGitHubProjectProps {\n  /**\n   * The repository to publish to\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * GitHub Pages branch to push to.\n   * @default gh-pages\n   */\n  branch?: string;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishDocsToGitHubProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishDocsToGitHubProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'docs'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        // Must be SSH because we use an SSH key to authenticate\n        GITHUB_REPO: props.githubRepo.repositoryUrlSsh,\n        GITHUB_PAGES_BRANCH: props.branch || 'gh-pages',\n        SSH_KEY_SECRET: props.githubRepo.sshKeySecret.secretArn,\n        FOR_REAL: forReal,\n        COMMIT_USERNAME: props.githubRepo.commitUsername,\n        COMMIT_EMAIL: props.githubRepo.commitEmail,\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubRepo.sshKeySecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToGitHubProps {\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The repository to create a release in.\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * The signign key to use to create a GPG signature of the artifact.\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * The name of the changelog markdown file, used to create release notes.\n   * Relative to the artifacts root.\n   * @default \"./CHANGELOG.md\"\n   */\n  changelogFileName?: string;\n\n  /**\n   * The name of the release notes file, containing the completed release notes\n   * for the current release.\n   * Relative to the artifacts root.\n   * NOTE - If this value is set and points to a valid file, the file in its entirety\n   * will be read and used for the release notes. The value of `changelogFileName` will\n   * be ignored.\n   * @default \"./RELEASE_NOTES.md\"\n   */\n  releaseNotesFileName?: string;\n\n  /**\n   * Additional input artifacts to publish binaries from to GitHub release\n   */\n  additionalInputArtifacts?: cpipeline.Artifact[];\n\n  /**\n   * Whether to sign the additional artifacts\n   *\n   * @default true\n   */\n  signAdditionalArtifacts?: boolean;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToGitHub extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n  private readonly additionalInputArtifacts?: cpipeline.Artifact[];\n\n  constructor(parent: Construct, id: string, props: PublishToGitHubProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n    this.additionalInputArtifacts = props.additionalInputArtifacts;\n\n    // The release notes, if set and a valid file, overrides any usages of the changelog.\n    if (props.changelogFileName && props.releaseNotesFileName) {\n      throw new Error('both `releaseNotesFileName` and `changelogFileName` cannot be specified; use one or the other');\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'github'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        CHANGELOG: props.changelogFileName || './CHANGELOG.md',\n        RELEASE_NOTES: props.releaseNotesFileName || './RELEASE_NOTES.md',\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        GITHUB_OWNER: props.githubRepo.owner,\n        GITHUB_REPO: props.githubRepo.repo,\n        FOR_REAL: forReal,\n        // Transmit the names of the secondary sources to the shell script (for easier iteration)\n        SECONDARY_SOURCE_NAMES: props.additionalInputArtifacts ? props.additionalInputArtifacts.map(a => a.artifactName).join(' ') : undefined,\n        SIGN_ADDITIONAL_ARTIFACTS: props.additionalInputArtifacts && props.signAdditionalArtifacts !== false ? 'true' : undefined,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n      environmentSecrets: {\n        GITHUB_TOKEN: props.githubRepo.tokenSecretArn,\n      },\n    });\n\n    // allow script to read the signing key\n    if (shellable.role) {\n      props.signingKey.grantRead(shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      extraInputs: this.additionalInputArtifacts,\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToS3Props {\n  bucket: s3.IBucket;\n\n  /**\n   * Make files publicly readable\n   *\n   * @default false\n   */\n  public?: boolean;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToS3 extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(scope: Construct, id: string, props: PublishToS3Props) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 's3'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUCKET_URL: `s3://${props.bucket.bucketName}`,\n        CHANGELOG: props.public ? 'true' : 'false',\n        FOR_REAL: forReal,\n      }),\n    });\n\n    // Allow script to write to bucket\n    if (shellable.role) {\n      props.bucket.grantReadWrite(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToPyPiProps {\n  /**\n   * Identifier of the secret that contains the PyPI credentials under\n   * \"username\" and \"password\" keys.\n   */\n  loginSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToPyPi extends Construct {\n\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToPyPiProps) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'pypi'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        FOR_REAL: forReal,\n        PYPI_CREDENTIALS_SECRET_ID: props.loginSecret.secretArn,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.loginSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\n/**\n * Props for Go publishing.\n */\nexport interface PublishToGolangProps {\n  /**\n   * Identifier of the secret that contains the GitHub personal access token\n   * used to push the go code to the github repository defined by it's name.\n   *\n   * @see https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token\n   */\n  readonly githubTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * Username to perform the commit with.\n   */\n  readonly gitUserName: string;\n\n  /**\n   * Email to perform the commit with.\n   */\n  readonly gitUserEmail: string;\n\n  /**\n   * Set to \"true\" for a dry run.\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Module version.\n   *\n   * @default - Defaults to the value in the 'version' file of the module\n   * directory. Fails if it doesn't exist.\n   */\n  readonly version?: string;\n\n  /**\n   * Branch to push to.\n   *\n   * @default \"main\"\n   */\n  readonly gitBranch?: string;\n\n  /**\n   * The commit message.\n   *\n   * @default \"chore(release): $VERSION\"\n   */\n  readonly gitCommitMessage?: string;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * Pushes a directory of golang modules to a GitHub repository.\n */\nexport class PublishToGolang extends Construct {\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToGolangProps) {\n    super(scope, id);\n\n    const dryRun = props.dryRun ?? false;\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'golang'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        DRYRUN: dryRun ? 'true' : undefined,\n        GITHUB_TOKEN_SECRET: props.githubTokenSecret.secretArn,\n        VERSION: props.version,\n        GIT_BRANCH: props.gitBranch,\n        GIT_USER_NAME: props.gitUserName,\n        GIT_USER_EMAIL: props.gitUserEmail,\n        GIT_COMMIT_MESSAGE: props.gitCommitMessage,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubTokenSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nfunction grantSsmPrefix(role: iam.IRole, ssmPrefix?: string) {\n  if (ssmPrefix) {\n    if (!ssmPrefix.startsWith('/')) {\n      throw new Error(`SSM prefix should start with '/', got: ${ssmPrefix}`);\n    }\n    if (ssmPrefix.endsWith('/')) {\n      throw new Error(`SSM prefix must not end with '/', got: ${ssmPrefix}`);\n    }\n\n    role?.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['ssm:PutParameter', 'ssm:GetParameter'],\n      resources: [Stack.of(role).formatArn({\n        service: 'ssm',\n        resource: 'parameter',\n        resourceName: `${ssmPrefix.slice(1)}/*`,\n      })],\n    }));\n  }\n}"]}
396
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["publishing.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA6B;AAC7B,6CAOqB;AACrB,2CAAuC;AAEvC,2CAAuD;AAEvD,2DAA6C;AAG7C,2CAAuD;AACvD,iCAAqC;AAErC;;GAEG;AACH,IAAY,SAUX;AAVD,WAAY,SAAS;IACnB;;OAEG;IACH,8BAAiB,CAAA;IAEjB;;OAEG;IACH,sCAAyB,CAAA;AAC3B,CAAC,EAVW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAUpB;AAwED;;GAEG;AACH,MAAa,qBAAsB,SAAQ,sBAAS;IAIlD,YAAY,MAAiB,EAAE,EAAU,EAAE,KAAiC;QAC1E,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QAElB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAElF,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,IAAI,yBAAa,CAAC,KAAK,CAAC,UAAU,IAAI,2BAAM,CAAC,eAAe,CAAC,kBAAkB,CAAC,oCAAwB,CAAC,CAAC;YACpH,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,OAAO,CAAC;YAC5D,UAAU,EAAE,YAAY;YACxB,WAAW,EAAE,IAAA,kBAAW,EAAC;gBACvB,kBAAkB,EAAE,KAAK,CAAC,gBAAgB;gBAC1C,eAAe,EAAE,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS;gBACtD,QAAQ,EAAE,OAAO;gBACjB,kBAAkB,EAAE,KAAK,CAAC,gBAAgB,CAAC,SAAS;gBACpD,cAAc,EAAE,KAAK,CAAC,aAAa,IAAI,0BAA0B;gBACjE,eAAe,EAAE,KAAK,CAAC,QAAQ;gBAC/B,UAAU,EAAE,KAAK,CAAC,SAAS;aAC5B,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,gBAAgB,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;YACpE,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;SAC5C;QACD,cAAc,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QAEhD,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,KAAuB,EAAE,EAAU,EAAE,OAA6B;QACrF,KAAK,CAAC,SAAS,CAAC,IAAI,sCAAiB,CAAC,eAAe,CAAC;YACpD,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,OAAO,CAAC,aAAa,IAAI,IAAI,8BAAS,CAAC,QAAQ,EAAE;YACxD,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AA3CD,sDA2CC;AAmDD;;GAEG;AACH,MAAa,mBAAoB,SAAQ,sBAAS;IAIhD,YAAY,MAAiB,EAAE,EAAU,EAAE,KAA+B;QACxE,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QAElB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAElF,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,IAAI,SAAS,CAAC,MAAM,CAAC;QAEhD,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,IAAI,yBAAa,CAAC,2BAAM,CAAC,eAAe,CAAC,YAAY,CAAC;YAChE,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,KAAK,CAAC;YAC1D,UAAU,EAAE,YAAY;YACxB,WAAW,EAAE,IAAA,kBAAW,EAAC;gBACvB,QAAQ,EAAE,OAAO;gBACjB,gBAAgB,EAAE,KAAK,CAAC,cAAc,CAAC,SAAS;gBAChD,OAAO,EAAE,KAAK,CAAC,OAAO,IAAI,EAAE;gBAC5B,MAAM,EAAE,MAAM;gBACd,UAAU,EAAE,KAAK,CAAC,SAAS;aAC5B,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,cAAc,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;SACnE;QAED,cAAc,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QAEhD,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,KAAuB,EAAE,EAAU,EAAE,OAA6B;QACrF,KAAK,CAAC,SAAS,CAAC,IAAI,sCAAiB,CAAC,eAAe,CAAC;YACpD,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,OAAO,CAAC,aAAa,IAAI,IAAI,8BAAS,CAAC,QAAQ,EAAE;YACxD,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AA3CD,kDA2CC;AA8CD;;GAEG;AACH,MAAa,qBAAsB,SAAQ,sBAAS;IAIlD,YAAY,MAAiB,EAAE,EAAU,EAAE,KAAiC;QAC1E,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QAElB,MAAM,WAAW,GAA8B,EAAE,CAAC;QAElD,WAAW,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEzF,IAAI,KAAK,CAAC,iBAAiB,CAAC,aAAa,EAAE;YACzC,WAAW,CAAC,cAAc,GAAG,KAAK,CAAC,iBAAiB,CAAC,aAAa,CAAC;SACpE;QAED,IAAI,KAAK,CAAC,iBAAiB,CAAC,MAAM,EAAE;YAClC,WAAW,CAAC,mBAAmB,GAAG,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAAC;SAClE;aAAM;YACL,WAAW,CAAC,mBAAmB,GAAG,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC;SACzD;QAED,WAAW,CAAC,eAAe,GAAG,KAAK,CAAC,iBAAiB,CAAC,SAAS,CAAC;QAChE,IAAI,KAAK,CAAC,SAAS,EAAE;YACnB,WAAW,CAAC,UAAU,GAAG,KAAK,CAAC,SAAS,CAAC;SAC1C;QAED,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,IAAI,yBAAa,CAAC,KAAK,CAAC,UAAU,IAAI,2BAAM,CAAC,eAAe,CAAC,kBAAkB,CAAC,oCAAwB,CAAC,CAAC;YACpH,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,OAAO,CAAC;YAC5D,UAAU,EAAE,YAAY;YACxB,WAAW;SACZ,CAAC,CAAC;QAEH,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,WAAW,CAAC,sBAAsB,GAAG,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC;YACzE,WAAW,CAAC,2BAA2B,GAAG,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,aAAa,CAAC;SAClF;QAED,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,IAAI,KAAK,CAAC,iBAAiB,CAAC,aAAa,EAAE;gBACzC,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,iBAAiB,CAAC,aAAa,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;aACpF;iBAAM;gBACL,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,iBAAiB,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;aACtE;YAED,IAAI,KAAK,CAAC,QAAQ,EAAE;gBAClB,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;aAC7C;SACF;QAED,cAAc,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QAEhD,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,KAAuB,EAAE,EAAU,EAAE,OAA6B;QACrF,KAAK,CAAC,SAAS,CAAC,IAAI,sCAAiB,CAAC,eAAe,CAAC;YACpD,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,OAAO,CAAC,aAAa,IAAI,IAAI,8BAAS,CAAC,QAAQ,EAAE;YACxD,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AAjED,sDAiEC;AA4CD;;GAEG;AACH,MAAa,0BAA2B,SAAQ,sBAAS;IAIvD,YAAY,MAAiB,EAAE,EAAU,EAAE,KAAsC;QAC/E,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QAElB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAElF,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,IAAI,yBAAa,CAAC,2BAAM,CAAC,eAAe,CAAC,YAAY,CAAC;YAChE,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,MAAM,CAAC;YAC3D,UAAU,EAAE,YAAY;YACxB,WAAW,EAAE,IAAA,kBAAW,EAAC;gBACvB,wDAAwD;gBACxD,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC,gBAAgB;gBAC9C,mBAAmB,EAAE,KAAK,CAAC,MAAM,IAAI,UAAU;gBAC/C,cAAc,EAAE,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,SAAS;gBACvD,QAAQ,EAAE,OAAO;gBACjB,eAAe,EAAE,KAAK,CAAC,UAAU,CAAC,cAAc;gBAChD,YAAY,EAAE,KAAK,CAAC,UAAU,CAAC,WAAW;gBAC1C,cAAc,EAAE,KAAK,CAAC,qBAAqB,IAAI,cAAc;gBAC7D,UAAU,EAAE,KAAK,CAAC,SAAS;aAC5B,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,UAAU,CAAC,YAAY,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;SAC5E;QAED,cAAc,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QAEhD,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,KAAuB,EAAE,EAAU,EAAE,OAA6B;QACrF,KAAK,CAAC,SAAS,CAAC,IAAI,sCAAiB,CAAC,eAAe,CAAC;YACpD,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,OAAO,CAAC,aAAa,IAAI,IAAI,8BAAS,CAAC,QAAQ,EAAE;YACxD,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AA7CD,gEA6CC;AAyED,MAAa,eAAgB,SAAQ,sBAAS;IAK5C,YAAY,MAAiB,EAAE,EAAU,EAAE,KAA2B;QACpE,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QAElB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAClF,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC,wBAAwB,CAAC;QAE/D,qFAAqF;QACrF,IAAI,KAAK,CAAC,iBAAiB,IAAI,KAAK,CAAC,oBAAoB,EAAE;YACzD,MAAM,IAAI,KAAK,CAAC,+FAA+F,CAAC,CAAC;SAClH;QAED,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,IAAI,yBAAa,CAAC,2BAAM,CAAC,eAAe,CAAC,YAAY,CAAC;YAChE,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,QAAQ,CAAC;YAC7D,UAAU,EAAE,YAAY;YACxB,WAAW,EAAE,IAAA,kBAAW,EAAC;gBACvB,cAAc,EAAE,KAAK,CAAC,qBAAqB,IAAI,cAAc;gBAC7D,SAAS,EAAE,KAAK,CAAC,iBAAiB,IAAI,gBAAgB;gBACtD,aAAa,EAAE,KAAK,CAAC,oBAAoB,IAAI,oBAAoB;gBACjE,eAAe,EAAE,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS;gBACtD,YAAY,EAAE,KAAK,CAAC,UAAU,CAAC,KAAK;gBACpC,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC,IAAI;gBAClC,QAAQ,EAAE,OAAO;gBACjB,yFAAyF;gBACzF,sBAAsB,EAAE,KAAK,CAAC,wBAAwB,CAAC,CAAC,CAAC,KAAK,CAAC,wBAAwB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;gBACtI,yBAAyB,EAAE,KAAK,CAAC,wBAAwB,IAAI,KAAK,CAAC,uBAAuB,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;gBACzH,UAAU,EAAE,KAAK,CAAC,SAAS;aAC5B,CAAC;YACF,kBAAkB,EAAE;gBAClB,YAAY,EAAE,KAAK,CAAC,UAAU,CAAC,cAAc;aAC9C;SACF,CAAC,CAAC;QAEH,uCAAuC;QACvC,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;SAC5C;QAED,cAAc,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QAChD,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,KAAuB,EAAE,EAAU,EAAE,OAA6B;QACrF,KAAK,CAAC,SAAS,CAAC,IAAI,sCAAiB,CAAC,eAAe,CAAC;YACpD,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,OAAO,CAAC,aAAa,IAAI,IAAI,8BAAS,CAAC,QAAQ,EAAE;YACxD,WAAW,EAAE,IAAI,CAAC,wBAAwB;YAC1C,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AA1DD,0CA0DC;AA0BD,MAAa,WAAY,SAAQ,sBAAS;IAIxC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAuB;QAC/D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAElF,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,IAAI,yBAAa,CAAC,2BAAM,CAAC,eAAe,CAAC,YAAY,CAAC;YAChE,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,IAAI,CAAC;YACzD,UAAU,EAAE,YAAY;YACxB,WAAW,EAAE,IAAA,kBAAW,EAAC;gBACvB,UAAU,EAAE,QAAQ,KAAK,CAAC,MAAM,CAAC,UAAU,EAAE;gBAC7C,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO;gBAC1C,QAAQ,EAAE,OAAO;aAClB,CAAC;SACH,CAAC,CAAC;QAEH,kCAAkC;QAClC,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;SAC7C;QAED,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,KAAuB,EAAE,EAAU,EAAE,OAA6B;QACrF,KAAK,CAAC,SAAS,CAAC,IAAI,sCAAiB,CAAC,eAAe,CAAC;YACpD,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,OAAO,CAAC,aAAa,IAAI,IAAI,8BAAS,CAAC,QAAQ,EAAE;YACxD,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AAtCD,kCAsCC;AAgCD,MAAa,aAAc,SAAQ,sBAAS;IAK1C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAyB;QACjE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QAElF,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,IAAI,yBAAa,CAAC,2BAAM,CAAC,eAAe,CAAC,YAAY,CAAC;YAChE,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,MAAM,CAAC;YAC3D,UAAU,EAAE,YAAY;YACxB,WAAW,EAAE,IAAA,kBAAW,EAAC;gBACvB,QAAQ,EAAE,OAAO;gBACjB,0BAA0B,EAAE,KAAK,CAAC,WAAW,CAAC,SAAS;gBACvD,UAAU,EAAE,KAAK,CAAC,SAAS;aAC5B,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,WAAW,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;SAChE;QAED,cAAc,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QAEhD,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,KAAuB,EAAE,EAAU,EAAE,OAA6B;QACrF,KAAK,CAAC,SAAS,CAAC,IAAI,sCAAiB,CAAC,eAAe,CAAC;YACpD,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,OAAO,CAAC,aAAa,IAAI,IAAI,8BAAS,CAAC,QAAQ,EAAE;YACxD,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AAxCD,sCAwCC;AAqED;;GAEG;AACH,MAAa,eAAgB,SAAQ,sBAAS;IAI5C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA2B;QACnE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC;QAErC,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,IAAI,EAAE,SAAS,EAAE;YAC/C,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,QAAQ,EAAE,IAAI,yBAAa,CAAC,2BAAM,CAAC,eAAe,CAAC,YAAY,CAAC;YAChE,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,QAAQ,CAAC;YAC7D,UAAU,EAAE,YAAY;YACxB,WAAW,EAAE,IAAA,kBAAW,EAAC;gBACvB,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;gBACnC,mBAAmB,EAAE,KAAK,CAAC,iBAAiB,CAAC,SAAS;gBACtD,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,UAAU,EAAE,KAAK,CAAC,SAAS;gBAC3B,aAAa,EAAE,KAAK,CAAC,WAAW;gBAChC,cAAc,EAAE,KAAK,CAAC,YAAY;gBAClC,kBAAkB,EAAE,KAAK,CAAC,gBAAgB;gBAC1C,UAAU,EAAE,KAAK,CAAC,SAAS;aAC5B,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,iBAAiB,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;SACtE;QAED,cAAc,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;QAEhD,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,KAAuB,EAAE,EAAU,EAAE,OAA6B;QACrF,KAAK,CAAC,SAAS,CAAC,IAAI,sCAAiB,CAAC,eAAe,CAAC;YACpD,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,OAAO,CAAC,aAAa,IAAI,IAAI,8BAAS,CAAC,QAAQ,EAAE;YACxD,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AA5CD,0CA4CC;AAED,SAAS,cAAc,CAAC,IAAe,EAAE,SAAkB;IACzD,IAAI,SAAS,EAAE;QACb,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;YAC9B,MAAM,IAAI,KAAK,CAAC,0CAA0C,SAAS,EAAE,CAAC,CAAC;SACxE;QACD,IAAI,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,0CAA0C,SAAS,EAAE,CAAC,CAAC;SACxE;QAED,IAAI,EAAE,oBAAoB,CAAC,IAAI,qBAAG,CAAC,eAAe,CAAC;YACjD,OAAO,EAAE,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;YACjD,SAAS,EAAE,CAAC,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;oBACnC,OAAO,EAAE,KAAK;oBACd,QAAQ,EAAE,WAAW;oBACrB,YAAY,EAAE,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI;iBACxC,CAAC,CAAC;SACJ,CAAC,CAAC,CAAC;KACL;AACH,CAAC","sourcesContent":["import * as path from 'path';\nimport {\n  Stack,\n  aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline,\n  aws_codepipeline_actions as cpipeline_actions,\n  aws_iam as iam,\n  aws_s3 as s3,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ICodeSigningCertificate } from './code-signing';\nimport { DEFAULT_SUPERCHAIN_IMAGE } from './constants';\nimport { OpenPGPKeyPair } from './open-pgp-key-pair';\nimport * as permissions from './permissions';\nimport { AddToPipelineOptions, IPublisher } from './pipeline';\nimport { WritableGitHubRepo } from './repo';\nimport { LinuxPlatform, Shellable } from './shellable';\nimport { noUndefined } from './util';\n\n/**\n * Type of access permissions to request from npmjs.\n */\nexport enum NpmAccess {\n  /**\n   * No access restriction. Note that unscoped packages must always be public.\n   */\n  PUBLIC = 'public',\n\n  /**\n   * Limit access to whitelisted npmjs users.\n   */\n  RESTRICTED = 'restricted',\n}\n\nexport interface PublishToMavenProjectProps {\n  /**\n   * The signing key itself\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The ID of the sonatype staging profile (e.g. \"68a05363083174\").\n   */\n  stagingProfileId: string;\n\n  /**\n   * Identifier of the secret that contains the Maven login\n   */\n  mavenLoginSecret: permissions.ExternalSecret;\n\n  /**\n   * If true (default) performs a dry-run only instead of actually publishing.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The Maven publishing endpoint to be used.\n   *\n   * @default \"https://oss.sonatype.org\"\n   */\n  mavenEndpoint?: string;\n\n  /**\n   * The server ID\n   *\n   * The only sensible value here is `central-ossrh`, which will use the new\n   * publishing endpoint that is mandatory starting June 30th.\n   *\n   * Any other value can `central-ossrh` will cause the underlying publishing\n   * library `publib` to assume publishing to a custom Nexus server, but this\n   * action currently doesn't have a way of specifying that Nexus server's\n   * endpoint.\n   *\n   * @default - Use legacy OSSRH server\n   */\n  serverId?: string;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have Maven preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to Maven\n */\nexport class PublishToMavenProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToMavenProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry(DEFAULT_SUPERCHAIN_IMAGE)),\n      scriptDirectory: path.join(__dirname, 'publishing', 'maven'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        STAGING_PROFILE_ID: props.stagingProfileId,\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        FOR_REAL: forReal,\n        MAVEN_LOGIN_SECRET: props.mavenLoginSecret.secretArn,\n        MAVEN_ENDPOINT: props.mavenEndpoint || 'https://oss.sonatype.org',\n        MAVEN_SERVER_ID: props.serverId,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.mavenLoginSecret, shellable.role);\n      props.signingKey.grantRead(shellable.role);\n    }\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNpmProjectProps {\n  /**\n   * Identifier of the secret that contains the NPM token\n   */\n  npmTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * npm dist-tag to use when publishing artifacts.\n   *\n   * @default - npm default behavior (\"latest\" unless dist tag is specified in package.json)\n   */\n  distTag?: string;\n\n  /**\n   * npm --access public|restricted\n   *\n   * See https://docs.npmjs.com/cli-commands/publish#:~:text=Tells%20the\n   *\n   * Tells the registry whether this package should be published as public or restricted.\n   * Only applies to scoped packages, which default to restricted.\n   * If you don’t have a paid account, you must publish with --access public to publish scoped packages.\n   *\n   * @default NpmAccess.PUBLIC\n   */\n  access?: NpmAccess;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NPM\n */\nexport class PublishToNpmProject extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNpmProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const access = props.access ?? NpmAccess.PUBLIC;\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'npm'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        FOR_REAL: forReal,\n        NPM_TOKEN_SECRET: props.npmTokenSecret.secretArn,\n        DISTTAG: props.distTag || '',\n        ACCESS: access,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.npmTokenSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToNuGetProjectProps {\n  /**\n   * The SecretsManager secret which stores the Nuget API key.\n   */\n  nugetApiKeySecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * A code signing certificate to use to sign assemblies.\n   * @default No signing\n   */\n  codeSign?: ICodeSigningCertificate;\n\n  /**\n   * The build image to do the publishing in\n   *\n   * Needs to have NuGet preinstalled.\n   *\n   * @default Latest superchain\n   */\n  readonly buildImage?: cbuild.IBuildImage;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishToNuGetProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishToNuGetProjectProps) {\n    super(parent, id);\n\n    const environment: { [key: string]: string } = {};\n\n    environment.FOR_REAL = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    if (props.nugetApiKeySecret.assumeRoleArn) {\n      environment.NUGET_ROLE_ARN = props.nugetApiKeySecret.assumeRoleArn;\n    }\n\n    if (props.nugetApiKeySecret.region) {\n      environment.NUGET_SECRET_REGION = props.nugetApiKeySecret.region;\n    } else {\n      environment.NUGET_SECRET_REGION = Stack.of(this).region;\n    }\n\n    environment.NUGET_SECRET_ID = props.nugetApiKeySecret.secretArn;\n    if (props.ssmPrefix) {\n      environment.SSM_PREFIX = props.ssmPrefix;\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(props.buildImage ?? cbuild.LinuxBuildImage.fromDockerRegistry(DEFAULT_SUPERCHAIN_IMAGE)),\n      scriptDirectory: path.join(__dirname, 'publishing', 'nuget'),\n      entrypoint: 'publish.sh',\n      environment,\n    });\n\n    if (props.codeSign) {\n      environment.CODE_SIGNING_SECRET_ID = props.codeSign.credential.secretArn;\n      environment.CODE_SIGNING_PARAMETER_NAME = props.codeSign.principal.parameterName;\n    }\n\n    if (shellable.role) {\n      if (props.nugetApiKeySecret.assumeRoleArn) {\n        permissions.grantAssumeRole(props.nugetApiKeySecret.assumeRoleArn, shellable.role);\n      } else {\n        permissions.grantSecretRead(props.nugetApiKeySecret, shellable.role);\n      }\n\n      if (props.codeSign) {\n        props.codeSign.grantDecrypt(shellable.role);\n      }\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishDocsToGitHubProjectProps {\n  /**\n   * The repository to publish to\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * GitHub Pages branch to push to.\n   * @default gh-pages\n   */\n  branch?: string;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * CodeBuild project that will publish all packages in a release bundle to NuGet\n */\nexport class PublishDocsToGitHubProject extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(parent: Construct, id: string, props: PublishDocsToGitHubProjectProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'docs'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        // Must be SSH because we use an SSH key to authenticate\n        GITHUB_REPO: props.githubRepo.repositoryUrlSsh,\n        GITHUB_PAGES_BRANCH: props.branch || 'gh-pages',\n        SSH_KEY_SECRET: props.githubRepo.sshKeySecret.secretArn,\n        FOR_REAL: forReal,\n        COMMIT_USERNAME: props.githubRepo.commitUsername,\n        COMMIT_EMAIL: props.githubRepo.commitEmail,\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubRepo.sshKeySecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToGitHubProps {\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The repository to create a release in.\n   */\n  githubRepo: WritableGitHubRepo;\n\n  /**\n   * The signign key to use to create a GPG signature of the artifact.\n   */\n  signingKey: OpenPGPKeyPair;\n\n  /**\n   * The name of the build manifest JSON file (must include \"name\" and \"version\" fields).\n   * Relative to the artifacts root.\n   * @default \"./build.json\"\n   */\n  buildManifestFileName?: string;\n\n  /**\n   * The name of the changelog markdown file, used to create release notes.\n   * Relative to the artifacts root.\n   * @default \"./CHANGELOG.md\"\n   */\n  changelogFileName?: string;\n\n  /**\n   * The name of the release notes file, containing the completed release notes\n   * for the current release.\n   * Relative to the artifacts root.\n   * NOTE - If this value is set and points to a valid file, the file in its entirety\n   * will be read and used for the release notes. The value of `changelogFileName` will\n   * be ignored.\n   * @default \"./RELEASE_NOTES.md\"\n   */\n  releaseNotesFileName?: string;\n\n  /**\n   * Additional input artifacts to publish binaries from to GitHub release\n   */\n  additionalInputArtifacts?: cpipeline.Artifact[];\n\n  /**\n   * Whether to sign the additional artifacts\n   *\n   * @default true\n   */\n  signAdditionalArtifacts?: boolean;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToGitHub extends Construct implements IPublisher {\n  public readonly role: iam.IRole;\n  public readonly project: cbuild.Project;\n  private readonly additionalInputArtifacts?: cpipeline.Artifact[];\n\n  constructor(parent: Construct, id: string, props: PublishToGitHubProps) {\n    super(parent, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n    this.additionalInputArtifacts = props.additionalInputArtifacts;\n\n    // The release notes, if set and a valid file, overrides any usages of the changelog.\n    if (props.changelogFileName && props.releaseNotesFileName) {\n      throw new Error('both `releaseNotesFileName` and `changelogFileName` cannot be specified; use one or the other');\n    }\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'github'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUILD_MANIFEST: props.buildManifestFileName || './build.json',\n        CHANGELOG: props.changelogFileName || './CHANGELOG.md',\n        RELEASE_NOTES: props.releaseNotesFileName || './RELEASE_NOTES.md',\n        SIGNING_KEY_ARN: props.signingKey.credential.secretArn,\n        GITHUB_OWNER: props.githubRepo.owner,\n        GITHUB_REPO: props.githubRepo.repo,\n        FOR_REAL: forReal,\n        // Transmit the names of the secondary sources to the shell script (for easier iteration)\n        SECONDARY_SOURCE_NAMES: props.additionalInputArtifacts ? props.additionalInputArtifacts.map(a => a.artifactName).join(' ') : undefined,\n        SIGN_ADDITIONAL_ARTIFACTS: props.additionalInputArtifacts && props.signAdditionalArtifacts !== false ? 'true' : undefined,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n      environmentSecrets: {\n        GITHUB_TOKEN: props.githubRepo.tokenSecretArn,\n      },\n    });\n\n    // allow script to read the signing key\n    if (shellable.role) {\n      props.signingKey.grantRead(shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      extraInputs: this.additionalInputArtifacts,\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToS3Props {\n  bucket: s3.IBucket;\n\n  /**\n   * Make files publicly readable\n   *\n   * @default false\n   */\n  public?: boolean;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToS3 extends Construct implements IPublisher {\n  public readonly role?: iam.IRole;\n  public readonly project: cbuild.Project;\n\n  constructor(scope: Construct, id: string, props: PublishToS3Props) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 's3'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        BUCKET_URL: `s3://${props.bucket.bucketName}`,\n        CHANGELOG: props.public ? 'true' : 'false',\n        FOR_REAL: forReal,\n      }),\n    });\n\n    // Allow script to write to bucket\n    if (shellable.role) {\n      props.bucket.grantReadWrite(shellable.role);\n    }\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nexport interface PublishToPyPiProps {\n  /**\n   * Identifier of the secret that contains the PyPI credentials under\n   * \"username\" and \"password\" keys.\n   */\n  loginSecret: permissions.ExternalSecret;\n\n  /**\n   * If `true` (default) will only perform a dry-run but will not actually publish.\n   * @default true\n   */\n  dryRun?: boolean;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\nexport class PublishToPyPi extends Construct {\n\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToPyPiProps) {\n    super(scope, id);\n\n    const forReal = props.dryRun === undefined ? 'false' : (!props.dryRun).toString();\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'pypi'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        FOR_REAL: forReal,\n        PYPI_CREDENTIALS_SECRET_ID: props.loginSecret.secretArn,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.loginSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\n/**\n * Props for Go publishing.\n */\nexport interface PublishToGolangProps {\n  /**\n   * Identifier of the secret that contains the GitHub personal access token\n   * used to push the go code to the github repository defined by it's name.\n   *\n   * @see https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token\n   */\n  readonly githubTokenSecret: permissions.ExternalSecret;\n\n  /**\n   * Username to perform the commit with.\n   */\n  readonly gitUserName: string;\n\n  /**\n   * Email to perform the commit with.\n   */\n  readonly gitUserEmail: string;\n\n  /**\n   * Set to \"true\" for a dry run.\n   * @default false\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Module version.\n   *\n   * @default - Defaults to the value in the 'version' file of the module\n   * directory. Fails if it doesn't exist.\n   */\n  readonly version?: string;\n\n  /**\n   * Branch to push to.\n   *\n   * @default \"main\"\n   */\n  readonly gitBranch?: string;\n\n  /**\n   * The commit message.\n   *\n   * @default \"chore(release): $VERSION\"\n   */\n  readonly gitCommitMessage?: string;\n\n  /**\n   * The prefix under which to record the fact that the publish step executed\n   *\n   * This will write `<prefix>/version` and `<prefix>/timestamp` variables\n   *\n   * @default - no SSM parameters\n   */\n  ssmPrefix?: string;\n\n  /**\n   * Description for the CodeBuild project\n   *\n   * @default - No description\n   */\n  description?: string;\n}\n\n/**\n * Pushes a directory of golang modules to a GitHub repository.\n */\nexport class PublishToGolang extends Construct {\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  constructor(scope: Construct, id: string, props: PublishToGolangProps) {\n    super(scope, id);\n\n    const dryRun = props.dryRun ?? false;\n\n    const shellable = new Shellable(this, 'Default', {\n      description: props.description,\n      platform: new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_7_0),\n      scriptDirectory: path.join(__dirname, 'publishing', 'golang'),\n      entrypoint: 'publish.sh',\n      environment: noUndefined({\n        DRYRUN: dryRun ? 'true' : undefined,\n        GITHUB_TOKEN_SECRET: props.githubTokenSecret.secretArn,\n        VERSION: props.version,\n        GIT_BRANCH: props.gitBranch,\n        GIT_USER_NAME: props.gitUserName,\n        GIT_USER_EMAIL: props.gitUserEmail,\n        GIT_COMMIT_MESSAGE: props.gitCommitMessage,\n        SSM_PREFIX: props.ssmPrefix,\n      }),\n    });\n\n    if (shellable.role) {\n      permissions.grantSecretRead(props.githubTokenSecret, shellable.role);\n    }\n\n    grantSsmPrefix(shellable.role, props.ssmPrefix);\n\n    this.role = shellable.role;\n    this.project = shellable.project;\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, id: string, options: AddToPipelineOptions): void {\n    stage.addAction(new cpipeline_actions.CodeBuildAction({\n      actionName: id,\n      input: options.inputArtifact || new cpipeline.Artifact(),\n      runOrder: options.runOrder,\n      project: this.project,\n    }));\n  }\n}\n\nfunction grantSsmPrefix(role: iam.IRole, ssmPrefix?: string) {\n  if (ssmPrefix) {\n    if (!ssmPrefix.startsWith('/')) {\n      throw new Error(`SSM prefix should start with '/', got: ${ssmPrefix}`);\n    }\n    if (ssmPrefix.endsWith('/')) {\n      throw new Error(`SSM prefix must not end with '/', got: ${ssmPrefix}`);\n    }\n\n    role?.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['ssm:PutParameter', 'ssm:GetParameter'],\n      resources: [Stack.of(role).formatArn({\n        service: 'ssm',\n        resource: 'parameter',\n        resourceName: `${ssmPrefix.slice(1)}/*`,\n      })],\n    }));\n  }\n}"]}
package/package.json CHANGED
@@ -97,7 +97,7 @@
97
97
  "publishConfig": {
98
98
  "access": "public"
99
99
  },
100
- "version": "15.0.4",
100
+ "version": "15.0.5",
101
101
  "jest": {
102
102
  "coverageProvider": "v8",
103
103
  "testMatch": [
@@ -1,185 +0,0 @@
1
- #!/bin/bash
2
- set -eu # we don't want "pipefail" to implement idempotency
3
-
4
- ###
5
- # Usage: ./publish-mvn.sh
6
- #
7
- # Publishes the content of a release bundle (current directory)to Maven Central.
8
- #
9
- # This script expects the following environment variables to be set to appropriate
10
- # values (which can be achieved by using scripts/with-signing-key.sh):
11
- #
12
- # + GNUPGHOME - A GnuPG home directory containing the signing key
13
- # + KEY_ID - The ID of the GnuPG key that will be used for signing
14
- # + KEY_PASSPHRASE - The passphrase of the provided key.
15
- # + FOR_REAL - Set to "true" to do actual publishing
16
- # + STAGING_PROFILE_ID - The Maven Central (sonatype) staging profile ID (e.g. 68a05363083174)
17
- # + MAVEN_USERNAME - User name for Sonatype
18
- # + MAVEN_PASSWORD - Password for Sonatype
19
- ###
20
-
21
- error() { echo "❌ $@"; exit 1; }
22
-
23
- [ -z "${GNUPGHOME:-}" ] && error "GNUPGHOME is required"
24
- [ -z "${KEY_ID:-}" ] && error "KEY_ID is required"
25
- [ -z "${KEY_PASSPHRASE:-}" ] && echo "KEY_PASSPHRASE is required"
26
- [ -z "${STAGING_PROFILE_ID:-}" ] && echo "STAGING_PROFILE_ID is required"
27
- [ -z "${MAVEN_USERNAME:-}" ] && echo "MAVEN_USERNAME is required"
28
- [ -z "${MAVEN_PASSWORD:-}" ] && echo "MAVEN_PASSWORD is required"
29
-
30
- if [[ "${FOR_REAL:-}" == "true" ]]; then
31
- mvn=mvn
32
- dry_run=false
33
- else
34
- echo "==========================================="
35
- echo " 🏜️ DRY-RUN MODE 🏜️"
36
- echo
37
- echo "Set FOR_REAL=true to do actual publishing!"
38
- echo "==========================================="
39
- mvn="echo mvn"
40
- dry_run=true
41
- fi
42
-
43
- staging=$(mktemp -d)
44
- workdir=$(mktemp -d)
45
-
46
- if [[ ! -d ./java ]]; then
47
- echo "❌ No JARS to publish: 'java/' directory is missing."
48
- exit 1
49
- fi
50
-
51
- echo "📦 Publishing to Maven Central"
52
-
53
- # Create a settings.xml file with the user+password for maven
54
- mvn_settings="${workdir}/mvn-settings.xml"
55
- cat > ${mvn_settings} <<-EOF
56
- <?xml version="1.0" encoding="UTF-8" ?>
57
- <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
58
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
59
- xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0
60
- http://maven.apache.org/xsd/settings-1.0.0.xsd">
61
- <servers>
62
- <server>
63
- <id>ossrh</id>
64
- <username>${MAVEN_USERNAME}</username>
65
- <password>${MAVEN_PASSWORD}</password>
66
- </server>
67
- </servers>
68
- </settings>
69
- EOF
70
-
71
- echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
72
- echo " Preparing repository"
73
- echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
74
-
75
- # Sign and stage our artifacts into a local directory
76
- found=false
77
- for pom in $(find ./java -name '*.pom'); do
78
- found=true
79
-
80
- source_arg=""
81
- if [[ -f ${pom/.pom/-sources.jar} ]]; then
82
- source_arg="-Dsources=${pom/.pom/-sources.jar}"
83
- fi
84
-
85
- javadoc_arg=""
86
- if [[ -f ${pom/.pom/-javadoc.jar} ]]; then
87
- javadoc_arg="-Djavadoc=${pom/.pom/-javadoc.jar}"
88
- fi
89
-
90
- $mvn --settings=${mvn_settings} gpg:sign-and-deploy-file \
91
- -Durl=file://${staging} \
92
- -DrepositoryId=maven-central \
93
- -Dgpg.homedir=${GNUPGHOME} \
94
- -Dgpg.keyname=0x${KEY_ID} \
95
- -Dgpg.passphrase=${KEY_PASSPHRASE} \
96
- -DpomFile=${pom} \
97
- -Dfile=${pom/.pom/.jar} \
98
- $source_arg \
99
- $javadoc_arg
100
- done
101
-
102
- if ! $found; then
103
- echo "❌ No JARS to publish: no .pom files found in java/ directory."
104
- exit 1
105
- fi
106
-
107
- echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
108
- echo " Deploying and closing repository..."
109
- echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
110
-
111
- nexus_staging_maven_plugin_version='1.6.13'
112
- staging_output="${workdir}/deploy-output.txt"
113
- $mvn --settings=${mvn_settings} \
114
- org.sonatype.plugins:nexus-staging-maven-plugin:${nexus_staging_maven_plugin_version}:deploy-staged-repository \
115
- -DrepositoryDirectory=${staging} \
116
- -DnexusUrl=${MAVEN_ENDPOINT:-https://oss.sonatype.org} \
117
- -DserverId=ossrh \
118
- -DautoReleaseAfterClose=true \
119
- -DstagingProgressTimeoutMinutes=10 \
120
- -DstagingProfileId=${STAGING_PROFILE_ID} | tee ${staging_output}
121
-
122
- # we need to consule PIPESTATUS sinec "tee" is the last command
123
- if [ ${PIPESTATUS[0]} -ne 0 ]; then
124
- echo "❌ Repository deployment failed"
125
- exit 1
126
- fi
127
-
128
- echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
129
- echo " Releasing repository"
130
- echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
131
-
132
- # Extract the ID of the closed repository from the log output of "deploy-staged-repository"
133
- # This is because "deploy-staged-repository" doesn't seem to support autoReleaseAfterClose
134
- # See https://issues.sonatype.org/browse/OSSRH-42487
135
- if $dry_run; then
136
- echo 'Closing staging repository with ID "dummyrepo"' > ${staging_output}
137
- fi
138
-
139
- repository_id="$(cat ${staging_output} | grep "Closing staging repository with ID" | cut -d'"' -f2)"
140
- if [ -z "${repository_id}" ]; then
141
- echo "❌ Unable to extract repository ID from deploy-staged-repository output."
142
- echo "This means it failed to close or there was an unexpected problem."
143
- echo "At any rate, we can't release it. Sorry"
144
- exit 1
145
- fi
146
-
147
- echo "Repository ID: ${repository_id}"
148
-
149
- # Create a dummy pom.xml because the "release" goal needs one, but it doesn't care about it at all
150
- release_pom="${workdir}/release-pom.xml"
151
- cat > ${release_pom} <<HERE
152
- <?xml version="1.0" encoding="UTF-8"?>
153
- <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
154
- <modelVersion>4.0.0</modelVersion>
155
- <groupId>dummy</groupId>
156
- <artifactId>dummy</artifactId>
157
- <version>0.0.0</version>
158
- </project>
159
- HERE
160
-
161
- # Release!
162
- release_output="${workdir}/release-output.txt"
163
- export MAVEN_OPTS="--add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.text=ALL-UNNAMED --add-opens=java.desktop/java.awt.font=ALL-UNNAMED"
164
- $mvn --settings ${mvn_settings} -f ${release_pom} \
165
- org.sonatype.plugins:nexus-staging-maven-plugin:${nexus_staging_maven_plugin_version}:release \
166
- -DserverId=ossrh \
167
- -DnexusUrl=${MAVEN_ENDPOINT:-https://oss.sonatype.org} \
168
- -DstagingProfileId=${STAGING_PROFILE_ID} \
169
- -DstagingRepositoryId=${repository_id} | tee ${release_output}
170
-
171
- # If release failed, check if this was caused because we are trying to publish
172
- # the same version again, which is not an error. The magic string "does not
173
- # allow updating artifact" for a ".pom" file indicates that we are trying to
174
- # override an existing version. Otherwise, fail!
175
- if [ ${PIPESTATUS[0]} -ne 0 ]; then
176
- if cat ${release_output} | grep "does not allow updating artifact" | grep -q ".pom"; then
177
- echo "⚠️ Artifact already published. Skipping"
178
- else
179
- echo "❌ Release failed"
180
- exit 1
181
- fi
182
- fi
183
-
184
- echo "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
185
- echo "✅ All Done!"