@aws-cdk/toolkit-lib 0.1.3 → 0.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/build-info.json +2 -2
  2. package/db.json.gz +0 -0
  3. package/lib/actions/bootstrap/index.d.ts +174 -0
  4. package/lib/actions/bootstrap/index.js +94 -0
  5. package/lib/actions/bootstrap/private/helpers.d.ts +5 -0
  6. package/lib/actions/bootstrap/private/helpers.js +23 -0
  7. package/lib/actions/bootstrap/private/index.d.ts +1 -0
  8. package/lib/actions/bootstrap/private/index.js +18 -0
  9. package/lib/actions/deploy/index.d.ts +4 -2
  10. package/lib/actions/deploy/index.js +4 -1
  11. package/lib/actions/deploy/private/deploy-options.d.ts +1 -1
  12. package/lib/actions/deploy/private/deploy-options.js +1 -1
  13. package/lib/actions/deploy/private/helpers.d.ts +3 -2
  14. package/lib/actions/deploy/private/helpers.js +1 -1
  15. package/lib/actions/destroy/index.d.ts +1 -1
  16. package/lib/actions/destroy/index.js +1 -1
  17. package/lib/actions/diff/private/helpers.d.ts +5 -5
  18. package/lib/actions/diff/private/helpers.js +13 -11
  19. package/lib/actions/index.d.ts +1 -0
  20. package/lib/actions/index.js +2 -1
  21. package/lib/api/aws-cdk.d.ts +5 -9
  22. package/lib/api/aws-cdk.js +1593 -735
  23. package/lib/api/aws-cdk.js.map +4 -4
  24. package/lib/api/bootstrap/bootstrap-template.yaml +707 -0
  25. package/lib/api/cloud-assembly/index.d.ts +1 -1
  26. package/lib/api/cloud-assembly/index.js +2 -2
  27. package/lib/api/cloud-assembly/private/cached-source.d.ts +2 -2
  28. package/lib/api/cloud-assembly/private/cached-source.js +1 -1
  29. package/lib/api/cloud-assembly/private/context-aware-source.d.ts +4 -4
  30. package/lib/api/cloud-assembly/private/context-aware-source.js +11 -12
  31. package/lib/api/cloud-assembly/private/identity-source.d.ts +1 -1
  32. package/lib/api/cloud-assembly/private/identity-source.js +1 -1
  33. package/lib/api/cloud-assembly/private/prepare-source.d.ts +5 -5
  34. package/lib/api/cloud-assembly/private/prepare-source.js +10 -7
  35. package/lib/api/cloud-assembly/private/source-builder.d.ts +4 -4
  36. package/lib/api/cloud-assembly/private/source-builder.js +24 -12
  37. package/lib/api/cloud-assembly/private/stack-assembly.d.ts +3 -3
  38. package/lib/api/cloud-assembly/private/stack-assembly.js +1 -1
  39. package/lib/api/cloud-assembly/private/stack-selectors.d.ts +1 -1
  40. package/lib/api/cloud-assembly/private/stack-selectors.js +1 -1
  41. package/lib/api/cloud-assembly/source-builder.d.ts +36 -0
  42. package/lib/api/cloud-assembly/source-builder.js +1 -1
  43. package/lib/api/cloud-assembly/stack-selector.d.ts +2 -81
  44. package/lib/api/cloud-assembly/stack-selector.js +5 -62
  45. package/lib/api/io/index.d.ts +1 -2
  46. package/lib/api/io/index.js +1 -17
  47. package/lib/api/io/private/index.d.ts +3 -6
  48. package/lib/api/io/private/index.js +7 -7
  49. package/lib/api/io/private/io-host-wrappers.d.ts +17 -0
  50. package/lib/api/io/private/io-host-wrappers.js +74 -0
  51. package/lib/api/io/private/sdk-logger.d.ts +3 -0
  52. package/lib/api/io/private/sdk-logger.js +124 -0
  53. package/lib/api/shared-private.d.ts +1 -0
  54. package/lib/api/shared-private.js +711 -0
  55. package/lib/api/shared-private.js.map +7 -0
  56. package/lib/api/shared-public.d.ts +2464 -1
  57. package/lib/api/shared-public.js +78 -5
  58. package/lib/api/shared-public.js.map +4 -4
  59. package/lib/index.d.ts +3 -0
  60. package/lib/index.js +4 -1
  61. package/lib/private/util.d.ts +1 -0
  62. package/lib/private/util.js +720 -0
  63. package/lib/private/util.js.map +7 -0
  64. package/lib/toolkit/index.d.ts +1 -1
  65. package/lib/toolkit/index.js +2 -2
  66. package/lib/toolkit/private/index.d.ts +12 -3
  67. package/lib/toolkit/private/index.js +18 -1
  68. package/lib/toolkit/toolkit.d.ts +10 -16
  69. package/lib/toolkit/toolkit.js +205 -152
  70. package/lib/util/concurrency.d.ts +5 -0
  71. package/lib/util/concurrency.js +11 -0
  72. package/package.json +12 -11
  73. package/CODE_REGISTRY.md +0 -35
  74. package/lib/api/io/io-host.d.ts +0 -15
  75. package/lib/api/io/io-host.js +0 -3
  76. package/lib/api/io/io-message.d.ts +0 -59
  77. package/lib/api/io/io-message.js +0 -3
  78. package/lib/api/io/private/codes.d.ts +0 -67
  79. package/lib/api/io/private/codes.js +0 -187
  80. package/lib/api/io/private/level-priority.d.ts +0 -11
  81. package/lib/api/io/private/level-priority.js +0 -33
  82. package/lib/api/io/private/logger.d.ts +0 -40
  83. package/lib/api/io/private/logger.js +0 -211
  84. package/lib/api/io/private/messages.d.ts +0 -58
  85. package/lib/api/io/private/messages.js +0 -163
  86. package/lib/api/io/private/timer.d.ts +0 -29
  87. package/lib/api/io/private/timer.js +0 -55
  88. package/lib/api/io/private/types.d.ts +0 -25
  89. package/lib/api/io/private/types.js +0 -3
  90. package/lib/toolkit/types.d.ts +0 -76
  91. package/lib/toolkit/types.js +0 -3
@@ -6,19 +6,24 @@ const cxapi = require("@aws-cdk/cx-api");
6
6
  const chalk = require("chalk");
7
7
  const chokidar = require("chokidar");
8
8
  const fs = require("fs-extra");
9
+ const private_1 = require("./private");
10
+ const bootstrap_1 = require("../actions/bootstrap");
9
11
  const deploy_1 = require("../actions/deploy");
10
- const private_1 = require("../actions/deploy/private");
11
- const private_2 = require("../actions/diff/private");
12
- const private_3 = require("../actions/watch/private");
12
+ const private_2 = require("../actions/deploy/private");
13
+ const private_3 = require("../actions/diff/private");
14
+ const private_4 = require("../actions/watch/private");
13
15
  const aws_cdk_1 = require("../api/aws-cdk");
14
16
  const cloud_assembly_1 = require("../api/cloud-assembly");
15
- const private_4 = require("../api/cloud-assembly/private");
16
- const private_5 = require("../api/io/private");
17
+ const private_5 = require("../api/cloud-assembly/private");
18
+ const private_6 = require("../api/io/private");
19
+ const shared_private_1 = require("../api/shared-private");
17
20
  const shared_public_1 = require("../api/shared-public");
21
+ const util_1 = require("../private/util");
22
+ const concurrency_1 = require("../util/concurrency");
18
23
  /**
19
24
  * The AWS CDK Programmatic Toolkit
20
25
  */
21
- class Toolkit extends private_4.CloudAssemblySourceBuilder {
26
+ class Toolkit extends private_5.CloudAssemblySourceBuilder {
22
27
  props;
23
28
  /**
24
29
  * The toolkit stack name used for bootstrapping resources.
@@ -40,14 +45,14 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
40
45
  }
41
46
  let ioHost = globalIoHost;
42
47
  if (props.emojis === false) {
43
- ioHost = (0, private_5.withoutEmojis)(ioHost);
48
+ ioHost = (0, private_6.withoutEmojis)(ioHost);
44
49
  }
45
50
  if (props.color === false) {
46
- ioHost = (0, private_5.withoutColor)(ioHost);
51
+ ioHost = (0, private_6.withoutColor)(ioHost);
47
52
  }
48
53
  // After removing emojis and color, we might end up with floating whitespace at either end of the message
49
54
  // This also removes newlines that we currently emit for CLI backwards compatibility.
50
- this.ioHost = (0, private_5.withTrimmedWhitespace)(ioHost);
55
+ this.ioHost = (0, private_6.withTrimmedWhitespace)(ioHost);
51
56
  }
52
57
  async dispose() {
53
58
  // nothing to do yet
@@ -63,7 +68,7 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
63
68
  if (!this._sdkProvider) {
64
69
  this._sdkProvider = await aws_cdk_1.SdkProvider.withAwsCliCompatibleDefaults({
65
70
  ...this.props.sdkConfig,
66
- logger: (0, private_5.asSdkLogger)(this.ioHost, action),
71
+ logger: (0, private_6.asSdkLogger)((0, shared_private_1.asIoHelper)(this.ioHost, action)),
67
72
  });
68
73
  }
69
74
  return this._sdkProvider;
@@ -73,21 +78,61 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
73
78
  */
74
79
  async sourceBuilderServices() {
75
80
  return {
76
- ioHost: (0, private_5.withAction)(this.ioHost, 'assembly'),
81
+ ioHelper: (0, shared_private_1.asIoHelper)(this.ioHost, 'assembly'),
77
82
  sdkProvider: await this.sdkProvider('assembly'),
78
83
  };
79
84
  }
85
+ /**
86
+ * Bootstrap Action
87
+ */
88
+ async bootstrap(environments, options) {
89
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'bootstrap');
90
+ const bootstrapEnvironments = await environments.getEnvironments();
91
+ const source = options.source ?? bootstrap_1.BootstrapSource.default();
92
+ const parameters = options.parameters;
93
+ const bootstrapper = new aws_cdk_1.Bootstrapper(source, ioHelper);
94
+ const sdkProvider = await this.sdkProvider('bootstrap');
95
+ const limit = (0, concurrency_1.pLimit)(20);
96
+ // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism
97
+ await Promise.all(bootstrapEnvironments.map((environment, currentIdx) => limit(async () => {
98
+ const bootstrapSpan = await ioHelper.span(private_6.SPAN.BOOTSTRAP_SINGLE)
99
+ .begin(`${chalk.bold(environment.name)}: bootstrapping...`, {
100
+ total: bootstrapEnvironments.length,
101
+ current: currentIdx + 1,
102
+ environment,
103
+ });
104
+ try {
105
+ const bootstrapResult = await bootstrapper.bootstrapEnvironment(environment, sdkProvider, {
106
+ ...options,
107
+ toolkitStackName: this.toolkitStackName,
108
+ source,
109
+ parameters: parameters?.parameters,
110
+ usePreviousParameters: parameters?.keepExistingParameters,
111
+ });
112
+ const message = bootstrapResult.noOp
113
+ ? ` ✅ ${environment.name} (no changes)`
114
+ : ` ✅ ${environment.name}`;
115
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I9900.msg(chalk.green('\n' + message), { environment }));
116
+ await bootstrapSpan.end();
117
+ }
118
+ catch (e) {
119
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_E9900.msg(`\n ❌ ${chalk.bold(environment.name)} failed: ${(0, util_1.formatErrorMessage)(e)}`, { error: e }));
120
+ throw e;
121
+ }
122
+ })));
123
+ }
80
124
  /**
81
125
  * Synth Action
82
126
  */
83
127
  async synth(cx, options = {}) {
84
- const ioHost = (0, private_5.withAction)(this.ioHost, 'synth');
85
- const synthTimer = private_5.Timer.start();
86
- const assembly = await this.assemblyFromSource(cx);
87
- const stacks = assembly.selectStacksV2(options.stacks ?? private_4.ALL_STACKS);
128
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'synth');
129
+ const selectStacks = options.stacks ?? private_5.ALL_STACKS;
130
+ const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
131
+ const assembly = await (0, private_1.assemblyFromSource)(cx);
132
+ const stacks = assembly.selectStacksV2(selectStacks);
88
133
  const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];
89
- await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHost);
90
- await synthTimer.endAs(ioHost, 'synth');
134
+ await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHelper);
135
+ await synthSpan.end();
91
136
  // if we have a single stack, print it to STDOUT
92
137
  const message = `Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`;
