aws-cdk 2.5.0 → 2.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (80) hide show
  1. package/README.md +8 -1
  2. package/bin/cdk.js +22 -6
  3. package/build-info.json +2 -2
  4. package/lib/api/aws-auth/sdk-provider.d.ts +26 -1
  5. package/lib/api/aws-auth/sdk-provider.js +4 -4
  6. package/lib/api/aws-auth/sdk.d.ts +2 -0
  7. package/lib/api/aws-auth/sdk.js +4 -1
  8. package/lib/api/bootstrap/deploy-bootstrap.js +14 -3
  9. package/lib/api/cloudformation-deployments.d.ts +63 -1
  10. package/lib/api/cloudformation-deployments.js +74 -4
  11. package/lib/api/cxapp/cloud-assembly.js +5 -5
  12. package/lib/api/deploy-stack.d.ts +0 -1
  13. package/lib/api/deploy-stack.js +8 -9
  14. package/lib/api/{hotswap/evaluate-cloudformation-template.d.ts → evaluate-cloudformation-template.d.ts} +14 -1
  15. package/lib/api/evaluate-cloudformation-template.js +289 -0
  16. package/lib/api/hotswap/code-build-projects.d.ts +1 -1
  17. package/lib/api/hotswap/code-build-projects.js +2 -2
  18. package/lib/api/hotswap/common.d.ts +0 -6
  19. package/lib/api/hotswap/common.js +2 -19
  20. package/lib/api/hotswap/ecs-services.d.ts +1 -1
  21. package/lib/api/hotswap/ecs-services.js +2 -2
  22. package/lib/api/hotswap/lambda-functions.d.ts +1 -1
  23. package/lib/api/hotswap/lambda-functions.js +69 -3
  24. package/lib/api/hotswap/s3-bucket-deployments.d.ts +1 -1
  25. package/lib/api/hotswap/s3-bucket-deployments.js +1 -1
  26. package/lib/api/hotswap/stepfunctions-state-machines.d.ts +1 -1
  27. package/lib/api/hotswap/stepfunctions-state-machines.js +1 -1
  28. package/lib/api/hotswap-deployments.js +9 -35
  29. package/lib/api/logs/find-cloudwatch-logs.d.ts +24 -0
  30. package/lib/api/logs/find-cloudwatch-logs.js +84 -0
  31. package/lib/api/logs/logs-monitor.d.ts +53 -0
  32. package/lib/api/logs/logs-monitor.js +163 -0
  33. package/lib/api/toolkit-info.d.ts +5 -5
  34. package/lib/api/toolkit-info.js +10 -10
  35. package/lib/api/util/cloudformation/stack-activity-monitor.js +22 -22
  36. package/lib/assets.js +3 -3
  37. package/lib/cdk-toolkit.d.ts +15 -0
  38. package/lib/cdk-toolkit.js +30 -20
  39. package/lib/commands/context.js +7 -7
  40. package/lib/commands/docs.js +4 -4
  41. package/lib/commands/doctor.js +6 -6
  42. package/lib/context-providers/ami.js +2 -2
  43. package/lib/context-providers/availability-zones.js +2 -2
  44. package/lib/context-providers/endpoint-service-availability-zones.js +2 -2
  45. package/lib/context-providers/hosted-zones.js +2 -2
  46. package/lib/context-providers/keys.js +2 -2
  47. package/lib/context-providers/load-balancers.js +3 -3
  48. package/lib/context-providers/security-groups.js +2 -2
  49. package/lib/context-providers/ssm-parameters.js +2 -2
  50. package/lib/context-providers/vpcs.js +2 -2
  51. package/lib/diff.js +3 -3
  52. package/lib/init.js +14 -14
  53. package/lib/logging.js +7 -7
  54. package/lib/os.js +3 -3
  55. package/lib/plugin.js +4 -4
  56. package/lib/util/asset-publishing.js +3 -3
  57. package/lib/util/console-formatters.js +4 -3
  58. package/lib/version.js +3 -3
  59. package/npm-shrinkwrap.json +90 -95
  60. package/package.json +22 -21
  61. package/test/api/bootstrap2.test.js +2 -3
  62. package/test/api/cloudformation-deployments.test.js +2 -2
  63. package/test/api/hotswap/lambda-functions-docker-hotswap-deployments.test.d.ts +1 -0
  64. package/test/api/hotswap/lambda-functions-docker-hotswap-deployments.test.js +64 -0
  65. package/test/api/hotswap/lambda-functions-inline-hotswap-deployments.test.d.ts +1 -0
  66. package/test/api/hotswap/lambda-functions-inline-hotswap-deployments.test.js +139 -0
  67. package/test/api/logs/find-cloudwatch-logs.test.d.ts +1 -0
  68. package/test/api/logs/find-cloudwatch-logs.test.js +264 -0
  69. package/test/api/logs/logs-monitor.test.d.ts +1 -0
  70. package/test/api/logs/logs-monitor.test.js +59 -0
  71. package/test/api/sdk-provider.test.js +11 -11
  72. package/test/api/stack-activity-monitor.test.js +13 -13
  73. package/test/cdk-toolkit.test.js +271 -10
  74. package/test/context-providers/load-balancers.test.js +4 -4
  75. package/test/util/cloudformation.test.js +2 -2
  76. package/test/util/console-formatters.test.js +6 -6
  77. package/test/util/mock-sdk.d.ts +8 -2
  78. package/test/util/mock-sdk.js +12 -2
  79. package/test/util/mock-toolkitinfo.js +2 -2
  80. package/lib/api/hotswap/evaluate-cloudformation-template.js +0 -247
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.CurrentActivityPrinter = exports.HistoryActivityPrinter = exports.StackActivityMonitor = exports.StackActivityProgress = void 0;
4
4
  const util = require("util");
5
5
  const cxschema = require("@aws-cdk/cloud-assembly-schema");
6
- const colors = require("colors/safe");
6
+ const chalk = require("chalk");
7
7
  const logging_1 = require("../../../logging");
8
8
  const display_1 = require("../display");
