UNPKG

aws-cdk

Version:

AWS CDK CLI, the command line tool for CDK apps

114 lines 15.9 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ActivityPrinterBase = void 0; const private_1 = require("../../../../@aws-cdk/tmp-toolkit-helpers/src/api/io/private"); const util_1 = require("../../util"); class ActivityPrinterBase { constructor(props) { this.props = props; /** * The with of the "resource type" column. */ this.resourceTypeColumnWidth = (0, util_1.maxResourceTypeLength)({}); /** * A list of resource IDs which are currently being processed */ this.resourcesInProgress = {}; this.rollingBack = false; this.failures = new Array(); this.hookFailureMap = new Map(); this.stream = props.stream; } /** * Receive a stack activity message */ notify(msg) { switch (true) { case private_1.IO.CDK_TOOLKIT_I5501.is(msg): this.start(msg.data); break; case private_1.IO.CDK_TOOLKIT_I5502.is(msg): this.activity(msg.data); break; case private_1.IO.CDK_TOOLKIT_I5503.is(msg): this.stop(); break; default: // ignore all other messages break; } } start({ stack }) { this.resourceTypeColumnWidth = (0, util_1.maxResourceTypeLength)(stack.template); } activity(activity) { // process the activity and then call print this.addActivity(activity); this.print(); } stop() { // final print after the stack is done this.print(); } addActivity(activity) { const status = activity.event.ResourceStatus; const hookStatus = activity.event.HookStatus; const hookType = activity.event.HookType; if (!status || !activity.event.LogicalResourceId) { return; } this.stackProgress = activity.progress; if (status === 'ROLLBACK_IN_PROGRESS' || status === 'UPDATE_ROLLBACK_IN_PROGRESS') { // Only triggered on the stack once we've started doing a rollback this.rollingBack = true; } if (status.endsWith('_IN_PROGRESS')) { this.resourcesInProgress[activity.event.LogicalResourceId] = activity; } if ((0, util_1.stackEventHasErrorMessage)(status)) { const isCancelled = (activity.event.ResourceStatusReason ?? '').indexOf('cancelled') > -1; // Cancelled is not an interesting failure reason if (!isCancelled) { this.failures.push(activity); } } if (status.endsWith('_COMPLETE') || status.endsWith('_FAILED')) { delete this.resourcesInProgress[activity.event.LogicalResourceId]; } if (hookStatus !== undefined && hookStatus.endsWith('_COMPLETE_FAILED') && activity.event.LogicalResourceId !== undefined && hookType !== undefined) { if (this.hookFailureMap.has(activity.event.LogicalResourceId)) { this.hookFailureMap.get(activity.event.LogicalResourceId)?.set(hookType, activity.event.HookStatusReason ?? ''); } else { this.hookFailureMap.set(activity.event.LogicalResourceId, new Map()); this.hookFailureMap.get(activity.event.LogicalResourceId)?.set(hookType, activity.event.HookStatusReason ?? ''); } } } failureReason(activity) { const resourceStatusReason = activity.event.ResourceStatusReason ?? ''; const logicalResourceId = activity.event.LogicalResourceId ?? ''; const hookFailureReasonMap = this.hookFailureMap.get(logicalResourceId); if (hookFailureReasonMap !== undefined) { for (const hookType of hookFailureReasonMap.keys()) { if (resourceStatusReason.includes(hookType)) { return resourceStatusReason + ' : ' + hookFailureReasonMap.get(hookType); } } } return resourceStatusReason; } /** * Is the activity a meta activity for the stack itself. */ isActivityForTheStack(activity) { return activity.event.PhysicalResourceId === activity.event.StackId; } } exports.ActivityPrinterBase = ActivityPrinterBase; ActivityPrinterBase.TIMESTAMP_WIDTH = 12; ActivityPrinterBase.STATUS_WIDTH = 20; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["base.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CloudFormationStackArtifact } from '@aws-cdk/cx-api';\nimport { type StackActivity, type StackProgress } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api';\nimport { IO } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api/io/private';\nimport { maxResourceTypeLength, stackEventHasErrorMessage } from '../../util';\nimport type { IoMessage } from '../io-host/cli-io-host';\n\nexport interface IActivityPrinter {\n  notify(msg: IoMessage<unknown>): void;\n}\n\nexport interface ActivityPrinterProps {\n  /**\n   * Stream to write to\n   */\n  readonly stream: NodeJS.WriteStream;\n}\n\nexport abstract class ActivityPrinterBase implements IActivityPrinter {\n  protected static readonly TIMESTAMP_WIDTH = 12;\n  protected static readonly STATUS_WIDTH = 20;\n\n  /**\n   * Stream to write to\n   */\n  protected readonly stream: NodeJS.WriteStream;\n\n  /**\n   * The with of the \"resource type\" column.\n   */\n  protected resourceTypeColumnWidth: number = maxResourceTypeLength({});\n\n  /**\n   * A list of resource IDs which are currently being processed\n   */\n  protected resourcesInProgress: Record<string, StackActivity> = {};\n\n  protected stackProgress?: StackProgress;\n\n  protected rollingBack = false;\n\n  protected readonly failures = new Array<StackActivity>();\n\n  protected hookFailureMap = new Map<string, Map<string, string>>();\n\n  constructor(protected readonly props: ActivityPrinterProps) {\n    this.stream = props.stream;\n  }\n\n  protected abstract print(): void;\n\n  /**\n   * Receive a stack activity message\n   */\n  public notify(msg: IoMessage<unknown>): void {\n    switch (true) {\n      case IO.CDK_TOOLKIT_I5501.is(msg):\n        this.start(msg.data);\n        break;\n      case IO.CDK_TOOLKIT_I5502.is(msg):\n        this.activity(msg.data);\n        break;\n      case IO.CDK_TOOLKIT_I5503.is(msg):\n        this.stop();\n        break;\n      default:\n        // ignore all other messages\n        break;\n    }\n  }\n\n  public start({ stack }: { stack: CloudFormationStackArtifact}) {\n    this.resourceTypeColumnWidth = maxResourceTypeLength(stack.template);\n  }\n\n  public activity(activity: StackActivity) {\n    // process the activity and then call print\n    this.addActivity(activity);\n    this.print();\n  }\n\n  public stop() {\n    // final print after the stack is done\n    this.print();\n  }\n\n  protected addActivity(activity: StackActivity) {\n    const status = activity.event.ResourceStatus;\n    const hookStatus = activity.event.HookStatus;\n    const hookType = activity.event.HookType;\n    if (!status || !activity.event.LogicalResourceId) {\n      return;\n    }\n\n    this.stackProgress = activity.progress;\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 (stackEventHasErrorMessage(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 (\n      hookStatus !== undefined &&\n        hookStatus.endsWith('_COMPLETE_FAILED') &&\n        activity.event.LogicalResourceId !== undefined &&\n        hookType !== undefined\n    ) {\n      if (this.hookFailureMap.has(activity.event.LogicalResourceId)) {\n        this.hookFailureMap.get(activity.event.LogicalResourceId)?.set(hookType, activity.event.HookStatusReason ?? '');\n      } else {\n        this.hookFailureMap.set(activity.event.LogicalResourceId, new Map<string, string>());\n        this.hookFailureMap.get(activity.event.LogicalResourceId)?.set(hookType, activity.event.HookStatusReason ?? '');\n      }\n    }\n  }\n\n  protected failureReason(activity: StackActivity) {\n    const resourceStatusReason = activity.event.ResourceStatusReason ?? '';\n    const logicalResourceId = activity.event.LogicalResourceId ?? '';\n    const hookFailureReasonMap = this.hookFailureMap.get(logicalResourceId);\n\n    if (hookFailureReasonMap !== undefined) {\n      for (const hookType of hookFailureReasonMap.keys()) {\n        if (resourceStatusReason.includes(hookType)) {\n          return resourceStatusReason + ' : ' + hookFailureReasonMap.get(hookType);\n        }\n      }\n    }\n    return resourceStatusReason;\n  }\n\n  /**\n   * Is the activity a meta activity for the stack itself.\n   */\n  protected isActivityForTheStack(activity: StackActivity) {\n    return activity.event.PhysicalResourceId === activity.event.StackId;\n  }\n}\n"]}