93
138
  const assemblyData = {
@@ -98,24 +143,24 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
98
143
  if (stacks.stackCount === 1) {
99
144
  const firstStack = stacks.firstStack;
100
145
  const template = firstStack.template;
101
- const obscuredTemplate = (0, aws_cdk_1.obscureTemplate)(template);
102
- await ioHost.notify((0, private_5.result)(message, private_5.CODES.CDK_TOOLKIT_I1901, {
146
+ const obscuredTemplate = (0, util_1.obscureTemplate)(template);
147
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I1901.msg(message, {
103
148
  ...assemblyData,
104
149
  stack: {
105
150
  stackName: firstStack.stackName,
106
151
  hierarchicalId: firstStack.hierarchicalId,
107
152
  template,
108
- stringifiedJson: (0, aws_cdk_1.serializeStructure)(obscuredTemplate, true),
109
- stringifiedYaml: (0, aws_cdk_1.serializeStructure)(obscuredTemplate, false),
153
+ stringifiedJson: (0, util_1.serializeStructure)(obscuredTemplate, true),
154
+ stringifiedYaml: (0, util_1.serializeStructure)(obscuredTemplate, false),
110
155
  },
111
156
  }));
112
157
  }
113
158
  else {
114
159
  // not outputting template to stdout, let's explain things to the user a little bit...
115
- await ioHost.notify((0, private_5.result)(chalk.green(message), private_5.CODES.CDK_TOOLKIT_I1902, assemblyData));
116
- await ioHost.notify((0, private_5.info)(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));
160
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I1902.msg(chalk.green(message), assemblyData));
161
+ await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_INFO.msg(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));
117
162
  }
118
- return new private_4.IdentityCloudAssemblySource(assembly.assembly);
163
+ return new private_5.IdentityCloudAssemblySource(assembly.assembly);
119
164
  }
120
165
  /**
121
166
  * List Action
@@ -123,14 +168,15 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
123
168
  * List selected stacks and their dependencies
124
169
  */
125
170
  async list(cx, options = {}) {
126
- const ioHost = (0, private_5.withAction)(this.ioHost, 'list');
127
- const synthTimer = private_5.Timer.start();
128
- const assembly = await this.assemblyFromSource(cx);
129
- const stackCollection = await assembly.selectStacksV2(options.stacks ?? private_4.ALL_STACKS);
130
- await synthTimer.endAs(ioHost, 'synth');
171
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'list');
172
+ const selectStacks = options.stacks ?? private_5.ALL_STACKS;
173
+ const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
174
+ const assembly = await (0, private_1.assemblyFromSource)(cx);
175
+ const stackCollection = await assembly.selectStacksV2(selectStacks);
176
+ await synthSpan.end();
131
177
  const stacks = stackCollection.withDependencies();
132
178
  const message = stacks.map(s => s.id).join('\n');
133
- await ioHost.notify((0, private_5.result)(message, private_5.CODES.CDK_TOOLKIT_I2901, { stacks }));
179
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I2901.msg(message, { stacks }));
134
180
  return stacks;
135
181
  }
136
182
  /**
@@ -139,30 +185,30 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
139
185
  * Deploys the selected stacks into an AWS account
140
186
  */
141
187
  async deploy(cx, options = {}) {
142
- const assembly = await this.assemblyFromSource(cx);
188
+ const assembly = await (0, private_1.assemblyFromSource)(cx);
143
189
  return this._deploy(assembly, 'deploy', options);
144
190
  }
145
191
  /**
146
192
  * Helper to allow deploy being called as part of the watch action.
147
193
  */
148
194
  async _deploy(assembly, action, options = {}) {
149
- const ioHost = (0, private_5.withAction)(this.ioHost, action);
150
- const synthTimer = private_5.Timer.start();
151
- const stackCollection = assembly.selectStacksV2(options.stacks ?? private_4.ALL_STACKS);
152
- await this.validateStacksMetadata(stackCollection, ioHost);
153
- const synthDuration = await synthTimer.endAs(ioHost, 'synth');
195
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, action);
196
+ const selectStacks = options.stacks ?? private_5.ALL_STACKS;
197
+ const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
198
+ const stackCollection = assembly.selectStacksV2(selectStacks);
199
+ await this.validateStacksMetadata(stackCollection, ioHelper);
200
+ const synthDuration = await synthSpan.end();
154
201
  if (stackCollection.stackCount === 0) {
155
- await ioHost.notify((0, private_5.error)('This app contains no stacks', private_5.CODES.CDK_TOOLKIT_E5001));
202
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_E5001.msg('This app contains no stacks'));
156
203
  return;
157
204
  }
158
205
  const deployments = await this.deploymentsForAction('deploy');
159
- const migrator = new aws_cdk_1.ResourceMigrator({ deployments, ioHost, action });
206
+ const migrator = new aws_cdk_1.ResourceMigrator({ deployments, ioHelper });
160
207
  await migrator.tryMigrateResources(stackCollection, options);
161
- const requireApproval = options.requireApproval ?? deploy_1.RequireApproval.NEVER;
162
- const parameterMap = (0, private_1.buildParameterMap)(options.parameters?.parameters);
208
+ const parameterMap = (0, private_2.buildParameterMap)(options.parameters?.parameters);
163
209
  const hotswapMode = options.hotswap ?? aws_cdk_1.HotswapMode.FULL_DEPLOYMENT;
164
210
  if (hotswapMode !== aws_cdk_1.HotswapMode.FULL_DEPLOYMENT) {
165
- await ioHost.notify((0, private_5.warn)([
211
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_W5400.msg([
166
212
  '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',
167
213
  '⚠️ They should only be used for development - never use them for your production Stacks!',
168
214
  ].join('\n')));
@@ -171,23 +217,32 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
171
217
  const stackOutputs = {};
172
218
  const outputsFile = options.outputsFile;
173
219
  const buildAsset = async (assetNode) => {
220
+ const buildAssetSpan = await ioHelper.span(private_6.SPAN.BUILD_ASSET).begin({
221
+ asset: assetNode.asset,
222
+ });
174
223
  await deployments.buildSingleAsset(assetNode.assetManifestArtifact, assetNode.assetManifest, assetNode.asset, {
175
224
  stack: assetNode.parentStack,
176
225
  roleArn: options.roleArn,
177
226
  stackName: assetNode.parentStack.stackName,
178
227
  });
228
+ await buildAssetSpan.end();
179
229
  };
180
230
  const publishAsset = async (assetNode) => {
231
+ const publishAssetSpan = await ioHelper.span(private_6.SPAN.PUBLISH_ASSET).begin({
232
+ asset: assetNode.asset,
233
+ });
181
234
  await deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {
182
235
  stack: assetNode.parentStack,
183
236
  roleArn: options.roleArn,
184
237
  stackName: assetNode.parentStack.stackName,
238
+ forcePublish: options.force,
185
239
  });
240
+ await publishAssetSpan.end();
186
241
  };
187
242
  const deployStack = async (stackNode) => {
188
243
  const stack = stackNode.stack;
189
244
  if (stackCollection.stackCount !== 1) {
190
- await ioHost.notify((0, private_5.info)(chalk.bold(stack.displayName)));
245
+ await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_INFO.msg(chalk.bold(stack.displayName)));
191
246
  }
192
247
  if (!stack.environment) {
193
248
  throw new shared_public_1.ToolkitError(`Stack ${stack.displayName} does not define an environment, and AWS credentials could not be obtained from standard locations or no region was configured.`);
@@ -197,10 +252,10 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
197
252
  // stack is empty and doesn't exist => do nothing
198
253
  const stackExists = await deployments.stackExists({ stack });
199
254
  if (!stackExists) {
200
- return ioHost.notify((0, private_5.warn)(`${chalk.bold(stack.displayName)}: stack has no resources, skipping deployment.`));
255
+ return ioHelper.notify(private_6.IO.CDK_TOOLKIT_W5021.msg(`${chalk.bold(stack.displayName)}: stack has no resources, skipping deployment.`));
201
256
  }
202
257
  // stack is empty, but exists => delete
203
- await ioHost.notify((0, private_5.warn)(`${chalk.bold(stack.displayName)}: stack has no resources, deleting existing stack.`));
258
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_W5022.msg(`${chalk.bold(stack.displayName)}: stack has no resources, deleting existing stack.`));
204
259
  await this._destroy(assembly, 'deploy', {
205
260
  stacks: { patterns: [stack.hierarchicalId], strategy: cloud_assembly_1.StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },
206
261
  roleArn: options.roleArn,
@@ -208,16 +263,17 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
208
263
  });
209
264
  return;
210
265
  }
211
- if (requireApproval !== deploy_1.RequireApproval.NEVER) {
212
- const currentTemplate = await deployments.readCurrentTemplate(stack);
213
- if ((0, private_2.diffRequiresApproval)(currentTemplate, stack, requireApproval)) {
214
- const motivation = '"--require-approval" is enabled and stack includes security-sensitive updates.';
215
- const question = `${motivation}\nDo you wish to deploy these changes`;
216
- const confirmed = await ioHost.requestResponse((0, private_5.confirm)(private_5.CODES.CDK_TOOLKIT_I5060, question, motivation, true, concurrency));
217
- if (!confirmed) {
218
- throw new shared_public_1.ToolkitError('Aborted by user');
219
- }
220
- }
266
+ const currentTemplate = await deployments.readCurrentTemplate(stack);
267
+ const permissionChangeType = (0, private_3.determinePermissionType)(currentTemplate, stack);
268
+ const deployMotivation = '"--require-approval" is enabled and stack includes security-sensitive updates.';
269
+ const deployQuestion = `${deployMotivation}\nDo you wish to deploy these changes`;
270
+ const deployConfirmed = await ioHelper.requestResponse(private_6.IO.CDK_TOOLKIT_I5060.req(deployQuestion, {
271
+ motivation: deployMotivation,
272
+ concurrency,
273
+ permissionChangeType,
274
+ }));
275
+ if (!deployConfirmed) {
276
+ throw new shared_public_1.ToolkitError('Aborted by user');
221
277
  }
222
278
  // Following are the same semantics we apply with respect to Notification ARNs (dictated by the SDK)
223
279
  //
@@ -228,13 +284,17 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
228
284
  ? (options.notificationArns ?? []).concat(stack.notificationArns ?? [])
229
285
  : undefined;
230
286
  for (const notificationArn of notificationArns ?? []) {
231
- if (!(0, aws_cdk_1.validateSnsTopicArn)(notificationArn)) {
287
+ if (!(0, util_1.validateSnsTopicArn)(notificationArn)) {
232
288
  throw new shared_public_1.ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);
233
289
  }
234
290
  }
235
291
  const stackIndex = stacks.indexOf(stack) + 1;
236
- await ioHost.notify((0, private_5.info)(`${chalk.bold(stack.displayName)}: deploying... [${stackIndex}/${stackCollection.stackCount}]`));
237
- const deployTimer = private_5.Timer.start();
292
+ const deploySpan = await ioHelper.span(private_6.SPAN.DEPLOY_STACK)
293
+ .begin(`${chalk.bold(stack.displayName)}: deploying... [${stackIndex}/${stackCollection.stackCount}]`, {
294
+ total: stackCollection.stackCount,
295
+ current: stackIndex,
296
+ stack,
297
+ });
238
298
  let tags = options.tags;
239
299
  if (!tags || tags.length === 0) {
240
300
  tags = (0, aws_cdk_1.tagsForStack)(stack);
@@ -263,7 +323,7 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
263
323
  rollback,
264
324
  hotswap: hotswapMode,
265
325
  extraUserAgent: options.extraUserAgent,
266
- hotswapPropertyOverrides: options.hotswapProperties ? (0, private_1.createHotswapPropertyOverrides)(options.hotswapProperties) : undefined,
326
+ hotswapPropertyOverrides: options.hotswapProperties ? (0, private_2.createHotswapPropertyOverrides)(options.hotswapProperties) : undefined,
267
327
  assetParallelism: options.assetParallelism,
268
328
  });
269
329
  switch (r.type) {
@@ -276,10 +336,13 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
276
336
  : `Stack is in a paused fail state (${r.status}) and command line arguments do not include "--no-rollback"`;
277
337
  const question = `${motivation}. Perform a regular deployment`;
278
338
  if (options.force) {
279
- await ioHost.notify((0, private_5.warn)(`${motivation}. Rolling back first (--force).`));
339
+ await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_WARN.msg(`${motivation}. Rolling back first (--force).`));
280
340
  }
281
341
  else {
282
- const confirmed = await ioHost.requestResponse((0, private_5.confirm)(private_5.CODES.CDK_TOOLKIT_I5050, question, motivation, true, concurrency));
342
+ const confirmed = await ioHelper.requestResponse(private_6.IO.CDK_TOOLKIT_I5050.req(question, {
343
+ motivation,
344
+ concurrency,
345
+ }));
283
346
  if (!confirmed) {
284
347
  throw new shared_public_1.ToolkitError('Aborted by user');
285
348
  }
@@ -298,10 +361,13 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
298
361
  const question = `${motivation}. Perform a regular deployment`;
299
362
  // @todo no force here
300
363
  if (options.force) {
301
- await ioHost.notify((0, private_5.warn)(`${motivation}. Proceeding with regular deployment (--force).`));
364
+ await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_WARN.msg(`${motivation}. Proceeding with regular deployment (--force).`));
302
365
  }
303
366
  else {
304
- const confirmed = await ioHost.requestResponse((0, private_5.confirm)(private_5.CODES.CDK_TOOLKIT_I5050, question, motivation, true, concurrency));
367
+ const confirmed = await ioHelper.requestResponse(private_6.IO.CDK_TOOLKIT_I5050.req(question, {
368
+ motivation,
369
+ concurrency,
370
+ }));
305
371
  if (!confirmed) {
306
372
  throw new shared_public_1.ToolkitError('Aborted by user');
307
373
  }
@@ -317,8 +383,8 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
317
383
  const message = deployResult.noOp
318
384
  ? ` ✅ ${stack.displayName} (no changes)`
319
385
  : ` ✅ ${stack.displayName}`;
320
- await ioHost.notify((0, private_5.result)(chalk.green('\n' + message), private_5.CODES.CDK_TOOLKIT_I5900, deployResult));
321
- deployDuration = await deployTimer.endAs(ioHost, 'deploy');
386
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5900.msg(chalk.green('\n' + message), deployResult));
387
+ deployDuration = await deploySpan.timing(private_6.IO.CDK_TOOLKIT_I5000);
322
388
  if (Object.keys(deployResult.outputs).length > 0) {
323
389
  const buffer = ['Outputs:'];
324
390
  stackOutputs[stack.stackName] = deployResult.outputs;
@@ -326,9 +392,9 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
326
392
  const value = deployResult.outputs[name];
327
393
  buffer.push(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);
328
394
  }
329
- await ioHost.notify((0, private_5.info)(buffer.join('\n')));
395
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5901.msg(buffer.join('\n')));
330
396
  }