9
9
  /**
@@ -347,17 +347,17 @@ class HistoryActivityPrinter extends ActivityPrinterBase {
347
347
  printOne(activity, progress) {
348
348
  const e = activity.event;
349
349
  const color = colorFromStatusResult(e.ResourceStatus);
350
- let reasonColor = colors.cyan;
350
+ let reasonColor = chalk.cyan;
351
351
  let stackTrace = '';
352
352
  const md = activity.metadata;
353
353
  if (md && e.ResourceStatus && e.ResourceStatus.indexOf('FAILED') !== -1) {
354
354
  stackTrace = md.entry.trace ? `\n\t${md.entry.trace.join('\n\t\\_ ')}` : '';
355
- reasonColor = colors.red;
355
+ reasonColor = chalk.red;
356
356
  }
357
357
  const resourceName = md ? md.constructPath : (e.LogicalResourceId || '');
358
358
  const logicalId = resourceName !== e.LogicalResourceId ? `(${e.LogicalResourceId}) ` : '';
359
359
  this.stream.write(util.format('%s | %s%s | %s | %s | %s %s%s%s\n', e.StackName, (progress !== false ? `${this.progress()} | ` : ''), new Date(e.Timestamp).toLocaleTimeString(), color(padRight(STATUS_WIDTH, (e.ResourceStatus || '').substr(0, STATUS_WIDTH))), // pad left and trim
360
- padRight(this.props.resourceTypeColumnWidth, e.ResourceType || ''), color(colors.bold(resourceName)), logicalId, reasonColor(colors.bold(e.ResourceStatusReason ? e.ResourceStatusReason : '')), reasonColor(stackTrace)));
360
+ padRight(this.props.resourceTypeColumnWidth, e.ResourceType || ''), color(chalk.bold(resourceName)), logicalId, reasonColor(chalk.bold(e.ResourceStatusReason ? e.ResourceStatusReason : '')), reasonColor(stackTrace)));
361
361
  this.lastPrintTime = Date.now();
362
362
  }
363
363
  /**
@@ -378,7 +378,7 @@ class HistoryActivityPrinter extends ActivityPrinterBase {
378
378
  return;
379
379
  }
380
380
  if (Object.keys(this.resourcesInProgress).length > 0) {
381
- this.stream.write(util.format('%s Currently in progress: %s\n', this.progress(), colors.bold(Object.keys(this.resourcesInProgress).join(', '))));
381
+ this.stream.write(util.format('%s Currently in progress: %s\n', this.progress(), chalk.bold(Object.keys(this.resourcesInProgress).join(', '))));
382
382
  }
383
383
  // We cheat a bit here. To prevent printInProgress() from repeatedly triggering,
384
384
  // we set the timestamp into the future. It will be reset whenever a regular print
@@ -428,7 +428,7 @@ class CurrentActivityPrinter extends ActivityPrinterBase {
428
428
  var _a, _b, _c;
429
429
  const color = colorFromStatusActivity(res.event.ResourceStatus);
430
430
  const resourceName = (_c = (_b = (_a = res.metadata) === null || _a === void 0 ? void 0 : _a.constructPath) !== null && _b !== void 0 ? _b : res.event.LogicalResourceId) !== null && _c !== void 0 ? _c : '';
431
- return util.format('%s | %s | %s | %s%s', padLeft(TIMESTAMP_WIDTH, new Date(res.event.Timestamp).toLocaleTimeString()), color(padRight(STATUS_WIDTH, (res.event.ResourceStatus || '').substr(0, STATUS_WIDTH))), padRight(this.props.resourceTypeColumnWidth, res.event.ResourceType || ''), color(colors.bold(shorten(40, resourceName))), this.failureReasonOnNextLine(res));
431
+ return util.format('%s | %s | %s | %s%s', padLeft(TIMESTAMP_WIDTH, new Date(res.event.Timestamp).toLocaleTimeString()), color(padRight(STATUS_WIDTH, (res.event.ResourceStatus || '').substr(0, STATUS_WIDTH))), padRight(this.props.resourceTypeColumnWidth, res.event.ResourceType || ''), color(chalk.bold(shorten(40, resourceName))), this.failureReasonOnNextLine(res));
432
432
  }));
433
433
  this.block.displayLines(lines);
434
434
  }
@@ -448,10 +448,10 @@ class CurrentActivityPrinter extends ActivityPrinterBase {
448
448
  if (failure.event.StackName === failure.event.LogicalResourceId) {
449
449
  continue;
450
450
  }
451
- lines.push(util.format(colors.red('%s | %s | %s | %s%s') + '\n', padLeft(TIMESTAMP_WIDTH, new Date(failure.event.Timestamp).toLocaleTimeString()), padRight(STATUS_WIDTH, (failure.event.ResourceStatus || '').substr(0, STATUS_WIDTH)), padRight(this.props.resourceTypeColumnWidth, failure.event.ResourceType || ''), shorten(40, (_a = failure.event.LogicalResourceId) !== null && _a !== void 0 ? _a : ''), this.failureReasonOnNextLine(failure)));
451
+ lines.push(util.format(chalk.red('%s | %s | %s | %s%s') + '\n', padLeft(TIMESTAMP_WIDTH, new Date(failure.event.Timestamp).toLocaleTimeString()), padRight(STATUS_WIDTH, (failure.event.ResourceStatus || '').substr(0, STATUS_WIDTH)), padRight(this.props.resourceTypeColumnWidth, failure.event.ResourceType || ''), shorten(40, (_a = failure.event.LogicalResourceId) !== null && _a !== void 0 ? _a : ''), this.failureReasonOnNextLine(failure)));
452
452
  const trace = (_c = (_b = failure.metadata) === null || _b === void 0 ? void 0 : _b.entry) === null || _c === void 0 ? void 0 : _c.trace;
453
453
  if (trace) {
454
- lines.push(colors.red(`\t${trace.join('\n\t\\_ ')}\n`));
454
+ lines.push(chalk.red(`\t${trace.join('\n\t\\_ ')}\n`));
455
455
  }
456
456
  }
457
457
  // Display in the same block space, otherwise we're going to have silly empty lines.
@@ -468,13 +468,13 @@ class CurrentActivityPrinter extends ActivityPrinterBase {
468
468
  const fullChars = FULL_BLOCK.repeat(Math.floor(chars));
469
469
  const partialChar = PARTIAL_BLOCK[Math.floor(remainder * PARTIAL_BLOCK.length)];
470
470
  const filler = '·'.repeat(innerWidth - Math.floor(chars) - (partialChar ? 1 : 0));
471
- const color = this.rollingBack ? colors.yellow : colors.green;
471
+ const color = this.rollingBack ? chalk.yellow : chalk.green;
472
472
  return '[' + color(fullChars + partialChar) + filler + `] (${this.resourcesDone}/${this.resourcesTotal})`;
473
473
  }
474
474
  failureReasonOnNextLine(activity) {
475
475
  var _a, _b;
476
476
  return hasErrorMessage((_a = activity.event.ResourceStatus) !== null && _a !== void 0 ? _a : '')
477
- ? `\n${' '.repeat(TIMESTAMP_WIDTH + STATUS_WIDTH + 6)}${colors.red((_b = activity.event.ResourceStatusReason) !== null && _b !== void 0 ? _b : '')}`
477
+ ? `\n${' '.repeat(TIMESTAMP_WIDTH + STATUS_WIDTH + 6)}${chalk.red((_b = activity.event.ResourceStatusReason) !== null && _b !== void 0 ? _b : '')}`
478
478
  : '';
479
479
  }
480
480
  }
@@ -489,37 +489,37 @@ function hasErrorMessage(status) {
489
489
  }
490
490
  function colorFromStatusResult(status) {
491
491
  if (!status) {
492
- return colors.reset;
492
+ return chalk.reset;
493
493
  }
494
494
  if (status.indexOf('FAILED') !== -1) {
495
- return colors.red;
495
+ return chalk.red;
496
496
  }
497
497
  if (status.indexOf('ROLLBACK') !== -1) {
498
- return colors.yellow;
498
+ return chalk.yellow;
499
499
  }
500
500
  if (status.indexOf('COMPLETE') !== -1) {
501
- return colors.green;
501
+ return chalk.green;
502
502
  }
503
- return colors.reset;
503
+ return chalk.reset;
504
504
  }
505
505
  function colorFromStatusActivity(status) {
506
506
  if (!status) {
507
- return colors.reset;
507
+ return chalk.reset;
508
508
  }
509
509
  if (status.endsWith('_FAILED')) {
510
- return colors.red;
510
+ return chalk.red;
511
511
  }
512
512
  if (status.startsWith('CREATE_') || status.startsWith('UPDATE_')) {
513
- return colors.green;
513
+ return chalk.green;
514
514
  }
515
515
  // For stacks, it may also be 'UPDDATE_ROLLBACK_IN_PROGRESS'
516
516
  if (status.indexOf('ROLLBACK_') !== -1) {
517
- return colors.yellow;
517
+ return chalk.yellow;
518
518
  }
519
519
  if (status.startsWith('DELETE_')) {
520
- return colors.yellow;
520
+ return chalk.yellow;
521
521
  }
522
- return colors.reset;
522
+ return chalk.reset;
523
523
  }
524
524
  function shorten(maxWidth, p) {
525
525
  if (p.length <= maxWidth) {
@@ -530,4 +530,4 @@ function shorten(maxWidth, p) {
530
530
  }
531
531
  const TIMESTAMP_WIDTH = 12;
532
532
  const STATUS_WIDTH = 20;
533
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-activity-monitor.js","sourceRoot":"","sources":["stack-activity-monitor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as util from 'util';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as aws from 'aws-sdk';\nimport * as colors from 'colors/safe';\nimport { error, logLevel, LogLevel, setLogLevel } from '../../../logging';\nimport { RewritableBlock } from '../display';\n\nexport interface StackActivity {\n  readonly event: aws.CloudFormation.StackEvent;\n  readonly metadata?: ResourceMetadata;\n}\n\nexport interface ResourceMetadata {\n  entry: cxschema.MetadataEntry;\n  constructPath: string;\n}\n\n/**\n * Supported display modes for stack deployment activity\n */\nexport enum StackActivityProgress {\n  /**\n   * Displays a progress bar with only the events for the resource currently being deployed\n   */\n  BAR = 'bar',\n\n  /**\n   * Displays complete history with all CloudFormation stack events\n   */\n  EVENTS = 'events',\n}\n\nexport interface WithDefaultPrinterProps {\n  /**\n   * Total number of resources to update\n   *\n   * Used to calculate a progress bar.\n   *\n   * @default - No progress reporting.\n   */\n  readonly resourcesTotal?: number;\n\n  /**\n   * The log level that was requested in the CLI\n   *\n   * If verbose or trace is requested, we'll always use the full history printer.\n   *\n   * @default - Use value from logging.logLevel\n   */\n  readonly logLevel?: LogLevel;\n\n  /**\n   * Whether to display all stack events or to display only the events for the\n   * resource currently being deployed\n   *\n   * If not set, the stack history with all stack events will be displayed\n   *\n   * @default false\n   */\n  progress?: StackActivityProgress;\n\n  /**\n   * Whether we are on a CI system\n   *\n   * If so, disable the \"optimized\" stack monitor.\n   *\n   * @default false\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Creation time of the change set\n   *\n   * This will be used to filter events, only showing those from after the change\n   * set creation time.\n   *\n   * It is recommended to use this, otherwise the filtering will be subject\n   * to clock drift between local and cloud machines.\n   *\n   * @default - local machine's current time\n   */\n  readonly changeSetCreationTime?: Date;\n}\n\nexport class StackActivityMonitor {\n\n  /**\n   * Create a Stack Activity Monitor using a default printer, based on context clues\n   */\n  public static withDefaultPrinter(\n    cfn: aws.CloudFormation,\n    stackName: string,\n    stackArtifact: cxapi.CloudFormationStackArtifact, options: WithDefaultPrinterProps = {}) {\n    const stream = process.stderr;\n\n    const props: PrinterProps = {\n      resourceTypeColumnWidth: calcMaxResourceTypeLength(stackArtifact.template),\n      resourcesTotal: options.resourcesTotal,\n      stream,\n    };\n\n    const isWindows = process.platform === 'win32';\n    const verbose = options.logLevel ?? logLevel;\n    // On some CI systems (such as CircleCI) output still reports as a TTY so we also\n    // need an individual check for whether we're running on CI.\n    // see: https://discuss.circleci.com/t/circleci-terminal-is-a-tty-but-term-is-not-set/9965\n    const fancyOutputAvailable = !isWindows && stream.isTTY && !options.ci;\n    const progress = options.progress ?? StackActivityProgress.BAR;\n\n    const printer = fancyOutputAvailable && !verbose && (progress === StackActivityProgress.BAR)\n      ? new CurrentActivityPrinter(props)\n      : new HistoryActivityPrinter(props);\n\n    return new StackActivityMonitor(cfn, stackName, printer, stackArtifact, options.changeSetCreationTime);\n  }\n\n\n  private active = false;\n  private activity: { [eventId: string]: StackActivity } = { };\n\n  /**\n   * Determines which events not to display\n   */\n  private readonly startTime: number;\n\n  /**\n   * Current tick timer\n   */\n  private tickTimer?: NodeJS.Timer;\n\n  /**\n   * Set to the activity of reading the current events\n   */\n  private readPromise?: Promise<any>;\n\n  constructor(\n    private readonly cfn: aws.CloudFormation,\n    private readonly stackName: string,\n    private readonly printer: IActivityPrinter,\n    private readonly stack?: cxapi.CloudFormationStackArtifact,\n    changeSetCreationTime?: Date,\n  ) {\n    this.startTime = changeSetCreationTime?.getTime() ?? Date.now();\n  }\n\n  public start() {\n    this.active = true;\n    this.printer.start();\n    this.scheduleNextTick();\n    return this;\n  }\n\n  public async stop() {\n    this.active = false;\n    if (this.tickTimer) {\n      clearTimeout(this.tickTimer);\n    }\n\n    // Do a final poll for all events. This is to handle the situation where DescribeStackStatus\n    // already returned an error, but the monitor hasn't seen all the events yet and we'd end\n    // up not printing the failure reason to users.\n    await this.finalPollToEnd();\n\n    this.printer.stop();\n  }\n\n  private scheduleNextTick() {\n    if (!this.active) {\n      return;\n    }\n\n    this.tickTimer = setTimeout(() => void(this.tick()), this.printer.updateSleep);\n  }\n\n  private async tick() {\n    if (!this.active) {\n      return;\n    }\n\n    try {\n      this.readPromise = this.readNewEvents();\n      await this.readPromise;\n      this.readPromise = undefined;\n\n      // We might have been stop()ped while the network call was in progress.\n      if (!this.active) { return; }\n\n      this.printer.print();\n    } catch (e) {\n      error('Error occurred while monitoring stack: %s', e);\n    }\n    this.scheduleNextTick();\n  }\n\n  private findMetadataFor(logicalId: string | undefined): ResourceMetadata | undefined {\n    const metadata = this.stack?.manifest?.metadata;\n    if (!logicalId || !metadata) { return undefined; }\n    for (const path of Object.keys(metadata)) {\n      const entry = metadata[path]\n        .filter(e => e.type === cxschema.ArtifactMetadataEntryType.LOGICAL_ID)\n        .find(e => e.data === logicalId);\n      if (entry) {\n        return {\n          entry,\n          constructPath: this.simplifyConstructPath(path),\n        };\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Reads all new events from the stack history\n   *\n   * The events are returned in reverse chronological order; we continue to the next page if we\n   * see a next page and the last event in the page is new to us (and within the time window).\n   * haven't seen the final event\n   */\n  private async readNewEvents(): Promise<void> {\n    const events: StackActivity[] = [];\n\n    try {\n      let nextToken: string | undefined;\n      let finished = false;\n      while (!finished) {\n        const response = await this.cfn.describeStackEvents({ StackName: this.stackName, NextToken: nextToken }).promise();\n        const eventPage = response?.StackEvents ?? [];\n\n        for (const event of eventPage) {\n          // Event from before we were interested in 'em\n          if (event.Timestamp.valueOf() < this.startTime) {\n            finished = true;\n            break;\n          }\n\n          // Already seen this one\n          if (event.EventId in this.activity) {\n            finished = true;\n            break;\n          }\n\n          // Fresh event\n          events.push(this.activity[event.EventId] = {\n            event: event,\n            metadata: this.findMetadataFor(event.LogicalResourceId),\n          });\n        }\n\n        // We're also done if there's nothing left to read\n        nextToken = response?.NextToken;\n        if (nextToken === undefined) {\n          finished = true;\n        }\n      }\n    } catch (e) {\n      if (e.code === 'ValidationError' && e.message === `Stack [${this.stackName}] does not exist`) {\n        return;\n      }\n      throw e;\n    }\n\n    events.reverse();\n    for (const event of events) {\n      this.printer.addActivity(event);\n    }\n  }\n\n  /**\n   * Perform a final poll to the end and flush out all events to the printer\n   *\n   * Finish any poll currently in progress, then do a final one until we've\n   * reached the last page.\n   */\n  private async finalPollToEnd() {\n    // If we were doing a poll, finish that first. It was started before\n    // the moment we were sure we weren't going to get any new events anymore\n    // so we need to do a new one anyway. Need to wait for this one though\n    // because our state is single-threaded.\n    if (this.readPromise) {\n      await this.readPromise;\n    }\n\n    await this.readNewEvents();\n  }\n\n  private simplifyConstructPath(path: string) {\n    path = path.replace(/\\/Resource$/, '');\n    path = path.replace(/^\\//, ''); // remove \"/\" prefix\n\n    // remove \"<stack-name>/\" prefix\n    if (path.startsWith(this.stackName + '/')) {\n      path = path.substr(this.stackName.length + 1);\n    }\n    return path;\n  }\n}\n\nfunction padRight(n: number, x: string): string {\n  return x + ' '.repeat(Math.max(0, n - x.length));\n}\n\n/**\n * Infamous padLeft()\n */\nfunction padLeft(n: number, x: string): string {\n  return ' '.repeat(Math.max(0, n - x.length)) + x;\n}\n\nfunction calcMaxResourceTypeLength(template: any) {\n  const resources = (template && template.Resources) || {};\n  let maxWidth = 0;\n  for (const id of Object.keys(resources)) {\n    const type = resources[id].Type || '';\n    if (type.length > maxWidth) {\n      maxWidth = type.length;\n    }\n  }\n  return maxWidth;\n}\n\ninterface PrinterProps {\n  /**\n   * Total resources to deploy\n   */\n  readonly resourcesTotal?: number\n\n  /**\n   * The with of the \"resource type\" column.\n   */\n  readonly resourceTypeColumnWidth: number;\n\n  /**\n   * Stream to write to\n   */\n  readonly stream: NodeJS.WriteStream;\n}\n\nexport interface IActivityPrinter {\n  readonly updateSleep: number;\n\n  addActivity(activity: StackActivity): void;\n  print(): void;\n  start(): void;\n  stop(): void;\n}\n\nabstract class ActivityPrinterBase implements IActivityPrinter {\n  /**\n   * Fetch new activity every 5 seconds\n   */\n  public readonly updateSleep: number = 5_000;\n\n  /**\n   * A list of resource IDs which are currently being processed\n   */\n  protected resourcesInProgress: Record<string, StackActivity> = {};\n\n  /**\n   * Previous completion state observed by logical ID\n   *\n   * We use this to detect that if we see a DELETE_COMPLETE after a\n   * CREATE_COMPLETE, it's actually a rollback and we should DECREASE\n   * resourcesDone instead of increase it\n   */\n  protected resourcesPrevCompleteState: Record<string, string> = {};\n\n  /**\n   * Count of resources that have reported a _COMPLETE status\n   */\n  protected resourcesDone: number = 0;\n\n  /**\n   * How many digits we need to represent the total count (for lining up the status reporting)\n   */\n  protected readonly resourceDigits: number = 0;\n\n  protected readonly resourcesTotal?: number;\n\n  protected rollingBack = false;\n\n  protected readonly failures = new Array<StackActivity>();\n\n  protected readonly stream: NodeJS.WriteStream;\n\n  constructor(protected readonly props: PrinterProps) {\n    // +1 because the stack also emits a \"COMPLETE\" event at the end, and that wasn't\n    // counted yet. This makes it line up with the amount of events we expect.\n    this.resourcesTotal = props.resourcesTotal ? props.resourcesTotal + 1 : undefined;\n\n    // How many digits does this number take to represent?\n    this.resourceDigits = this.resourcesTotal ? Math.ceil(Math.log10(this.resourcesTotal)) : 0;\n\n    this.stream = props.stream;\n  }\n\n  public addActivity(activity: StackActivity) {\n    const status = activity.event.ResourceStatus;\n    if (!status || !activity.event.LogicalResourceId) { return; }\n\n    if (status === 'ROLLBACK_IN_PROGRESS' || status === 'UPDATE_ROLLBACK_IN_PROGRESS') {\n      // Only triggered on the stack once we've started doing a rollback\n      this.rollingBack = true;\n    }\n\n    if (status.endsWith('_IN_PROGRESS')) {\n      this.resourcesInProgress[activity.event.LogicalResourceId] = activity;\n    }\n\n    if (hasErrorMessage(status)) {\n      const isCancelled = (activity.event.ResourceStatusReason ?? '').indexOf('cancelled') > -1;\n\n      // Cancelled is not an interesting failure reason\n      if (!isCancelled) {\n        this.failures.push(activity);\n      }\n    }\n\n    if (status.endsWith('_COMPLETE') || status.endsWith('_FAILED')) {\n      delete this.resourcesInProgress[activity.event.LogicalResourceId];\n    }\n\n    if (status.endsWith('_COMPLETE_CLEANUP_IN_PROGRESS')) {\n      this.resourcesDone++;\n    }\n\n    if (status.endsWith('_COMPLETE')) {\n      const prevState = this.resourcesPrevCompleteState[activity.event.LogicalResourceId];\n      if (!prevState) {\n        this.resourcesDone++;\n      } else {\n        // If we completed this before and we're completing it AGAIN, means we're rolling back.\n        // Protect against silly underflow.\n        this.resourcesDone--;\n        if (this.resourcesDone < 0) {\n          this.resourcesDone = 0;\n        }\n      }\n      this.resourcesPrevCompleteState[activity.event.LogicalResourceId] = status;\n    }\n  }\n\n  public abstract print(): void;\n\n  public start() {\n    // Empty on purpose\n  }\n\n  public stop() {\n    // Empty on purpose\n  }\n}\n\n/**\n * Activity Printer which shows a full log of all CloudFormation events\n *\n * When there hasn't been activity for a while, it will print the resources\n * that are currently in progress, to show what's holding up the deployment.\n */\nexport class HistoryActivityPrinter extends ActivityPrinterBase {\n  /**\n   * Last time we printed something to the console.\n   *\n   * Used to measure timeout for progress reporting.\n   */\n  private lastPrintTime = Date.now();\n\n  /**\n   * Number of ms of change absence before we tell the user about the resources that are currently in progress.\n   */\n  private readonly inProgressDelay = 30_000;\n\n  private readonly printable = new Array<StackActivity>();\n\n  constructor(props: PrinterProps) {\n    super(props);\n  }\n\n  public addActivity(activity: StackActivity) {\n    super.addActivity(activity);\n    this.printable.push(activity);\n    this.print();\n  }\n\n  public print() {\n    for (const activity of this.printable) {\n      this.printOne(activity);\n    }\n    this.printable.splice(0, this.printable.length);\n    this.printInProgress();\n  }\n\n  public stop() {\n    // Print failures at the end\n    if (this.failures.length > 0) {\n      this.stream.write('\\nFailed resources:\\n');\n      for (const failure of this.failures) {\n        // Root stack failures are not interesting\n        if (failure.event.StackName === failure.event.LogicalResourceId) {\n          continue;\n        }\n\n        this.printOne(failure, false);\n      }\n    }\n  }\n\n  private printOne(activity: StackActivity, progress?: boolean) {\n    const e = activity.event;\n    const color = colorFromStatusResult(e.ResourceStatus);\n    let reasonColor = colors.cyan;\n\n    let stackTrace = '';\n    const md = activity.metadata;\n    if (md && e.ResourceStatus && e.ResourceStatus.indexOf('FAILED') !== -1) {\n      stackTrace = md.entry.trace ? `\\n\\t${md.entry.trace.join('\\n\\t\\\\_ ')}` : '';\n      reasonColor = colors.red;\n    }\n\n    const resourceName = md ? md.constructPath : (e.LogicalResourceId || '');\n\n    const logicalId = resourceName !== e.LogicalResourceId ? `(${e.LogicalResourceId}) ` : '';\n\n    this.stream.write(\n      util.format(\n        '%s | %s%s | %s | %s | %s %s%s%s\\n',\n        e.StackName,\n        (progress !== false ? `${this.progress()} | ` : ''),\n        new Date(e.Timestamp).toLocaleTimeString(),\n        color(padRight(STATUS_WIDTH, (e.ResourceStatus || '').substr(0, STATUS_WIDTH))), // pad left and trim\n        padRight(this.props.resourceTypeColumnWidth, e.ResourceType || ''),\n        color(colors.bold(resourceName)),\n        logicalId,\n        reasonColor(colors.bold(e.ResourceStatusReason ? e.ResourceStatusReason : '')),\n        reasonColor(stackTrace),\n      ),\n    );\n\n    this.lastPrintTime = Date.now();\n  }\n\n  /**\n   * Report the current progress as a [34/42] string, or just [34] if the total is unknown\n   */\n  private progress(): string {\n    if (this.resourcesTotal == null) {\n      // Don't have total, show simple count and hope the human knows\n      return padLeft(3, util.format('%s', this.resourcesDone)); // max 500 resources\n    }\n\n    return util.format('%s/%s',\n      padLeft(this.resourceDigits, this.resourcesDone.toString()),\n      padLeft(this.resourceDigits, this.resourcesTotal != null ? this.resourcesTotal.toString() : '?'));\n  }\n\n  /**\n   * If some resources are taking a while to create, notify the user about what's currently in progress\n   */\n  private printInProgress() {\n    if (Date.now() < this.lastPrintTime + this.inProgressDelay) {\n      return;\n    }\n\n    if (Object.keys(this.resourcesInProgress).length > 0) {\n      this.stream.write(util.format('%s Currently in progress: %s\\n',\n        this.progress(),\n        colors.bold(Object.keys(this.resourcesInProgress).join(', '))));\n    }\n\n    // We cheat a bit here. To prevent printInProgress() from repeatedly triggering,\n    // we set the timestamp into the future. It will be reset whenever a regular print\n    // occurs, after which we can be triggered again.\n    this.lastPrintTime = +Infinity;\n  }\n\n}\n\n/**\n * Activity Printer which shows the resources currently being updated\n *\n * It will continuously reupdate the terminal and show only the resources\n * that are currently being updated, in addition to a progress bar which\n * shows how far along the deployment is.\n *\n * Resources that have failed will always be shown, and will be recapitulated\n * along with their stack trace when the monitoring ends.\n *\n * Resources that failed deployment because they have been cancelled are\n * not included.\n */\nexport class CurrentActivityPrinter extends ActivityPrinterBase {\n  /**\n   * This looks very disorienting sleeping for 5 seconds. Update quicker.\n   */\n  public readonly updateSleep: number = 2_000;\n\n  private oldLogLevel: LogLevel = LogLevel.DEFAULT;\n  private block = new RewritableBlock(this.stream);\n\n  constructor(props: PrinterProps) {\n    super(props);\n  }\n\n  public print(): void {\n    const lines = [];\n\n    // Add a progress bar at the top\n    const progressWidth = Math.max(Math.min((this.block.width ?? 80) - PROGRESSBAR_EXTRA_SPACE - 1, MAX_PROGRESSBAR_WIDTH), MIN_PROGRESSBAR_WIDTH);\n    const prog = this.progressBar(progressWidth);\n    if (prog) {\n      lines.push('  ' + prog, '');\n    }\n\n    // Normally we'd only print \"resources in progress\", but it's also useful\n    // to keep an eye on the failures and know about the specific errors asquickly\n    // as possible (while the stack is still rolling back), so add those in.\n    const toPrint: StackActivity[] = [...this.failures, ...Object.values(this.resourcesInProgress)];\n    toPrint.sort((a, b) => a.event.Timestamp.getTime() - b.event.Timestamp.getTime());\n\n    lines.push(...toPrint.map(res => {\n      const color = colorFromStatusActivity(res.event.ResourceStatus);\n      const resourceName = res.metadata?.constructPath ?? res.event.LogicalResourceId ?? '';\n\n      return util.format('%s | %s | %s | %s%s',\n        padLeft(TIMESTAMP_WIDTH, new Date(res.event.Timestamp).toLocaleTimeString()),\n        color(padRight(STATUS_WIDTH, (res.event.ResourceStatus || '').substr(0, STATUS_WIDTH))),\n        padRight(this.props.resourceTypeColumnWidth, res.event.ResourceType || ''),\n        color(colors.bold(shorten(40, resourceName))),\n        this.failureReasonOnNextLine(res));\n    }));\n\n    this.block.displayLines(lines);\n  }\n\n  public start() {\n    // Need to prevent the waiter from printing 'stack not stable' every 5 seconds, it messes\n    // with the output calculations.\n    this.oldLogLevel = logLevel;\n    setLogLevel(LogLevel.DEFAULT);\n  }\n\n  public stop() {\n    setLogLevel(this.oldLogLevel);\n\n    // Print failures at the end\n    const lines = new Array<string>();\n    for (const failure of this.failures) {\n      // Root stack failures are not interesting\n      if (failure.event.StackName === failure.event.LogicalResourceId) {\n        continue;\n      }\n\n      lines.push(util.format(colors.red('%s | %s | %s | %s%s') + '\\n',\n        padLeft(TIMESTAMP_WIDTH, new Date(failure.event.Timestamp).toLocaleTimeString()),\n        padRight(STATUS_WIDTH, (failure.event.ResourceStatus || '').substr(0, STATUS_WIDTH)),\n        padRight(this.props.resourceTypeColumnWidth, failure.event.ResourceType || ''),\n        shorten(40, failure.event.LogicalResourceId ?? ''),\n        this.failureReasonOnNextLine(failure)));\n\n      const trace = failure.metadata?.entry?.trace;\n      if (trace) {\n        lines.push(colors.red(`\\t${trace.join('\\n\\t\\\\_ ')}\\n`));\n      }\n    }\n\n    // Display in the same block space, otherwise we're going to have silly empty lines.\n    this.block.displayLines(lines);\n  }\n\n  private progressBar(width: number) {\n    if (!this.resourcesTotal) { return ''; }\n    const fraction = Math.min(this.resourcesDone / this.resourcesTotal, 1);\n    const innerWidth = Math.max(1, width - 2);\n    const chars = innerWidth * fraction;\n    const remainder = chars - Math.floor(chars);\n\n    const fullChars = FULL_BLOCK.repeat(Math.floor(chars));\n    const partialChar = PARTIAL_BLOCK[Math.floor(remainder * PARTIAL_BLOCK.length)];\n    const filler = '·'.repeat(innerWidth - Math.floor(chars) - (partialChar ? 1 : 0));\n\n    const color = this.rollingBack ? colors.yellow : colors.green;\n\n    return '[' + color(fullChars + partialChar) + filler + `] (${this.resourcesDone}/${this.resourcesTotal})`;\n  }\n\n  private failureReasonOnNextLine(activity: StackActivity) {\n    return hasErrorMessage(activity.event.ResourceStatus ?? '')\n      ? `\\n${' '.repeat(TIMESTAMP_WIDTH + STATUS_WIDTH + 6)}${colors.red(activity.event.ResourceStatusReason ?? '')}`\n      : '';\n  }\n}\n\nconst FULL_BLOCK = '█';\nconst PARTIAL_BLOCK = ['', '▏', '▎', '▍', '▌', '▋', '▊', '▉'];\nconst MAX_PROGRESSBAR_WIDTH = 60;\nconst MIN_PROGRESSBAR_WIDTH = 10;\nconst PROGRESSBAR_EXTRA_SPACE = 2 /* leading spaces */ + 2 /* brackets */ + 4 /* progress number decoration */ + 6 /* 2 progress numbers up to 999 */;\n\nfunction hasErrorMessage(status: string) {\n  return status.endsWith('_FAILED') || status === 'ROLLBACK_IN_PROGRESS' || status === 'UPDATE_ROLLBACK_IN_PROGRESS';\n}\n\nfunction colorFromStatusResult(status?: string) {\n  if (!status) {\n    return colors.reset;\n  }\n\n  if (status.indexOf('FAILED') !== -1) {\n    return colors.red;\n  }\n  if (status.indexOf('ROLLBACK') !== -1) {\n    return colors.yellow;\n  }\n  if (status.indexOf('COMPLETE') !== -1) {\n    return colors.green;\n  }\n\n  return colors.reset;\n}\n\nfunction colorFromStatusActivity(status?: string) {\n  if (!status) {\n    return colors.reset;\n  }\n\n  if (status.endsWith('_FAILED')) {\n    return colors.red;\n  }\n\n  if (status.startsWith('CREATE_') || status.startsWith('UPDATE_')) {\n    return colors.green;\n  }\n  // For stacks, it may also be 'UPDDATE_ROLLBACK_IN_PROGRESS'\n  if (status.indexOf('ROLLBACK_') !== -1) {\n    return colors.yellow;\n  }\n  if (status.startsWith('DELETE_')) {\n    return colors.yellow;\n  }\n\n  return colors.reset;\n}\n\nfunction shorten(maxWidth: number, p: string) {\n  if (p.length <= maxWidth) { return p; }\n  const half = Math.floor((maxWidth - 3) / 2);\n  return p.substr(0, half) + '...' + p.substr(p.length - half);\n}\n\nconst TIMESTAMP_WIDTH = 12;\nconst STATUS_WIDTH = 20;\n"]}
533
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-activity-monitor.js","sourceRoot":"","sources":["stack-activity-monitor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as util from 'util';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as aws from 'aws-sdk';\nimport * as chalk from 'chalk';\nimport { error, logLevel, LogLevel, setLogLevel } from '../../../logging';\nimport { RewritableBlock } from '../display';\n\nexport interface StackActivity {\n  readonly event: aws.CloudFormation.StackEvent;\n  readonly metadata?: ResourceMetadata;\n}\n\nexport interface ResourceMetadata {\n  entry: cxschema.MetadataEntry;\n  constructPath: string;\n}\n\n/**\n * Supported display modes for stack deployment activity\n */\nexport enum StackActivityProgress {\n  /**\n   * Displays a progress bar with only the events for the resource currently being deployed\n   */\n  BAR = 'bar',\n\n  /**\n   * Displays complete history with all CloudFormation stack events\n   */\n  EVENTS = 'events',\n}\n\nexport interface WithDefaultPrinterProps {\n  /**\n   * Total number of resources to update\n   *\n   * Used to calculate a progress bar.\n   *\n   * @default - No progress reporting.\n   */\n  readonly resourcesTotal?: number;\n\n  /**\n   * The log level that was requested in the CLI\n   *\n   * If verbose or trace is requested, we'll always use the full history printer.\n   *\n   * @default - Use value from logging.logLevel\n   */\n  readonly logLevel?: LogLevel;\n\n  /**\n   * Whether to display all stack events or to display only the events for the\n   * resource currently being deployed\n   *\n   * If not set, the stack history with all stack events will be displayed\n   *\n   * @default false\n   */\n  progress?: StackActivityProgress;\n\n  /**\n   * Whether we are on a CI system\n   *\n   * If so, disable the \"optimized\" stack monitor.\n   *\n   * @default false\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Creation time of the change set\n   *\n   * This will be used to filter events, only showing those from after the change\n   * set creation time.\n   *\n   * It is recommended to use this, otherwise the filtering will be subject\n   * to clock drift between local and cloud machines.\n   *\n   * @default - local machine's current time\n   */\n  readonly changeSetCreationTime?: Date;\n}\n\nexport class StackActivityMonitor {\n\n  /**\n   * Create a Stack Activity Monitor using a default printer, based on context clues\n   */\n  public static withDefaultPrinter(\n    cfn: aws.CloudFormation,\n    stackName: string,\n    stackArtifact: cxapi.CloudFormationStackArtifact, options: WithDefaultPrinterProps = {}) {\n    const stream = process.stderr;\n\n    const props: PrinterProps = {\n      resourceTypeColumnWidth: calcMaxResourceTypeLength(stackArtifact.template),\n      resourcesTotal: options.resourcesTotal,\n      stream,\n    };\n\n    const isWindows = process.platform === 'win32';\n    const verbose = options.logLevel ?? logLevel;\n    // On some CI systems (such as CircleCI) output still reports as a TTY so we also\n    // need an individual check for whether we're running on CI.\n    // see: https://discuss.circleci.com/t/circleci-terminal-is-a-tty-but-term-is-not-set/9965\n    const fancyOutputAvailable = !isWindows && stream.isTTY && !options.ci;\n    const progress = options.progress ?? StackActivityProgress.BAR;\n\n    const printer = fancyOutputAvailable && !verbose && (progress === StackActivityProgress.BAR)\n      ? new CurrentActivityPrinter(props)\n      : new HistoryActivityPrinter(props);\n\n    return new StackActivityMonitor(cfn, stackName, printer, stackArtifact, options.changeSetCreationTime);\n  }\n\n\n  private active = false;\n  private activity: { [eventId: string]: StackActivity } = { };\n\n  /**\n   * Determines which events not to display\n   */\n  private readonly startTime: number;\n\n  /**\n   * Current tick timer\n   */\n  private tickTimer?: NodeJS.Timer;\n\n  /**\n   * Set to the activity of reading the current events\n   */\n  private readPromise?: Promise<any>;\n\n  constructor(\n    private readonly cfn: aws.CloudFormation,\n    private readonly stackName: string,\n    private readonly printer: IActivityPrinter,\n    private readonly stack?: cxapi.CloudFormationStackArtifact,\n    changeSetCreationTime?: Date,\n  ) {\n    this.startTime = changeSetCreationTime?.getTime() ?? Date.now();\n  }\n\n  public start() {\n    this.active = true;\n    this.printer.start();\n    this.scheduleNextTick();\n    return this;\n  }\n\n  public async stop() {\n    this.active = false;\n    if (this.tickTimer) {\n      clearTimeout(this.tickTimer);\n    }\n\n    // Do a final poll for all events. This is to handle the situation where DescribeStackStatus\n    // already returned an error, but the monitor hasn't seen all the events yet and we'd end\n    // up not printing the failure reason to users.\n    await this.finalPollToEnd();\n\n    this.printer.stop();\n  }\n\n  private scheduleNextTick() {\n    if (!this.active) {\n      return;\n    }\n\n    this.tickTimer = setTimeout(() => void(this.tick()), this.printer.updateSleep);\n  }\n\n  private async tick() {\n    if (!this.active) {\n      return;\n    }\n\n    try {\n      this.readPromise = this.readNewEvents();\n      await this.readPromise;\n      this.readPromise = undefined;\n\n      // We might have been stop()ped while the network call was in progress.\n      if (!this.active) { return; }\n\n      this.printer.print();\n    } catch (e) {\n      error('Error occurred while monitoring stack: %s', e);\n    }\n    this.scheduleNextTick();\n  }\n\n  private findMetadataFor(logicalId: string | undefined): ResourceMetadata | undefined {\n    const metadata = this.stack?.manifest?.metadata;\n    if (!logicalId || !metadata) { return undefined; }\n    for (const path of Object.keys(metadata)) {\n      const entry = metadata[path]\n        .filter(e => e.type === cxschema.ArtifactMetadataEntryType.LOGICAL_ID)\n        .find(e => e.data === logicalId);\n      if (entry) {\n        return {\n          entry,\n          constructPath: this.simplifyConstructPath(path),\n        };\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Reads all new events from the stack history\n   *\n   * The events are returned in reverse chronological order; we continue to the next page if we\n   * see a next page and the last event in the page is new to us (and within the time window).\n   * haven't seen the final event\n   */\n  private async readNewEvents(): Promise<void> {\n    const events: StackActivity[] = [];\n\n    try {\n      let nextToken: string | undefined;\n      let finished = false;\n      while (!finished) {\n        const response = await this.cfn.describeStackEvents({ StackName: this.stackName, NextToken: nextToken }).promise();\n        const eventPage = response?.StackEvents ?? [];\n\n        for (const event of eventPage) {\n          // Event from before we were interested in 'em\n          if (event.Timestamp.valueOf() < this.startTime) {\n            finished = true;\n            break;\n          }\n\n          // Already seen this one\n          if (event.EventId in this.activity) {\n            finished = true;\n            break;\n          }\n\n          // Fresh event\n          events.push(this.activity[event.EventId] = {\n            event: event,\n            metadata: this.findMetadataFor(event.LogicalResourceId),\n          });\n        }\n\n        // We're also done if there's nothing left to read\n        nextToken = response?.NextToken;\n        if (nextToken === undefined) {\n          finished = true;\n        }\n      }\n    } catch (e) {\n      if (e.code === 'ValidationError' && e.message === `Stack [${this.stackName}] does not exist`) {\n        return;\n      }\n      throw e;\n    }\n\n    events.reverse();\n    for (const event of events) {\n      this.printer.addActivity(event);\n    }\n  }\n\n  /**\n   * Perform a final poll to the end and flush out all events to the printer\n   *\n   * Finish any poll currently in progress, then do a final one until we've\n   * reached the last page.\n   */\n  private async finalPollToEnd() {\n    // If we were doing a poll, finish that first. It was started before\n    // the moment we were sure we weren't going to get any new events anymore\n    // so we need to do a new one anyway. Need to wait for this one though\n    // because our state is single-threaded.\n    if (this.readPromise) {\n      await this.readPromise;\n    }\n\n    await this.readNewEvents();\n  }\n\n  private simplifyConstructPath(path: string) {\n    path = path.replace(/\\/Resource$/, '');\n    path = path.replace(/^\\//, ''); // remove \"/\" prefix\n\n    // remove \"<stack-name>/\" prefix\n    if (path.startsWith(this.stackName + '/')) {\n      path = path.substr(this.stackName.length + 1);\n    }\n    return path;\n  }\n}\n\nfunction padRight(n: number, x: string): string {\n  return x + ' '.repeat(Math.max(0, n - x.length));\n}\n\n/**\n * Infamous padLeft()\n */\nfunction padLeft(n: number, x: string): string {\n  return ' '.repeat(Math.max(0, n - x.length)) + x;\n}\n\nfunction calcMaxResourceTypeLength(template: any) {\n  const resources = (template && template.Resources) || {};\n  let maxWidth = 0;\n  for (const id of Object.keys(resources)) {\n    const type = resources[id].Type || '';\n    if (type.length > maxWidth) {\n      maxWidth = type.length;\n    }\n  }\n  return maxWidth;\n}\n\ninterface PrinterProps {\n  /**\n   * Total resources to deploy\n   */\n  readonly resourcesTotal?: number\n\n  /**\n   * The with of the \"resource type\" column.\n   */\n  readonly resourceTypeColumnWidth: number;\n\n  /**\n   * Stream to write to\n   */\n  readonly stream: NodeJS.WriteStream;\n}\n\nexport interface IActivityPrinter {\n  readonly updateSleep: number;\n\n  addActivity(activity: StackActivity): void;\n  print(): void;\n  start(): void;\n  stop(): void;\n}\n\nabstract class ActivityPrinterBase implements IActivityPrinter {\n  /**\n   * Fetch new activity every 5 seconds\n   */\n  public readonly updateSleep: number = 5_000;\n\n  /**\n   * A list of resource IDs which are currently being processed\n   */\n  protected resourcesInProgress: Record<string, StackActivity> = {};\n\n  /**\n   * Previous completion state observed by logical ID\n   *\n   * We use this to detect that if we see a DELETE_COMPLETE after a\n   * CREATE_COMPLETE, it's actually a rollback and we should DECREASE\n   * resourcesDone instead of increase it\n   */\n  protected resourcesPrevCompleteState: Record<string, string> = {};\n\n  /**\n   * Count of resources that have reported a _COMPLETE status\n   */\n  protected resourcesDone: number = 0;\n\n  /**\n   * How many digits we need to represent the total count (for lining up the status reporting)\n   */\n  protected readonly resourceDigits: number = 0;\n\n  protected readonly resourcesTotal?: number;\n\n  protected rollingBack = false;\n\n  protected readonly failures = new Array<StackActivity>();\n\n  protected readonly stream: NodeJS.WriteStream;\n\n  constructor(protected readonly props: PrinterProps) {\n    // +1 because the stack also emits a \"COMPLETE\" event at the end, and that wasn't\n    // counted yet. This makes it line up with the amount of events we expect.\n    this.resourcesTotal = props.resourcesTotal ? props.resourcesTotal + 1 : undefined;\n\n    // How many digits does this number take to represent?\n    this.resourceDigits = this.resourcesTotal ? Math.ceil(Math.log10(this.resourcesTotal)) : 0;\n\n    this.stream = props.stream;\n  }\n\n  public addActivity(activity: StackActivity) {\n    const status = activity.event.ResourceStatus;\n    if (!status || !activity.event.LogicalResourceId) { return; }\n\n    if (status === 'ROLLBACK_IN_PROGRESS' || status === 'UPDATE_ROLLBACK_IN_PROGRESS') {\n      // Only triggered on the stack once we've started doing a rollback\n      this.rollingBack = true;\n    }\n\n    if (status.endsWith('_IN_PROGRESS')) {\n      this.resourcesInProgress[activity.event.LogicalResourceId] = activity;\n    }\n\n    if (hasErrorMessage(status)) {\n      const isCancelled = (activity.event.ResourceStatusReason ?? '').indexOf('cancelled') > -1;\n\n      // Cancelled is not an interesting failure reason\n      if (!isCancelled) {\n        this.failures.push(activity);\n      }\n    }\n\n    if (status.endsWith('_COMPLETE') || status.endsWith('_FAILED')) {\n      delete this.resourcesInProgress[activity.event.LogicalResourceId];\n    }\n\n    if (status.endsWith('_COMPLETE_CLEANUP_IN_PROGRESS')) {\n      this.resourcesDone++;\n    }\n\n    if (status.endsWith('_COMPLETE')) {\n      const prevState = this.resourcesPrevCompleteState[activity.event.LogicalResourceId];\n      if (!prevState) {\n        this.resourcesDone++;\n      } else {\n        // If we completed this before and we're completing it AGAIN, means we're rolling back.\n        // Protect against silly underflow.\n        this.resourcesDone--;\n        if (this.resourcesDone < 0) {\n          this.resourcesDone = 0;\n        }\n      }\n      this.resourcesPrevCompleteState[activity.event.LogicalResourceId] = status;\n    }\n  }\n\n  public abstract print(): void;\n\n  public start() {\n    // Empty on purpose\n  }\n\n  public stop() {\n    // Empty on purpose\n  }\n}\n\n/**\n * Activity Printer which shows a full log of all CloudFormation events\n *\n * When there hasn't been activity for a while, it will print the resources\n * that are currently in progress, to show what's holding up the deployment.\n */\nexport class HistoryActivityPrinter extends ActivityPrinterBase {\n  /**\n   * Last time we printed something to the console.\n   *\n   * Used to measure timeout for progress reporting.\n   */\n  private lastPrintTime = Date.now();\n\n  /**\n   * Number of ms of change absence before we tell the user about the resources that are currently in progress.\n   */\n  private readonly inProgressDelay = 30_000;\n\n  private readonly printable = new Array<StackActivity>();\n\n  constructor(props: PrinterProps) {\n    super(props);\n  }\n\n  public addActivity(activity: StackActivity) {\n    super.addActivity(activity);\n    this.printable.push(activity);\n    this.print();\n  }\n\n  public print() {\n    for (const activity of this.printable) {\n      this.printOne(activity);\n    }\n    this.printable.splice(0, this.printable.length);\n    this.printInProgress();\n  }\n\n  public stop() {\n    // Print failures at the end\n    if (this.failures.length > 0) {\n      this.stream.write('\\nFailed resources:\\n');\n      for (const failure of this.failures) {\n        // Root stack failures are not interesting\n        if (failure.event.StackName === failure.event.LogicalResourceId) {\n          continue;\n        }\n\n        this.printOne(failure, false);\n      }\n    }\n  }\n\n  private printOne(activity: StackActivity, progress?: boolean) {\n    const e = activity.event;\n    const color = colorFromStatusResult(e.ResourceStatus);\n    let reasonColor = chalk.cyan;\n\n    let stackTrace = '';\n    const md = activity.metadata;\n    if (md && e.ResourceStatus && e.ResourceStatus.indexOf('FAILED') !== -1) {\n      stackTrace = md.entry.trace ? `\\n\\t${md.entry.trace.join('\\n\\t\\\\_ ')}` : '';\n      reasonColor = chalk.red;\n    }\n\n    const resourceName = md ? md.constructPath : (e.LogicalResourceId || '');\n\n    const logicalId = resourceName !== e.LogicalResourceId ? `(${e.LogicalResourceId}) ` : '';\n\n    this.stream.write(\n      util.format(\n        '%s | %s%s | %s | %s | %s %s%s%s\\n',\n        e.StackName,\n        (progress !== false ? `${this.progress()} | ` : ''),\n        new Date(e.Timestamp).toLocaleTimeString(),\n        color(padRight(STATUS_WIDTH, (e.ResourceStatus || '').substr(0, STATUS_WIDTH))), // pad left and trim\n        padRight(this.props.resourceTypeColumnWidth, e.ResourceType || ''),\n        color(chalk.bold(resourceName)),\n        logicalId,\n        reasonColor(chalk.bold(e.ResourceStatusReason ? e.ResourceStatusReason : '')),\n        reasonColor(stackTrace),\n      ),\n    );\n\n    this.lastPrintTime = Date.now();\n  }\n\n  /**\n   * Report the current progress as a [34/42] string, or just [34] if the total is unknown\n   */\n  private progress(): string {\n    if (this.resourcesTotal == null) {\n      // Don't have total, show simple count and hope the human knows\n      return padLeft(3, util.format('%s', this.resourcesDone)); // max 500 resources\n    }\n\n    return util.format('%s/%s',\n      padLeft(this.resourceDigits, this.resourcesDone.toString()),\n      padLeft(this.resourceDigits, this.resourcesTotal != null ? this.resourcesTotal.toString() : '?'));\n  }\n\n  /**\n   * If some resources are taking a while to create, notify the user about what's currently in progress\n   */\n  private printInProgress() {\n    if (Date.now() < this.lastPrintTime + this.inProgressDelay) {\n      return;\n    }\n\n    if (Object.keys(this.resourcesInProgress).length > 0) {\n      this.stream.write(util.format('%s Currently in progress: %s\\n',\n        this.progress(),\n        chalk.bold(Object.keys(this.resourcesInProgress).join(', '))));\n    }\n\n    // We cheat a bit here. To prevent printInProgress() from repeatedly triggering,\n    // we set the timestamp into the future. It will be reset whenever a regular print\n    // occurs, after which we can be triggered again.\n    this.lastPrintTime = +Infinity;\n  }\n\n}\n\n/**\n * Activity Printer which shows the resources currently being updated\n *\n * It will continuously reupdate the terminal and show only the resources\n * that are currently being updated, in addition to a progress bar which\n * shows how far along the deployment is.\n *\n * Resources that have failed will always be shown, and will be recapitulated\n * along with their stack trace when the monitoring ends.\n *\n * Resources that failed deployment because they have been cancelled are\n * not included.\n */\nexport class CurrentActivityPrinter extends ActivityPrinterBase {\n  /**\n   * This looks very disorienting sleeping for 5 seconds. Update quicker.\n   */\n  public readonly updateSleep: number = 2_000;\n\n  private oldLogLevel: LogLevel = LogLevel.DEFAULT;\n  private block = new RewritableBlock(this.stream);\n\n  constructor(props: PrinterProps) {\n    super(props);\n  }\n\n  public print(): void {\n    const lines = [];\n\n    // Add a progress bar at the top\n    const progressWidth = Math.max(Math.min((this.block.width ?? 80) - PROGRESSBAR_EXTRA_SPACE - 1, MAX_PROGRESSBAR_WIDTH), MIN_PROGRESSBAR_WIDTH);\n    const prog = this.progressBar(progressWidth);\n    if (prog) {\n      lines.push('  ' + prog, '');\n    }\n\n    // Normally we'd only print \"resources in progress\", but it's also useful\n    // to keep an eye on the failures and know about the specific errors asquickly\n    // as possible (while the stack is still rolling back), so add those in.\n    const toPrint: StackActivity[] = [...this.failures, ...Object.values(this.resourcesInProgress)];\n    toPrint.sort((a, b) => a.event.Timestamp.getTime() - b.event.Timestamp.getTime());\n\n    lines.push(...toPrint.map(res => {\n      const color = colorFromStatusActivity(res.event.ResourceStatus);\n      const resourceName = res.metadata?.constructPath ?? res.event.LogicalResourceId ?? '';\n\n      return util.format('%s | %s | %s | %s%s',\n        padLeft(TIMESTAMP_WIDTH, new Date(res.event.Timestamp).toLocaleTimeString()),\n        color(padRight(STATUS_WIDTH, (res.event.ResourceStatus || '').substr(0, STATUS_WIDTH))),\n        padRight(this.props.resourceTypeColumnWidth, res.event.ResourceType || ''),\n        color(chalk.bold(shorten(40, resourceName))),\n        this.failureReasonOnNextLine(res));\n    }));\n\n    this.block.displayLines(lines);\n  }\n\n  public start() {\n    // Need to prevent the waiter from printing 'stack not stable' every 5 seconds, it messes\n    // with the output calculations.\n    this.oldLogLevel = logLevel;\n    setLogLevel(LogLevel.DEFAULT);\n  }\n\n  public stop() {\n    setLogLevel(this.oldLogLevel);\n\n    // Print failures at the end\n    const lines = new Array<string>();\n    for (const failure of this.failures) {\n      // Root stack failures are not interesting\n      if (failure.event.StackName === failure.event.LogicalResourceId) {\n        continue;\n      }\n\n      lines.push(util.format(chalk.red('%s | %s | %s | %s%s') + '\\n',\n        padLeft(TIMESTAMP_WIDTH, new Date(failure.event.Timestamp).toLocaleTimeString()),\n        padRight(STATUS_WIDTH, (failure.event.ResourceStatus || '').substr(0, STATUS_WIDTH)),\n        padRight(this.props.resourceTypeColumnWidth, failure.event.ResourceType || ''),\n        shorten(40, failure.event.LogicalResourceId ?? ''),\n        this.failureReasonOnNextLine(failure)));\n\n      const trace = failure.metadata?.entry?.trace;\n      if (trace) {\n        lines.push(chalk.red(`\\t${trace.join('\\n\\t\\\\_ ')}\\n`));\n      }\n    }\n\n    // Display in the same block space, otherwise we're going to have silly empty lines.\n    this.block.displayLines(lines);\n  }\n\n  private progressBar(width: number) {\n    if (!this.resourcesTotal) { return ''; }\n    const fraction = Math.min(this.resourcesDone / this.resourcesTotal, 1);\n    const innerWidth = Math.max(1, width - 2);\n    const chars = innerWidth * fraction;\n    const remainder = chars - Math.floor(chars);\n\n    const fullChars = FULL_BLOCK.repeat(Math.floor(chars));\n    const partialChar = PARTIAL_BLOCK[Math.floor(remainder * PARTIAL_BLOCK.length)];\n    const filler = '·'.repeat(innerWidth - Math.floor(chars) - (partialChar ? 1 : 0));\n\n    const color = this.rollingBack ? chalk.yellow : chalk.green;\n\n    return '[' + color(fullChars + partialChar) + filler + `] (${this.resourcesDone}/${this.resourcesTotal})`;\n  }\n\n  private failureReasonOnNextLine(activity: StackActivity) {\n    return hasErrorMessage(activity.event.ResourceStatus ?? '')\n      ? `\\n${' '.repeat(TIMESTAMP_WIDTH + STATUS_WIDTH + 6)}${chalk.red(activity.event.ResourceStatusReason ?? '')}`\n      : '';\n  }\n}\n\nconst FULL_BLOCK = '█';\nconst PARTIAL_BLOCK = ['', '▏', '▎', '▍', '▌', '▋', '▊', '▉'];\nconst MAX_PROGRESSBAR_WIDTH = 60;\nconst MIN_PROGRESSBAR_WIDTH = 10;\nconst PROGRESSBAR_EXTRA_SPACE = 2 /* leading spaces */ + 2 /* brackets */ + 4 /* progress number decoration */ + 6 /* 2 progress numbers up to 999 */;\n\nfunction hasErrorMessage(status: string) {\n  return status.endsWith('_FAILED') || status === 'ROLLBACK_IN_PROGRESS' || status === 'UPDATE_ROLLBACK_IN_PROGRESS';\n}\n\nfunction colorFromStatusResult(status?: string) {\n  if (!status) {\n    return chalk.reset;\n  }\n\n  if (status.indexOf('FAILED') !== -1) {\n    return chalk.red;\n  }\n  if (status.indexOf('ROLLBACK') !== -1) {\n    return chalk.yellow;\n  }\n  if (status.indexOf('COMPLETE') !== -1) {\n    return chalk.green;\n  }\n\n  return chalk.reset;\n}\n\nfunction colorFromStatusActivity(status?: string) {\n  if (!status) {\n    return chalk.reset;\n  }\n\n  if (status.endsWith('_FAILED')) {\n    return chalk.red;\n  }\n\n  if (status.startsWith('CREATE_') || status.startsWith('UPDATE_')) {\n    return chalk.green;\n  }\n  // For stacks, it may also be 'UPDDATE_ROLLBACK_IN_PROGRESS'\n  if (status.indexOf('ROLLBACK_') !== -1) {\n    return chalk.yellow;\n  }\n  if (status.startsWith('DELETE_')) {\n    return chalk.yellow;\n  }\n\n  return chalk.reset;\n}\n\nfunction shorten(maxWidth: number, p: string) {\n  if (p.length <= maxWidth) { return p; }\n  const half = Math.floor((maxWidth - 3) / 2);\n  return p.substr(0, half) + '...' + p.substr(p.length - half);\n}\n\nconst TIMESTAMP_WIDTH = 12;\nconst STATUS_WIDTH = 20;\n"]}
package/lib/assets.js CHANGED
@@ -5,7 +5,7 @@ exports.addMetadataAssetsToManifest = void 0;
5
5
  const path = require("path");
6
6
  const cxschema = require("@aws-cdk/cloud-assembly-schema");
7
7
  const cxapi = require("@aws-cdk/cx-api");
8
- const colors = require("colors");
8
+ const chalk = require("chalk");
9
9
  const logging_1 = require("./logging");
10
10
  /**
11
11
  * Take the metadata assets from the given stack and add them to the given asset manifest
@@ -22,7 +22,7 @@ async function addMetadataAssetsToManifest(stack, assetManifest, toolkitInfo, re
22
22
  }
23
23
  if (!toolkitInfo.found) {
24
24
  // eslint-disable-next-line max-len
25
- throw new Error(`This stack uses assets, so the toolkit stack must be deployed to the environment (Run "${colors.blue('cdk bootstrap ' + stack.environment.name)}")`);
25
+ throw new Error(`This stack uses assets, so the toolkit stack must be deployed to the environment (Run "${chalk.blue('cdk bootstrap ' + stack.environment.name)}")`);
26
26
  }
27
27
  const params = {};
28
28
  for (const asset of assets) {
@@ -103,4 +103,4 @@ async function prepareDockerImageAsset(asset, assetManifest, toolkitInfo) {
103
103
  }
104
104
  return { [asset.imageNameParameter]: `${repositoryUri}:${imageTag}` };
105
105
  }
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assets.js","sourceRoot":"","sources":["assets.ts"],"names":[],"mappings":";;;AAAA,mCAAmC;AACnC,6BAA6B;AAC7B,2DAA2D;AAC3D,yCAAyC;AACzC,iCAAiC;AAEjC,uCAAkC;AAGlC;;;;;GAKG;AACH,mCAAmC;AAC5B,KAAK,UAAU,2BAA2B,CAAC,KAAwC,EAAE,aAAmC,EAAE,WAAwB,EAAE,KAAgB;IACzK,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;IACpB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;IAE5B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QACvB,OAAO,EAAE,CAAC;KACX;IAED,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;QACtB,mCAAmC;QACnC,MAAM,IAAI,KAAK,CAAC,0FAA0F,MAAM,CAAC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,WAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KACxK;IAED,MAAM,MAAM,GAA2B,EAAE,CAAC;IAE1C,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;QAC1B,+FAA+F;QAC/F,gFAAgF;QAChF,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;QAEhD,IAAI,UAAU,EAAE;YACd,eAAK,CAAC,iBAAiB,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAC7D,SAAS;SACV;QAED,eAAK,CAAC,mBAAmB,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC/D,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;YACnB,MAAM,IAAI,KAAK,CAAC,qFAAqF,CAAC,CAAC;SACxG;QAED,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,YAAY,CAAC,KAAK,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC,CAAC;KAC9E;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAlCD,kEAkCC;AAED,mCAAmC;AACnC,KAAK,UAAU,YAAY,CAAC,KAAkC,EAAE,aAAmC,EAAE,WAAwB;IAC3H,QAAQ,KAAK,CAAC,SAAS,EAAE;QACvB,KAAK,KAAK,CAAC;QACX,KAAK,MAAM;YACT,OAAO,gBAAgB,CACrB,KAAK,EACL,aAAa,EACb,WAAW,EACX,KAAK,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAC9G,KAAK,iBAAiB;YACpB,OAAO,uBAAuB,CAAC,KAAK,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;QACpE;YACE,mCAAmC;YACnC,MAAM,IAAI,KAAK,CAAC,+BAAgC,KAAa,CAAC,SAAS,8EAA8E,CAAC,CAAC;KAC1J;AACH,CAAC;AAED,SAAS,gBAAgB,CACvB,KAAsC,EACtC,aAAmC,EACnC,WAAwB,EACxB,SAAsC;IAEtC,MAAM,SAAS,GAAG,SAAS,KAAK,QAAQ,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC9G,MAAM,QAAQ,GAAG,GAAG,KAAK,CAAC,UAAU,GAAG,SAAS,EAAE,CAAC;IACnD,yHAAyH;IACzH,MAAM,QAAQ,GAAG,KAAK,CAAC,EAAE,KAAK,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,KAAK,CAAC,EAAE,GAAG,CAAC;IACnF,MAAM,GAAG,GAAG,GAAG,QAAQ,GAAG,QAAQ,EAAE,CAAC;IACrC,MAAM,KAAK,GAAG,QAAQ,WAAW,CAAC,UAAU,IAAI,GAAG,EAAE,CAAC;IAEtD,eAAK,CAAC,iBAAiB,KAAK,CAAC,IAAI,OAAO,KAAK,EAAE,CAAC,CAAC;IAEjD,aAAa,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,EAAE;QAC3C,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,SAAS;KACV,EAAE;QACD,UAAU,EAAE,WAAW,CAAC,UAAU;QAClC,SAAS,EAAE,GAAG;KACf,CAAC,CAAC;IAEH,OAAO;QACL,CAAC,KAAK,CAAC,iBAAiB,CAAC,EAAE,WAAW,CAAC,UAAU;QACjD,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,GAAG,QAAQ,GAAG,KAAK,CAAC,sBAAsB,GAAG,QAAQ,EAAE;QAC/E,CAAC,KAAK,CAAC,qBAAqB,CAAC,EAAE,KAAK,CAAC,UAAU;KAChD,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,uBAAuB,CACpC,KAAgD,EAChD,aAAmC,EACnC,WAAwB;;IAExB,oGAAoG;IACpG,qFAAqF;IACrF,kGAAkG;IAClG,wFAAwF;IACxF,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,CAAC,CAAC,KAAK,CAAC,cAAc,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE;QAC3E,MAAM,IAAI,KAAK,CAAC,8HAA8H,CAAC,CAAC;KACjJ;IAED,MAAM,cAAc,SAAG,KAAK,CAAC,cAAc,mCAAI,MAAM,GAAG,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;IAErG,0FAA0F;IAC1F,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,WAAW,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;IACjF,MAAM,QAAQ,SAAG,KAAK,CAAC,QAAQ,mCAAI,KAAK,CAAC,UAAU,CAAC;IAEpD,aAAa,CAAC,mBAAmB,CAAC,KAAK,CAAC,UAAU,EAAE;QAClD,SAAS,EAAE,KAAK,CAAC,IAAI;QACrB,eAAe,EAAE,KAAK,CAAC,SAAS;QAChC,iBAAiB,EAAE,KAAK,CAAC,MAAM;QAC/B,UAAU,EAAE,KAAK,CAAC,IAAI;KACvB,EAAE;QACD,cAAc;QACd,QAAQ;KACT,CAAC,CAAC;IAEH,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE;QAAE,OAAO,EAAE,CAAC;KAAE;IAC7C,OAAO,EAAE,CAAC,KAAK,CAAC,kBAAkB,CAAC,EAAE,GAAG,aAAa,IAAI,QAAQ,EAAE,EAAE,CAAC;AACxE,CAAC","sourcesContent":["// eslint-disable-next-line max-len\nimport * as path from 'path';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as colors from 'colors';\nimport { ToolkitInfo } from './api/toolkit-info';\nimport { debug } from './logging';\nimport { AssetManifestBuilder } from './util/asset-manifest-builder';\n\n/**\n * Take the metadata assets from the given stack and add them to the given asset manifest\n *\n * Returns the CloudFormation parameters that need to be sent to the template to\n * pass Asset coordinates.\n */\n// eslint-disable-next-line max-len\nexport async function addMetadataAssetsToManifest(stack: cxapi.CloudFormationStackArtifact, assetManifest: AssetManifestBuilder, toolkitInfo: ToolkitInfo, reuse?: string[]): Promise<Record<string, string>> {\n  reuse = reuse || [];\n  const assets = stack.assets;\n\n  if (assets.length === 0) {\n    return {};\n  }\n\n  if (!toolkitInfo.found) {\n    // eslint-disable-next-line max-len\n    throw new Error(`This stack uses assets, so the toolkit stack must be deployed to the environment (Run \"${colors.blue('cdk bootstrap ' + stack.environment!.name)}\")`);\n  }\n\n  const params: Record<string, string> = {};\n\n  for (const asset of assets) {\n    // FIXME: Should have excluded by construct path here instead of by unique ID, preferably using\n    // minimatch so we can support globs. Maybe take up during artifact refactoring.\n    const reuseAsset = reuse.indexOf(asset.id) > -1;\n\n    if (reuseAsset) {\n      debug(`Reusing asset ${asset.id}: ${JSON.stringify(asset)}`);\n      continue;\n    }\n\n    debug(`Preparing asset ${asset.id}: ${JSON.stringify(asset)}`);\n    if (!stack.assembly) {\n      throw new Error('Unexpected: stack assembly is required in order to find assets in assemly directory');\n    }\n\n    Object.assign(params, await prepareAsset(asset, assetManifest, toolkitInfo));\n  }\n\n  return params;\n}\n\n// eslint-disable-next-line max-len\nasync function prepareAsset(asset: cxschema.AssetMetadataEntry, assetManifest: AssetManifestBuilder, toolkitInfo: ToolkitInfo): Promise<Record<string, string>> {\n  switch (asset.packaging) {\n    case 'zip':\n    case 'file':\n      return prepareFileAsset(\n        asset,\n        assetManifest,\n        toolkitInfo,\n        asset.packaging === 'zip' ? cxschema.FileAssetPackaging.ZIP_DIRECTORY : cxschema.FileAssetPackaging.FILE);\n    case 'container-image':\n      return prepareDockerImageAsset(asset, assetManifest, toolkitInfo);\n    default:\n      // eslint-disable-next-line max-len\n      throw new Error(`Unsupported packaging type: ${(asset as any).packaging}. You might need to upgrade your aws-cdk toolkit to support this asset type.`);\n  }\n}\n\nfunction prepareFileAsset(\n  asset: cxschema.FileAssetMetadataEntry,\n  assetManifest: AssetManifestBuilder,\n  toolkitInfo: ToolkitInfo,\n  packaging: cxschema.FileAssetPackaging): Record<string, string> {\n\n  const extension = packaging === cxschema.FileAssetPackaging.ZIP_DIRECTORY ? '.zip' : path.extname(asset.path);\n  const baseName = `${asset.sourceHash}${extension}`;\n  // Simplify key: assets/abcdef/abcdef.zip is kinda silly and unnecessary, so if they're the same just pick one component.\n  const s3Prefix = asset.id === asset.sourceHash ? 'assets/' : `assets/${asset.id}/`;\n  const key = `${s3Prefix}${baseName}`;\n  const s3url = `s3://${toolkitInfo.bucketName}/${key}`;\n\n  debug(`Storing asset ${asset.path} at ${s3url}`);\n\n  assetManifest.addFileAsset(asset.sourceHash, {\n    path: asset.path,\n    packaging,\n  }, {\n    bucketName: toolkitInfo.bucketName,\n    objectKey: key,\n  });\n\n  return {\n    [asset.s3BucketParameter]: toolkitInfo.bucketName,\n    [asset.s3KeyParameter]: `${s3Prefix}${cxapi.ASSET_PREFIX_SEPARATOR}${baseName}`,\n    [asset.artifactHashParameter]: asset.sourceHash,\n  };\n}\n\nasync function prepareDockerImageAsset(\n  asset: cxschema.ContainerImageAssetMetadataEntry,\n  assetManifest: AssetManifestBuilder,\n  toolkitInfo: ToolkitInfo): Promise<Record<string, string>> {\n\n  // Pre-1.21.0, repositoryName can be specified by the user or can be left out, in which case we make\n  // a per-asset repository which will get adopted and cleaned up along with the stack.\n  // Post-1.21.0, repositoryName will always be specified and it will be a shared repository between\n  // all assets, and asset will have imageTag specified as well. Validate the combination.\n  if (!asset.imageNameParameter && (!asset.repositoryName || !asset.imageTag)) {\n    throw new Error('Invalid Docker image asset configuration: \"repositoryName\" and \"imageTag\" are required when \"imageNameParameter\" is left out');\n  }\n\n  const repositoryName = asset.repositoryName ?? 'cdk/' + asset.id.replace(/[:/]/g, '-').toLowerCase();\n\n  // Make sure the repository exists, since the 'cdk-assets' tool will not create it for us.\n  const { repositoryUri } = await toolkitInfo.prepareEcrRepository(repositoryName);\n  const imageTag = asset.imageTag ?? asset.sourceHash;\n\n  assetManifest.addDockerImageAsset(asset.sourceHash, {\n    directory: asset.path,\n    dockerBuildArgs: asset.buildArgs,\n    dockerBuildTarget: asset.target,\n    dockerFile: asset.file,\n  }, {\n    repositoryName,\n    imageTag,\n  });\n\n  if (!asset.imageNameParameter) { return {}; }\n  return { [asset.imageNameParameter]: `${repositoryUri}:${imageTag}` };\n}"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assets.js","sourceRoot":"","sources":["assets.ts"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable-next-line max-len\nimport * as path from 'path';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport { ToolkitInfo } from './api/toolkit-info';\nimport { debug } from './logging';\nimport { AssetManifestBuilder } from './util/asset-manifest-builder';\n\n/**\n * Take the metadata assets from the given stack and add them to the given asset manifest\n *\n * Returns the CloudFormation parameters that need to be sent to the template to\n * pass Asset coordinates.\n */\n// eslint-disable-next-line max-len\nexport async function addMetadataAssetsToManifest(stack: cxapi.CloudFormationStackArtifact, assetManifest: AssetManifestBuilder, toolkitInfo: ToolkitInfo, reuse?: string[]): Promise<Record<string, string>> {\n  reuse = reuse || [];\n  const assets = stack.assets;\n\n  if (assets.length === 0) {\n    return {};\n  }\n\n  if (!toolkitInfo.found) {\n    // eslint-disable-next-line max-len\n    throw new Error(`This stack uses assets, so the toolkit stack must be deployed to the environment (Run \"${chalk.blue('cdk bootstrap ' + stack.environment!.name)}\")`);\n  }\n\n  const params: Record<string, string> = {};\n\n  for (const asset of assets) {\n    // FIXME: Should have excluded by construct path here instead of by unique ID, preferably using\n    // minimatch so we can support globs. Maybe take up during artifact refactoring.\n    const reuseAsset = reuse.indexOf(asset.id) > -1;\n\n    if (reuseAsset) {\n      debug(`Reusing asset ${asset.id}: ${JSON.stringify(asset)}`);\n      continue;\n    }\n\n    debug(`Preparing asset ${asset.id}: ${JSON.stringify(asset)}`);\n    if (!stack.assembly) {\n      throw new Error('Unexpected: stack assembly is required in order to find assets in assemly directory');\n    }\n\n    Object.assign(params, await prepareAsset(asset, assetManifest, toolkitInfo));\n  }\n\n  return params;\n}\n\n// eslint-disable-next-line max-len\nasync function prepareAsset(asset: cxschema.AssetMetadataEntry, assetManifest: AssetManifestBuilder, toolkitInfo: ToolkitInfo): Promise<Record<string, string>> {\n  switch (asset.packaging) {\n    case 'zip':\n    case 'file':\n      return prepareFileAsset(\n        asset,\n        assetManifest,\n        toolkitInfo,\n        asset.packaging === 'zip' ? cxschema.FileAssetPackaging.ZIP_DIRECTORY : cxschema.FileAssetPackaging.FILE);\n    case 'container-image':\n      return prepareDockerImageAsset(asset, assetManifest, toolkitInfo);\n    default:\n      // eslint-disable-next-line max-len\n      throw new Error(`Unsupported packaging type: ${(asset as any).packaging}. You might need to upgrade your aws-cdk toolkit to support this asset type.`);\n  }\n}\n\nfunction prepareFileAsset(\n  asset: cxschema.FileAssetMetadataEntry,\n  assetManifest: AssetManifestBuilder,\n  toolkitInfo: ToolkitInfo,\n  packaging: cxschema.FileAssetPackaging): Record<string, string> {\n\n  const extension = packaging === cxschema.FileAssetPackaging.ZIP_DIRECTORY ? '.zip' : path.extname(asset.path);\n  const baseName = `${asset.sourceHash}${extension}`;\n  // Simplify key: assets/abcdef/abcdef.zip is kinda silly and unnecessary, so if they're the same just pick one component.\n  const s3Prefix = asset.id === asset.sourceHash ? 'assets/' : `assets/${asset.id}/`;\n  const key = `${s3Prefix}${baseName}`;\n  const s3url = `s3://${toolkitInfo.bucketName}/${key}`;\n\n  debug(`Storing asset ${asset.path} at ${s3url}`);\n\n  assetManifest.addFileAsset(asset.sourceHash, {\n    path: asset.path,\n    packaging,\n  }, {\n    bucketName: toolkitInfo.bucketName,\n    objectKey: key,\n  });\n\n  return {\n    [asset.s3BucketParameter]: toolkitInfo.bucketName,\n    [asset.s3KeyParameter]: `${s3Prefix}${cxapi.ASSET_PREFIX_SEPARATOR}${baseName}`,\n    [asset.artifactHashParameter]: asset.sourceHash,\n  };\n}\n\nasync function prepareDockerImageAsset(\n  asset: cxschema.ContainerImageAssetMetadataEntry,\n  assetManifest: AssetManifestBuilder,\n  toolkitInfo: ToolkitInfo): Promise<Record<string, string>> {\n\n  // Pre-1.21.0, repositoryName can be specified by the user or can be left out, in which case we make\n  // a per-asset repository which will get adopted and cleaned up along with the stack.\n  // Post-1.21.0, repositoryName will always be specified and it will be a shared repository between\n  // all assets, and asset will have imageTag specified as well. Validate the combination.\n  if (!asset.imageNameParameter && (!asset.repositoryName || !asset.imageTag)) {\n    throw new Error('Invalid Docker image asset configuration: \"repositoryName\" and \"imageTag\" are required when \"imageNameParameter\" is left out');\n  }\n\n  const repositoryName = asset.repositoryName ?? 'cdk/' + asset.id.replace(/[:/]/g, '-').toLowerCase();\n\n  // Make sure the repository exists, since the 'cdk-assets' tool will not create it for us.\n  const { repositoryUri } = await toolkitInfo.prepareEcrRepository(repositoryName);\n  const imageTag = asset.imageTag ?? asset.sourceHash;\n\n  assetManifest.addDockerImageAsset(asset.sourceHash, {\n    directory: asset.path,\n    dockerBuildArgs: asset.buildArgs,\n    dockerBuildTarget: asset.target,\n    dockerFile: asset.file,\n  }, {\n    repositoryName,\n    imageTag,\n  });\n\n  if (!asset.imageNameParameter) { return {}; }\n  return { [asset.imageNameParameter]: `${repositoryUri}:${imageTag}` };\n}\n"]}
@@ -5,6 +5,7 @@ import { Bootstrapper, BootstrapEnvironmentOptions } from './api/bootstrap';
5
5
  import { CloudFormationDeployments } from './api/cloudformation-deployments';
6
6
  import { StackSelector } from './api/cxapp/cloud-assembly';
7
7
  import { CloudExecutable } from './api/cxapp/cloud-executable';
8
+ import { CloudWatchLogEventMonitor } from './api/logs/logs-monitor';
8
9
  import { StackActivityProgress } from './api/util/cloudformation/stack-activity-monitor';
9
10
  import { RequireApproval } from './diff';
10
11
  import { Configuration } from './settings';
@@ -216,6 +217,13 @@ interface WatchOptions {
216
217
  * @default - nothing extra is appended to the User-Agent header
217
218
  */
218
219
  readonly extraUserAgent?: string;
220
+ /**
221
+ * Whether to show CloudWatch logs for hotswapped resources
222
+ * locally in the users terminal
223
+ *
224
+ * @default - false
225
+ */
226
+ readonly traceLogs?: boolean;
219
227
  }
220
228
  export interface DeployOptions extends WatchOptions {
221
229
  /**
@@ -278,6 +286,13 @@ export interface DeployOptions extends WatchOptions {
278
286
  * @default true
279
287
  */
280
288
  readonly cacheCloudAssembly?: boolean;
289
+ /**
290
+ * Allows adding CloudWatch log groups to the log monitor via
291
+ * cloudWatchLogMonitor.setLogGroups();
292
+ *
293
+ * @default - not monitoring CloudWatch logs
294
+ */
295
+ readonly cloudWatchLogMonitor?: CloudWatchLogEventMonitor;
281
296
  }
282
297
  export interface DestroyOptions {
283
298
  /**