cdk-assets 2.154.9 → 2.155.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,18 @@
1
1
  import { DockerFactory } from './docker';
2
2
  import { IAws } from '../aws';
3
3
  import { EventType } from '../progress';
4
+ /**
5
+ * Options for publishing an asset.
6
+ */
7
+ export interface PublishOptions {
8
+ /**
9
+ * Whether or not to allow cross account publishing. That is,
10
+ * publish to a bucket belonging to a different account than the target account.
11
+ *
12
+ * @default true
13
+ */
14
+ readonly allowCrossAccount?: boolean;
15
+ }
4
16
  /**
5
17
  * Handler for asset building and publishing.
6
18
  */
@@ -12,7 +24,7 @@ export interface IAssetHandler {
12
24
  /**
13
25
  * Publish the asset.
14
26
  */
15
- publish(): Promise<void>;
27
+ publish(options?: PublishOptions): Promise<void>;
16
28
  /**
17
29
  * Return whether the asset already exists
18
30
  */
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQtaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImFzc2V0LWhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERvY2tlckZhY3RvcnkgfSBmcm9tICcuL2RvY2tlcic7XG5pbXBvcnQgeyBJQXdzIH0gZnJvbSAnLi4vYXdzJztcbmltcG9ydCB7IEV2ZW50VHlwZSB9IGZyb20gJy4uL3Byb2dyZXNzJztcblxuLyoqXG4gKiBIYW5kbGVyIGZvciBhc3NldCBidWlsZGluZyBhbmQgcHVibGlzaGluZy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJQXNzZXRIYW5kbGVyIHtcbiAgLyoqXG4gICAqIEJ1aWxkIHRoZSBhc3NldC5cbiAgICovXG4gIGJ1aWxkKCk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFB1Ymxpc2ggdGhlIGFzc2V0LlxuICAgKi9cbiAgcHVibGlzaCgpOiBQcm9taXNlPHZvaWQ+O1xuXG4gIC8qKlxuICAgKiBSZXR1cm4gd2hldGhlciB0aGUgYXNzZXQgYWxyZWFkeSBleGlzdHNcbiAgICovXG4gIGlzUHVibGlzaGVkKCk6IFByb21pc2U8Ym9vbGVhbj47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUhhbmRsZXJIb3N0IHtcbiAgcmVhZG9ubHkgYXdzOiBJQXdzO1xuICByZWFkb25seSBhYm9ydGVkOiBib29sZWFuO1xuICByZWFkb25seSBkb2NrZXJGYWN0b3J5OiBEb2NrZXJGYWN0b3J5O1xuXG4gIGVtaXRNZXNzYWdlKHR5cGU6IEV2ZW50VHlwZSwgbTogc3RyaW5nKTogdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJSGFuZGxlck9wdGlvbnMge1xuICAvKipcbiAgICogU3VwcHJlc3MgYWxsIG91dHB1dFxuICAgKi9cbiAgcmVhZG9ubHkgcXVpZXQ/OiBib29sZWFuO1xufVxuIl19
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQtaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImFzc2V0LWhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERvY2tlckZhY3RvcnkgfSBmcm9tICcuL2RvY2tlcic7XG5pbXBvcnQgeyBJQXdzIH0gZnJvbSAnLi4vYXdzJztcbmltcG9ydCB7IEV2ZW50VHlwZSB9IGZyb20gJy4uL3Byb2dyZXNzJztcblxuLyoqXG4gKiBPcHRpb25zIGZvciBwdWJsaXNoaW5nIGFuIGFzc2V0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFB1Ymxpc2hPcHRpb25zIHtcbiAgLyoqXG4gICAqIFdoZXRoZXIgb3Igbm90IHRvIGFsbG93IGNyb3NzIGFjY291bnQgcHVibGlzaGluZy4gVGhhdCBpcyxcbiAgICogcHVibGlzaCB0byBhIGJ1Y2tldCBiZWxvbmdpbmcgdG8gYSBkaWZmZXJlbnQgYWNjb3VudCB0aGFuIHRoZSB0YXJnZXQgYWNjb3VudC5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgcmVhZG9ubHkgYWxsb3dDcm9zc0FjY291bnQ/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIEhhbmRsZXIgZm9yIGFzc2V0IGJ1aWxkaW5nIGFuZCBwdWJsaXNoaW5nLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIElBc3NldEhhbmRsZXIge1xuICAvKipcbiAgICogQnVpbGQgdGhlIGFzc2V0LlxuICAgKi9cbiAgYnVpbGQoKTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogUHVibGlzaCB0aGUgYXNzZXQuXG4gICAqL1xuICBwdWJsaXNoKG9wdGlvbnM/OiBQdWJsaXNoT3B0aW9ucyk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFJldHVybiB3aGV0aGVyIHRoZSBhc3NldCBhbHJlYWR5IGV4aXN0c1xuICAgKi9cbiAgaXNQdWJsaXNoZWQoKTogUHJvbWlzZTxib29sZWFuPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJSGFuZGxlckhvc3Qge1xuICByZWFkb25seSBhd3M6IElBd3M7XG4gIHJlYWRvbmx5IGFib3J0ZWQ6IGJvb2xlYW47XG4gIHJlYWRvbmx5IGRvY2tlckZhY3Rvcnk6IERvY2tlckZhY3Rvcnk7XG5cbiAgZW1pdE1lc3NhZ2UodHlwZTogRXZlbnRUeXBlLCBtOiBzdHJpbmcpOiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElIYW5kbGVyT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBTdXBwcmVzcyBhbGwgb3V0cHV0XG4gICAqL1xuICByZWFkb25seSBxdWlldD86IGJvb2xlYW47XG59XG4iXX0=
@@ -1,5 +1,5 @@
1
1
  import { FileManifestEntry } from '../../asset-manifest';
2
- import { IAssetHandler, IHandlerHost } from '../asset-handler';
2
+ import { IAssetHandler, IHandlerHost, type PublishOptions } from '../asset-handler';
3
3
  export declare class FileAssetHandler implements IAssetHandler {
4
4
  private readonly workDir;
5
5
  private readonly asset;
@@ -8,7 +8,7 @@ export declare class FileAssetHandler implements IAssetHandler {
8
8
  constructor(workDir: string, asset: FileManifestEntry, host: IHandlerHost);
9
9
  build(): Promise<void>;
10
10
  isPublished(): Promise<boolean>;
11
- publish(): Promise<void>;
11
+ publish(options?: PublishOptions): Promise<void>;
12
12
  private packageFile;
13
13
  private externalPackageFile;
14
14
  }
@@ -44,7 +44,7 @@ class FileAssetHandler {
44
44
  }
45
45
  return false;
46
46
  }
47
- async publish() {
47
+ async publish(options = {}) {
48
48
  const destination = await (0, placeholders_1.replaceAwsPlaceholders)(this.asset.destination, this.host.aws);
49
49
  const s3Url = `s3://${destination.bucketName}/${destination.objectKey}`;
50
50
  const clientOptions = (0, _1.destinationToClientOptions)(destination);
@@ -53,14 +53,20 @@ class FileAssetHandler {
53
53
  const bucketInfo = BucketInformation.for(this.host);
54
54
  // A thunk for describing the current account. Used when we need to format an error
55
55
  // message, not in the success case.
56
- const account = async () => (await this.host.aws.discoverTargetAccount(clientOptions))?.accountId;
57
- switch (await bucketInfo.bucketOwnership(s3, destination.bucketName)) {
56
+ const account = async () => (await this.host.aws.discoverTargetAccount(clientOptions)).accountId;
57
+ const allowCrossAccount = options.allowCrossAccount ?? true;
58
+ switch (await bucketInfo.bucketOwnership(s3, destination.bucketName, allowCrossAccount ? undefined : await account())) {
58
59
  case BucketOwnership.MINE:
59
60
  break;
60
61
  case BucketOwnership.DOES_NOT_EXIST:
61
62
  throw new Error(`No bucket named '${destination.bucketName}'. Is account ${await account()} bootstrapped?`);
62
- case BucketOwnership.SOMEONE_ELSES_OR_NO_ACCESS:
63
- throw new Error(`Bucket named '${destination.bucketName}' exists, but not in account ${await account()}. Wrong account?`);
63
+ case BucketOwnership.NO_ACCESS:
64
+ throw new Error(`Bucket named '${destination.bucketName}' exists, but we dont have access to it.`);
65
+ case BucketOwnership.SOMEONE_ELSES_AND_HAVE_ACCESS:
66
+ if (!allowCrossAccount) {
67
+ throw new Error(`Bucket named '${destination.bucketName}' exists, but not in account ${await account()}. Wrong account?`);
68
+ }
69
+ break;
64
70
  }
65
71
  if (await objectExists(s3, destination.bucketName, destination.objectKey)) {
66
72
  this.host.emitMessage(progress_1.EventType.FOUND, `Found ${s3Url}`);
@@ -84,7 +90,7 @@ class FileAssetHandler {
84
90
  };
85
91
  break;
86
92
  case 'does_not_exist':
87
- this.host.emitMessage(progress_1.EventType.DEBUG, `No bucket named '${destination.bucketName}'. Is account ${await account()} bootstrapped?`);
93
+ this.host.emitMessage(progress_1.EventType.DEBUG, `No bucket named '${destination.bucketName}'. Is account ${account} bootstrapped?`);
88
94
  break;
89
95
  case 'access_denied':
90
96
  this.host.emitMessage(progress_1.EventType.DEBUG, `Could not read encryption settings of bucket '${destination.bucketName}': uploading with default settings ("cdk bootstrap" to version 9 if your organization's policies prevent a successful upload or to get rid of this message).`);
@@ -140,7 +146,8 @@ var BucketOwnership;
140
146
  (function (BucketOwnership) {
141
147
  BucketOwnership[BucketOwnership["DOES_NOT_EXIST"] = 0] = "DOES_NOT_EXIST";
142
148
  BucketOwnership[BucketOwnership["MINE"] = 1] = "MINE";
143
- BucketOwnership[BucketOwnership["SOMEONE_ELSES_OR_NO_ACCESS"] = 2] = "SOMEONE_ELSES_OR_NO_ACCESS";
149
+ BucketOwnership[BucketOwnership["NO_ACCESS"] = 2] = "NO_ACCESS";
150
+ BucketOwnership[BucketOwnership["SOMEONE_ELSES_AND_HAVE_ACCESS"] = 3] = "SOMEONE_ELSES_AND_HAVE_ACCESS";
144
151
  })(BucketOwnership || (BucketOwnership = {}));
145
152
  async function objectExists(s3, bucket, key) {
146
153
  /*
@@ -184,15 +191,29 @@ class BucketInformation {
184
191
  this.ownerships = new Map();
185
192
  this.encryptions = new Map();
186
193
  }
187
- async bucketOwnership(s3, bucket) {
188
- return cached(this.ownerships, bucket, () => this._bucketOwnership(s3, bucket));
194
+ async bucketOwnership(s3, bucket, expectedAccount) {
195
+ return cached(this.ownerships, bucket, async () => {
196
+ const anyAccount = await this._bucketOwnership(s3, bucket);
197
+ switch (anyAccount) {
198
+ case BucketOwnership.MINE:
199
+ if (expectedAccount &&
200
+ (await this._bucketOwnership(s3, bucket, expectedAccount)) === BucketOwnership.NO_ACCESS) {
201
+ // if the only difference between MINE and NO_ACCESS is the expected account,
202
+ // then its definitely someone else's bucket.
203
+ return BucketOwnership.SOMEONE_ELSES_AND_HAVE_ACCESS;
204
+ }
205
+ return BucketOwnership.MINE;
206
+ default:
207
+ return anyAccount;
208
+ }
209
+ });
189
210
  }
190
211
  async bucketEncryption(s3, bucket) {
191
212
  return cached(this.encryptions, bucket, () => this._bucketEncryption(s3, bucket));
192
213
  }
193
- async _bucketOwnership(s3, bucket) {
214
+ async _bucketOwnership(s3, bucket, account) {
194
215
  try {
195
- await s3.getBucketLocation({ Bucket: bucket }).promise();
216
+ await s3.getBucketLocation({ Bucket: bucket, ExpectedBucketOwner: account }).promise();
196
217
  return BucketOwnership.MINE;
197
218
  }
198
219
  catch (e) {
@@ -200,7 +221,7 @@ class BucketInformation {
200
221
  return BucketOwnership.DOES_NOT_EXIST;
201
222
  }
202
223
  if (['AccessDenied', 'AllAccessDisabled'].includes(e.code)) {
203
- return BucketOwnership.SOMEONE_ELSES_OR_NO_ACCESS;
224
+ return BucketOwnership.NO_ACCESS;
204
225
  }
205
226
  throw e;
206
227
  }
@@ -243,4 +264,4 @@ async function cached(cache, key, factory) {
243
264
  cache.set(key, fresh);
244
265
  return fresh;
245
266
  }
246
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files.js","sourceRoot":"","sources":["files.ts"],"names":[],"mappings":"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","sourcesContent":["import { createReadStream, promises as fs } from 'fs';\nimport * as path from 'path';\nimport { FileAssetPackaging, FileSource } from '@aws-cdk/cloud-assembly-schema';\nimport * as mime from 'mime';\nimport { destinationToClientOptions } from '.';\nimport { FileManifestEntry } from '../../asset-manifest';\nimport { EventType } from '../../progress';\nimport { zipDirectory } from '../archive';\nimport { IAssetHandler, IHandlerHost } from '../asset-handler';\nimport { pathExists } from '../fs-extra';\nimport { replaceAwsPlaceholders } from '../placeholders';\nimport { shell } from '../shell';\n\n/**\n * The size of an empty zip file is 22 bytes\n *\n * Ref: https://en.wikipedia.org/wiki/ZIP_(file_format)\n */\nconst EMPTY_ZIP_FILE_SIZE = 22;\n\nexport class FileAssetHandler implements IAssetHandler {\n  private readonly fileCacheRoot: string;\n\n  constructor(\n    private readonly workDir: string,\n    private readonly asset: FileManifestEntry,\n    private readonly host: IHandlerHost\n  ) {\n    this.fileCacheRoot = path.join(workDir, '.cache');\n  }\n\n  public async build(): Promise<void> {}\n\n  public async isPublished(): Promise<boolean> {\n    const destination = await replaceAwsPlaceholders(this.asset.destination, this.host.aws);\n    const s3Url = `s3://${destination.bucketName}/${destination.objectKey}`;\n    try {\n      const s3 = await this.host.aws.s3Client({\n        ...destinationToClientOptions(destination),\n        quiet: true,\n      });\n      this.host.emitMessage(EventType.CHECK, `Check ${s3Url}`);\n\n      if (await objectExists(s3, destination.bucketName, destination.objectKey)) {\n        this.host.emitMessage(EventType.FOUND, `Found ${s3Url}`);\n        return true;\n      }\n    } catch (e: any) {\n      this.host.emitMessage(EventType.DEBUG, `${e.message}`);\n    }\n    return false;\n  }\n\n  public async publish(): Promise<void> {\n    const destination = await replaceAwsPlaceholders(this.asset.destination, this.host.aws);\n    const s3Url = `s3://${destination.bucketName}/${destination.objectKey}`;\n\n    const clientOptions = destinationToClientOptions(destination);\n    const s3 = await this.host.aws.s3Client(clientOptions);\n    this.host.emitMessage(EventType.CHECK, `Check ${s3Url}`);\n\n    const bucketInfo = BucketInformation.for(this.host);\n\n    // A thunk for describing the current account. Used when we need to format an error\n    // message, not in the success case.\n    const account = async () =>\n      (await this.host.aws.discoverTargetAccount(clientOptions))?.accountId;\n    switch (await bucketInfo.bucketOwnership(s3, destination.bucketName)) {\n      case BucketOwnership.MINE:\n        break;\n      case BucketOwnership.DOES_NOT_EXIST:\n        throw new Error(\n          `No bucket named '${destination.bucketName}'. Is account ${await account()} bootstrapped?`\n        );\n      case BucketOwnership.SOMEONE_ELSES_OR_NO_ACCESS:\n        throw new Error(\n          `Bucket named '${destination.bucketName}' exists, but not in account ${await account()}. Wrong account?`\n        );\n    }\n\n    if (await objectExists(s3, destination.bucketName, destination.objectKey)) {\n      this.host.emitMessage(EventType.FOUND, `Found ${s3Url}`);\n      return;\n    }\n\n    // Identify the the bucket encryption type to set the header on upload\n    // required for SCP rules denying uploads without encryption header\n    let paramsEncryption: { [index: string]: any } = {};\n    const encryption2 = await bucketInfo.bucketEncryption(s3, destination.bucketName);\n    switch (encryption2.type) {\n      case 'no_encryption':\n        break;\n      case 'aes256':\n        paramsEncryption = { ServerSideEncryption: 'AES256' };\n        break;\n      case 'kms':\n        // We must include the key ID otherwise S3 will encrypt with the default key\n        paramsEncryption = {\n          ServerSideEncryption: 'aws:kms',\n          SSEKMSKeyId: encryption2.kmsKeyId,\n        };\n        break;\n      case 'does_not_exist':\n        this.host.emitMessage(\n          EventType.DEBUG,\n          `No bucket named '${destination.bucketName}'. Is account ${await account()} bootstrapped?`\n        );\n        break;\n      case 'access_denied':\n        this.host.emitMessage(\n          EventType.DEBUG,\n          `Could not read encryption settings of bucket '${destination.bucketName}': uploading with default settings (\"cdk bootstrap\" to version 9 if your organization's policies prevent a successful upload or to get rid of this message).`\n        );\n        break;\n    }\n\n    if (this.host.aborted) {\n      return;\n    }\n    const publishFile = this.asset.source.executable\n      ? await this.externalPackageFile(this.asset.source.executable)\n      : await this.packageFile(this.asset.source);\n\n    this.host.emitMessage(EventType.UPLOAD, `Upload ${s3Url}`);\n\n    const params = Object.assign(\n      {},\n      {\n        Bucket: destination.bucketName,\n        Key: destination.objectKey,\n        Body: createReadStream(publishFile.packagedPath),\n        ContentType: publishFile.contentType,\n      },\n      paramsEncryption\n    );\n\n    await s3.upload(params).promise();\n  }\n\n  private async packageFile(source: FileSource): Promise<PackagedFileAsset> {\n    if (!source.path) {\n      throw new Error(\n        `'path' is expected in the File asset source, got: ${JSON.stringify(source)}`\n      );\n    }\n\n    const fullPath = path.resolve(this.workDir, source.path);\n\n    if (source.packaging === FileAssetPackaging.ZIP_DIRECTORY) {\n      const contentType = 'application/zip';\n\n      await fs.mkdir(this.fileCacheRoot, { recursive: true });\n      const packagedPath = path.join(this.fileCacheRoot, `${this.asset.id.assetId}.zip`);\n\n      if (await pathExists(packagedPath)) {\n        this.host.emitMessage(EventType.CACHED, `From cache ${packagedPath}`);\n        return { packagedPath, contentType };\n      }\n\n      this.host.emitMessage(EventType.BUILD, `Zip ${fullPath} -> ${packagedPath}`);\n      await zipDirectory(fullPath, packagedPath, (m) => this.host.emitMessage(EventType.DEBUG, m));\n      return { packagedPath, contentType };\n    } else {\n      const contentType = mime.getType(fullPath) ?? 'application/octet-stream';\n      return { packagedPath: fullPath, contentType };\n    }\n  }\n\n  private async externalPackageFile(executable: string[]): Promise<PackagedFileAsset> {\n    this.host.emitMessage(EventType.BUILD, `Building asset source using command: '${executable}'`);\n\n    return {\n      packagedPath: (await shell(executable, { quiet: true })).trim(),\n      contentType: 'application/zip',\n    };\n  }\n}\n\nenum BucketOwnership {\n  DOES_NOT_EXIST,\n  MINE,\n  SOMEONE_ELSES_OR_NO_ACCESS,\n}\n\ntype BucketEncryption =\n  | { readonly type: 'no_encryption' }\n  | { readonly type: 'aes256' }\n  | { readonly type: 'kms'; readonly kmsKeyId?: string }\n  | { readonly type: 'access_denied' }\n  | { readonly type: 'does_not_exist' };\n\nasync function objectExists(s3: AWS.S3, bucket: string, key: string) {\n  /*\n   * The object existence check here refrains from using the `headObject` operation because this\n   * would create a negative cache entry, making GET-after-PUT eventually consistent. This has been\n   * observed to result in CloudFormation issuing \"ValidationError: S3 error: Access Denied\", for\n   * example in https://github.com/aws/aws-cdk/issues/6430.\n   *\n   * To prevent this, we are instead using the listObjectsV2 call, using the looked up key as the\n   * prefix, and limiting results to 1. Since the list operation returns keys ordered by binary\n   * UTF-8 representation, the key we are looking for is guaranteed to always be the first match\n   * returned if it exists.\n   *\n   * If the file is too small, we discount it as a cache hit. There is an issue\n   * somewhere that sometimes produces empty zip files, and we would otherwise\n   * never retry building those assets without users having to manually clear\n   * their bucket, which is a bad experience.\n   */\n  const response = await s3.listObjectsV2({ Bucket: bucket, Prefix: key, MaxKeys: 1 }).promise();\n  return (\n    response.Contents != null &&\n    response.Contents.some(\n      (object) => object.Key === key && (object.Size == null || object.Size > EMPTY_ZIP_FILE_SIZE)\n    )\n  );\n}\n\n/**\n * A packaged asset which can be uploaded (either a single file or directory)\n */\ninterface PackagedFileAsset {\n  /**\n   * Path of the file or directory\n   */\n  readonly packagedPath: string;\n\n  /**\n   * Content type to be added in the S3 upload action\n   *\n   * @default - No content type\n   */\n  readonly contentType?: string;\n}\n\n/**\n * Cache for bucket information, so we don't have to keep doing the same calls again and again\n *\n * We scope the lifetime of the cache to the lifetime of the host, so that we don't have to do\n * anything special for tests and yet the cache will live for the entire lifetime of the asset\n * upload session when used by the CLI.\n */\nclass BucketInformation {\n  public static for(host: IHandlerHost) {\n    const existing = BucketInformation.caches.get(host);\n    if (existing) {\n      return existing;\n    }\n\n    const fresh = new BucketInformation();\n    BucketInformation.caches.set(host, fresh);\n    return fresh;\n  }\n\n  private static readonly caches = new WeakMap<IHandlerHost, BucketInformation>();\n\n  private readonly ownerships = new Map<string, BucketOwnership>();\n  private readonly encryptions = new Map<string, BucketEncryption>();\n\n  private constructor() {}\n\n  public async bucketOwnership(s3: AWS.S3, bucket: string): Promise<BucketOwnership> {\n    return cached(this.ownerships, bucket, () => this._bucketOwnership(s3, bucket));\n  }\n\n  public async bucketEncryption(s3: AWS.S3, bucket: string): Promise<BucketEncryption> {\n    return cached(this.encryptions, bucket, () => this._bucketEncryption(s3, bucket));\n  }\n\n  private async _bucketOwnership(s3: AWS.S3, bucket: string): Promise<BucketOwnership> {\n    try {\n      await s3.getBucketLocation({ Bucket: bucket }).promise();\n      return BucketOwnership.MINE;\n    } catch (e: any) {\n      if (e.code === 'NoSuchBucket') {\n        return BucketOwnership.DOES_NOT_EXIST;\n      }\n      if (['AccessDenied', 'AllAccessDisabled'].includes(e.code)) {\n        return BucketOwnership.SOMEONE_ELSES_OR_NO_ACCESS;\n      }\n      throw e;\n    }\n  }\n\n  private async _bucketEncryption(s3: AWS.S3, bucket: string): Promise<BucketEncryption> {\n    try {\n      const encryption = await s3.getBucketEncryption({ Bucket: bucket }).promise();\n      const l = encryption?.ServerSideEncryptionConfiguration?.Rules?.length ?? 0;\n      if (l > 0) {\n        const apply =\n          encryption?.ServerSideEncryptionConfiguration?.Rules[0]\n            ?.ApplyServerSideEncryptionByDefault;\n        let ssealgo = apply?.SSEAlgorithm;\n        if (ssealgo === 'AES256') return { type: 'aes256' };\n        if (ssealgo === 'aws:kms') return { type: 'kms', kmsKeyId: apply?.KMSMasterKeyID };\n      }\n      return { type: 'no_encryption' };\n    } catch (e: any) {\n      if (e.code === 'NoSuchBucket') {\n        return { type: 'does_not_exist' };\n      }\n      if (e.code === 'ServerSideEncryptionConfigurationNotFoundError') {\n        return { type: 'no_encryption' };\n      }\n\n      if (['AccessDenied', 'AllAccessDisabled'].includes(e.code)) {\n        return { type: 'access_denied' };\n      }\n      return { type: 'no_encryption' };\n    }\n  }\n}\n\nasync function cached<A, B>(cache: Map<A, B>, key: A, factory: (x: A) => Promise<B>): Promise<B> {\n  if (cache.has(key)) {\n    return cache.get(key)!;\n  }\n\n  const fresh = await factory(key);\n  cache.set(key, fresh);\n  return fresh;\n}\n"]}
267
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files.js","sourceRoot":"","sources":["files.ts"],"names":[],"mappings":"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","sourcesContent":["import { createReadStream, promises as fs } from 'fs';\nimport * as path from 'path';\nimport { FileAssetPackaging, FileSource } from '@aws-cdk/cloud-assembly-schema';\nimport * as mime from 'mime';\nimport { destinationToClientOptions } from '.';\nimport { FileManifestEntry } from '../../asset-manifest';\nimport { EventType } from '../../progress';\nimport { zipDirectory } from '../archive';\nimport { IAssetHandler, IHandlerHost, type PublishOptions } from '../asset-handler';\nimport { pathExists } from '../fs-extra';\nimport { replaceAwsPlaceholders } from '../placeholders';\nimport { shell } from '../shell';\n\n/**\n * The size of an empty zip file is 22 bytes\n *\n * Ref: https://en.wikipedia.org/wiki/ZIP_(file_format)\n */\nconst EMPTY_ZIP_FILE_SIZE = 22;\n\nexport class FileAssetHandler implements IAssetHandler {\n  private readonly fileCacheRoot: string;\n\n  constructor(\n    private readonly workDir: string,\n    private readonly asset: FileManifestEntry,\n    private readonly host: IHandlerHost\n  ) {\n    this.fileCacheRoot = path.join(workDir, '.cache');\n  }\n\n  public async build(): Promise<void> {}\n\n  public async isPublished(): Promise<boolean> {\n    const destination = await replaceAwsPlaceholders(this.asset.destination, this.host.aws);\n    const s3Url = `s3://${destination.bucketName}/${destination.objectKey}`;\n    try {\n      const s3 = await this.host.aws.s3Client({\n        ...destinationToClientOptions(destination),\n        quiet: true,\n      });\n      this.host.emitMessage(EventType.CHECK, `Check ${s3Url}`);\n\n      if (await objectExists(s3, destination.bucketName, destination.objectKey)) {\n        this.host.emitMessage(EventType.FOUND, `Found ${s3Url}`);\n        return true;\n      }\n    } catch (e: any) {\n      this.host.emitMessage(EventType.DEBUG, `${e.message}`);\n    }\n    return false;\n  }\n\n  public async publish(options: PublishOptions = {}): Promise<void> {\n    const destination = await replaceAwsPlaceholders(this.asset.destination, this.host.aws);\n    const s3Url = `s3://${destination.bucketName}/${destination.objectKey}`;\n\n    const clientOptions = destinationToClientOptions(destination);\n    const s3 = await this.host.aws.s3Client(clientOptions);\n    this.host.emitMessage(EventType.CHECK, `Check ${s3Url}`);\n\n    const bucketInfo = BucketInformation.for(this.host);\n\n    // A thunk for describing the current account. Used when we need to format an error\n    // message, not in the success case.\n    const account = async () =>\n      (await this.host.aws.discoverTargetAccount(clientOptions)).accountId;\n\n    const allowCrossAccount = options.allowCrossAccount ?? true;\n    switch (\n      await bucketInfo.bucketOwnership(\n        s3,\n        destination.bucketName,\n        allowCrossAccount ? undefined : await account()\n      )\n    ) {\n      case BucketOwnership.MINE:\n        break;\n      case BucketOwnership.DOES_NOT_EXIST:\n        throw new Error(\n          `No bucket named '${destination.bucketName}'. Is account ${await account()} bootstrapped?`\n        );\n      case BucketOwnership.NO_ACCESS:\n        throw new Error(\n          `Bucket named '${destination.bucketName}' exists, but we dont have access to it.`\n        );\n      case BucketOwnership.SOMEONE_ELSES_AND_HAVE_ACCESS:\n        if (!allowCrossAccount) {\n          throw new Error(\n            `Bucket named '${destination.bucketName}' exists, but not in account ${await account()}. Wrong account?`\n          );\n        }\n        break;\n    }\n\n    if (await objectExists(s3, destination.bucketName, destination.objectKey)) {\n      this.host.emitMessage(EventType.FOUND, `Found ${s3Url}`);\n      return;\n    }\n\n    // Identify the the bucket encryption type to set the header on upload\n    // required for SCP rules denying uploads without encryption header\n    let paramsEncryption: { [index: string]: any } = {};\n    const encryption2 = await bucketInfo.bucketEncryption(s3, destination.bucketName);\n    switch (encryption2.type) {\n      case 'no_encryption':\n        break;\n      case 'aes256':\n        paramsEncryption = { ServerSideEncryption: 'AES256' };\n        break;\n      case 'kms':\n        // We must include the key ID otherwise S3 will encrypt with the default key\n        paramsEncryption = {\n          ServerSideEncryption: 'aws:kms',\n          SSEKMSKeyId: encryption2.kmsKeyId,\n        };\n        break;\n      case 'does_not_exist':\n        this.host.emitMessage(\n          EventType.DEBUG,\n          `No bucket named '${destination.bucketName}'. Is account ${account} bootstrapped?`\n        );\n        break;\n      case 'access_denied':\n        this.host.emitMessage(\n          EventType.DEBUG,\n          `Could not read encryption settings of bucket '${destination.bucketName}': uploading with default settings (\"cdk bootstrap\" to version 9 if your organization's policies prevent a successful upload or to get rid of this message).`\n        );\n        break;\n    }\n\n    if (this.host.aborted) {\n      return;\n    }\n    const publishFile = this.asset.source.executable\n      ? await this.externalPackageFile(this.asset.source.executable)\n      : await this.packageFile(this.asset.source);\n\n    this.host.emitMessage(EventType.UPLOAD, `Upload ${s3Url}`);\n\n    const params = Object.assign(\n      {},\n      {\n        Bucket: destination.bucketName,\n        Key: destination.objectKey,\n        Body: createReadStream(publishFile.packagedPath),\n        ContentType: publishFile.contentType,\n      },\n      paramsEncryption\n    );\n\n    await s3.upload(params).promise();\n  }\n\n  private async packageFile(source: FileSource): Promise<PackagedFileAsset> {\n    if (!source.path) {\n      throw new Error(\n        `'path' is expected in the File asset source, got: ${JSON.stringify(source)}`\n      );\n    }\n\n    const fullPath = path.resolve(this.workDir, source.path);\n\n    if (source.packaging === FileAssetPackaging.ZIP_DIRECTORY) {\n      const contentType = 'application/zip';\n\n      await fs.mkdir(this.fileCacheRoot, { recursive: true });\n      const packagedPath = path.join(this.fileCacheRoot, `${this.asset.id.assetId}.zip`);\n\n      if (await pathExists(packagedPath)) {\n        this.host.emitMessage(EventType.CACHED, `From cache ${packagedPath}`);\n        return { packagedPath, contentType };\n      }\n\n      this.host.emitMessage(EventType.BUILD, `Zip ${fullPath} -> ${packagedPath}`);\n      await zipDirectory(fullPath, packagedPath, (m) => this.host.emitMessage(EventType.DEBUG, m));\n      return { packagedPath, contentType };\n    } else {\n      const contentType = mime.getType(fullPath) ?? 'application/octet-stream';\n      return { packagedPath: fullPath, contentType };\n    }\n  }\n\n  private async externalPackageFile(executable: string[]): Promise<PackagedFileAsset> {\n    this.host.emitMessage(EventType.BUILD, `Building asset source using command: '${executable}'`);\n\n    return {\n      packagedPath: (await shell(executable, { quiet: true })).trim(),\n      contentType: 'application/zip',\n    };\n  }\n}\n\nenum BucketOwnership {\n  DOES_NOT_EXIST,\n  MINE,\n  NO_ACCESS,\n  SOMEONE_ELSES_AND_HAVE_ACCESS,\n}\n\ntype BucketEncryption =\n  | { readonly type: 'no_encryption' }\n  | { readonly type: 'aes256' }\n  | { readonly type: 'kms'; readonly kmsKeyId?: string }\n  | { readonly type: 'access_denied' }\n  | { readonly type: 'does_not_exist' };\n\nasync function objectExists(s3: AWS.S3, bucket: string, key: string) {\n  /*\n   * The object existence check here refrains from using the `headObject` operation because this\n   * would create a negative cache entry, making GET-after-PUT eventually consistent. This has been\n   * observed to result in CloudFormation issuing \"ValidationError: S3 error: Access Denied\", for\n   * example in https://github.com/aws/aws-cdk/issues/6430.\n   *\n   * To prevent this, we are instead using the listObjectsV2 call, using the looked up key as the\n   * prefix, and limiting results to 1. Since the list operation returns keys ordered by binary\n   * UTF-8 representation, the key we are looking for is guaranteed to always be the first match\n   * returned if it exists.\n   *\n   * If the file is too small, we discount it as a cache hit. There is an issue\n   * somewhere that sometimes produces empty zip files, and we would otherwise\n   * never retry building those assets without users having to manually clear\n   * their bucket, which is a bad experience.\n   */\n  const response = await s3.listObjectsV2({ Bucket: bucket, Prefix: key, MaxKeys: 1 }).promise();\n  return (\n    response.Contents != null &&\n    response.Contents.some(\n      (object) => object.Key === key && (object.Size == null || object.Size > EMPTY_ZIP_FILE_SIZE)\n    )\n  );\n}\n\n/**\n * A packaged asset which can be uploaded (either a single file or directory)\n */\ninterface PackagedFileAsset {\n  /**\n   * Path of the file or directory\n   */\n  readonly packagedPath: string;\n\n  /**\n   * Content type to be added in the S3 upload action\n   *\n   * @default - No content type\n   */\n  readonly contentType?: string;\n}\n\n/**\n * Cache for bucket information, so we don't have to keep doing the same calls again and again\n *\n * We scope the lifetime of the cache to the lifetime of the host, so that we don't have to do\n * anything special for tests and yet the cache will live for the entire lifetime of the asset\n * upload session when used by the CLI.\n */\nclass BucketInformation {\n  public static for(host: IHandlerHost) {\n    const existing = BucketInformation.caches.get(host);\n    if (existing) {\n      return existing;\n    }\n\n    const fresh = new BucketInformation();\n    BucketInformation.caches.set(host, fresh);\n    return fresh;\n  }\n\n  private static readonly caches = new WeakMap<IHandlerHost, BucketInformation>();\n\n  private readonly ownerships = new Map<string, BucketOwnership>();\n  private readonly encryptions = new Map<string, BucketEncryption>();\n\n  private constructor() {}\n\n  public async bucketOwnership(\n    s3: AWS.S3,\n    bucket: string,\n    expectedAccount?: string\n  ): Promise<BucketOwnership> {\n    return cached(this.ownerships, bucket, async () => {\n      const anyAccount = await this._bucketOwnership(s3, bucket);\n\n      switch (anyAccount) {\n        case BucketOwnership.MINE:\n          if (\n            expectedAccount &&\n            (await this._bucketOwnership(s3, bucket, expectedAccount)) === BucketOwnership.NO_ACCESS\n          ) {\n            // if the only difference between MINE and NO_ACCESS is the expected account,\n            // then its definitely someone else's bucket.\n            return BucketOwnership.SOMEONE_ELSES_AND_HAVE_ACCESS;\n          }\n          return BucketOwnership.MINE;\n        default:\n          return anyAccount;\n      }\n    });\n  }\n\n  public async bucketEncryption(s3: AWS.S3, bucket: string): Promise<BucketEncryption> {\n    return cached(this.encryptions, bucket, () => this._bucketEncryption(s3, bucket));\n  }\n\n  private async _bucketOwnership(\n    s3: AWS.S3,\n    bucket: string,\n    account?: string\n  ): Promise<BucketOwnership.MINE | BucketOwnership.DOES_NOT_EXIST | BucketOwnership.NO_ACCESS> {\n    try {\n      await s3.getBucketLocation({ Bucket: bucket, ExpectedBucketOwner: account }).promise();\n      return BucketOwnership.MINE;\n    } catch (e: any) {\n      if (e.code === 'NoSuchBucket') {\n        return BucketOwnership.DOES_NOT_EXIST;\n      }\n      if (['AccessDenied', 'AllAccessDisabled'].includes(e.code)) {\n        return BucketOwnership.NO_ACCESS;\n      }\n      throw e;\n    }\n  }\n\n  private async _bucketEncryption(s3: AWS.S3, bucket: string): Promise<BucketEncryption> {\n    try {\n      const encryption = await s3.getBucketEncryption({ Bucket: bucket }).promise();\n      const l = encryption?.ServerSideEncryptionConfiguration?.Rules?.length ?? 0;\n      if (l > 0) {\n        const apply =\n          encryption?.ServerSideEncryptionConfiguration?.Rules[0]\n            ?.ApplyServerSideEncryptionByDefault;\n        let ssealgo = apply?.SSEAlgorithm;\n        if (ssealgo === 'AES256') return { type: 'aes256' };\n        if (ssealgo === 'aws:kms') return { type: 'kms', kmsKeyId: apply?.KMSMasterKeyID };\n      }\n      return { type: 'no_encryption' };\n    } catch (e: any) {\n      if (e.code === 'NoSuchBucket') {\n        return { type: 'does_not_exist' };\n      }\n      if (e.code === 'ServerSideEncryptionConfigurationNotFoundError') {\n        return { type: 'no_encryption' };\n      }\n\n      if (['AccessDenied', 'AllAccessDisabled'].includes(e.code)) {\n        return { type: 'access_denied' };\n      }\n      return { type: 'no_encryption' };\n    }\n  }\n}\n\nasync function cached<A, B>(cache: Map<A, B>, key: A, factory: (x: A) => Promise<B>): Promise<B> {\n  if (cache.has(key)) {\n    return cache.get(key)!;\n  }\n\n  const fresh = await factory(key);\n  cache.set(key, fresh);\n  return fresh;\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import { AssetManifest, IManifestEntry } from './asset-manifest';
2
2
  import { IAws } from './aws';
3
+ import { type PublishOptions } from './private/asset-handler';
3
4
  import { IPublishProgress, IPublishProgressListener } from './progress';
4
5
  export interface AssetPublishingOptions {
5
6
  /**
@@ -81,7 +82,7 @@ export declare class AssetPublishing implements IPublishProgress {
81
82
  /**
82
83
  * Publish all assets from the manifest
83
84
  */
84
- publish(): Promise<void>;
85
+ publish(options?: PublishOptions): Promise<void>;
85
86
  /**
86
87
  * Build a single asset from the manifest
87
88
  */
@@ -89,7 +90,7 @@ export declare class AssetPublishing implements IPublishProgress {
89
90
  /**
90
91
  * Publish a single asset from the manifest
91
92
  */
92
- publishEntry(asset: IManifestEntry): Promise<boolean>;
93
+ publishEntry(asset: IManifestEntry, options?: PublishOptions): Promise<boolean>;
93
94
  /**
94
95
  * Return whether a single asset is published
95
96
  */
package/lib/publishing.js CHANGED
@@ -36,13 +36,13 @@ class AssetPublishing {
36
36
  /**
37
37
  * Publish all assets from the manifest
38
38
  */
39
- async publish() {
39
+ async publish(options = {}) {
40
40
  if (this.publishInParallel) {
41
- await Promise.all(this.assets.map(async (asset) => this.publishAsset(asset)));
41
+ await Promise.all(this.assets.map(async (asset) => this.publishAsset(asset, options)));
42
42
  }
43
43
  else {
44
44
  for (const asset of this.assets) {
45
- if (!(await this.publishAsset(asset))) {
45
+ if (!(await this.publishAsset(asset, options))) {
46
46
  break;
47
47
  }
48
48
  }
@@ -81,13 +81,13 @@ class AssetPublishing {
81
81
  /**
82
82
  * Publish a single asset from the manifest
83
83
  */
84
- async publishEntry(asset) {
84
+ async publishEntry(asset, options = {}) {
85
85
  try {
86
86
  if (this.progressEvent(progress_1.EventType.START, `Publishing ${asset.id}`)) {
87
87
  return false;
88
88
  }
89
89
  const handler = this.assetHandler(asset);
90
- await handler.publish();
90
+ await handler.publish(options);
91
91
  if (this.aborted) {
92
92
  throw new Error('Aborted');
93
93
  }
@@ -117,7 +117,7 @@ class AssetPublishing {
117
117
  * @param asset The asset to publish
118
118
  * @returns false when publishing should stop
119
119
  */
120
- async publishAsset(asset) {
120
+ async publishAsset(asset, options = {}) {
121
121
  try {
122
122
  if (this.progressEvent(progress_1.EventType.START, `Publishing ${asset.id}`)) {
123
123
  return false;
@@ -127,7 +127,7 @@ class AssetPublishing {
127
127
  await handler.build();
128
128
  }
129
129
  if (this.publishAssets) {
130
- await handler.publish();
130
+ await handler.publish(options);
131
131
  }
132
132
  if (this.aborted) {
133
133
  throw new Error('Aborted');
@@ -183,4 +183,4 @@ class AssetPublishing {
183
183
  }
184
184
  }
185
185
  exports.AssetPublishing = AssetPublishing;
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["publishing.ts"],"names":[],"mappings":"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","sourcesContent":["import { AssetManifest, IManifestEntry } from './asset-manifest';\nimport { IAws } from './aws';\nimport { IAssetHandler, IHandlerHost } from './private/asset-handler';\nimport { DockerFactory } from './private/docker';\nimport { makeAssetHandler } from './private/handlers';\nimport { EventType, IPublishProgress, IPublishProgressListener } from './progress';\n\nexport interface AssetPublishingOptions {\n  /**\n   * Entry point for AWS client\n   */\n  readonly aws: IAws;\n\n  /**\n   * Listener for progress events\n   *\n   * @default No listener\n   */\n  readonly progressListener?: IPublishProgressListener;\n\n  /**\n   * Whether to throw at the end if there were errors\n   *\n   * @default true\n   */\n  readonly throwOnError?: boolean;\n\n  /**\n   * Whether to publish in parallel, when 'publish()' is called\n   *\n   * @default false\n   */\n  readonly publishInParallel?: boolean;\n\n  /**\n   * Whether to build assets, when 'publish()' is called\n   *\n   * @default true\n   */\n  readonly buildAssets?: boolean;\n\n  /**\n   * Whether to publish assets, when 'publish()' is called\n   *\n   * @default true\n   */\n  readonly publishAssets?: boolean;\n\n  /**\n   * Whether to print publishing logs\n   *\n   * @default true\n   */\n  readonly quiet?: boolean;\n}\n\n/**\n * A failure to publish an asset\n */\nexport interface FailedAsset {\n  /**\n   * The asset that failed to publish\n   */\n  readonly asset: IManifestEntry;\n\n  /**\n   * The failure that occurred\n   */\n  readonly error: Error;\n}\n\nexport class AssetPublishing implements IPublishProgress {\n  /**\n   * The message for the IPublishProgress interface\n   */\n  public message: string = 'Starting';\n\n  /**\n   * The current asset for the IPublishProgress interface\n   */\n  public currentAsset?: IManifestEntry;\n  public readonly failures = new Array<FailedAsset>();\n  private readonly assets: IManifestEntry[];\n\n  private readonly totalOperations: number;\n  private completedOperations: number = 0;\n  private aborted = false;\n  private readonly handlerHost: IHandlerHost;\n  private readonly publishInParallel: boolean;\n  private readonly buildAssets: boolean;\n  private readonly publishAssets: boolean;\n  private readonly handlerCache = new Map<IManifestEntry, IAssetHandler>();\n\n  constructor(\n    private readonly manifest: AssetManifest,\n    private readonly options: AssetPublishingOptions\n  ) {\n    this.assets = manifest.entries;\n    this.totalOperations = this.assets.length;\n    this.publishInParallel = options.publishInParallel ?? false;\n    this.buildAssets = options.buildAssets ?? true;\n    this.publishAssets = options.publishAssets ?? true;\n\n    const self = this;\n    this.handlerHost = {\n      aws: this.options.aws,\n      get aborted() {\n        return self.aborted;\n      },\n      emitMessage(t, m) {\n        self.progressEvent(t, m);\n      },\n      dockerFactory: new DockerFactory(),\n    };\n  }\n\n  /**\n   * Publish all assets from the manifest\n   */\n  public async publish(): Promise<void> {\n    if (this.publishInParallel) {\n      await Promise.all(this.assets.map(async (asset) => this.publishAsset(asset)));\n    } else {\n      for (const asset of this.assets) {\n        if (!(await this.publishAsset(asset))) {\n          break;\n        }\n      }\n    }\n\n    if ((this.options.throwOnError ?? true) && this.failures.length > 0) {\n      throw new Error(`Error publishing: ${this.failures.map((e) => e.error.message)}`);\n    }\n  }\n\n  /**\n   * Build a single asset from the manifest\n   */\n  public async buildEntry(asset: IManifestEntry) {\n    try {\n      if (this.progressEvent(EventType.START, `Building ${asset.id}`)) {\n        return false;\n      }\n\n      const handler = this.assetHandler(asset);\n      await handler.build();\n\n      if (this.aborted) {\n        throw new Error('Aborted');\n      }\n\n      this.completedOperations++;\n      if (this.progressEvent(EventType.SUCCESS, `Built ${asset.id}`)) {\n        return false;\n      }\n    } catch (e: any) {\n      this.failures.push({ asset, error: e });\n      this.completedOperations++;\n      if (this.progressEvent(EventType.FAIL, e.message)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  /**\n   * Publish a single asset from the manifest\n   */\n  public async publishEntry(asset: IManifestEntry) {\n    try {\n      if (this.progressEvent(EventType.START, `Publishing ${asset.id}`)) {\n        return false;\n      }\n\n      const handler = this.assetHandler(asset);\n      await handler.publish();\n\n      if (this.aborted) {\n        throw new Error('Aborted');\n      }\n\n      this.completedOperations++;\n      if (this.progressEvent(EventType.SUCCESS, `Published ${asset.id}`)) {\n        return false;\n      }\n    } catch (e: any) {\n      this.failures.push({ asset, error: e });\n      this.completedOperations++;\n      if (this.progressEvent(EventType.FAIL, e.message)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  /**\n   * Return whether a single asset is published\n   */\n  public isEntryPublished(asset: IManifestEntry) {\n    const handler = this.assetHandler(asset);\n    return handler.isPublished();\n  }\n\n  /**\n   * publish an asset (used by 'publish()')\n   * @param asset The asset to publish\n   * @returns false when publishing should stop\n   */\n  private async publishAsset(asset: IManifestEntry) {\n    try {\n      if (this.progressEvent(EventType.START, `Publishing ${asset.id}`)) {\n        return false;\n      }\n\n      const handler = this.assetHandler(asset);\n\n      if (this.buildAssets) {\n        await handler.build();\n      }\n\n      if (this.publishAssets) {\n        await handler.publish();\n      }\n\n      if (this.aborted) {\n        throw new Error('Aborted');\n      }\n\n      this.completedOperations++;\n      if (this.progressEvent(EventType.SUCCESS, `Published ${asset.id}`)) {\n        return false;\n      }\n    } catch (e: any) {\n      this.failures.push({ asset, error: e });\n      this.completedOperations++;\n      if (this.progressEvent(EventType.FAIL, e.message)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  public get percentComplete() {\n    if (this.totalOperations === 0) {\n      return 100;\n    }\n    return Math.floor((this.completedOperations / this.totalOperations) * 100);\n  }\n\n  public abort(): void {\n    this.aborted = true;\n  }\n\n  public get hasFailures() {\n    return this.failures.length > 0;\n  }\n\n  /**\n   * Publish a progress event to the listener, if present.\n   *\n   * Returns whether an abort is requested. Helper to get rid of repetitive code in publish().\n   */\n  private progressEvent(event: EventType, message: string): boolean {\n    this.message = message;\n    if (this.options.progressListener) {\n      this.options.progressListener.onPublishEvent(event, this);\n    }\n    return this.aborted;\n  }\n\n  private assetHandler(asset: IManifestEntry) {\n    const existing = this.handlerCache.get(asset);\n    if (existing) {\n      return existing;\n    }\n    const ret = makeAssetHandler(this.manifest, asset, this.handlerHost, {\n      quiet: this.options.quiet,\n    });\n    this.handlerCache.set(asset, ret);\n    return ret;\n  }\n}\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"publishing.js","sourceRoot":"","sources":["publishing.ts"],"names":[],"mappings":"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","sourcesContent":["import { AssetManifest, IManifestEntry } from './asset-manifest';\nimport { IAws } from './aws';\nimport { IAssetHandler, IHandlerHost, type PublishOptions } from './private/asset-handler';\nimport { DockerFactory } from './private/docker';\nimport { makeAssetHandler } from './private/handlers';\nimport { EventType, IPublishProgress, IPublishProgressListener } from './progress';\n\nexport interface AssetPublishingOptions {\n  /**\n   * Entry point for AWS client\n   */\n  readonly aws: IAws;\n\n  /**\n   * Listener for progress events\n   *\n   * @default No listener\n   */\n  readonly progressListener?: IPublishProgressListener;\n\n  /**\n   * Whether to throw at the end if there were errors\n   *\n   * @default true\n   */\n  readonly throwOnError?: boolean;\n\n  /**\n   * Whether to publish in parallel, when 'publish()' is called\n   *\n   * @default false\n   */\n  readonly publishInParallel?: boolean;\n\n  /**\n   * Whether to build assets, when 'publish()' is called\n   *\n   * @default true\n   */\n  readonly buildAssets?: boolean;\n\n  /**\n   * Whether to publish assets, when 'publish()' is called\n   *\n   * @default true\n   */\n  readonly publishAssets?: boolean;\n\n  /**\n   * Whether to print publishing logs\n   *\n   * @default true\n   */\n  readonly quiet?: boolean;\n}\n\n/**\n * A failure to publish an asset\n */\nexport interface FailedAsset {\n  /**\n   * The asset that failed to publish\n   */\n  readonly asset: IManifestEntry;\n\n  /**\n   * The failure that occurred\n   */\n  readonly error: Error;\n}\n\nexport class AssetPublishing implements IPublishProgress {\n  /**\n   * The message for the IPublishProgress interface\n   */\n  public message: string = 'Starting';\n\n  /**\n   * The current asset for the IPublishProgress interface\n   */\n  public currentAsset?: IManifestEntry;\n  public readonly failures = new Array<FailedAsset>();\n  private readonly assets: IManifestEntry[];\n\n  private readonly totalOperations: number;\n  private completedOperations: number = 0;\n  private aborted = false;\n  private readonly handlerHost: IHandlerHost;\n  private readonly publishInParallel: boolean;\n  private readonly buildAssets: boolean;\n  private readonly publishAssets: boolean;\n  private readonly handlerCache = new Map<IManifestEntry, IAssetHandler>();\n\n  constructor(\n    private readonly manifest: AssetManifest,\n    private readonly options: AssetPublishingOptions\n  ) {\n    this.assets = manifest.entries;\n    this.totalOperations = this.assets.length;\n    this.publishInParallel = options.publishInParallel ?? false;\n    this.buildAssets = options.buildAssets ?? true;\n    this.publishAssets = options.publishAssets ?? true;\n\n    const self = this;\n    this.handlerHost = {\n      aws: this.options.aws,\n      get aborted() {\n        return self.aborted;\n      },\n      emitMessage(t, m) {\n        self.progressEvent(t, m);\n      },\n      dockerFactory: new DockerFactory(),\n    };\n  }\n\n  /**\n   * Publish all assets from the manifest\n   */\n  public async publish(options: PublishOptions = {}): Promise<void> {\n    if (this.publishInParallel) {\n      await Promise.all(this.assets.map(async (asset) => this.publishAsset(asset, options)));\n    } else {\n      for (const asset of this.assets) {\n        if (!(await this.publishAsset(asset, options))) {\n          break;\n        }\n      }\n    }\n\n    if ((this.options.throwOnError ?? true) && this.failures.length > 0) {\n      throw new Error(`Error publishing: ${this.failures.map((e) => e.error.message)}`);\n    }\n  }\n\n  /**\n   * Build a single asset from the manifest\n   */\n  public async buildEntry(asset: IManifestEntry) {\n    try {\n      if (this.progressEvent(EventType.START, `Building ${asset.id}`)) {\n        return false;\n      }\n\n      const handler = this.assetHandler(asset);\n      await handler.build();\n\n      if (this.aborted) {\n        throw new Error('Aborted');\n      }\n\n      this.completedOperations++;\n      if (this.progressEvent(EventType.SUCCESS, `Built ${asset.id}`)) {\n        return false;\n      }\n    } catch (e: any) {\n      this.failures.push({ asset, error: e });\n      this.completedOperations++;\n      if (this.progressEvent(EventType.FAIL, e.message)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  /**\n   * Publish a single asset from the manifest\n   */\n  public async publishEntry(asset: IManifestEntry, options: PublishOptions = {}) {\n    try {\n      if (this.progressEvent(EventType.START, `Publishing ${asset.id}`)) {\n        return false;\n      }\n\n      const handler = this.assetHandler(asset);\n      await handler.publish(options);\n\n      if (this.aborted) {\n        throw new Error('Aborted');\n      }\n\n      this.completedOperations++;\n      if (this.progressEvent(EventType.SUCCESS, `Published ${asset.id}`)) {\n        return false;\n      }\n    } catch (e: any) {\n      this.failures.push({ asset, error: e });\n      this.completedOperations++;\n      if (this.progressEvent(EventType.FAIL, e.message)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  /**\n   * Return whether a single asset is published\n   */\n  public isEntryPublished(asset: IManifestEntry) {\n    const handler = this.assetHandler(asset);\n    return handler.isPublished();\n  }\n\n  /**\n   * publish an asset (used by 'publish()')\n   * @param asset The asset to publish\n   * @returns false when publishing should stop\n   */\n  private async publishAsset(asset: IManifestEntry, options: PublishOptions = {}) {\n    try {\n      if (this.progressEvent(EventType.START, `Publishing ${asset.id}`)) {\n        return false;\n      }\n\n      const handler = this.assetHandler(asset);\n\n      if (this.buildAssets) {\n        await handler.build();\n      }\n\n      if (this.publishAssets) {\n        await handler.publish(options);\n      }\n\n      if (this.aborted) {\n        throw new Error('Aborted');\n      }\n\n      this.completedOperations++;\n      if (this.progressEvent(EventType.SUCCESS, `Published ${asset.id}`)) {\n        return false;\n      }\n    } catch (e: any) {\n      this.failures.push({ asset, error: e });\n      this.completedOperations++;\n      if (this.progressEvent(EventType.FAIL, e.message)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  public get percentComplete() {\n    if (this.totalOperations === 0) {\n      return 100;\n    }\n    return Math.floor((this.completedOperations / this.totalOperations) * 100);\n  }\n\n  public abort(): void {\n    this.aborted = true;\n  }\n\n  public get hasFailures() {\n    return this.failures.length > 0;\n  }\n\n  /**\n   * Publish a progress event to the listener, if present.\n   *\n   * Returns whether an abort is requested. Helper to get rid of repetitive code in publish().\n   */\n  private progressEvent(event: EventType, message: string): boolean {\n    this.message = message;\n    if (this.options.progressListener) {\n      this.options.progressListener.onPublishEvent(event, this);\n    }\n    return this.aborted;\n  }\n\n  private assetHandler(asset: IManifestEntry) {\n    const existing = this.handlerCache.get(asset);\n    if (existing) {\n      return existing;\n    }\n    const ret = makeAssetHandler(this.manifest, asset, this.handlerHost, {\n      quiet: this.options.quiet,\n    });\n    this.handlerCache.set(asset, ret);\n    return ret;\n  }\n}\n"]}
@@ -134,13 +134,13 @@
134
134
  }
135
135
  },
136
136
  "node_modules/@babel/code-frame": {
137
- "version": "7.24.7",
138
- "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz",
139
- "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==",
137
+ "version": "7.25.7",
138
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.25.7.tgz",
139
+ "integrity": "sha512-0xZJFNE5XMpENsgfHYTw8FbX4kv53mFLn2i3XPoq69LyhYSCBJtitaHx9QnsVTrsogI4Z3+HtEfZ2/GFPOtf5g==",
140
140
  "dev": true,
141
141
  "license": "MIT",
142
142
  "dependencies": {
143
- "@babel/highlight": "^7.24.7",
143
+ "@babel/highlight": "^7.25.7",
144
144
  "picocolors": "^1.0.0"
145
145
  },
146
146
  "engines": {
@@ -148,9 +148,9 @@
148
148
  }
149
149
  },
150
150
  "node_modules/@babel/compat-data": {
151
- "version": "7.25.4",
152
- "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.25.4.tgz",
153
- "integrity": "sha512-+LGRog6RAsCJrrrg/IO6LGmpphNe5DiK30dGjCoxxeGv49B10/3XYGxPsAwrDlMFcFEvdAUavDT8r9k/hSyQqQ==",
151
+ "version": "7.25.7",
152
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.25.7.tgz",
153
+ "integrity": "sha512-9ickoLz+hcXCeh7jrcin+/SLWm+GkxE2kTvoYyp38p4WkdFXfQJxDFGWp/YHjiKLPx06z2A7W8XKuqbReXDzsw==",
154
154
  "dev": true,
155
155
  "license": "MIT",
156
156
  "engines": {
@@ -158,22 +158,22 @@
158
158
  }
159
159
  },
160
160
  "node_modules/@babel/core": {
161
- "version": "7.25.2",
162
- "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.25.2.tgz",
163
- "integrity": "sha512-BBt3opiCOxUr9euZ5/ro/Xv8/V7yJ5bjYMqG/C1YAo8MIKAnumZalCN+msbci3Pigy4lIQfPUpfMM27HMGaYEA==",
161
+ "version": "7.25.7",
162
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.25.7.tgz",
163
+ "integrity": "sha512-yJ474Zv3cwiSOO9nXJuqzvwEeM+chDuQ8GJirw+pZ91sCGCyOZ3dJkVE09fTV0VEVzXyLWhh3G/AolYTPX7Mow==",
164
164
  "dev": true,
165
165
  "license": "MIT",
166
166
  "dependencies": {
167
167
  "@ampproject/remapping": "^2.2.0",
168
- "@babel/code-frame": "^7.24.7",
169
- "@babel/generator": "^7.25.0",
170
- "@babel/helper-compilation-targets": "^7.25.2",
171
- "@babel/helper-module-transforms": "^7.25.2",
172
- "@babel/helpers": "^7.25.0",
173
- "@babel/parser": "^7.25.0",
174
- "@babel/template": "^7.25.0",
175
- "@babel/traverse": "^7.25.2",
176
- "@babel/types": "^7.25.2",
168
+ "@babel/code-frame": "^7.25.7",
169
+ "@babel/generator": "^7.25.7",
170
+ "@babel/helper-compilation-targets": "^7.25.7",
171
+ "@babel/helper-module-transforms": "^7.25.7",
172
+ "@babel/helpers": "^7.25.7",
173
+ "@babel/parser": "^7.25.7",
174
+ "@babel/template": "^7.25.7",
175
+ "@babel/traverse": "^7.25.7",
176
+ "@babel/types": "^7.25.7",
177
177
  "convert-source-map": "^2.0.0",
178
178
  "debug": "^4.1.0",
179
179
  "gensync": "^1.0.0-beta.2",
@@ -199,31 +199,31 @@
199
199
  }
200
200
  },
201
201
  "node_modules/@babel/generator": {
202
- "version": "7.25.6",
203
- "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.6.tgz",
204
- "integrity": "sha512-VPC82gr1seXOpkjAAKoLhP50vx4vGNlF4msF64dSFq1P8RfB+QAuJWGHPXXPc8QyfVWwwB/TNNU4+ayZmHNbZw==",
202
+ "version": "7.25.7",
203
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.7.tgz",
204
+ "integrity": "sha512-5Dqpl5fyV9pIAD62yK9P7fcA768uVPUyrQmqpqstHWgMma4feF1x/oFysBCVZLY5wJ2GkMUCdsNDnGZrPoR6rA==",
205
205
  "dev": true,
206
206
  "license": "MIT",
207
207
  "dependencies": {
208
- "@babel/types": "^7.25.6",
208
+ "@babel/types": "^7.25.7",
209
209
  "@jridgewell/gen-mapping": "^0.3.5",
210
210
  "@jridgewell/trace-mapping": "^0.3.25",
211
- "jsesc": "^2.5.1"
211
+ "jsesc": "^3.0.2"
212
212
  },
213
213
  "engines": {
214
214
  "node": ">=6.9.0"
215
215
  }
216
216
  },
217
217
  "node_modules/@babel/helper-compilation-targets": {
218
- "version": "7.25.2",
219
- "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.2.tgz",
220
- "integrity": "sha512-U2U5LsSaZ7TAt3cfaymQ8WHh0pxvdHoEk6HVpaexxixjyEquMh0L0YNJNM6CTGKMXV1iksi0iZkGw4AcFkPaaw==",
218
+ "version": "7.25.7",
219
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.7.tgz",
220
+ "integrity": "sha512-DniTEax0sv6isaw6qSQSfV4gVRNtw2rte8HHM45t9ZR0xILaufBRNkpMifCRiAPyvL4ACD6v0gfCwCmtOQaV4A==",
221
221
  "dev": true,
222
222
  "license": "MIT",
223
223
  "dependencies": {
224
- "@babel/compat-data": "^7.25.2",
225
- "@babel/helper-validator-option": "^7.24.8",
226
- "browserslist": "^4.23.1",
224
+ "@babel/compat-data": "^7.25.7",
225
+ "@babel/helper-validator-option": "^7.25.7",
226
+ "browserslist": "^4.24.0",
227
227
  "lru-cache": "^5.1.1",
228
228
  "semver": "^6.3.1"
229
229
  },
@@ -259,30 +259,30 @@
259
259
  "license": "ISC"
260
260
  },
261
261
  "node_modules/@babel/helper-module-imports": {
262
- "version": "7.24.7",
263
- "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz",
264
- "integrity": "sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==",
262
+ "version": "7.25.7",
263
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.7.tgz",
264
+ "integrity": "sha512-o0xCgpNmRohmnoWKQ0Ij8IdddjyBFE4T2kagL/x6M3+4zUgc+4qTOUBoNe4XxDskt1HPKO007ZPiMgLDq2s7Kw==",
265
265
  "dev": true,
266
266
  "license": "MIT",
267
267
  "dependencies": {
268
- "@babel/traverse": "^7.24.7",
269
- "@babel/types": "^7.24.7"
268
+ "@babel/traverse": "^7.25.7",
269
+ "@babel/types": "^7.25.7"
270
270
  },
271
271
  "engines": {
272
272
  "node": ">=6.9.0"
273
273
  }
274
274
  },
275
275
  "node_modules/@babel/helper-module-transforms": {
276
- "version": "7.25.2",
277
- "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.25.2.tgz",
278
- "integrity": "sha512-BjyRAbix6j/wv83ftcVJmBt72QtHI56C7JXZoG2xATiLpmoC7dpd8WnkikExHDVPpi/3qCmO6WY1EaXOluiecQ==",
276
+ "version": "7.25.7",
277
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.25.7.tgz",
278
+ "integrity": "sha512-k/6f8dKG3yDz/qCwSM+RKovjMix563SLxQFo0UhRNo239SP6n9u5/eLtKD6EAjwta2JHJ49CsD8pms2HdNiMMQ==",
279
279
  "dev": true,
280
280
  "license": "MIT",
281
281
  "dependencies": {
282
- "@babel/helper-module-imports": "^7.24.7",
283
- "@babel/helper-simple-access": "^7.24.7",
284
- "@babel/helper-validator-identifier": "^7.24.7",
285
- "@babel/traverse": "^7.25.2"
282
+ "@babel/helper-module-imports": "^7.25.7",
283
+ "@babel/helper-simple-access": "^7.25.7",
284
+ "@babel/helper-validator-identifier": "^7.25.7",
285
+ "@babel/traverse": "^7.25.7"
286
286
  },
287
287
  "engines": {
288
288
  "node": ">=6.9.0"
@@ -292,9 +292,9 @@
292
292
  }
293
293
  },
294
294
  "node_modules/@babel/helper-plugin-utils": {
295
- "version": "7.24.8",
296
- "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.8.tgz",
297
- "integrity": "sha512-FFWx5142D8h2Mgr/iPVGH5G7w6jDn4jUSpZTyDnQO0Yn7Ks2Kuz6Pci8H6MPCoUJegd/UZQ3tAvfLCxQSnWWwg==",
295
+ "version": "7.25.7",
296
+ "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.25.7.tgz",
297
+ "integrity": "sha512-eaPZai0PiqCi09pPs3pAFfl/zYgGaE6IdXtYvmf0qlcDTd3WCtO7JWCcRd64e0EQrcYgiHibEZnOGsSY4QSgaw==",
298
298
  "dev": true,
299
299
  "license": "MIT",
300
300
  "engines": {
@@ -302,23 +302,23 @@
302
302
  }
303
303
  },
304
304
  "node_modules/@babel/helper-simple-access": {
305
- "version": "7.24.7",
306
- "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz",
307
- "integrity": "sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==",
305
+ "version": "7.25.7",
306
+ "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.25.7.tgz",
307
+ "integrity": "sha512-FPGAkJmyoChQeM+ruBGIDyrT2tKfZJO8NcxdC+CWNJi7N8/rZpSxK7yvBJ5O/nF1gfu5KzN7VKG3YVSLFfRSxQ==",
308
308
  "dev": true,
309
309
  "license": "MIT",
310
310
  "dependencies": {
311
- "@babel/traverse": "^7.24.7",
312
- "@babel/types": "^7.24.7"
311
+ "@babel/traverse": "^7.25.7",
312
+ "@babel/types": "^7.25.7"
313
313
  },
314
314
  "engines": {
315
315
  "node": ">=6.9.0"
316
316
  }
317
317
  },
318
318
  "node_modules/@babel/helper-string-parser": {
319
- "version": "7.24.8",
320
- "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.8.tgz",
321
- "integrity": "sha512-pO9KhhRcuUyGnJWwyEgnRJTSIZHiT+vMD0kPeD+so0l7mxkMT19g3pjY9GTnHySck/hDzq+dtW/4VgnMkippsQ==",
319
+ "version": "7.25.7",
320
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.7.tgz",
321
+ "integrity": "sha512-CbkjYdsJNHFk8uqpEkpCvRs3YRp9tY6FmFY7wLMSYuGYkrdUi7r2lc4/wqsvlHoMznX3WJ9IP8giGPq68T/Y6g==",
322
322
  "dev": true,
323
323
  "license": "MIT",
324
324
  "engines": {
@@ -326,9 +326,9 @@
326
326
  }
327
327
  },
328
328
  "node_modules/@babel/helper-validator-identifier": {
329
- "version": "7.24.7",
330
- "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz",
331
- "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==",
329
+ "version": "7.25.7",
330
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.7.tgz",
331
+ "integrity": "sha512-AM6TzwYqGChO45oiuPqwL2t20/HdMC1rTPAesnBCgPCSF1x3oN9MVUwQV2iyz4xqWrctwK5RNC8LV22kaQCNYg==",
332
332
  "dev": true,
333
333
  "license": "MIT",
334
334
  "engines": {
@@ -336,9 +336,9 @@
336
336
  }
337
337
  },
338
338
  "node_modules/@babel/helper-validator-option": {
339
- "version": "7.24.8",
340
- "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.8.tgz",
341
- "integrity": "sha512-xb8t9tD1MHLungh/AIoWYN+gVHaB9kwlu8gffXGSt3FFEIT7RjS+xWbc2vUD1UTZdIpKj/ab3rdqJ7ufngyi2Q==",
339
+ "version": "7.25.7",
340
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.25.7.tgz",
341
+ "integrity": "sha512-ytbPLsm+GjArDYXJ8Ydr1c/KJuutjF2besPNbIZnZ6MKUxi/uTA22t2ymmA4WFjZFpjiAMO0xuuJPqK2nvDVfQ==",
342
342
  "dev": true,
343
343
  "license": "MIT",
344
344
  "engines": {
@@ -346,27 +346,27 @@
346
346
  }
347
347
  },
348
348
  "node_modules/@babel/helpers": {
349
- "version": "7.25.6",
350
- "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.25.6.tgz",
351
- "integrity": "sha512-Xg0tn4HcfTijTwfDwYlvVCl43V6h4KyVVX2aEm4qdO/PC6L2YvzLHFdmxhoeSA3eslcE6+ZVXHgWwopXYLNq4Q==",
349
+ "version": "7.25.7",
350
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.25.7.tgz",
351
+ "integrity": "sha512-Sv6pASx7Esm38KQpF/U/OXLwPPrdGHNKoeblRxgZRLXnAtnkEe4ptJPDtAZM7fBLadbc1Q07kQpSiGQ0Jg6tRA==",
352
352
  "dev": true,
353
353
  "license": "MIT",
354
354
  "dependencies": {
355
- "@babel/template": "^7.25.0",
356
- "@babel/types": "^7.25.6"
355
+ "@babel/template": "^7.25.7",
356
+ "@babel/types": "^7.25.7"
357
357
  },
358
358
  "engines": {
359
359
  "node": ">=6.9.0"
360
360
  }
361
361
  },
362
362
  "node_modules/@babel/highlight": {
363
- "version": "7.24.7",
364
- "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz",
365
- "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==",
363
+ "version": "7.25.7",
364
+ "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.25.7.tgz",
365
+ "integrity": "sha512-iYyACpW3iW8Fw+ZybQK+drQre+ns/tKpXbNESfrhNnPLIklLbXr7MYJ6gPEd0iETGLOK+SxMjVvKb/ffmk+FEw==",
366
366
  "dev": true,
367
367
  "license": "MIT",
368
368
  "dependencies": {
369
- "@babel/helper-validator-identifier": "^7.24.7",
369
+ "@babel/helper-validator-identifier": "^7.25.7",
370
370
  "chalk": "^2.4.2",
371
371
  "js-tokens": "^4.0.0",
372
372
  "picocolors": "^1.0.0"
@@ -444,13 +444,13 @@
444
444
  }
445
445
  },
446
446
  "node_modules/@babel/parser": {
447
- "version": "7.25.6",
448
- "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.6.tgz",
449
- "integrity": "sha512-trGdfBdbD0l1ZPmcJ83eNxB9rbEax4ALFTF7fN386TMYbeCQbyme5cOEXQhbGXKebwGaB/J52w1mrklMcbgy6Q==",
447
+ "version": "7.25.7",
448
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.7.tgz",
449
+ "integrity": "sha512-aZn7ETtQsjjGG5HruveUK06cU3Hljuhd9Iojm4M8WWv3wLE6OkE5PWbDUkItmMgegmccaITudyuW5RPYrYlgWw==",
450
450
  "dev": true,
451
451
  "license": "MIT",
452
452
  "dependencies": {
453
- "@babel/types": "^7.25.6"
453
+ "@babel/types": "^7.25.7"
454
454
  },
455
455
  "bin": {
456
456
  "parser": "bin/babel-parser.js"
@@ -515,13 +515,13 @@
515
515
  }
516
516
  },
517
517
  "node_modules/@babel/plugin-syntax-import-attributes": {
518
- "version": "7.25.6",
519
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.25.6.tgz",
520
- "integrity": "sha512-sXaDXaJN9SNLymBdlWFA+bjzBhFD617ZaFiY13dGt7TVslVvVgA6fkZOP7Ki3IGElC45lwHdOTrCtKZGVAWeLQ==",
518
+ "version": "7.25.7",
519
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.25.7.tgz",
520
+ "integrity": "sha512-AqVo+dguCgmpi/3mYBdu9lkngOBlQ2w2vnNpa6gfiCxQZLzV4ZbhsXitJ2Yblkoe1VQwtHSaNmIaGll/26YWRw==",
521
521
  "dev": true,
522
522
  "license": "MIT",
523
523
  "dependencies": {
524
- "@babel/helper-plugin-utils": "^7.24.8"
524
+ "@babel/helper-plugin-utils": "^7.25.7"
525
525
  },
526
526
  "engines": {
527
527
  "node": ">=6.9.0"
@@ -557,13 +557,13 @@
557
557
  }
558
558
  },
559
559
  "node_modules/@babel/plugin-syntax-jsx": {
560
- "version": "7.24.7",
561
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.24.7.tgz",
562
- "integrity": "sha512-6ddciUPe/mpMnOKv/U+RSd2vvVy+Yw/JfBB0ZHYjEZt9NLHmCUylNYlsbqCCS1Bffjlb0fCwC9Vqz+sBz6PsiQ==",
560
+ "version": "7.25.7",
561
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.25.7.tgz",
562
+ "integrity": "sha512-ruZOnKO+ajVL/MVx+PwNBPOkrnXTXoWMtte1MBpegfCArhqOe3Bj52avVj1huLLxNKYKXYaSxZ2F+woK1ekXfw==",
563
563
  "dev": true,
564
564
  "license": "MIT",
565
565
  "dependencies": {
566
- "@babel/helper-plugin-utils": "^7.24.7"
566
+ "@babel/helper-plugin-utils": "^7.25.7"
567
567
  },
568
568
  "engines": {
569
569
  "node": ">=6.9.0"
@@ -683,13 +683,13 @@
683
683
  }
684
684
  },
685
685
  "node_modules/@babel/plugin-syntax-typescript": {
686
- "version": "7.25.4",
687
- "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.25.4.tgz",
688
- "integrity": "sha512-uMOCoHVU52BsSWxPOMVv5qKRdeSlPuImUCB2dlPuBSU+W2/ROE7/Zg8F2Kepbk+8yBa68LlRKxO+xgEVWorsDg==",
686
+ "version": "7.25.7",
687
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.25.7.tgz",
688
+ "integrity": "sha512-rR+5FDjpCHqqZN2bzZm18bVYGaejGq5ZkpVCJLXor/+zlSrSoc4KWcHI0URVWjl/68Dyr1uwZUz/1njycEAv9g==",
689
689
  "dev": true,
690
690
  "license": "MIT",
691
691
  "dependencies": {
692
- "@babel/helper-plugin-utils": "^7.24.8"
692
+ "@babel/helper-plugin-utils": "^7.25.7"
693
693
  },
694
694
  "engines": {
695
695
  "node": ">=6.9.0"
@@ -699,32 +699,32 @@
699
699
  }
700
700
  },
701
701
  "node_modules/@babel/template": {
702
- "version": "7.25.0",
703
- "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.0.tgz",
704
- "integrity": "sha512-aOOgh1/5XzKvg1jvVz7AVrx2piJ2XBi227DHmbY6y+bM9H2FlN+IfecYu4Xl0cNiiVejlsCri89LUsbj8vJD9Q==",
702
+ "version": "7.25.7",
703
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.7.tgz",
704
+ "integrity": "sha512-wRwtAgI3bAS+JGU2upWNL9lSlDcRCqD05BZ1n3X2ONLH1WilFP6O1otQjeMK/1g0pvYcXC7b/qVUB1keofjtZA==",
705
705
  "dev": true,
706
706
  "license": "MIT",
707
707
  "dependencies": {
708
- "@babel/code-frame": "^7.24.7",
709
- "@babel/parser": "^7.25.0",
710
- "@babel/types": "^7.25.0"
708
+ "@babel/code-frame": "^7.25.7",
709
+ "@babel/parser": "^7.25.7",
710
+ "@babel/types": "^7.25.7"
711
711
  },
712
712
  "engines": {
713
713
  "node": ">=6.9.0"
714
714
  }
715
715
  },
716
716
  "node_modules/@babel/traverse": {
717
- "version": "7.25.6",
718
- "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.6.tgz",
719
- "integrity": "sha512-9Vrcx5ZW6UwK5tvqsj0nGpp/XzqthkT0dqIc9g1AdtygFToNtTF67XzYS//dm+SAK9cp3B9R4ZO/46p63SCjlQ==",
717
+ "version": "7.25.7",
718
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.7.tgz",
719
+ "integrity": "sha512-jatJPT1Zjqvh/1FyJs6qAHL+Dzb7sTb+xr7Q+gM1b+1oBsMsQQ4FkVKb6dFlJvLlVssqkRzV05Jzervt9yhnzg==",
720
720
  "dev": true,
721
721
  "license": "MIT",
722
722
  "dependencies": {
723
- "@babel/code-frame": "^7.24.7",
724
- "@babel/generator": "^7.25.6",
725
- "@babel/parser": "^7.25.6",
726
- "@babel/template": "^7.25.0",
727
- "@babel/types": "^7.25.6",
723
+ "@babel/code-frame": "^7.25.7",
724
+ "@babel/generator": "^7.25.7",
725
+ "@babel/parser": "^7.25.7",
726
+ "@babel/template": "^7.25.7",
727
+ "@babel/types": "^7.25.7",
728
728
  "debug": "^4.3.1",
729
729
  "globals": "^11.1.0"
730
730
  },
@@ -743,14 +743,14 @@
743
743
  }
744
744
  },
745
745
  "node_modules/@babel/types": {
746
- "version": "7.25.6",
747
- "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.6.tgz",
748
- "integrity": "sha512-/l42B1qxpG6RdfYf343Uw1vmDjeNhneUXtzhojE7pDgfpEypmRhI6j1kr17XCVv4Cgl9HdAiQY2x0GwKm7rWCw==",
746
+ "version": "7.25.7",
747
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.7.tgz",
748
+ "integrity": "sha512-vwIVdXG+j+FOpkwqHRcBgHLYNL7XMkufrlaFvL9o6Ai9sJn9+PdyIL5qa0XzTZw084c+u9LOls53eoZWP/W5WQ==",
749
749
  "dev": true,
750
750
  "license": "MIT",
751
751
  "dependencies": {
752
- "@babel/helper-string-parser": "^7.24.8",
753
- "@babel/helper-validator-identifier": "^7.24.7",
752
+ "@babel/helper-string-parser": "^7.25.7",
753
+ "@babel/helper-validator-identifier": "^7.25.7",
754
754
  "to-fast-properties": "^2.0.0"
755
755
  },
756
756
  "engines": {
@@ -2916,9 +2916,9 @@
2916
2916
  }
2917
2917
  },
2918
2918
  "node_modules/caniuse-lite": {
2919
- "version": "1.0.30001664",
2920
- "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001664.tgz",
2921
- "integrity": "sha512-AmE7k4dXiNKQipgn7a2xg558IRqPN3jMQY/rOsbxDhrd0tyChwbITBfiwtnqz8bi2M5mIWbxAYBvk7W7QBUS2g==",
2919
+ "version": "1.0.30001666",
2920
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001666.tgz",
2921
+ "integrity": "sha512-gD14ICmoV5ZZM1OdzPWmpx+q4GyefaK06zi8hmfHV5xe4/2nOQX3+Dw5o+fSqOws2xVwL9j+anOPFwHzdEdV4g==",
2922
2922
  "dev": true,
2923
2923
  "funding": [
2924
2924
  {
@@ -4076,9 +4076,9 @@
4076
4076
  }
4077
4077
  },
4078
4078
  "node_modules/electron-to-chromium": {
4079
- "version": "1.5.30",
4080
- "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.30.tgz",
4081
- "integrity": "sha512-sXI35EBN4lYxzc/pIGorlymYNzDBOqkSlVRe6MkgBsW/hW1tpC/HDJ2fjG7XnjakzfLEuvdmux0Mjs6jHq4UOA==",
4079
+ "version": "1.5.31",
4080
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.31.tgz",
4081
+ "integrity": "sha512-QcDoBbQeYt0+3CWcK/rEbuHvwpbT/8SV9T3OSgs6cX1FlcUAkgrkqbg9zLnDrMM/rLamzQwal4LYFCiWk861Tg==",
4082
4082
  "dev": true,
4083
4083
  "license": "ISC"
4084
4084
  },
@@ -7166,16 +7166,16 @@
7166
7166
  }
7167
7167
  },
7168
7168
  "node_modules/jsesc": {
7169
- "version": "2.5.2",
7170
- "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
7171
- "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
7169
+ "version": "3.0.2",
7170
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.0.2.tgz",
7171
+ "integrity": "sha512-xKqzzWXDttJuOcawBt4KnKHHIf5oQ/Cxax+0PWFG+DFDgHNAdi+TXECADI+RYiFUMmx8792xsMbbgXj4CwnP4g==",
7172
7172
  "dev": true,
7173
7173
  "license": "MIT",
7174
7174
  "bin": {
7175
7175
  "jsesc": "bin/jsesc"
7176
7176
  },
7177
7177
  "engines": {
7178
- "node": ">=4"
7178
+ "node": ">=6"
7179
7179
  }
7180
7180
  },
7181
7181
  "node_modules/json-buffer": {
@@ -10344,22 +10344,22 @@
10344
10344
  }
10345
10345
  },
10346
10346
  "node_modules/tldts": {
10347
- "version": "6.1.48",
10348
- "resolved": "https://registry.npmjs.org/tldts/-/tldts-6.1.48.tgz",
10349
- "integrity": "sha512-SPbnh1zaSzi/OsmHb1vrPNnYuwJbdWjwo5TbBYYMlTtH3/1DSb41t8bcSxkwDmmbG2q6VLPVvQc7Yf23T+1EEw==",
10347
+ "version": "6.1.49",
10348
+ "resolved": "https://registry.npmjs.org/tldts/-/tldts-6.1.49.tgz",
10349
+ "integrity": "sha512-E5se9HuCyfwWvmc0JiXiocOw+Cm4tlJCKewdB5RKMH8MmtiTsQCc+yu5BBYB5ZN4lNbz8Xg65bqJ1odS9+RhIA==",
10350
10350
  "dev": true,
10351
10351
  "license": "MIT",
10352
10352
  "dependencies": {
10353
- "tldts-core": "^6.1.48"
10353
+ "tldts-core": "^6.1.49"
10354
10354
  },
10355
10355
  "bin": {
10356
10356
  "tldts": "bin/cli.js"
10357
10357
  }
10358
10358
  },
10359
10359
  "node_modules/tldts-core": {
10360
- "version": "6.1.48",
10361
- "resolved": "https://registry.npmjs.org/tldts-core/-/tldts-core-6.1.48.tgz",
10362
- "integrity": "sha512-3gD9iKn/n2UuFH1uilBviK9gvTNT6iYwdqrj1Vr5mh8FuelvpRNaYVH4pNYqUgOGU4aAdL9X35eLuuj0gRsx+A==",
10360
+ "version": "6.1.49",
10361
+ "resolved": "https://registry.npmjs.org/tldts-core/-/tldts-core-6.1.49.tgz",
10362
+ "integrity": "sha512-ctRO/wzBasOCxAStJG/60Qe8/QpGmaVPsE8djdk0vioxN4uCOgKoveH71Qc2EOmVMIjVf0BjigI5p9ZDuLOygg==",
10363
10363
  "dev": true,
10364
10364
  "license": "MIT"
10365
10365
  },
package/package.json CHANGED
@@ -78,7 +78,7 @@
78
78
  "publishConfig": {
79
79
  "access": "public"
80
80
  },
81
- "version": "2.154.9",
81
+ "version": "2.155.1",
82
82
  "types": "lib/index.d.ts",
83
83
  "//": "~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\"."
84
84
  }