331
- await ioHost.notify((0, private_5.info)(`Stack ARN:\n${deployResult.stackArn}`));
397
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5901.msg(`Stack ARN:\n${deployResult.stackArn}`));
332
398
  }
333
399
  catch (e) {
334
400
  // It has to be exactly this string because an integration test tests for
@@ -338,10 +404,10 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
338
404
  finally {
339
405
  if (options.traceLogs) {
340
406
  // deploy calls that originate from watch will come with their own cloudWatchLogMonitor
341
- const cloudWatchLogMonitor = options.cloudWatchLogMonitor ?? new aws_cdk_1.CloudWatchLogEventMonitor();
342
- const foundLogGroupsResult = await (0, aws_cdk_1.findCloudWatchLogGroups)(await this.sdkProvider('deploy'), { ioHost, action }, stack);
407
+ const cloudWatchLogMonitor = options.cloudWatchLogMonitor ?? new aws_cdk_1.CloudWatchLogEventMonitor({ ioHelper });
408
+ const foundLogGroupsResult = await (0, aws_cdk_1.findCloudWatchLogGroups)(await this.sdkProvider('deploy'), ioHelper, stack);
343
409
  cloudWatchLogMonitor.addLogGroups(foundLogGroupsResult.env, foundLogGroupsResult.sdk, foundLogGroupsResult.logGroupNames);
344
- await ioHost.notify((0, private_5.info)(`The following log groups are added: ${foundLogGroupsResult.logGroupNames}`, private_5.CODES.CDK_TOOLKIT_I5031));
410
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5031.msg(`The following log groups are added: ${foundLogGroupsResult.logGroupNames}`));
345
411
  }
346
412
  // If an outputs file has been specified, create the file path and write stack outputs to it once.
347
413
  // Outputs are written after all stacks have been deployed. If a stack deployment fails,
@@ -355,7 +421,7 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
355
421
  }
356
422
  }
357
423
  const duration = synthDuration.asMs + (deployDuration?.asMs ?? 0);
358
- await ioHost.notify((0, private_5.info)(`\n✨ Total time: ${(0, aws_cdk_1.formatTime)(duration)}s\n`, private_5.CODES.CDK_TOOLKIT_I5001, { duration }));
424
+ await deploySpan.end(`\n✨ Total time: ${(0, util_1.formatTime)(duration)}s\n`, { duration });
359
425
  };
360
426
  const assetBuildTime = options.assetBuildTime ?? deploy_1.AssetBuildTime.ALL_BEFORE_DEPLOY;
361
427
  const prebuildAssets = assetBuildTime === deploy_1.AssetBuildTime.ALL_BEFORE_DEPLOY;
@@ -364,10 +430,10 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
364
430
  stack,
365
431
  ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),
366
432
  ]);
367
- const workGraph = new aws_cdk_1.WorkGraphBuilder({ ioHost, action }, prebuildAssets).build(stacksAndTheirAssetManifests);
433
+ const workGraph = new aws_cdk_1.WorkGraphBuilder(ioHelper, prebuildAssets).build(stacksAndTheirAssetManifests);
368
434
  // Unless we are running with '--force', skip already published assets
369
435
  if (!options.force) {
370
- await (0, private_1.removePublishedAssets)(workGraph, deployments, options);
436
+ await (0, private_2.removePublishedAssets)(workGraph, deployments, options);
371
437
  }
372
438
  const graphConcurrency = {
373
439
  'stack': concurrency,
@@ -387,10 +453,9 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
387
453
  * Implies hotswap deployments.
388
454
  */
389
455
  async watch(cx, options) {
390
- const assembly = await this.assemblyFromSource(cx, false);
391
- const ioHost = (0, private_5.withAction)(this.ioHost, 'watch');
456
+ const assembly = await (0, private_1.assemblyFromSource)(cx, false);
457
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'watch');
392
458
  const rootDir = options.watchDir ?? process.cwd();
393
- await ioHost.notify((0, private_5.debug)(`root directory used for 'watch' is: ${rootDir}`));
394
459
  if (options.include === undefined && options.exclude === undefined) {
395
460
  throw new shared_public_1.ToolkitError("Cannot use the 'watch' command without specifying at least one directory to monitor. " +
396
461
  'Make sure to add a "watch" key to your cdk.json');
@@ -400,11 +465,10 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
400
465
  // 2. "watch" setting without an "include" key? We default to observing "./**".
401
466
  // 3. "watch" setting with an empty "include" key? We default to observing "./**".
402
467
  // 4. Non-empty "include" key? Just use the "include" key.
403
- const watchIncludes = (0, private_3.patternsArrayForWatch)(options.include, {
468
+ const watchIncludes = (0, private_4.patternsArrayForWatch)(options.include, {
404
469
  rootDir,
405
470
  returnRootDirIfEmpty: true,
406
471
  });
407
- await ioHost.notify((0, private_5.debug)(`'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`));
408
472
  // For the "exclude" subkey under the "watch" key,
409
473
  // the behavior is to add some default excludes in addition to the ones specified by the user:
410
474
  // 1. The CDK output directory.
@@ -412,27 +476,25 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
412
476
  // 3. Any directory's content whose name starts with a dot.
413
477
  // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)
414
478
  const outdir = options.outdir ?? 'cdk.out';
415
- const watchExcludes = (0, private_3.patternsArrayForWatch)(options.exclude, {
479
+ const watchExcludes = (0, private_4.patternsArrayForWatch)(options.exclude, {
416
480
  rootDir,
417
481
  returnRootDirIfEmpty: false,
418
482
  }).concat(`${outdir}/**`, '**/.*', '**/.*/**', '**/node_modules/**');
419
- await ioHost.notify((0, private_5.debug)(`'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`));
420
- // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,
421
- // introduce a concurrency latch that tracks the state.
422
- // This way, if file change events arrive when a 'cdk deploy' is still executing,
423
- // we will batch them, and trigger another 'cdk deploy' after the current one finishes,
424
- // making sure 'cdk deploy's always execute one at a time.
425
- // Here's a diagram showing the state transitions:
426
- // -------------- -------- file changed -------------- file changed -------------- file changed
427
- // | | ready event | | ------------------> | | ------------------> | | --------------|
428
- // | pre-ready | -------------> | open | | deploying | | queued | |
429
- // | | | | <------------------ | | <------------------ | | <-------------|
430
- // -------------- -------- 'cdk deploy' done -------------- 'cdk deploy' done --------------
483
+ // Print some debug information on computed settings
484
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5310.msg([
485
+ `root directory used for 'watch' is: ${rootDir}`,
486
+ `'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`,
487
+ `'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`,
488
+ ].join('\n'), {
489
+ watchDir: rootDir,
490
+ includes: watchIncludes,
491
+ excludes: watchExcludes,
492
+ }));
431
493
  let latch = 'pre-ready';
432
- const cloudWatchLogMonitor = options.traceLogs ? new aws_cdk_1.CloudWatchLogEventMonitor() : undefined;
494
+ const cloudWatchLogMonitor = options.traceLogs ? new aws_cdk_1.CloudWatchLogEventMonitor({ ioHelper }) : undefined;
433
495
  const deployAndWatch = async () => {
434
496
  latch = 'deploying';
435
- cloudWatchLogMonitor?.deactivate();
497
+ await cloudWatchLogMonitor?.deactivate();
436
498
  await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);
437
499
  // If latch is still 'deploying' after the 'await', that's fine,
438
500
  // but if it's 'queued', that means we need to deploy again
@@ -440,11 +502,11 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
440
502
  // TypeScript doesn't realize latch can change between 'awaits',
441
503
  // and thinks the above 'while' condition is always 'false' without the cast
442
504
  latch = 'deploying';
443
- await ioHost.notify((0, private_5.info)("Detected file changes during deployment. Invoking 'cdk deploy' again"));
505
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5315.msg("Detected file changes during deployment. Invoking 'cdk deploy' again"));
444
506
  await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);
445
507
  }
446
508
  latch = 'open';
447
- cloudWatchLogMonitor?.activate();
509
+ await cloudWatchLogMonitor?.activate();
448
510
  };
449
511
  chokidar
450
512
  .watch(watchIncludes, {
@@ -453,22 +515,26 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
453
515
  })
454
516
  .on('ready', async () => {
455
517
  latch = 'open';
456
- await ioHost.notify((0, private_5.debug)("'watch' received the 'ready' event. From now on, all file changes will trigger a deployment"));
457
- await ioHost.notify((0, private_5.info)("Triggering initial 'cdk deploy'"));
518
+ await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_DEBUG.msg("'watch' received the 'ready' event. From now on, all file changes will trigger a deployment"));
519
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5314.msg("Triggering initial 'cdk deploy'"));
458
520
  await deployAndWatch();
459
521
  })
460
522
  .on('all', async (event, filePath) => {
523
+ const watchEvent = {
524
+ event,
525
+ path: filePath,
526
+ };
461
527
  if (latch === 'pre-ready') {
462
- await ioHost.notify((0, private_5.info)(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`));
528
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5311.msg(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`, watchEvent));
463
529
  }
464
530
  else if (latch === 'open') {
465
- await ioHost.notify((0, private_5.info)(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`));
531
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5312.msg(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`, watchEvent));
466
532
  await deployAndWatch();
467
533
  }
468
534
  else {
469
535
  // this means latch is either 'deploying' or 'queued'
470
536
  latch = 'queued';
471
- await ioHost.notify((0, private_5.info)(`Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`));
537
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5313.msg(`Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`, watchEvent));
472
538
  }
473
539
  });
474
540
  }
@@ -478,26 +544,29 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
478
544
  * Rolls back the selected stacks.
479
545
  */
480
546
  async rollback(cx, options) {
481
- const assembly = await this.assemblyFromSource(cx);
547
+ const assembly = await (0, private_1.assemblyFromSource)(cx);
482
548
  return this._rollback(assembly, 'rollback', options);
483
549
  }
484
550
  /**
485
551
  * Helper to allow rollback being called as part of the deploy or watch action.
486
552
  */
487
553
  async _rollback(assembly, action, options) {
488
- const ioHost = (0, private_5.withAction)(this.ioHost, action);
489
- const synthTimer = private_5.Timer.start();
554
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, action);
555
+ const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });
490
556
  const stacks = assembly.selectStacksV2(options.stacks);
491
- await this.validateStacksMetadata(stacks, ioHost);
492
- await synthTimer.endAs(ioHost, 'synth');
557
+ await this.validateStacksMetadata(stacks, ioHelper);
558
+ await synthSpan.end();
493
559
  if (stacks.stackCount === 0) {
494
- await ioHost.notify((0, private_5.error)('No stacks selected', private_5.CODES.CDK_TOOLKIT_E6001));
560
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_E6001.msg('No stacks selected'));
495
561
  return;
496
562
  }
497
563
  let anyRollbackable = false;
498
- for (const stack of stacks.stackArtifacts) {
499
- await ioHost.notify((0, private_5.info)(`Rolling back ${chalk.bold(stack.displayName)}`));
500
- const rollbackTimer = private_5.Timer.start();
564
+ for (const [index, stack] of stacks.stackArtifacts.entries()) {
565
+ const rollbackSpan = await ioHelper.span(private_6.SPAN.ROLLBACK_STACK).begin(`Rolling back ${chalk.bold(stack.displayName)}`, {
566
+ total: stacks.stackCount,
567
+ current: index + 1,
568
+ stack,
569
+ });
501
570
  const deployments = await this.deploymentsForAction('rollback');
502
571
  try {
503
572
  const stackResult = await deployments.rollbackStack({
@@ -511,10 +580,10 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
511
580
  if (!stackResult.notInRollbackableState) {
512
581
  anyRollbackable = true;
513
582
  }
514
- await rollbackTimer.endAs(ioHost, 'rollback');
583
+ await rollbackSpan.end();
515
584
  }
516
585
  catch (e) {
517
- await ioHost.notify((0, private_5.error)(`\n ❌ ${chalk.bold(stack.displayName)} failed: ${(0, aws_cdk_1.formatErrorMessage)(e)}`, private_5.CODES.CDK_TOOLKIT_E6900));
586
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_E6900.msg(`\n ❌ ${chalk.bold(stack.displayName)} failed: ${(0, util_1.formatErrorMessage)(e)}`, { error: e }));
518
587
  throw new shared_public_1.ToolkitError('Rollback failed (use --force to orphan failing resources)');
519
588
  }
520
589
  }
@@ -528,82 +597,67 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
528
597
  * Destroys the selected Stacks.
529
598
  */
530
599
  async destroy(cx, options) {
531
- const assembly = await this.assemblyFromSource(cx);
600
+ const assembly = await (0, private_1.assemblyFromSource)(cx);
532
601
  return this._destroy(assembly, 'destroy', options);
533
602
  }
534
603
  /**
535
604
  * Helper to allow destroy being called as part of the deploy action.
536
605
  */
537
606
  async _destroy(assembly, action, options) {
538
- const ioHost = (0, private_5.withAction)(this.ioHost, action);
539
- const synthTimer = private_5.Timer.start();
607
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, action);
608
+ const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });
540
609
  // The stacks will have been ordered for deployment, so reverse them for deletion.
541
610
  const stacks = await assembly.selectStacksV2(options.stacks).reversed();
542
- await synthTimer.endAs(ioHost, 'synth');
611
+ await synthSpan.end();
543
612
  const motivation = 'Destroying stacks is an irreversible action';
544
613
  const question = `Are you sure you want to delete: ${chalk.red(stacks.hierarchicalIds.join(', '))}`;
545
- const confirmed = await ioHost.requestResponse((0, private_5.confirm)(private_5.CODES.CDK_TOOLKIT_I7010, question, motivation, true));
614
+ const confirmed = await ioHelper.requestResponse(private_6.IO.CDK_TOOLKIT_I7010.req(question, { motivation }));
546
615
  if (!confirmed) {
547
- return ioHost.notify((0, private_5.error)('Aborted by user', private_5.CODES.CDK_TOOLKIT_E7010));
616
+ return ioHelper.notify(private_6.IO.CDK_TOOLKIT_E7010.msg('Aborted by user'));
548
617
  }
549
- const destroyTimer = private_5.Timer.start();
618
+ const destroySpan = await ioHelper.span(private_6.SPAN.DESTROY_ACTION).begin({
619
+ stacks: stacks.stackArtifacts,
620
+ });
550
621
  try {
551
622
  for (const [index, stack] of stacks.stackArtifacts.entries()) {
552
- await ioHost.notify((0, private_5.success)(`${chalk.blue(stack.displayName)}: destroying... [${index + 1}/${stacks.stackCount}]`));
553
623
  try {
624
+ const singleDestroySpan = await ioHelper.span(private_6.SPAN.DESTROY_STACK)
625
+ .begin(chalk.green(`${chalk.blue(stack.displayName)}: destroying... [${index + 1}/${stacks.stackCount}]`), {
626
+ total: stacks.stackCount,
627
+ current: index + 1,
628
+ stack,
629
+ });
554
630
  const deployments = await this.deploymentsForAction(action);
555
631
  await deployments.destroyStack({
556
632
  stack,
557
633
  deployName: stack.stackName,
558
634
  roleArn: options.roleArn,
559
- ci: options.ci,
560
635
  });
561
- await ioHost.notify((0, private_5.success)(`\n ✅ ${chalk.blue(stack.displayName)}: ${action}ed`));
636
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I7900.msg(chalk.green(`\n ✅ ${chalk.blue(stack.displayName)}: ${action}ed`), stack));
637
+ await singleDestroySpan.end();
562
638
  }
563
639
  catch (e) {
564
- await ioHost.notify((0, private_5.error)(`\n ❌ ${chalk.blue(stack.displayName)}: ${action} failed ${e}`, private_5.CODES.CDK_TOOLKIT_E7900));
640
+ await ioHelper.notify(private_6.IO.CDK_TOOLKIT_E7900.msg(`\n ❌ ${chalk.blue(stack.displayName)}: ${action} failed ${e}`, { error: e }));
565
641
  throw e;
566
642
  }
567
643
  }
568
644
  }
569
645
  finally {
570
- await destroyTimer.endAs(ioHost, 'destroy');
646
+ await destroySpan.end();
571
647
  }
572
648
  }
573
649
  /**
574
650
  * Validate the stacks for errors and warnings according to the CLI's current settings
575
651
  */
576
652
  async validateStacksMetadata(stacks, ioHost) {
577
- // @TODO define these somewhere central
578
- const code = (level) => {
653
+ const builder = (level) => {
579
654
  switch (level) {
580
- case 'error': return 'CDK_ASSEMBLY_E9999';
581
- case 'warn': return 'CDK_ASSEMBLY_W9999';
582
- default: return 'CDK_ASSEMBLY_I9999';
655
+ case 'error': return private_6.IO.CDK_ASSEMBLY_E9999;
656
+ case 'warn': return private_6.IO.CDK_ASSEMBLY_W9999;
657
+ default: return private_6.IO.CDK_ASSEMBLY_I9999;
583
658
  }
584
659
  };
585
- await stacks.validateMetadata(this.props.assemblyFailureAt, async (level, msg) => ioHost.notify({
586
- time: new Date(),
587
- level,
588
- code: code(level),
589
- message: `[${level} at ${msg.id}] ${msg.entry.data}`,
590
- data: msg,
591
- }));
592
- }
593
- /**
594
- * Creates a Toolkit internal CloudAssembly from a CloudAssemblySource.
595
- * @param assemblySource the source for the cloud assembly
596
- * @param cache if the assembly should be cached, default: `true`
597
- * @returns the CloudAssembly object
598
- */
599
- async assemblyFromSource(assemblySource, cache = true) {
600
- if (assemblySource instanceof private_4.StackAssembly) {
601
- return assemblySource;
602
- }
603
- if (cache) {
604
- return new private_4.StackAssembly(await new private_4.CachedCloudAssemblySource(assemblySource).produce());
605
- }
606
- return new private_4.StackAssembly(await assemblySource.produce());
660
+ await stacks.validateMetadata(this.props.assemblyFailureAt, async (level, msg) => ioHost.notify(builder(level).msg(`[${level} at ${msg.id}] ${msg.entry.data}`, msg)));
607
661
  }
608
662
  /**
609
663
  * Create a deployments class
@@ -612,8 +666,7 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
612
666
  return new aws_cdk_1.Deployments({
613
667
  sdkProvider: await this.sdkProvider(action),
614
668
  toolkitStackName: this.toolkitStackName,
615
- ioHost: this.ioHost, // @todo temporary while we have to separate IIoHost interfaces
616
- action,
669
+ ioHelper: (0, shared_private_1.asIoHelper)(this.ioHost, action),
617
670
  });
618
671
  }
619
672
  async invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor) {
@@ -635,4 +688,4 @@ class Toolkit extends private_4.CloudAssemblySourceBuilder {
635
688
  }
636
689
  }
637
690
  exports.Toolkit = Toolkit;
638
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit.js","sourceRoot":"","sources":["toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'node:path';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport * as chokidar from 'chokidar';\nimport * as fs from 'fs-extra';\nimport { ToolkitServices } from './private';\nimport { AssemblyData, StackAndAssemblyData } from './types';\nimport { AssetBuildTime, type DeployOptions, RequireApproval } from '../actions/deploy';\nimport { type ExtendedDeployOptions, buildParameterMap, createHotswapPropertyOverrides, removePublishedAssets } from '../actions/deploy/private';\nimport { type DestroyOptions } from '../actions/destroy';\nimport { diffRequiresApproval } from '../actions/diff/private';\nimport { type ListOptions } from '../actions/list';\nimport { type RollbackOptions } from '../actions/rollback';\nimport { type SynthOptions } from '../actions/synth';\nimport { WatchOptions } from '../actions/watch';\nimport { patternsArrayForWatch } from '../actions/watch/private';\nimport { type SdkConfig } from '../api/aws-auth';\nimport { DEFAULT_TOOLKIT_STACK_NAME, SdkProvider, SuccessfulDeployStackResult, StackCollection, Deployments, HotswapMode, ResourceMigrator, obscureTemplate, serializeStructure, tagsForStack, CliIoHost, validateSnsTopicArn, Concurrency, WorkGraphBuilder, AssetBuildNode, AssetPublishNode, StackNode, formatErrorMessage, CloudWatchLogEventMonitor, findCloudWatchLogGroups, formatTime, StackDetails } from '../api/aws-cdk';\nimport { ICloudAssemblySource, StackSelectionStrategy } from '../api/cloud-assembly';\nimport { ALL_STACKS, CachedCloudAssemblySource, CloudAssemblySourceBuilder, IdentityCloudAssemblySource, StackAssembly } from '../api/cloud-assembly/private';\nimport { IIoHost, IoMessageCode, IoMessageLevel } from '../api/io';\nimport { asSdkLogger, withAction, Timer, confirm, error, info, success, warn, ActionAwareIoHost, debug, result, withoutEmojis, withoutColor, withTrimmedWhitespace, CODES } from '../api/io/private';\nimport { ToolkitError } from '../api/shared-public';\n\n/**\n * The current action being performed by the CLI. 'none' represents the absence of an action.\n */\nexport type ToolkitAction =\n| 'assembly'\n| 'bootstrap'\n| 'synth'\n| 'list'\n| 'diff'\n| 'deploy'\n| 'rollback'\n| 'watch'\n| 'destroy'\n| 'doctor'\n| 'gc'\n| 'import'\n| 'metadata'\n| 'init'\n| 'migrate';\n\nexport interface ToolkitOptions {\n  /**\n   * The IoHost implementation, handling the inline interactions between the Toolkit and an integration.\n   */\n  ioHost?: IIoHost;\n\n  /**\n   * Allow emojis in messages sent to the IoHost.\n   *\n   * @default true\n   */\n  emojis?: boolean;\n\n  /**\n   * Whether to allow ANSI colors and formatting in IoHost messages.\n   * Setting this value to `false` enforces that no color or style shows up\n   * in messages sent to the IoHost.\n   * Setting this value to true is a no-op; it is equivalent to the default.\n   *\n   * @default - detects color from the TTY status of the IoHost\n   */\n  color?: boolean;\n\n  /**\n   * Configuration options for the SDK.\n   */\n  sdkConfig?: SdkConfig;\n\n  /**\n   * Name of the toolkit stack to be used.\n   *\n   * @default \"CDKToolkit\"\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Fail Cloud Assemblies\n   *\n   * @default \"error\"\n   */\n  assemblyFailureAt?: 'error' | 'warn' | 'none';\n}\n\n/**\n * The AWS CDK Programmatic Toolkit\n */\nexport class Toolkit extends CloudAssemblySourceBuilder implements AsyncDisposable {\n  /**\n   * The toolkit stack name used for bootstrapping resources.\n   */\n  public readonly toolkitStackName: string;\n\n  /**\n   * The IoHost of this Toolkit\n   */\n  public readonly ioHost: IIoHost;\n  private _sdkProvider?: SdkProvider;\n\n  public constructor(private readonly props: ToolkitOptions = {}) {\n    super();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n\n    // Hacky way to re-use the global IoHost until we have fully removed the need for it\n    const globalIoHost = CliIoHost.instance();\n    if (props.ioHost) {\n      globalIoHost.registerIoHost(props.ioHost as any);\n    }\n    let ioHost = globalIoHost as IIoHost;\n    if (props.emojis === false) {\n      ioHost = withoutEmojis(ioHost);\n    }\n    if (props.color === false) {\n      ioHost = withoutColor(ioHost);\n    }\n    // After removing emojis and color, we might end up with floating whitespace at either end of the message\n    // This also removes newlines that we currently emit for CLI backwards compatibility.\n    this.ioHost = withTrimmedWhitespace(ioHost);\n  }\n\n  public async dispose(): Promise<void> {\n    // nothing to do yet\n  }\n\n  public async [Symbol.asyncDispose](): Promise<void> {\n    await this.dispose();\n  }\n\n  /**\n   * Access to the AWS SDK\n   */\n  private async sdkProvider(action: ToolkitAction): Promise<SdkProvider> {\n    // @todo this needs to be different instance per action\n    if (!this._sdkProvider) {\n      this._sdkProvider = await SdkProvider.withAwsCliCompatibleDefaults({\n        ...this.props.sdkConfig,\n        logger: asSdkLogger(this.ioHost, action),\n      });\n    }\n\n    return this._sdkProvider;\n  }\n\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   */\n  protected override async sourceBuilderServices(): Promise<ToolkitServices> {\n    return {\n      ioHost: withAction(this.ioHost, 'assembly'),\n      sdkProvider: await this.sdkProvider('assembly'),\n    };\n  }\n\n  /**\n   * Synth Action\n   */\n  public async synth(cx: ICloudAssemblySource, options: SynthOptions = {}): Promise<ICloudAssemblySource> {\n    const ioHost = withAction(this.ioHost, 'synth');\n    const synthTimer = Timer.start();\n    const assembly = await this.assemblyFromSource(cx);\n    const stacks = assembly.selectStacksV2(options.stacks ?? ALL_STACKS);\n    const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];\n    await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHost);\n    await synthTimer.endAs(ioHost, 'synth');\n\n    // if we have a single stack, print it to STDOUT\n    const message = `Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`;\n    const assemblyData: AssemblyData = {\n      assemblyDirectory: stacks.assembly.directory,\n      stacksCount: stacks.stackCount,\n      stackIds: stacks.hierarchicalIds,\n    };\n\n    if (stacks.stackCount === 1) {\n      const firstStack = stacks.firstStack!;\n      const template = firstStack.template;\n      const obscuredTemplate = obscureTemplate(template);\n      await ioHost.notify(result(message, CODES.CDK_TOOLKIT_I1901, {\n        ...assemblyData,\n        stack: {\n          stackName: firstStack.stackName,\n          hierarchicalId: firstStack.hierarchicalId,\n          template,\n          stringifiedJson: serializeStructure(obscuredTemplate, true),\n          stringifiedYaml: serializeStructure(obscuredTemplate, false),\n        },\n      } as StackAndAssemblyData));\n    } else {\n      // not outputting template to stdout, let's explain things to the user a little bit...\n      await ioHost.notify(result(chalk.green(message), CODES.CDK_TOOLKIT_I1902, assemblyData));\n      await ioHost.notify(info(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));\n    }\n\n    return new IdentityCloudAssemblySource(assembly.assembly);\n  }\n\n  /**\n   * List Action\n   *\n   * List selected stacks and their dependencies\n   */\n  public async list(cx: ICloudAssemblySource, options: ListOptions = {}): Promise<StackDetails[]> {\n    const ioHost = withAction(this.ioHost, 'list');\n    const synthTimer = Timer.start();\n    const assembly = await this.assemblyFromSource(cx);\n    const stackCollection = await assembly.selectStacksV2(options.stacks ?? ALL_STACKS);\n    await synthTimer.endAs(ioHost, 'synth');\n\n    const stacks = stackCollection.withDependencies();\n    const message = stacks.map(s => s.id).join('\\n');\n\n    await ioHost.notify(result(message, CODES.CDK_TOOLKIT_I2901, { stacks }));\n    return stacks;\n  }\n\n  /**\n   * Deploy Action\n   *\n   * Deploys the selected stacks into an AWS account\n   */\n  public async deploy(cx: ICloudAssemblySource, options: DeployOptions = {}): Promise<void> {\n    const assembly = await this.assemblyFromSource(cx);\n    return this._deploy(assembly, 'deploy', options);\n  }\n\n  /**\n   * Helper to allow deploy being called as part of the watch action.\n   */\n  private async _deploy(assembly: StackAssembly, action: 'deploy' | 'watch', options: ExtendedDeployOptions = {}) {\n    const ioHost = withAction(this.ioHost, action);\n    const synthTimer = Timer.start();\n    const stackCollection = assembly.selectStacksV2(options.stacks ?? ALL_STACKS);\n    await this.validateStacksMetadata(stackCollection, ioHost);\n    const synthDuration = await synthTimer.endAs(ioHost, 'synth');\n\n    if (stackCollection.stackCount === 0) {\n      await ioHost.notify(error('This app contains no stacks', CODES.CDK_TOOLKIT_E5001));\n      return;\n    }\n\n    const deployments = await this.deploymentsForAction('deploy');\n    const migrator = new ResourceMigrator({ deployments, ioHost, action });\n\n    await migrator.tryMigrateResources(stackCollection, options);\n\n    const requireApproval = options.requireApproval ?? RequireApproval.NEVER;\n\n    const parameterMap = buildParameterMap(options.parameters?.parameters);\n\n    const hotswapMode = options.hotswap ?? HotswapMode.FULL_DEPLOYMENT;\n    if (hotswapMode !== HotswapMode.FULL_DEPLOYMENT) {\n      await ioHost.notify(warn([\n        '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',\n        '⚠️ They should only be used for development - never use them for your production Stacks!',\n      ].join('\\n')));\n    }\n\n    const stacks = stackCollection.stackArtifacts;\n    const stackOutputs: { [key: string]: any } = {};\n    const outputsFile = options.outputsFile;\n\n    const buildAsset = async (assetNode: AssetBuildNode) => {\n      await deployments.buildSingleAsset(\n        assetNode.assetManifestArtifact,\n        assetNode.assetManifest,\n        assetNode.asset,\n        {\n          stack: assetNode.parentStack,\n          roleArn: options.roleArn,\n          stackName: assetNode.parentStack.stackName,\n        },\n      );\n    };\n\n    const publishAsset = async (assetNode: AssetPublishNode) => {\n      await deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {\n        stack: assetNode.parentStack,\n        roleArn: options.roleArn,\n        stackName: assetNode.parentStack.stackName,\n      });\n    };\n\n    const deployStack = async (stackNode: StackNode) => {\n      const stack = stackNode.stack;\n      if (stackCollection.stackCount !== 1) {\n        await ioHost.notify(info(chalk.bold(stack.displayName)));\n      }\n\n      if (!stack.environment) {\n        throw new ToolkitError(\n          `Stack ${stack.displayName} does not define an environment, and AWS credentials could not be obtained from standard locations or no region was configured.`,\n        );\n      }\n\n      // The generated stack has no resources\n      if (Object.keys(stack.template.Resources || {}).length === 0) {\n        // stack is empty and doesn't exist => do nothing\n        const stackExists = await deployments.stackExists({ stack });\n        if (!stackExists) {\n          return ioHost.notify(warn(`${chalk.bold(stack.displayName)}: stack has no resources, skipping deployment.`));\n        }\n\n        // stack is empty, but exists => delete\n        await ioHost.notify(warn(`${chalk.bold(stack.displayName)}: stack has no resources, deleting existing stack.`));\n        await this._destroy(assembly, 'deploy', {\n          stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n          roleArn: options.roleArn,\n          ci: options.ci,\n        });\n\n        return;\n      }\n\n      if (requireApproval !== RequireApproval.NEVER) {\n        const currentTemplate = await deployments.readCurrentTemplate(stack);\n        if (diffRequiresApproval(currentTemplate, stack, requireApproval)) {\n          const motivation = '\"--require-approval\" is enabled and stack includes security-sensitive updates.';\n          const question = `${motivation}\\nDo you wish to deploy these changes`;\n          const confirmed = await ioHost.requestResponse(confirm(CODES.CDK_TOOLKIT_I5060, question, motivation, true, concurrency));\n          if (!confirmed) {\n            throw new ToolkitError('Aborted by user');\n          }\n        }\n      }\n\n      // Following are the same semantics we apply with respect to Notification ARNs (dictated by the SDK)\n      //\n      //  - undefined  =>  cdk ignores it, as if it wasn't supported (allows external management).\n      //  - []:        =>  cdk manages it, and the user wants to wipe it out.\n      //  - ['arn-1']  =>  cdk manages it, and the user wants to set it to ['arn-1'].\n      const notificationArns = (!!options.notificationArns || !!stack.notificationArns)\n        ? (options.notificationArns ?? []).concat(stack.notificationArns ?? [])\n        : undefined;\n\n      for (const notificationArn of notificationArns ?? []) {\n        if (!validateSnsTopicArn(notificationArn)) {\n          throw new ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);\n        }\n      }\n\n      const stackIndex = stacks.indexOf(stack) + 1;\n      await ioHost.notify(\n        info(`${chalk.bold(stack.displayName)}: deploying... [${stackIndex}/${stackCollection.stackCount}]`),\n      );\n      const deployTimer = Timer.start();\n\n      let tags = options.tags;\n      if (!tags || tags.length === 0) {\n        tags = tagsForStack(stack);\n      }\n\n      let deployDuration;\n      try {\n        let deployResult: SuccessfulDeployStackResult | undefined;\n\n        let rollback = options.rollback;\n        let iteration = 0;\n        while (!deployResult) {\n          if (++iteration > 2) {\n            throw new ToolkitError('This loop should have stabilized in 2 iterations, but didn\\'t. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose');\n          }\n\n          const r = await deployments.deployStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n            toolkitStackName: this.toolkitStackName,\n            reuseAssets: options.reuseAssets,\n            notificationArns,\n            tags,\n            deploymentMethod: options.deploymentMethod,\n            force: options.force,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.parameters?.keepExistingParameters,\n            rollback,\n            hotswap: hotswapMode,\n            extraUserAgent: options.extraUserAgent,\n            hotswapPropertyOverrides: options.hotswapProperties ? createHotswapPropertyOverrides(options.hotswapProperties) : undefined,\n            assetParallelism: options.assetParallelism,\n          });\n\n          switch (r.type) {\n            case 'did-deploy-stack':\n              deployResult = r;\n              break;\n\n            case 'failpaused-need-rollback-first': {\n              const motivation = r.reason === 'replacement'\n                ? `Stack is in a paused fail state (${r.status}) and change includes a replacement which cannot be deployed with \"--no-rollback\"`\n                : `Stack is in a paused fail state (${r.status}) and command line arguments do not include \"--no-rollback\"`;\n              const question = `${motivation}. Perform a regular deployment`;\n\n              if (options.force) {\n                await ioHost.notify(warn(`${motivation}. Rolling back first (--force).`));\n              } else {\n                const confirmed = await ioHost.requestResponse(confirm(CODES.CDK_TOOLKIT_I5050, question, motivation, true, concurrency));\n                if (!confirmed) {\n                  throw new ToolkitError('Aborted by user');\n                }\n              }\n\n              // Perform a rollback\n              await this._rollback(assembly, action, {\n                stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n                orphanFailedResources: options.force,\n              });\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            case 'replacement-requires-rollback': {\n              const motivation = 'Change includes a replacement which cannot be deployed with \"--no-rollback\"';\n              const question = `${motivation}. Perform a regular deployment`;\n\n              // @todo no force here\n              if (options.force) {\n                await ioHost.notify(warn(`${motivation}. Proceeding with regular deployment (--force).`));\n              } else {\n                const confirmed = await ioHost.requestResponse(confirm(CODES.CDK_TOOLKIT_I5050, question, motivation, true, concurrency));\n                if (!confirmed) {\n                  throw new ToolkitError('Aborted by user');\n                }\n              }\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            default:\n              throw new ToolkitError(`Unexpected result type from deployStack: ${JSON.stringify(r)}. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose`);\n          }\n        }\n\n        const message = deployResult.noOp\n          ? ` ✅  ${stack.displayName} (no changes)`\n          : ` ✅  ${stack.displayName}`;\n\n        await ioHost.notify(result(chalk.green('\\n' + message), CODES.CDK_TOOLKIT_I5900, deployResult));\n        deployDuration = await deployTimer.endAs(ioHost, 'deploy');\n\n        if (Object.keys(deployResult.outputs).length > 0) {\n          const buffer = ['Outputs:'];\n          stackOutputs[stack.stackName] = deployResult.outputs;\n\n          for (const name of Object.keys(deployResult.outputs).sort()) {\n            const value = deployResult.outputs[name];\n            buffer.push(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);\n          }\n          await ioHost.notify(info(buffer.join('\\n')));\n        }\n        await ioHost.notify(info(`Stack ARN:\\n${deployResult.stackArn}`));\n      } catch (e: any) {\n        // It has to be exactly this string because an integration test tests for\n        // \"bold(stackname) failed: ResourceNotReady: <error>\"\n        throw new ToolkitError(\n          [`❌  ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), e.message].join(' '),\n        );\n      } finally {\n        if (options.traceLogs) {\n          // deploy calls that originate from watch will come with their own cloudWatchLogMonitor\n          const cloudWatchLogMonitor = options.cloudWatchLogMonitor ?? new CloudWatchLogEventMonitor();\n          const foundLogGroupsResult = await findCloudWatchLogGroups(await this.sdkProvider('deploy'), { ioHost, action }, stack);\n          cloudWatchLogMonitor.addLogGroups(\n            foundLogGroupsResult.env,\n            foundLogGroupsResult.sdk,\n            foundLogGroupsResult.logGroupNames,\n          );\n          await ioHost.notify(info(`The following log groups are added: ${foundLogGroupsResult.logGroupNames}`, CODES.CDK_TOOLKIT_I5031));\n        }\n\n        // If an outputs file has been specified, create the file path and write stack outputs to it once.\n        // Outputs are written after all stacks have been deployed. If a stack deployment fails,\n        // all of the outputs from successfully deployed stacks before the failure will still be written.\n        if (outputsFile) {\n          fs.ensureFileSync(outputsFile);\n          await fs.writeJson(outputsFile, stackOutputs, {\n            spaces: 2,\n            encoding: 'utf8',\n          });\n        }\n      }\n      const duration = synthDuration.asMs + (deployDuration?.asMs ?? 0);\n      await ioHost.notify(info(`\\n✨  Total time: ${formatTime(duration)}s\\n`, CODES.CDK_TOOLKIT_I5001, { duration }));\n    };\n\n    const assetBuildTime = options.assetBuildTime ?? AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const prebuildAssets = assetBuildTime === AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const concurrency = options.concurrency || 1;\n\n    const stacksAndTheirAssetManifests = stacks.flatMap((stack) => [\n      stack,\n      ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),\n    ]);\n    const workGraph = new WorkGraphBuilder({ ioHost, action }, prebuildAssets).build(stacksAndTheirAssetManifests);\n\n    // Unless we are running with '--force', skip already published assets\n    if (!options.force) {\n      await removePublishedAssets(workGraph, deployments, options);\n    }\n\n    const graphConcurrency: Concurrency = {\n      'stack': concurrency,\n      'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds\n      'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable\n    };\n\n    await workGraph.doParallel(graphConcurrency, {\n      deployStack,\n      buildAsset,\n      publishAsset,\n    });\n  }\n\n  /**\n   * Watch Action\n   *\n   * Continuously observe project files and deploy the selected stacks automatically when changes are detected.\n   * Implies hotswap deployments.\n   */\n  public async watch(cx: ICloudAssemblySource, options: WatchOptions): Promise<void> {\n    const assembly = await this.assemblyFromSource(cx, false);\n    const ioHost = withAction(this.ioHost, 'watch');\n    const rootDir = options.watchDir ?? process.cwd();\n    await ioHost.notify(debug(`root directory used for 'watch' is: ${rootDir}`));\n\n    if (options.include === undefined && options.exclude === undefined) {\n      throw new ToolkitError(\n        \"Cannot use the 'watch' command without specifying at least one directory to monitor. \" +\n          'Make sure to add a \"watch\" key to your cdk.json',\n      );\n    }\n\n    // For the \"include\" subkey under the \"watch\" key, the behavior is:\n    // 1. No \"watch\" setting? We error out.\n    // 2. \"watch\" setting without an \"include\" key? We default to observing \"./**\".\n    // 3. \"watch\" setting with an empty \"include\" key? We default to observing \"./**\".\n    // 4. Non-empty \"include\" key? Just use the \"include\" key.\n    const watchIncludes = patternsArrayForWatch(options.include, {\n      rootDir,\n      returnRootDirIfEmpty: true,\n    });\n    await ioHost.notify(debug(`'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`));\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outdir = options.outdir ?? 'cdk.out';\n    const watchExcludes = patternsArrayForWatch(options.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    }).concat(`${outdir}/**`, '**/.*', '**/.*/**', '**/node_modules/**');\n    await ioHost.notify(debug(`'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`));\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    let latch: 'pre-ready' | 'open' | 'deploying' | 'queued' = 'pre-ready';\n\n    const cloudWatchLogMonitor = options.traceLogs ? new CloudWatchLogEventMonitor() : undefined;\n    const deployAndWatch = async () => {\n      latch = 'deploying';\n      cloudWatchLogMonitor?.deactivate();\n\n      await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while ((latch as 'deploying' | 'queued') === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        await ioHost.notify(info(\"Detected file changes during deployment. Invoking 'cdk deploy' again\"));\n        await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n      }\n      latch = 'open';\n      cloudWatchLogMonitor?.activate();\n    };\n\n    chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        await ioHost.notify(debug(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\"));\n        await ioHost.notify(info(\"Triggering initial 'cdk deploy'\"));\n        await deployAndWatch();\n      })\n      .on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath?: string) => {\n        if (latch === 'pre-ready') {\n          await ioHost.notify(info(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`));\n        } else if (latch === 'open') {\n          await ioHost.notify(info(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`));\n          await deployAndWatch();\n        } else {\n          // this means latch is either 'deploying' or 'queued'\n          latch = 'queued';\n          await ioHost.notify(info(\n            `Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`,\n          ));\n        }\n      });\n  }\n\n  /**\n   * Rollback Action\n   *\n   * Rolls back the selected stacks.\n   */\n  public async rollback(cx: ICloudAssemblySource, options: RollbackOptions): Promise<void> {\n    const assembly = await this.assemblyFromSource(cx);\n    return this._rollback(assembly, 'rollback', options);\n  }\n\n  /**\n   * Helper to allow rollback being called as part of the deploy or watch action.\n   */\n  private async _rollback(assembly: StackAssembly, action: 'rollback' | 'deploy' | 'watch', options: RollbackOptions): Promise<void> {\n    const ioHost = withAction(this.ioHost, action);\n    const synthTimer = Timer.start();\n    const stacks = assembly.selectStacksV2(options.stacks);\n    await this.validateStacksMetadata(stacks, ioHost);\n    await synthTimer.endAs(ioHost, 'synth');\n\n    if (stacks.stackCount === 0) {\n      await ioHost.notify(error('No stacks selected', CODES.CDK_TOOLKIT_E6001));\n      return;\n    }\n\n    let anyRollbackable = false;\n\n    for (const stack of stacks.stackArtifacts) {\n      await ioHost.notify(info(`Rolling back ${chalk.bold(stack.displayName)}`));\n      const rollbackTimer = Timer.start();\n      const deployments = await this.deploymentsForAction('rollback');\n      try {\n        const stackResult = await deployments.rollbackStack({\n          stack,\n          roleArn: options.roleArn,\n          toolkitStackName: this.toolkitStackName,\n          force: options.orphanFailedResources,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!stackResult.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        await rollbackTimer.endAs(ioHost, 'rollback');\n      } catch (e: any) {\n        await ioHost.notify(error(`\\n ❌  ${chalk.bold(stack.displayName)} failed: ${formatErrorMessage(e)}`, CODES.CDK_TOOLKIT_E6900));\n        throw new ToolkitError('Rollback failed (use --force to orphan failing resources)');\n      }\n    }\n    if (!anyRollbackable) {\n      throw new ToolkitError('No stacks were in a state that could be rolled back');\n    }\n  }\n\n  /**\n   * Destroy Action\n   *\n   * Destroys the selected Stacks.\n   */\n  public async destroy(cx: ICloudAssemblySource, options: DestroyOptions): Promise<void> {\n    const assembly = await this.assemblyFromSource(cx);\n    return this._destroy(assembly, 'destroy', options);\n  }\n\n  /**\n   * Helper to allow destroy being called as part of the deploy action.\n   */\n  private async _destroy(assembly: StackAssembly, action: 'deploy' | 'destroy', options: DestroyOptions): Promise<void> {\n    const ioHost = withAction(this.ioHost, action);\n    const synthTimer = Timer.start();\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    const stacks = await assembly.selectStacksV2(options.stacks).reversed();\n    await synthTimer.endAs(ioHost, 'synth');\n\n    const motivation = 'Destroying stacks is an irreversible action';\n    const question = `Are you sure you want to delete: ${chalk.red(stacks.hierarchicalIds.join(', '))}`;\n    const confirmed = await ioHost.requestResponse(confirm(CODES.CDK_TOOLKIT_I7010, question, motivation, true));\n    if (!confirmed) {\n      return ioHost.notify(error('Aborted by user', CODES.CDK_TOOLKIT_E7010));\n    }\n\n    const destroyTimer = Timer.start();\n    try {\n      for (const [index, stack] of stacks.stackArtifacts.entries()) {\n        await ioHost.notify(success(`${chalk.blue(stack.displayName)}: destroying... [${index + 1}/${stacks.stackCount}]`));\n        try {\n          const deployments = await this.deploymentsForAction(action);\n          await deployments.destroyStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n            ci: options.ci,\n          });\n          await ioHost.notify(success(`\\n ✅  ${chalk.blue(stack.displayName)}: ${action}ed`));\n        } catch (e) {\n          await ioHost.notify(error(`\\n ❌  ${chalk.blue(stack.displayName)}: ${action} failed ${e}`, CODES.CDK_TOOLKIT_E7900));\n          throw e;\n        }\n      }\n    } finally {\n      await destroyTimer.endAs(ioHost, 'destroy');\n    }\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private async validateStacksMetadata(stacks: StackCollection, ioHost: ActionAwareIoHost) {\n    // @TODO define these somewhere central\n    const code = (level: IoMessageLevel): IoMessageCode => {\n      switch (level) {\n        case 'error': return 'CDK_ASSEMBLY_E9999';\n        case 'warn': return 'CDK_ASSEMBLY_W9999';\n        default: return 'CDK_ASSEMBLY_I9999';\n      }\n    };\n    await stacks.validateMetadata(this.props.assemblyFailureAt, async (level, msg) => ioHost.notify({\n      time: new Date(),\n      level,\n      code: code(level),\n      message: `[${level} at ${msg.id}] ${msg.entry.data}`,\n      data: msg,\n    }));\n  }\n\n  /**\n   * Creates a Toolkit internal CloudAssembly from a CloudAssemblySource.\n   * @param assemblySource the source for the cloud assembly\n   * @param cache if the assembly should be cached, default: `true`\n   * @returns the CloudAssembly object\n   */\n  private async assemblyFromSource(assemblySource: ICloudAssemblySource, cache: boolean = true): Promise<StackAssembly> {\n    if (assemblySource instanceof StackAssembly) {\n      return assemblySource;\n    }\n\n    if (cache) {\n      return new StackAssembly(await new CachedCloudAssemblySource(assemblySource).produce());\n    }\n\n    return new StackAssembly(await assemblySource.produce());\n  }\n\n  /**\n   * Create a deployments class\n   */\n  private async deploymentsForAction(action: ToolkitAction): Promise<Deployments> {\n    return new Deployments({\n      sdkProvider: await this.sdkProvider(action),\n      toolkitStackName: this.toolkitStackName,\n      ioHost: this.ioHost as any, // @todo temporary while we have to separate IIoHost interfaces\n      action,\n    });\n  }\n\n  private async invokeDeployFromWatch(\n    assembly: StackAssembly,\n    options: WatchOptions,\n    cloudWatchLogMonitor?: CloudWatchLogEventMonitor,\n  ): Promise<void> {\n    // watch defaults hotswap to enabled\n    const hotswap = options.hotswap ?? HotswapMode.HOTSWAP_ONLY;\n    const deployOptions: ExtendedDeployOptions = {\n      ...options,\n      requireApproval: RequireApproval.NEVER,\n      cloudWatchLogMonitor,\n      hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${hotswap === HotswapMode.FULL_DEPLOYMENT ? 'off' : 'on'}`,\n    };\n\n    try {\n      await this._deploy(assembly, 'watch', deployOptions);\n    } catch {\n      // just continue - deploy will show the error\n    }\n  }\n}\n"]}
691
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit.js","sourceRoot":"","sources":["toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'node:path';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport * as chokidar from 'chokidar';\nimport * as fs from 'fs-extra';\nimport type { ToolkitServices } from './private';\nimport { assemblyFromSource } from './private';\nimport type { BootstrapEnvironments, BootstrapOptions } from '../actions/bootstrap';\nimport { BootstrapSource } from '../actions/bootstrap';\nimport { AssetBuildTime, type DeployOptions, RequireApproval } from '../actions/deploy';\nimport { type ExtendedDeployOptions, buildParameterMap, createHotswapPropertyOverrides, removePublishedAssets } from '../actions/deploy/private';\nimport { type DestroyOptions } from '../actions/destroy';\nimport { determinePermissionType } from '../actions/diff/private';\nimport { type ListOptions } from '../actions/list';\nimport { type RollbackOptions } from '../actions/rollback';\nimport { type SynthOptions } from '../actions/synth';\nimport type { WatchOptions } from '../actions/watch';\nimport { patternsArrayForWatch } from '../actions/watch/private';\nimport { type SdkConfig } from '../api/aws-auth';\nimport type { SuccessfulDeployStackResult, StackCollection, Concurrency, AssetBuildNode, AssetPublishNode, StackNode } from '../api/aws-cdk';\nimport { DEFAULT_TOOLKIT_STACK_NAME, Bootstrapper, SdkProvider, Deployments, HotswapMode, ResourceMigrator, tagsForStack, CliIoHost, WorkGraphBuilder, CloudWatchLogEventMonitor, findCloudWatchLogGroups } from '../api/aws-cdk';\nimport type { ICloudAssemblySource } from '../api/cloud-assembly';\nimport { StackSelectionStrategy } from '../api/cloud-assembly';\nimport type { StackAssembly } from '../api/cloud-assembly/private';\nimport { ALL_STACKS, CloudAssemblySourceBuilder, IdentityCloudAssemblySource } from '../api/cloud-assembly/private';\nimport type { IIoHost, IoMessageLevel } from '../api/io';\nimport { IO, SPAN, asSdkLogger, withoutColor, withoutEmojis, withTrimmedWhitespace } from '../api/io/private';\nimport type { IoHelper } from '../api/shared-private';\nimport { asIoHelper } from '../api/shared-private';\nimport type { AssemblyData, StackDetails, ToolkitAction } from '../api/shared-public';\nimport { ToolkitError } from '../api/shared-public';\nimport { obscureTemplate, serializeStructure, validateSnsTopicArn, formatTime, formatErrorMessage } from '../private/util';\nimport { pLimit } from '../util/concurrency';\n\nexport interface ToolkitOptions {\n  /**\n   * The IoHost implementation, handling the inline interactions between the Toolkit and an integration.\n   */\n  ioHost?: IIoHost;\n\n  /**\n   * Allow emojis in messages sent to the IoHost.\n   *\n   * @default true\n   */\n  emojis?: boolean;\n\n  /**\n   * Whether to allow ANSI colors and formatting in IoHost messages.\n   * Setting this value to `false` enforces that no color or style shows up\n   * in messages sent to the IoHost.\n   * Setting this value to true is a no-op; it is equivalent to the default.\n   *\n   * @default - detects color from the TTY status of the IoHost\n   */\n  color?: boolean;\n\n  /**\n   * Configuration options for the SDK.\n   */\n  sdkConfig?: SdkConfig;\n\n  /**\n   * Name of the toolkit stack to be used.\n   *\n   * @default \"CDKToolkit\"\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Fail Cloud Assemblies\n   *\n   * @default \"error\"\n   */\n  assemblyFailureAt?: 'error' | 'warn' | 'none';\n}\n\n/**\n * The AWS CDK Programmatic Toolkit\n */\nexport class Toolkit extends CloudAssemblySourceBuilder implements AsyncDisposable {\n  /**\n   * The toolkit stack name used for bootstrapping resources.\n   */\n  public readonly toolkitStackName: string;\n\n  /**\n   * The IoHost of this Toolkit\n   */\n  public readonly ioHost: IIoHost;\n  private _sdkProvider?: SdkProvider;\n\n  public constructor(private readonly props: ToolkitOptions = {}) {\n    super();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n\n    // Hacky way to re-use the global IoHost until we have fully removed the need for it\n    const globalIoHost = CliIoHost.instance();\n    if (props.ioHost) {\n      globalIoHost.registerIoHost(props.ioHost as any);\n    }\n    let ioHost = globalIoHost as IIoHost;\n    if (props.emojis === false) {\n      ioHost = withoutEmojis(ioHost);\n    }\n    if (props.color === false) {\n      ioHost = withoutColor(ioHost);\n    }\n    // After removing emojis and color, we might end up with floating whitespace at either end of the message\n    // This also removes newlines that we currently emit for CLI backwards compatibility.\n    this.ioHost = withTrimmedWhitespace(ioHost);\n  }\n\n  public async dispose(): Promise<void> {\n    // nothing to do yet\n  }\n\n  public async [Symbol.asyncDispose](): Promise<void> {\n    await this.dispose();\n  }\n\n  /**\n   * Access to the AWS SDK\n   */\n  private async sdkProvider(action: ToolkitAction): Promise<SdkProvider> {\n    // @todo this needs to be different instance per action\n    if (!this._sdkProvider) {\n      this._sdkProvider = await SdkProvider.withAwsCliCompatibleDefaults({\n        ...this.props.sdkConfig,\n        logger: asSdkLogger(asIoHelper(this.ioHost, action)),\n      });\n    }\n\n    return this._sdkProvider;\n  }\n\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   */\n  protected override async sourceBuilderServices(): Promise<ToolkitServices> {\n    return {\n      ioHelper: asIoHelper(this.ioHost, 'assembly'),\n      sdkProvider: await this.sdkProvider('assembly'),\n    };\n  }\n\n  /**\n   * Bootstrap Action\n   */\n  public async bootstrap(environments: BootstrapEnvironments, options: BootstrapOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'bootstrap');\n    const bootstrapEnvironments = await environments.getEnvironments();\n    const source = options.source ?? BootstrapSource.default();\n    const parameters = options.parameters;\n    const bootstrapper = new Bootstrapper(source, ioHelper);\n    const sdkProvider = await this.sdkProvider('bootstrap');\n    const limit = pLimit(20);\n\n    // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism\n    await Promise.all(bootstrapEnvironments.map((environment: cxapi.Environment, currentIdx) => limit(async () => {\n      const bootstrapSpan = await ioHelper.span(SPAN.BOOTSTRAP_SINGLE)\n        .begin(`${chalk.bold(environment.name)}: bootstrapping...`, {\n          total: bootstrapEnvironments.length,\n          current: currentIdx+1,\n          environment,\n        });\n\n      try {\n        const bootstrapResult = await bootstrapper.bootstrapEnvironment(\n          environment,\n          sdkProvider,\n          {\n            ...options,\n            toolkitStackName: this.toolkitStackName,\n            source,\n            parameters: parameters?.parameters,\n            usePreviousParameters: parameters?.keepExistingParameters,\n          },\n        );\n        const message = bootstrapResult.noOp\n          ? ` ✅  ${environment.name} (no changes)`\n          : ` ✅  ${environment.name}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I9900.msg(chalk.green('\\n' + message), { environment }));\n        await bootstrapSpan.end();\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E9900.msg(`\\n ❌  ${chalk.bold(environment.name)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw e;\n      }\n    })));\n  }\n\n  /**\n   * Synth Action\n   */\n  public async synth(cx: ICloudAssemblySource, options: SynthOptions = {}): Promise<ICloudAssemblySource> {\n    const ioHelper = asIoHelper(this.ioHost, 'synth');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const assembly = await assemblyFromSource(cx);\n    const stacks = assembly.selectStacksV2(selectStacks);\n    const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];\n    await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHelper);\n    await synthSpan.end();\n\n    // if we have a single stack, print it to STDOUT\n    const message = `Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`;\n    const assemblyData: AssemblyData = {\n      assemblyDirectory: stacks.assembly.directory,\n      stacksCount: stacks.stackCount,\n      stackIds: stacks.hierarchicalIds,\n    };\n\n    if (stacks.stackCount === 1) {\n      const firstStack = stacks.firstStack!;\n      const template = firstStack.template;\n      const obscuredTemplate = obscureTemplate(template);\n      await ioHelper.notify(IO.CDK_TOOLKIT_I1901.msg(message, {\n        ...assemblyData,\n        stack: {\n          stackName: firstStack.stackName,\n          hierarchicalId: firstStack.hierarchicalId,\n          template,\n          stringifiedJson: serializeStructure(obscuredTemplate, true),\n          stringifiedYaml: serializeStructure(obscuredTemplate, false),\n        },\n      }));\n    } else {\n      // not outputting template to stdout, let's explain things to the user a little bit...\n      await ioHelper.notify(IO.CDK_TOOLKIT_I1902.msg(chalk.green(message), assemblyData));\n      await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));\n    }\n\n    return new IdentityCloudAssemblySource(assembly.assembly);\n  }\n\n  /**\n   * List Action\n   *\n   * List selected stacks and their dependencies\n   */\n  public async list(cx: ICloudAssemblySource, options: ListOptions = {}): Promise<StackDetails[]> {\n    const ioHelper = asIoHelper(this.ioHost, 'list');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const assembly = await assemblyFromSource(cx);\n    const stackCollection = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const stacks = stackCollection.withDependencies();\n    const message = stacks.map(s => s.id).join('\\n');\n\n    await ioHelper.notify(IO.CDK_TOOLKIT_I2901.msg(message, { stacks }));\n    return stacks;\n  }\n\n  /**\n   * Deploy Action\n   *\n   * Deploys the selected stacks into an AWS account\n   */\n  public async deploy(cx: ICloudAssemblySource, options: DeployOptions = {}): Promise<void> {\n    const assembly = await assemblyFromSource(cx);\n    return this._deploy(assembly, 'deploy', options);\n  }\n\n  /**\n   * Helper to allow deploy being called as part of the watch action.\n   */\n  private async _deploy(assembly: StackAssembly, action: 'deploy' | 'watch', options: ExtendedDeployOptions = {}) {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const stackCollection = assembly.selectStacksV2(selectStacks);\n    await this.validateStacksMetadata(stackCollection, ioHelper);\n    const synthDuration = await synthSpan.end();\n\n    if (stackCollection.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E5001.msg('This app contains no stacks'));\n      return;\n    }\n\n    const deployments = await this.deploymentsForAction('deploy');\n    const migrator = new ResourceMigrator({ deployments, ioHelper });\n\n    await migrator.tryMigrateResources(stackCollection, options);\n\n    const parameterMap = buildParameterMap(options.parameters?.parameters);\n\n    const hotswapMode = options.hotswap ?? HotswapMode.FULL_DEPLOYMENT;\n    if (hotswapMode !== HotswapMode.FULL_DEPLOYMENT) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_W5400.msg([\n        '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',\n        '⚠️ They should only be used for development - never use them for your production Stacks!',\n      ].join('\\n')));\n    }\n\n    const stacks = stackCollection.stackArtifacts;\n    const stackOutputs: { [key: string]: any } = {};\n    const outputsFile = options.outputsFile;\n\n    const buildAsset = async (assetNode: AssetBuildNode) => {\n      const buildAssetSpan = await ioHelper.span(SPAN.BUILD_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.buildSingleAsset(\n        assetNode.assetManifestArtifact,\n        assetNode.assetManifest,\n        assetNode.asset,\n        {\n          stack: assetNode.parentStack,\n          roleArn: options.roleArn,\n          stackName: assetNode.parentStack.stackName,\n        },\n      );\n      await buildAssetSpan.end();\n    };\n\n    const publishAsset = async (assetNode: AssetPublishNode) => {\n      const publishAssetSpan = await ioHelper.span(SPAN.PUBLISH_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {\n        stack: assetNode.parentStack,\n        roleArn: options.roleArn,\n        stackName: assetNode.parentStack.stackName,\n        forcePublish: options.force,\n      });\n      await publishAssetSpan.end();\n    };\n\n    const deployStack = async (stackNode: StackNode) => {\n      const stack = stackNode.stack;\n      if (stackCollection.stackCount !== 1) {\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(chalk.bold(stack.displayName)));\n      }\n\n      if (!stack.environment) {\n        throw new ToolkitError(\n          `Stack ${stack.displayName} does not define an environment, and AWS credentials could not be obtained from standard locations or no region was configured.`,\n        );\n      }\n\n      // The generated stack has no resources\n      if (Object.keys(stack.template.Resources || {}).length === 0) {\n        // stack is empty and doesn't exist => do nothing\n        const stackExists = await deployments.stackExists({ stack });\n        if (!stackExists) {\n          return ioHelper.notify(IO.CDK_TOOLKIT_W5021.msg(`${chalk.bold(stack.displayName)}: stack has no resources, skipping deployment.`));\n        }\n\n        // stack is empty, but exists => delete\n        await ioHelper.notify(IO.CDK_TOOLKIT_W5022.msg(`${chalk.bold(stack.displayName)}: stack has no resources, deleting existing stack.`));\n        await this._destroy(assembly, 'deploy', {\n          stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n          roleArn: options.roleArn,\n          ci: options.ci,\n        });\n\n        return;\n      }\n\n      const currentTemplate = await deployments.readCurrentTemplate(stack);\n      const permissionChangeType = determinePermissionType(currentTemplate, stack);\n      const deployMotivation = '\"--require-approval\" is enabled and stack includes security-sensitive updates.';\n      const deployQuestion = `${deployMotivation}\\nDo you wish to deploy these changes`;\n      const deployConfirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5060.req(deployQuestion, {\n        motivation: deployMotivation,\n        concurrency,\n        permissionChangeType,\n      }));\n      if (!deployConfirmed) {\n        throw new ToolkitError('Aborted by user');\n      }\n\n      // Following are the same semantics we apply with respect to Notification ARNs (dictated by the SDK)\n      //\n      //  - undefined  =>  cdk ignores it, as if it wasn't supported (allows external management).\n      //  - []:        =>  cdk manages it, and the user wants to wipe it out.\n      //  - ['arn-1']  =>  cdk manages it, and the user wants to set it to ['arn-1'].\n      const notificationArns = (!!options.notificationArns || !!stack.notificationArns)\n        ? (options.notificationArns ?? []).concat(stack.notificationArns ?? [])\n        : undefined;\n\n      for (const notificationArn of notificationArns ?? []) {\n        if (!validateSnsTopicArn(notificationArn)) {\n          throw new ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);\n        }\n      }\n\n      const stackIndex = stacks.indexOf(stack) + 1;\n      const deploySpan = await ioHelper.span(SPAN.DEPLOY_STACK)\n        .begin(`${chalk.bold(stack.displayName)}: deploying... [${stackIndex}/${stackCollection.stackCount}]`, {\n          total: stackCollection.stackCount,\n          current: stackIndex,\n          stack,\n        });\n\n      let tags = options.tags;\n      if (!tags || tags.length === 0) {\n        tags = tagsForStack(stack);\n      }\n\n      let deployDuration;\n      try {\n        let deployResult: SuccessfulDeployStackResult | undefined;\n\n        let rollback = options.rollback;\n        let iteration = 0;\n        while (!deployResult) {\n          if (++iteration > 2) {\n            throw new ToolkitError('This loop should have stabilized in 2 iterations, but didn\\'t. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose');\n          }\n\n          const r = await deployments.deployStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n            toolkitStackName: this.toolkitStackName,\n            reuseAssets: options.reuseAssets,\n            notificationArns,\n            tags,\n            deploymentMethod: options.deploymentMethod,\n            force: options.force,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.parameters?.keepExistingParameters,\n            rollback,\n            hotswap: hotswapMode,\n            extraUserAgent: options.extraUserAgent,\n            hotswapPropertyOverrides: options.hotswapProperties ? createHotswapPropertyOverrides(options.hotswapProperties) : undefined,\n            assetParallelism: options.assetParallelism,\n          });\n\n          switch (r.type) {\n            case 'did-deploy-stack':\n              deployResult = r;\n              break;\n\n            case 'failpaused-need-rollback-first': {\n              const motivation = r.reason === 'replacement'\n                ? `Stack is in a paused fail state (${r.status}) and change includes a replacement which cannot be deployed with \"--no-rollback\"`\n                : `Stack is in a paused fail state (${r.status}) and command line arguments do not include \"--no-rollback\"`;\n              const question = `${motivation}. Perform a regular deployment`;\n\n              if (options.force) {\n                await ioHelper.notify(IO.DEFAULT_TOOLKIT_WARN.msg(`${motivation}. Rolling back first (--force).`));\n              } else {\n                const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                  motivation,\n                  concurrency,\n                }));\n                if (!confirmed) {\n                  throw new ToolkitError('Aborted by user');\n                }\n              }\n\n              // Perform a rollback\n              await this._rollback(assembly, action, {\n                stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n                orphanFailedResources: options.force,\n              });\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            case 'replacement-requires-rollback': {\n              const motivation = 'Change includes a replacement which cannot be deployed with \"--no-rollback\"';\n              const question = `${motivation}. Perform a regular deployment`;\n\n              // @todo no force here\n              if (options.force) {\n                await ioHelper.notify(IO.DEFAULT_TOOLKIT_WARN.msg(`${motivation}. Proceeding with regular deployment (--force).`));\n              } else {\n                const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                  motivation,\n                  concurrency,\n                }));\n                if (!confirmed) {\n                  throw new ToolkitError('Aborted by user');\n                }\n              }\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            default:\n              throw new ToolkitError(`Unexpected result type from deployStack: ${JSON.stringify(r)}. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose`);\n          }\n        }\n\n        const message = deployResult.noOp\n          ? ` ✅  ${stack.displayName} (no changes)`\n          : ` ✅  ${stack.displayName}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5900.msg(chalk.green('\\n' + message), deployResult));\n        deployDuration = await deploySpan.timing(IO.CDK_TOOLKIT_I5000);\n\n        if (Object.keys(deployResult.outputs).length > 0) {\n          const buffer = ['Outputs:'];\n          stackOutputs[stack.stackName] = deployResult.outputs;\n\n          for (const name of Object.keys(deployResult.outputs).sort()) {\n            const value = deployResult.outputs[name];\n            buffer.push(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);\n          }\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(buffer.join('\\n')));\n        }\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(`Stack ARN:\\n${deployResult.stackArn}`));\n      } catch (e: any) {\n        // It has to be exactly this string because an integration test tests for\n        // \"bold(stackname) failed: ResourceNotReady: <error>\"\n        throw new ToolkitError(\n          [`❌  ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), e.message].join(' '),\n        );\n      } finally {\n        if (options.traceLogs) {\n          // deploy calls that originate from watch will come with their own cloudWatchLogMonitor\n          const cloudWatchLogMonitor = options.cloudWatchLogMonitor ?? new CloudWatchLogEventMonitor({ ioHelper });\n          const foundLogGroupsResult = await findCloudWatchLogGroups(await this.sdkProvider('deploy'), ioHelper, stack);\n          cloudWatchLogMonitor.addLogGroups(\n            foundLogGroupsResult.env,\n            foundLogGroupsResult.sdk,\n            foundLogGroupsResult.logGroupNames,\n          );\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5031.msg(`The following log groups are added: ${foundLogGroupsResult.logGroupNames}`));\n        }\n\n        // If an outputs file has been specified, create the file path and write stack outputs to it once.\n        // Outputs are written after all stacks have been deployed. If a stack deployment fails,\n        // all of the outputs from successfully deployed stacks before the failure will still be written.\n        if (outputsFile) {\n          fs.ensureFileSync(outputsFile);\n          await fs.writeJson(outputsFile, stackOutputs, {\n            spaces: 2,\n            encoding: 'utf8',\n          });\n        }\n      }\n      const duration = synthDuration.asMs + (deployDuration?.asMs ?? 0);\n      await deploySpan.end(`\\n✨  Total time: ${formatTime(duration)}s\\n`, { duration });\n    };\n\n    const assetBuildTime = options.assetBuildTime ?? AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const prebuildAssets = assetBuildTime === AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const concurrency = options.concurrency || 1;\n\n    const stacksAndTheirAssetManifests = stacks.flatMap((stack) => [\n      stack,\n      ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),\n    ]);\n    const workGraph = new WorkGraphBuilder(ioHelper, prebuildAssets).build(stacksAndTheirAssetManifests);\n\n    // Unless we are running with '--force', skip already published assets\n    if (!options.force) {\n      await removePublishedAssets(workGraph, deployments, options);\n    }\n\n    const graphConcurrency: Concurrency = {\n      'stack': concurrency,\n      'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds\n      'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable\n    };\n\n    await workGraph.doParallel(graphConcurrency, {\n      deployStack,\n      buildAsset,\n      publishAsset,\n    });\n  }\n\n  /**\n   * Watch Action\n   *\n   * Continuously observe project files and deploy the selected stacks automatically when changes are detected.\n   * Implies hotswap deployments.\n   */\n  public async watch(cx: ICloudAssemblySource, options: WatchOptions): Promise<void> {\n    const assembly = await assemblyFromSource(cx, false);\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    const rootDir = options.watchDir ?? process.cwd();\n\n    if (options.include === undefined && options.exclude === undefined) {\n      throw new ToolkitError(\n        \"Cannot use the 'watch' command without specifying at least one directory to monitor. \" +\n          'Make sure to add a \"watch\" key to your cdk.json',\n      );\n    }\n\n    // For the \"include\" subkey under the \"watch\" key, the behavior is:\n    // 1. No \"watch\" setting? We error out.\n    // 2. \"watch\" setting without an \"include\" key? We default to observing \"./**\".\n    // 3. \"watch\" setting with an empty \"include\" key? We default to observing \"./**\".\n    // 4. Non-empty \"include\" key? Just use the \"include\" key.\n    const watchIncludes = patternsArrayForWatch(options.include, {\n      rootDir,\n      returnRootDirIfEmpty: true,\n    });\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outdir = options.outdir ?? 'cdk.out';\n    const watchExcludes = patternsArrayForWatch(options.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    }).concat(`${outdir}/**`, '**/.*', '**/.*/**', '**/node_modules/**');\n\n    // Print some debug information on computed settings\n    await ioHelper.notify(IO.CDK_TOOLKIT_I5310.msg([\n      `root directory used for 'watch' is: ${rootDir}`,\n      `'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`,\n      `'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`,\n    ].join('\\n'), {\n      watchDir: rootDir,\n      includes: watchIncludes,\n      excludes: watchExcludes,\n    }));\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    type LatchState = 'pre-ready' | 'open' | 'deploying' | 'queued';\n    let latch: LatchState = 'pre-ready';\n\n    const cloudWatchLogMonitor = options.traceLogs ? new CloudWatchLogEventMonitor({ ioHelper }) : undefined;\n    const deployAndWatch = async () => {\n      latch = 'deploying' as LatchState;\n      await cloudWatchLogMonitor?.deactivate();\n\n      await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while (latch === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5315.msg(\"Detected file changes during deployment. Invoking 'cdk deploy' again\"));\n        await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n      }\n      latch = 'open';\n      await cloudWatchLogMonitor?.activate();\n    };\n\n    chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_DEBUG.msg(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\"));\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5314.msg(\"Triggering initial 'cdk deploy'\"));\n        await deployAndWatch();\n      })\n      .on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath: string) => {\n        const watchEvent = {\n          event,\n          path: filePath,\n        };\n        if (latch === 'pre-ready') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5311.msg(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`, watchEvent));\n        } else if (latch === 'open') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5312.msg(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`, watchEvent));\n          await deployAndWatch();\n        } else {\n          // this means latch is either 'deploying' or 'queued'\n          latch = 'queued';\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5313.msg(\n            `Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`,\n            watchEvent,\n          ));\n        }\n      });\n  }\n\n  /**\n   * Rollback Action\n   *\n   * Rolls back the selected stacks.\n   */\n  public async rollback(cx: ICloudAssemblySource, options: RollbackOptions): Promise<void> {\n    const assembly = await assemblyFromSource(cx);\n    return this._rollback(assembly, 'rollback', options);\n  }\n\n  /**\n   * Helper to allow rollback being called as part of the deploy or watch action.\n   */\n  private async _rollback(assembly: StackAssembly, action: 'rollback' | 'deploy' | 'watch', options: RollbackOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    const stacks = assembly.selectStacksV2(options.stacks);\n    await this.validateStacksMetadata(stacks, ioHelper);\n    await synthSpan.end();\n\n    if (stacks.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E6001.msg('No stacks selected'));\n      return;\n    }\n\n    let anyRollbackable = false;\n\n    for (const [index, stack] of stacks.stackArtifacts.entries()) {\n      const rollbackSpan = await ioHelper.span(SPAN.ROLLBACK_STACK).begin(`Rolling back ${chalk.bold(stack.displayName)}`, {\n        total: stacks.stackCount,\n        current: index + 1,\n        stack,\n      });\n      const deployments = await this.deploymentsForAction('rollback');\n      try {\n        const stackResult = await deployments.rollbackStack({\n          stack,\n          roleArn: options.roleArn,\n          toolkitStackName: this.toolkitStackName,\n          force: options.orphanFailedResources,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!stackResult.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        await rollbackSpan.end();\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E6900.msg(`\\n ❌  ${chalk.bold(stack.displayName)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw new ToolkitError('Rollback failed (use --force to orphan failing resources)');\n      }\n    }\n    if (!anyRollbackable) {\n      throw new ToolkitError('No stacks were in a state that could be rolled back');\n    }\n  }\n\n  /**\n   * Destroy Action\n   *\n   * Destroys the selected Stacks.\n   */\n  public async destroy(cx: ICloudAssemblySource, options: DestroyOptions): Promise<void> {\n    const assembly = await assemblyFromSource(cx);\n    return this._destroy(assembly, 'destroy', options);\n  }\n\n  /**\n   * Helper to allow destroy being called as part of the deploy action.\n   */\n  private async _destroy(assembly: StackAssembly, action: 'deploy' | 'destroy', options: DestroyOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    const stacks = await assembly.selectStacksV2(options.stacks).reversed();\n    await synthSpan.end();\n\n    const motivation = 'Destroying stacks is an irreversible action';\n    const question = `Are you sure you want to delete: ${chalk.red(stacks.hierarchicalIds.join(', '))}`;\n    const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I7010.req(question, { motivation }));\n    if (!confirmed) {\n      return ioHelper.notify(IO.CDK_TOOLKIT_E7010.msg('Aborted by user'));\n    }\n\n    const destroySpan = await ioHelper.span(SPAN.DESTROY_ACTION).begin({\n      stacks: stacks.stackArtifacts,\n    });\n    try {\n      for (const [index, stack] of stacks.stackArtifacts.entries()) {\n        try {\n          const singleDestroySpan = await ioHelper.span(SPAN.DESTROY_STACK)\n            .begin(chalk.green(`${chalk.blue(stack.displayName)}: destroying... [${index + 1}/${stacks.stackCount}]`), {\n              total: stacks.stackCount,\n              current: index + 1,\n              stack,\n            });\n          const deployments = await this.deploymentsForAction(action);\n          await deployments.destroyStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n          });\n          await ioHelper.notify(IO.CDK_TOOLKIT_I7900.msg(chalk.green(`\\n ✅  ${chalk.blue(stack.displayName)}: ${action}ed`), stack));\n          await singleDestroySpan.end();\n        } catch (e: any) {\n          await ioHelper.notify(IO.CDK_TOOLKIT_E7900.msg(`\\n ❌  ${chalk.blue(stack.displayName)}: ${action} failed ${e}`, { error: e }));\n          throw e;\n        }\n      }\n    } finally {\n      await destroySpan.end();\n    }\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private async validateStacksMetadata(stacks: StackCollection, ioHost: IoHelper) {\n    const builder = (level: IoMessageLevel) => {\n      switch (level) {\n        case 'error': return IO.CDK_ASSEMBLY_E9999;\n        case 'warn': return IO.CDK_ASSEMBLY_W9999;\n        default: return IO.CDK_ASSEMBLY_I9999;\n      }\n    };\n    await stacks.validateMetadata(\n      this.props.assemblyFailureAt,\n      async (level, msg) => ioHost.notify(builder(level).msg(`[${level} at ${msg.id}] ${msg.entry.data}`, msg)),\n    );\n  }\n\n  /**\n   * Create a deployments class\n   */\n  private async deploymentsForAction(action: ToolkitAction): Promise<Deployments> {\n    return new Deployments({\n      sdkProvider: await this.sdkProvider(action),\n      toolkitStackName: this.toolkitStackName,\n      ioHelper: asIoHelper(this.ioHost, action),\n    });\n  }\n\n  private async invokeDeployFromWatch(\n    assembly: StackAssembly,\n    options: WatchOptions,\n    cloudWatchLogMonitor?: CloudWatchLogEventMonitor,\n  ): Promise<void> {\n    // watch defaults hotswap to enabled\n    const hotswap = options.hotswap ?? HotswapMode.HOTSWAP_ONLY;\n    const deployOptions: ExtendedDeployOptions = {\n      ...options,\n      requireApproval: RequireApproval.NEVER,\n      cloudWatchLogMonitor,\n      hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${hotswap === HotswapMode.FULL_DEPLOYMENT ? 'off' : 'on'}`,\n    };\n\n    try {\n      await this._deploy(assembly, 'watch', deployOptions);\n    } catch {\n      // just continue - deploy will show the error\n    }\n  }\n}\n"]}