@aws-cdk/toolkit-lib 0.3.6 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (202) hide show
  1. package/README.md +5 -0
  2. package/api-extractor.json +1 -1
  3. package/build-info.json +2 -2
  4. package/db.json.gz +0 -0
  5. package/lib/actions/deploy/index.d.ts +106 -34
  6. package/lib/actions/deploy/index.js +2 -17
  7. package/lib/actions/deploy/private/deploy-options.d.ts +1 -90
  8. package/lib/actions/deploy/private/deploy-options.js +1 -1
  9. package/lib/actions/deploy/private/helpers.d.ts +1 -6
  10. package/lib/actions/deploy/private/helpers.js +1 -9
  11. package/lib/actions/destroy/index.d.ts +4 -2
  12. package/lib/actions/destroy/index.js +1 -1
  13. package/lib/actions/diff/index.d.ts +4 -10
  14. package/lib/actions/diff/index.js +1 -1
  15. package/lib/actions/diff/private/helpers.d.ts +2 -1
  16. package/lib/actions/diff/private/helpers.js +6 -6
  17. package/lib/actions/drift/index.d.ts +50 -0
  18. package/lib/actions/drift/index.js +3 -0
  19. package/lib/actions/index.d.ts +1 -0
  20. package/lib/actions/index.js +2 -1
  21. package/lib/actions/rollback/index.d.ts +3 -1
  22. package/lib/actions/rollback/index.js +1 -1
  23. package/lib/actions/watch/index.d.ts +7 -1
  24. package/lib/actions/watch/index.js +1 -1
  25. package/lib/api/aws-auth/awscli-compatible.d.ts +5 -5
  26. package/lib/api/aws-auth/awscli-compatible.js +13 -17
  27. package/lib/api/aws-auth/base-credentials.d.ts +109 -0
  28. package/lib/api/aws-auth/base-credentials.js +79 -0
  29. package/lib/api/aws-auth/credential-plugins.js +3 -3
  30. package/lib/api/aws-auth/index.d.ts +1 -0
  31. package/lib/api/aws-auth/index.js +2 -1
  32. package/lib/api/aws-auth/private/index.d.ts +0 -1
  33. package/lib/api/aws-auth/private/index.js +1 -2
  34. package/lib/api/aws-auth/sdk-provider.d.ts +23 -27
  35. package/lib/api/aws-auth/sdk-provider.js +19 -16
  36. package/lib/api/aws-auth/sdk.d.ts +9 -5
  37. package/lib/api/aws-auth/sdk.js +6 -3
  38. package/lib/api/aws-auth/types.d.ts +7 -87
  39. package/lib/api/aws-auth/types.js +1 -74
  40. package/lib/api/bootstrap/bootstrap-environment.d.ts +1 -1
  41. package/lib/api/bootstrap/bootstrap-environment.js +8 -9
  42. package/lib/api/bootstrap/deploy-bootstrap.d.ts +1 -1
  43. package/lib/api/bootstrap/deploy-bootstrap.js +4 -5
  44. package/lib/api/cloud-assembly/context-store.d.ts +78 -0
  45. package/lib/api/cloud-assembly/context-store.js +160 -0
  46. package/lib/api/cloud-assembly/environment.d.ts +19 -16
  47. package/lib/api/cloud-assembly/environment.js +21 -12
  48. package/lib/api/cloud-assembly/index.d.ts +1 -0
  49. package/lib/api/cloud-assembly/index.js +2 -1
  50. package/lib/api/cloud-assembly/private/context-aware-source.d.ts +3 -10
  51. package/lib/api/cloud-assembly/private/context-aware-source.js +6 -11
  52. package/lib/api/cloud-assembly/private/exec.d.ts +1 -1
  53. package/lib/api/cloud-assembly/private/exec.js +2 -5
  54. package/lib/api/cloud-assembly/private/helpers.d.ts +9 -0
  55. package/lib/api/cloud-assembly/private/helpers.js +44 -0
  56. package/lib/api/cloud-assembly/private/index.d.ts +0 -1
  57. package/lib/api/cloud-assembly/private/index.js +1 -2
  58. package/lib/api/cloud-assembly/private/prepare-source.d.ts +27 -16
  59. package/lib/api/cloud-assembly/private/prepare-source.js +49 -46
  60. package/lib/api/cloud-assembly/private/stack-assembly.d.ts +1 -1
  61. package/lib/api/cloud-assembly/private/stack-assembly.js +1 -1
  62. package/lib/api/cloud-assembly/source-builder.d.ts +142 -14
  63. package/lib/api/cloud-assembly/source-builder.js +307 -1
  64. package/lib/api/cloud-assembly/stack-assembly.js +3 -4
  65. package/lib/api/cloudformation/template-body-parameter.d.ts +1 -1
  66. package/lib/api/cloudformation/template-body-parameter.js +4 -5
  67. package/lib/api/context.d.ts +1 -1
  68. package/lib/api/context.js +1 -1
  69. package/lib/api/deployments/asset-publishing.js +15 -16
  70. package/lib/api/deployments/assets.d.ts +1 -1
  71. package/lib/api/deployments/assets.js +4 -5
  72. package/lib/api/deployments/cfn-api.d.ts +1 -1
  73. package/lib/api/deployments/cfn-api.js +14 -15
  74. package/lib/api/deployments/checks.d.ts +1 -1
  75. package/lib/api/deployments/checks.js +3 -4
  76. package/lib/api/deployments/deploy-stack.d.ts +14 -3
  77. package/lib/api/deployments/deploy-stack.js +73 -49
  78. package/lib/api/deployments/deployments.d.ts +13 -2
  79. package/lib/api/deployments/deployments.js +10 -9
  80. package/lib/api/deployments/index.d.ts +0 -1
  81. package/lib/api/deployments/index.js +1 -2
  82. package/lib/api/diff/diff-formatter.d.ts +3 -9
  83. package/lib/api/diff/diff-formatter.js +7 -14
  84. package/lib/api/drift/drift-formatter.d.ts +81 -0
  85. package/lib/api/drift/drift-formatter.js +201 -0
  86. package/lib/api/drift/drift.d.ts +12 -0
  87. package/lib/api/drift/drift.js +63 -0
  88. package/lib/api/drift/index.d.ts +2 -0
  89. package/lib/api/{io/private/testing → drift}/index.js +3 -3
  90. package/lib/api/environment/environment-access.d.ts +1 -1
  91. package/lib/api/environment/environment-access.js +3 -4
  92. package/lib/api/environment/environment-resources.d.ts +1 -1
  93. package/lib/api/environment/environment-resources.js +5 -6
  94. package/lib/api/garbage-collection/garbage-collector.js +44 -35
  95. package/lib/api/garbage-collection/progress-printer.d.ts +1 -1
  96. package/lib/api/garbage-collection/progress-printer.js +3 -4
  97. package/lib/api/garbage-collection/stack-refresh.d.ts +1 -1
  98. package/lib/api/garbage-collection/stack-refresh.js +3 -4
  99. package/lib/api/hotswap/common.d.ts +9 -4
  100. package/lib/api/hotswap/common.js +11 -4
  101. package/lib/api/hotswap/ecs-services.js +2 -2
  102. package/lib/api/hotswap/hotswap-deployments.js +3 -3
  103. package/lib/api/index.d.ts +1 -1
  104. package/lib/api/index.js +2 -2
  105. package/lib/api/io/io-host.d.ts +15 -1
  106. package/lib/api/io/io-host.js +1 -1
  107. package/lib/api/io/io-message.d.ts +7 -10
  108. package/lib/api/io/io-message.js +1 -1
  109. package/lib/api/io/private/index.d.ts +0 -1
  110. package/lib/api/io/private/index.js +1 -2
  111. package/lib/api/io/private/io-default-messages.d.ts +14 -10
  112. package/lib/api/io/private/io-default-messages.js +30 -28
  113. package/lib/api/io/private/io-helper.d.ts +9 -4
  114. package/lib/api/io/private/io-helper.js +24 -14
  115. package/lib/api/io/private/message-maker.d.ts +5 -1
  116. package/lib/api/io/private/message-maker.js +21 -1
  117. package/lib/api/io/private/messages.d.ts +20 -15
  118. package/lib/api/io/private/messages.js +57 -54
  119. package/lib/api/io/private/span.d.ts +18 -11
  120. package/lib/api/io/private/span.js +60 -42
  121. package/lib/api/io/toolkit-action.d.ts +1 -1
  122. package/lib/api/io/toolkit-action.js +1 -1
  123. package/lib/api/logs-monitor/find-cloudwatch-logs.js +2 -3
  124. package/lib/api/notices/cached-data-source.d.ts +3 -3
  125. package/lib/api/notices/cached-data-source.js +9 -8
  126. package/lib/api/notices/filter.d.ts +4 -4
  127. package/lib/api/notices/filter.js +27 -25
  128. package/lib/api/notices/notices.d.ts +18 -6
  129. package/lib/api/notices/notices.js +5 -7
  130. package/lib/api/notices/web-data-source.d.ts +30 -3
  131. package/lib/api/notices/web-data-source.js +37 -10
  132. package/lib/api/plugin/plugin.d.ts +1 -1
  133. package/lib/api/plugin/plugin.js +3 -3
  134. package/lib/api/refactoring/cloudformation.d.ts +7 -5
  135. package/lib/api/refactoring/cloudformation.js +1 -1
  136. package/lib/api/refactoring/digest.d.ts +2 -2
  137. package/lib/api/refactoring/digest.js +25 -61
  138. package/lib/api/refactoring/graph.d.ts +15 -0
  139. package/lib/api/refactoring/graph.js +108 -0
  140. package/lib/api/refactoring/index.js +12 -6
  141. package/lib/api/resource-import/importer.d.ts +2 -1
  142. package/lib/api/resource-import/importer.js +28 -28
  143. package/lib/api/resource-import/migrator.js +4 -4
  144. package/lib/api/toolkit-info.d.ts +1 -1
  145. package/lib/api/toolkit-info.js +3 -4
  146. package/lib/api/tree.d.ts +1 -1
  147. package/lib/api/tree.js +3 -3
  148. package/lib/api/work-graph/work-graph.d.ts +1 -1
  149. package/lib/api/work-graph/work-graph.js +4 -5
  150. package/lib/context-providers/index.d.ts +1 -2
  151. package/lib/context-providers/index.js +6 -4
  152. package/lib/index_bg.wasm +0 -0
  153. package/lib/payloads/context.d.ts +0 -1
  154. package/lib/payloads/context.js +1 -1
  155. package/lib/payloads/deploy.d.ts +2 -2
  156. package/lib/payloads/deploy.js +1 -1
  157. package/lib/payloads/destroy.d.ts +3 -3
  158. package/lib/payloads/destroy.js +1 -1
  159. package/lib/payloads/diff.d.ts +46 -5
  160. package/lib/payloads/diff.js +1 -1
  161. package/lib/payloads/drift.d.ts +12 -0
  162. package/lib/payloads/drift.js +3 -0
  163. package/lib/payloads/gc.d.ts +12 -0
  164. package/lib/payloads/gc.js +3 -0
  165. package/lib/payloads/import.d.ts +45 -0
  166. package/lib/payloads/import.js +3 -0
  167. package/lib/payloads/index.d.ts +4 -1
  168. package/lib/payloads/index.js +5 -2
  169. package/lib/payloads/rollback.d.ts +2 -2
  170. package/lib/payloads/rollback.js +1 -1
  171. package/lib/payloads/{sdk-trace.d.ts → sdk.d.ts} +10 -0
  172. package/lib/payloads/sdk.js +3 -0
  173. package/lib/payloads/stack-activity.d.ts +2 -2
  174. package/lib/payloads/stack-activity.js +1 -1
  175. package/lib/payloads/types.d.ts +21 -0
  176. package/lib/payloads/types.js +1 -1
  177. package/lib/toolkit/non-interactive-io-host.js +2 -2
  178. package/lib/toolkit/private/index.d.ts +2 -1
  179. package/lib/toolkit/private/index.js +1 -1
  180. package/lib/toolkit/toolkit.d.ts +14 -7
  181. package/lib/toolkit/toolkit.js +180 -103
  182. package/lib/util/objects.d.ts +4 -0
  183. package/lib/util/objects.js +8 -1
  184. package/package.json +18 -21
  185. package/lib/actions/import/index.d.ts +0 -21
  186. package/lib/actions/import/index.js +0 -3
  187. package/lib/api/aws-auth/proxy-agent.d.ts +0 -13
  188. package/lib/api/aws-auth/proxy-agent.js +0 -54
  189. package/lib/api/cloud-assembly/private/source-builder.d.ts +0 -52
  190. package/lib/api/cloud-assembly/private/source-builder.js +0 -262
  191. package/lib/api/deployments/deployment-method.d.ts +0 -24
  192. package/lib/api/deployments/deployment-method.js +0 -3
  193. package/lib/api/io/private/testing/fake-io-host.d.ts +0 -28
  194. package/lib/api/io/private/testing/fake-io-host.js +0 -41
  195. package/lib/api/io/private/testing/index.d.ts +0 -2
  196. package/lib/api/io/private/testing/test-io-host.d.ts +0 -27
  197. package/lib/api/io/private/testing/test-io-host.js +0 -61
  198. package/lib/api/require-approval.d.ts +0 -17
  199. package/lib/api/require-approval.js +0 -22
  200. package/lib/api/shared-private.d.ts +0 -8
  201. package/lib/api/shared-private.js +0 -32
  202. package/lib/payloads/sdk-trace.js +0 -3
@@ -73,8 +73,11 @@ const private_5 = require("../api/aws-auth/private");
73
73
  const bootstrap_2 = require("../api/bootstrap");
74
74
  const cloud_assembly_1 = require("../api/cloud-assembly");
75
75
  const private_6 = require("../api/cloud-assembly/private");
76
+ const source_builder_1 = require("../api/cloud-assembly/source-builder");
76
77
  const deployments_1 = require("../api/deployments");
77
78
  const diff_1 = require("../api/diff");
79
+ const drift_1 = require("../api/drift");
80
+ const drift_formatter_1 = require("../api/drift/drift-formatter");
78
81
  const private_7 = require("../api/io/private");
79
82
  const logs_monitor_1 = require("../api/logs-monitor");
80
83
  const plugin_1 = require("../api/plugin");
@@ -90,7 +93,7 @@ const promises_1 = require("../util/promises");
90
93
  /**
91
94
  * The AWS CDK Programmatic Toolkit
92
95
  */
93
- class Toolkit extends private_6.CloudAssemblySourceBuilder {
96
+ class Toolkit extends source_builder_1.CloudAssemblySourceBuilder {
94
97
  props;
95
98
  /**
96
99
  * The toolkit stack name used for bootstrapping resources.
@@ -124,10 +127,7 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
124
127
  // After removing emojis and color, we might end up with floating whitespace at either end of the message
125
128
  // This also removes newlines that we currently emit for CLI backwards compatibility.
126
129
  this.ioHost = (0, private_7.withTrimmedWhitespace)(ioHost);
127
- if (props.sdkConfig?.profile && props.sdkConfig?.baseCredentials) {
128
- throw new toolkit_error_1.ToolkitError('Specify at most one of \'sdkConfig.profile\' and \'sdkConfig.baseCredentials\'');
129
- }
130
- this.baseCredentials = props.sdkConfig?.baseCredentials ?? aws_auth_1.BaseCredentials.awsCliCompatible({ profile: props.sdkConfig?.profile });
130
+ this.baseCredentials = props.sdkConfig?.baseCredentials ?? aws_auth_1.BaseCredentials.awsCliCompatible();
131
131
  }
132
132
  /**
133
133
  * Access to the AWS SDK
@@ -137,14 +137,16 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
137
137
  // @todo this needs to be different instance per action
138
138
  if (!this.sdkProviderCache) {
139
139
  const ioHelper = (0, private_7.asIoHelper)(this.ioHost, action);
140
- const services = {
140
+ const clientConfig = {
141
+ requestHandler: (0, awscli_compatible_1.sdkRequestHandler)(this.props.sdkConfig?.httpOptions?.agent),
142
+ };
143
+ const config = await this.baseCredentials.sdkBaseConfig(ioHelper, clientConfig);
144
+ this.sdkProviderCache = new private_5.SdkProvider(config.credentialProvider, config.defaultRegion, {
141
145
  ioHelper,
142
- requestHandler: await (0, awscli_compatible_1.makeRequestHandler)(ioHelper, this.props.sdkConfig?.httpOptions),
143
146
  logger: new private_5.IoHostSdkLogger(ioHelper),
144
147
  pluginHost: this.pluginHost,
145
- };
146
- const config = await this.baseCredentials.makeSdkConfig(services);
147
- this.sdkProviderCache = new private_5.SdkProvider(config.credentialProvider, config.defaultRegion, services);
148
+ requestHandler: clientConfig.requestHandler,
149
+ });
148
150
  }
149
151
  return this.sdkProviderCache;
150
152
  }
@@ -162,7 +164,7 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
162
164
  /**
163
165
  * Bootstrap Action
164
166
  */
165
- async bootstrap(environments, options) {
167
+ async bootstrap(environments, options = {}) {
166
168
  const startTime = Date.now();
167
169
  const results = [];
168
170
  const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'bootstrap');
@@ -221,10 +223,10 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
221
223
  const selectStacks = options.stacks ?? private_6.ALL_STACKS;
222
224
  const synthSpan = await ioHelper.span(private_7.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
223
225
  // NOTE: NOT 'await using' because we return ownership to the caller
224
- const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
226
+ const assembly = await (0, private_1.assemblyFromSource)(synthSpan.asHelper, cx);
225
227
  const stacks = await assembly.selectStacksV2(selectStacks);
226
228
  const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];
227
- await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHelper);
229
+ await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), synthSpan.asHelper);
228
230
  await synthSpan.end();
229
231
  // if we have a single stack, print it to STDOUT
230
232
  const message = `Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`;
@@ -251,20 +253,20 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
251
253
  else {
252
254
  // not outputting template to stdout, let's explain things to the user a little bit...
253
255
  await ioHelper.notify(private_7.IO.CDK_TOOLKIT_I1902.msg(chalk.green(message), assemblyData));
254
- await ioHelper.notify(private_7.IO.DEFAULT_TOOLKIT_INFO.msg(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));
256
+ await ioHelper.defaults.info(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`);
255
257
  }
256
258
  return new cloud_assembly_1.CachedCloudAssembly(assembly);
257
259
  }
258
260
  /**
259
261
  * Diff Action
260
262
  */
261
- async diff(cx, options) {
263
+ async diff(cx, options = {}) {
262
264
  const env_1 = { stack: [], error: void 0, hasError: false };
263
265
  try {
264
266
  const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'diff');
265
267
  const selectStacks = options.stacks ?? private_6.ALL_STACKS;
266
268
  const synthSpan = await ioHelper.span(private_7.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
267
- const assembly = __addDisposableResource(env_1, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
269
+ const assembly = __addDisposableResource(env_1, await (0, private_1.assemblyFromSource)(synthSpan.asHelper, cx), true);
268
270
  const stacks = await assembly.selectStacksV2(selectStacks);
269
271
  await synthSpan.end();
270
272
  const diffSpan = await ioHelper.span(private_7.SPAN.DIFF_STACK).begin({ stacks: selectStacks });
@@ -272,38 +274,37 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
272
274
  const strict = !!options.strict;
273
275
  const contextLines = options.contextLines || 3;
274
276
  let diffs = 0;
275
- let formattedSecurityDiff = '';
276
- let formattedStackDiff = '';
277
- const templateInfos = await (0, private_3.prepareDiff)(ioHelper, stacks, deployments, await this.sdkProvider('diff'), options);
277
+ const templateInfos = await (0, private_3.prepareDiff)(diffSpan.asHelper, stacks, deployments, await this.sdkProvider('diff'), options);
278
278
  const templateDiffs = {};
279
279
  for (const templateInfo of templateInfos) {
280
- const formatter = new diff_1.DiffFormatter({
281
- ioHelper,
282
- templateInfo,
283
- });
284
- if (options.securityOnly) {
285
- const securityDiff = formatter.formatSecurityDiff();
286
- // In Diff, we only care about BROADENING security diffs
287
- if (securityDiff.permissionChangeType == payloads_1.PermissionChangeType.BROADENING) {
288
- const warningMessage = 'This deployment will make potentially sensitive changes according to your current security approval level.\nPlease confirm you intend to make the following modifications:\n';
289
- await ioHelper.notify(private_7.IO.DEFAULT_TOOLKIT_WARN.msg(warningMessage));
290
- formattedSecurityDiff = securityDiff.formattedDiff;
291
- diffs = securityDiff.formattedDiff ? diffs + 1 : diffs;
292
- }
293
- }
294
- else {
295
- const diff = formatter.formatStackDiff({
296
- strict,
297
- context: contextLines,
298
- });
299
- formattedStackDiff = diff.formattedDiff;
300
- diffs = diff.numStacksWithChanges;
280
+ const formatter = new diff_1.DiffFormatter({ templateInfo });
281
+ const stackDiff = formatter.formatStackDiff({ strict, contextLines });
282
+ // Security Diff
283
+ const securityDiff = formatter.formatSecurityDiff();
284
+ const formattedSecurityDiff = securityDiff.permissionChangeType !== payloads_1.PermissionChangeType.NONE ? stackDiff.formattedDiff : undefined;
285
+ // We only warn about BROADENING changes
286
+ if (securityDiff.permissionChangeType == payloads_1.PermissionChangeType.BROADENING) {
287
+ const warningMessage = 'This deployment will make potentially sensitive changes according to your current security approval level.\nPlease confirm you intend to make the following modifications:\n';
288
+ await diffSpan.defaults.warn(warningMessage);
289
+ await diffSpan.defaults.info(securityDiff.formattedDiff);
301
290
  }
291
+ // Stack Diff
292
+ diffs += stackDiff.numStacksWithChanges;
302
293
  (0, private_3.appendObject)(templateDiffs, formatter.diffs);
294
+ await diffSpan.notify(private_7.IO.CDK_TOOLKIT_I4002.msg(stackDiff.formattedDiff, {
295
+ stack: templateInfo.newTemplate,
296
+ diffs: formatter.diffs,
297
+ numStacksWithChanges: stackDiff.numStacksWithChanges,
298
+ permissionChanges: securityDiff.permissionChangeType,
299
+ formattedDiff: {
300
+ diff: stackDiff.formattedDiff,
301
+ security: formattedSecurityDiff,
302
+ },
303
+ }));
303
304
  }
304
305
  await diffSpan.end(`✨ Number of stacks with differences: ${diffs}`, {
305
- formattedSecurityDiff,
306
- formattedStackDiff,
306
+ numStacksWithChanges: diffs,
307
+ diffs: templateDiffs,
307
308
  });
308
309
  return templateDiffs;
309
310
  }
@@ -318,23 +319,72 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
318
319
  }
319
320
  }
320
321
  /**
321
- * List Action
322
- *
323
- * List selected stacks and their dependencies
322
+ * Drift Action
324
323
  */
325
- async list(cx, options = {}) {
324
+ async drift(cx, options) {
326
325
  const env_2 = { stack: [], error: void 0, hasError: false };
327
326
  try {
328
- const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'list');
327
+ const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'drift');
329
328
  const selectStacks = options.stacks ?? private_6.ALL_STACKS;
330
329
  const synthSpan = await ioHelper.span(private_7.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
331
- const assembly = __addDisposableResource(env_2, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
332
- const stackCollection = await assembly.selectStacksV2(selectStacks);
330
+ const assembly = __addDisposableResource(env_2, await (0, private_1.assemblyFromSource)(synthSpan.asHelper, cx), true);
331
+ const stacks = await assembly.selectStacksV2(selectStacks);
333
332
  await synthSpan.end();
334
- const stacks = stackCollection.withDependencies();
335
- const message = stacks.map(s => s.id).join('\n');
336
- await ioHelper.notify(private_7.IO.CDK_TOOLKIT_I2901.msg(message, { stacks }));
337
- return stacks;
333
+ const driftSpan = await ioHelper.span(private_7.SPAN.DRIFT_APP).begin({ stacks: selectStacks });
334
+ const allDriftResults = {};
335
+ const unavailableDrifts = [];
336
+ const sdkProvider = await this.sdkProvider('drift');
337
+ for (const stack of stacks.stackArtifacts) {
338
+ const cfn = (await sdkProvider.forEnvironment(stack.environment, plugin_1.Mode.ForReading)).sdk.cloudFormation();
339
+ const driftResults = await (0, drift_1.detectStackDrift)(cfn, driftSpan.asHelper, stack.stackName);
340
+ if (!driftResults.StackResourceDrifts) {
341
+ const stackName = stack.displayName ?? stack.stackName;
342
+ unavailableDrifts.push(stackName);
343
+ await driftSpan.notify(private_7.IO.CDK_TOOLKIT_W4591.msg(`${stackName}: No drift results available`, { stack }));
344
+ continue;
345
+ }
346
+ const formatter = new drift_formatter_1.DriftFormatter({ stack, resourceDrifts: driftResults.StackResourceDrifts });
347
+ const driftOutput = formatter.formatStackDrift();
348
+ const stackDrift = {
349
+ numResourcesWithDrift: driftOutput.numResourcesWithDrift,
350
+ numResourcesUnchecked: driftOutput.numResourcesUnchecked,
351
+ formattedDrift: {
352
+ unchanged: driftOutput.unchanged,
353
+ unchecked: driftOutput.unchecked,
354
+ modified: driftOutput.modified,
355
+ deleted: driftOutput.deleted,
356
+ },
357
+ };
358
+ allDriftResults[formatter.stackName] = stackDrift;
359
+ // header
360
+ await driftSpan.defaults.info(driftOutput.stackHeader);
361
+ // print the different sections at different levels
362
+ if (driftOutput.unchanged) {
363
+ await driftSpan.defaults.debug(driftOutput.unchanged);
364
+ }
365
+ if (driftOutput.unchecked) {
366
+ await driftSpan.defaults.debug(driftOutput.unchecked);
367
+ }
368
+ if (driftOutput.modified) {
369
+ await driftSpan.defaults.info(driftOutput.modified);
370
+ }
371
+ if (driftOutput.deleted) {
372
+ await driftSpan.defaults.info(driftOutput.deleted);
373
+ }
374
+ // main stack result
375
+ await driftSpan.notify(private_7.IO.CDK_TOOLKIT_I4590.msg(driftOutput.summary, {
376
+ stack,
377
+ drift: stackDrift,
378
+ }));
379
+ }
380
+ // print summary
381
+ const totalDrifts = Object.values(allDriftResults).reduce((total, current) => total + (current.numResourcesWithDrift ?? 0), 0);
382
+ const totalUnchecked = Object.values(allDriftResults).reduce((total, current) => total + (current.numResourcesUnchecked ?? 0), 0);
383
+ await driftSpan.end(`\n✨ Number of resources with drift: ${totalDrifts}${totalUnchecked ? ` (${totalUnchecked} unchecked)` : ''}`);
384
+ if (unavailableDrifts.length) {
385
+ await driftSpan.defaults.warn(`\n⚠️ Failed to check drift for ${unavailableDrifts.length} stack(s). Check log for more details.`);
386
+ }
387
+ return allDriftResults;
338
388
  }
339
389
  catch (e_2) {
340
390
  env_2.error = e_2;
@@ -347,16 +397,23 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
347
397
  }
348
398
  }
349
399
  /**
350
- * Deploy Action
400
+ * List Action
351
401
  *
352
- * Deploys the selected stacks into an AWS account
402
+ * List selected stacks and their dependencies
353
403
  */
354
- async deploy(cx, options = {}) {
404
+ async list(cx, options = {}) {
355
405
  const env_3 = { stack: [], error: void 0, hasError: false };
356
406
  try {
357
- const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'deploy');
407
+ const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'list');
408
+ const selectStacks = options.stacks ?? private_6.ALL_STACKS;
409
+ const synthSpan = await ioHelper.span(private_7.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
358
410
  const assembly = __addDisposableResource(env_3, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
359
- return await this._deploy(assembly, 'deploy', options);
411
+ const stackCollection = await assembly.selectStacksV2(selectStacks);
412
+ await synthSpan.end();
413
+ const stacks = stackCollection.withDependencies();
414
+ const message = stacks.map(s => s.id).join('\n');
415
+ await ioHelper.notify(private_7.IO.CDK_TOOLKIT_I2901.msg(message, { stacks }));
416
+ return stacks;
360
417
  }
361
418
  catch (e_3) {
362
419
  env_3.error = e_3;
@@ -368,6 +425,28 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
368
425
  await result_3;
369
426
  }
370
427
  }
428
+ /**
429
+ * Deploy Action
430
+ *
431
+ * Deploys the selected stacks into an AWS account
432
+ */
433
+ async deploy(cx, options = {}) {
434
+ const env_4 = { stack: [], error: void 0, hasError: false };
435
+ try {
436
+ const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'deploy');
437
+ const assembly = __addDisposableResource(env_4, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
438
+ return await this._deploy(assembly, 'deploy', options);
439
+ }
440
+ catch (e_4) {
441
+ env_4.error = e_4;
442
+ env_4.hasError = true;
443
+ }
444
+ finally {
445
+ const result_4 = __disposeResources(env_4);
446
+ if (result_4)
447
+ await result_4;
448
+ }
449
+ }
371
450
  /**
372
451
  * Helper to allow deploy being called as part of the watch action.
373
452
  */
@@ -389,10 +468,9 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
389
468
  const migrator = new resource_import_1.ResourceMigrator({ deployments, ioHelper });
390
469
  await migrator.tryMigrateResources(stackCollection, options);
391
470
  const parameterMap = (0, private_2.buildParameterMap)(options.parameters?.parameters);
392
- const hotswapMode = options.hotswap ?? deploy_1.HotswapMode.FULL_DEPLOYMENT;
393
- if (hotswapMode !== deploy_1.HotswapMode.FULL_DEPLOYMENT) {
471
+ if (options.deploymentMethod?.method === 'hotswap') {
394
472
  await ioHelper.notify(private_7.IO.CDK_TOOLKIT_W5400.msg([
395
- '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',
473
+ '⚠️ Hotswap deployments deliberately introduce CloudFormation drift to speed up deployments',
396
474
  '⚠️ They should only be used for development - never use them for your production Stacks!',
397
475
  ].join('\n')));
398
476
  }
@@ -425,7 +503,7 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
425
503
  const deployStack = async (stackNode) => {
426
504
  const stack = stackNode.stack;
427
505
  if (stackCollection.stackCount !== 1) {
428
- await ioHelper.notify(private_7.IO.DEFAULT_TOOLKIT_INFO.msg(chalk.bold(stack.displayName)));
506
+ await ioHelper.defaults.info(chalk.bold(stack.displayName));
429
507
  }
430
508
  if (!stack.environment) {
431
509
  throw new toolkit_error_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.`);
@@ -447,7 +525,6 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
447
525
  }
448
526
  const currentTemplate = await deployments.readCurrentTemplate(stack);
449
527
  const formatter = new diff_1.DiffFormatter({
450
- ioHelper,
451
528
  templateInfo: {
452
529
  oldTemplate: currentTemplate,
453
530
  newTemplate: stack,
@@ -514,9 +591,7 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
514
591
  parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),
515
592
  usePreviousParameters: options.parameters?.keepExistingParameters,
516
593
  rollback,
517
- hotswap: hotswapMode,
518
594
  extraUserAgent: options.extraUserAgent,
519
- hotswapPropertyOverrides: options.hotswapProperties ? (0, private_2.createHotswapPropertyOverrides)(options.hotswapProperties) : undefined,
520
595
  assetParallelism: options.assetParallelism,
521
596
  });
522
597
  switch (r.type) {
@@ -646,15 +721,15 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
646
721
  * Watch Action
647
722
  *
648
723
  * Continuously observe project files and deploy the selected stacks
649
- * automatically when changes are detected. Implies hotswap deployments.
724
+ * automatically when changes are detected. Defaults to hotswap deployments.
650
725
  *
651
726
  * This function returns immediately, starting a watcher in the background.
652
727
  */
653
- async watch(cx, options) {
654
- const env_4 = { stack: [], error: void 0, hasError: false };
728
+ async watch(cx, options = {}) {
729
+ const env_5 = { stack: [], error: void 0, hasError: false };
655
730
  try {
656
731
  const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'watch');
657
- const assembly = __addDisposableResource(env_4, await (0, private_1.assemblyFromSource)(ioHelper, cx, false), true);
732
+ const assembly = __addDisposableResource(env_5, await (0, private_1.assemblyFromSource)(ioHelper, cx, false), true);
658
733
  const rootDir = options.watchDir ?? process.cwd();
659
734
  if (options.include === undefined && options.exclude === undefined) {
660
735
  throw new toolkit_error_1.ToolkitError("Cannot use the 'watch' command without specifying at least one directory to monitor. " +
@@ -721,7 +796,7 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
721
796
  })
722
797
  .on('ready', async () => {
723
798
  latch = 'open';
724
- await ioHelper.notify(private_7.IO.DEFAULT_TOOLKIT_DEBUG.msg("'watch' received the 'ready' event. From now on, all file changes will trigger a deployment"));
799
+ await ioHelper.defaults.debug("'watch' received the 'ready' event. From now on, all file changes will trigger a deployment");
725
800
  await ioHelper.notify(private_7.IO.CDK_TOOLKIT_I5314.msg("Triggering initial 'cdk deploy'"));
726
801
  await deployAndWatch();
727
802
  })
@@ -762,14 +837,14 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
762
837
  },
763
838
  };
764
839
  }
765
- catch (e_4) {
766
- env_4.error = e_4;
767
- env_4.hasError = true;
840
+ catch (e_5) {
841
+ env_5.error = e_5;
842
+ env_5.hasError = true;
768
843
  }
769
844
  finally {
770
- const result_4 = __disposeResources(env_4);
771
- if (result_4)
772
- await result_4;
845
+ const result_5 = __disposeResources(env_5);
846
+ if (result_5)
847
+ await result_5;
773
848
  }
774
849
  }
775
850
  /**
@@ -777,30 +852,31 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
777
852
  *
778
853
  * Rolls back the selected stacks.
779
854
  */
780
- async rollback(cx, options) {
781
- const env_5 = { stack: [], error: void 0, hasError: false };
855
+ async rollback(cx, options = {}) {
856
+ const env_6 = { stack: [], error: void 0, hasError: false };
782
857
  try {
783
858
  const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'rollback');
784
- const assembly = __addDisposableResource(env_5, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
859
+ const assembly = __addDisposableResource(env_6, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
785
860
  return await this._rollback(assembly, 'rollback', options);
786
861
  }
787
- catch (e_5) {
788
- env_5.error = e_5;
789
- env_5.hasError = true;
862
+ catch (e_6) {
863
+ env_6.error = e_6;
864
+ env_6.hasError = true;
790
865
  }
791
866
  finally {
792
- const result_5 = __disposeResources(env_5);
793
- if (result_5)
794
- await result_5;
867
+ const result_6 = __disposeResources(env_6);
868
+ if (result_6)
869
+ await result_6;
795
870
  }
796
871
  }
797
872
  /**
798
873
  * Helper to allow rollback being called as part of the deploy or watch action.
799
874
  */
800
875
  async _rollback(assembly, action, options) {
876
+ const selectStacks = options.stacks ?? private_6.ALL_STACKS;
801
877
  const ioHelper = (0, private_7.asIoHelper)(this.ioHost, action);
802
- const synthSpan = await ioHelper.span(private_7.SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });
803
- const stacks = await assembly.selectStacksV2(options.stacks);
878
+ const synthSpan = await ioHelper.span(private_7.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
879
+ const stacks = await assembly.selectStacksV2(selectStacks);
804
880
  await this.validateStacksMetadata(stacks, ioHelper);
805
881
  await synthSpan.end();
806
882
  const ret = {
@@ -921,31 +997,32 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
921
997
  *
922
998
  * Destroys the selected Stacks.
923
999
  */
924
- async destroy(cx, options) {
925
- const env_6 = { stack: [], error: void 0, hasError: false };
1000
+ async destroy(cx, options = {}) {
1001
+ const env_7 = { stack: [], error: void 0, hasError: false };
926
1002
  try {
927
1003
  const ioHelper = (0, private_7.asIoHelper)(this.ioHost, 'destroy');
928
- const assembly = __addDisposableResource(env_6, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
1004
+ const assembly = __addDisposableResource(env_7, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
929
1005
  return await this._destroy(assembly, 'destroy', options);
930
1006
  }
931
- catch (e_6) {
932
- env_6.error = e_6;
933
- env_6.hasError = true;
1007
+ catch (e_7) {
1008
+ env_7.error = e_7;
1009
+ env_7.hasError = true;
934
1010
  }
935
1011
  finally {
936
- const result_6 = __disposeResources(env_6);
937
- if (result_6)
938
- await result_6;
1012
+ const result_7 = __disposeResources(env_7);
1013
+ if (result_7)
1014
+ await result_7;
939
1015
  }
940
1016
  }
941
1017
  /**
942
1018
  * Helper to allow destroy being called as part of the deploy action.
943
1019
  */
944
1020
  async _destroy(assembly, action, options) {
1021
+ const selectStacks = options.stacks ?? private_6.ALL_STACKS;
945
1022
  const ioHelper = (0, private_7.asIoHelper)(this.ioHost, action);
946
- const synthSpan = await ioHelper.span(private_7.SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });
1023
+ const synthSpan = await ioHelper.span(private_7.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
947
1024
  // The stacks will have been ordered for deployment, so reverse them for deletion.
948
- const stacks = (await assembly.selectStacksV2(options.stacks)).reversed();
1025
+ const stacks = (await assembly.selectStacksV2(selectStacks)).reversed();
949
1026
  await synthSpan.end();
950
1027
  const ret = {
951
1028
  stacks: [],
@@ -1025,13 +1102,13 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
1025
1102
  });
1026
1103
  }
1027
1104
  async invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor) {
1028
- // watch defaults hotswap to enabled
1029
- const hotswap = options.hotswap ?? deploy_1.HotswapMode.HOTSWAP_ONLY;
1105
+ // watch defaults to hotswap deployment
1106
+ const deploymentMethod = options.deploymentMethod ?? { method: 'hotswap' };
1030
1107
  const deployOptions = {
1031
1108
  ...options,
1032
1109
  cloudWatchLogMonitor,
1033
- hotswap,
1034
- extraUserAgent: `cdk-watch/hotswap-${hotswap === deploy_1.HotswapMode.FULL_DEPLOYMENT ? 'off' : 'on'}`,
1110
+ deploymentMethod,
1111
+ extraUserAgent: `cdk-watch/hotswap-${deploymentMethod.method === 'hotswap' ? 'on' : 'off'}`,
1035
1112
  };
1036
1113
  try {
1037
1114
  await this._deploy(assembly, 'watch', deployOptions);
@@ -1042,4 +1119,4 @@ class Toolkit extends private_6.CloudAssemblySourceBuilder {
1042
1119
  }
1043
1120
  }
1044
1121
  exports.Toolkit = Toolkit;
1045
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit.js","sourceRoot":"","sources":["toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import '../private/dispose-polyfill';\nimport * as path from 'node:path';\nimport type { TemplateDiff } from '@aws-cdk/cloudformation-diff';\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 { NonInteractiveIoHost } from './non-interactive-io-host';\nimport type { ToolkitServices } from './private';\nimport { assemblyFromSource } from './private';\nimport { ToolkitError } from './toolkit-error';\nimport type { DeployResult, DestroyResult, RollbackResult } from './types';\nimport type {\n  BootstrapEnvironments,\n  BootstrapOptions,\n  BootstrapResult,\n  EnvironmentBootstrapResult,\n} from '../actions/bootstrap';\nimport { BootstrapSource } from '../actions/bootstrap';\nimport { AssetBuildTime, type DeployOptions, HotswapMode } from '../actions/deploy';\nimport {\n  buildParameterMap,\n  createHotswapPropertyOverrides,\n  type ExtendedDeployOptions,\n  removePublishedAssetsFromWorkGraph,\n} from '../actions/deploy/private';\nimport { type DestroyOptions } from '../actions/destroy';\nimport type { DiffOptions } from '../actions/diff';\nimport { appendObject, prepareDiff } from '../actions/diff/private';\nimport { type ListOptions } from '../actions/list';\nimport type { MappingGroup, RefactorOptions } from '../actions/refactor';\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 { BaseCredentials, type SdkConfig } from '../api/aws-auth';\nimport { makeRequestHandler } from '../api/aws-auth/awscli-compatible';\nimport type { SdkProviderServices } from '../api/aws-auth/private';\nimport { SdkProvider, IoHostSdkLogger } from '../api/aws-auth/private';\nimport { Bootstrapper } from '../api/bootstrap';\nimport type { ICloudAssemblySource } from '../api/cloud-assembly';\nimport { CachedCloudAssembly, StackSelectionStrategy } from '../api/cloud-assembly';\nimport type { StackAssembly } from '../api/cloud-assembly/private';\nimport { ALL_STACKS, CloudAssemblySourceBuilder } from '../api/cloud-assembly/private';\nimport type { StackCollection } from '../api/cloud-assembly/stack-collection';\nimport { Deployments } from '../api/deployments';\nimport { DiffFormatter } from '../api/diff';\nimport type { IIoHost, IoMessageLevel, ToolkitAction } from '../api/io';\nimport type { IoHelper } from '../api/io/private';\nimport { asIoHelper, IO, SPAN, withoutColor, withoutEmojis, withTrimmedWhitespace } from '../api/io/private';\nimport { CloudWatchLogEventMonitor, findCloudWatchLogGroups } from '../api/logs-monitor';\nimport { PluginHost } from '../api/plugin';\nimport {\n  AmbiguityError,\n  ambiguousMovements,\n  findResourceMovements,\n  formatAmbiguousMappings,\n  formatTypedMappings,\n  fromManifestAndExclusionList,\n  resourceMappings,\n  usePrescribedMappings,\n} from '../api/refactoring';\nimport type { ResourceMapping } from '../api/refactoring/cloudformation';\nimport { ResourceMigrator } from '../api/resource-import';\nimport { tagsForStack } from '../api/tags';\nimport { DEFAULT_TOOLKIT_STACK_NAME } from '../api/toolkit-info';\nimport type { AssetBuildNode, AssetPublishNode, Concurrency, StackNode } from '../api/work-graph';\nimport { WorkGraphBuilder } from '../api/work-graph';\nimport type { AssemblyData, StackDetails, SuccessfulDeployStackResult } from '../payloads';\nimport { PermissionChangeType } from '../payloads';\nimport { formatErrorMessage, formatTime, obscureTemplate, serializeStructure, validateSnsTopicArn } from '../util';\nimport { pLimit } from '../util/concurrency';\nimport { promiseWithResolvers } from '../util/promises';\n\nexport interface ToolkitOptions {\n  /**\n   * The IoHost implementation, handling the inline interactions between the Toolkit and an integration.\n   */\n  readonly ioHost?: IIoHost;\n\n  /**\n   * Allow emojis in messages sent to the IoHost.\n   *\n   * @default true\n   */\n  readonly 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  readonly color?: boolean;\n\n  /**\n   * Configuration options for the SDK.\n   */\n  readonly sdkConfig?: SdkConfig;\n\n  /**\n   * Name of the toolkit stack to be used.\n   *\n   * @default \"CDKToolkit\"\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Fail Cloud Assemblies\n   *\n   * @default \"error\"\n   */\n  readonly assemblyFailureAt?: 'error' | 'warn' | 'none';\n\n  /**\n   * The plugin host to use for loading and querying plugins\n   *\n   * By default, a unique instance of a plugin managing class will be used.\n   *\n   * Use `toolkit.pluginHost.load()` to load plugins into the plugin host from disk.\n   *\n   * @default - A fresh plugin host\n   */\n  readonly pluginHost?: PluginHost;\n}\n\n/**\n * The AWS CDK Programmatic Toolkit\n */\nexport class Toolkit extends CloudAssemblySourceBuilder {\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\n  /**\n   * The plugin host for loading and managing plugins\n   */\n  public readonly pluginHost: PluginHost;\n\n  /**\n   * Cache of the internal SDK Provider instance\n   */\n  private sdkProviderCache?: SdkProvider;\n\n  private baseCredentials: BaseCredentials;\n\n  public constructor(private readonly props: ToolkitOptions = {}) {\n    super();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n\n    this.pluginHost = props.pluginHost ?? new PluginHost();\n\n    let ioHost = props.ioHost ?? new NonInteractiveIoHost();\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    if (props.sdkConfig?.profile && props.sdkConfig?.baseCredentials) {\n      throw new ToolkitError('Specify at most one of \\'sdkConfig.profile\\' and \\'sdkConfig.baseCredentials\\'');\n    }\n    this.baseCredentials = props.sdkConfig?.baseCredentials ?? BaseCredentials.awsCliCompatible({ profile: props.sdkConfig?.profile });\n  }\n\n  /**\n   * Access to the AWS SDK\n   * @internal\n   */\n  protected async sdkProvider(action: ToolkitAction): Promise<SdkProvider> {\n    // @todo this needs to be different instance per action\n    if (!this.sdkProviderCache) {\n      const ioHelper = asIoHelper(this.ioHost, action);\n      const services: SdkProviderServices = {\n        ioHelper,\n        requestHandler: await makeRequestHandler(ioHelper, this.props.sdkConfig?.httpOptions),\n        logger: new IoHostSdkLogger(ioHelper),\n        pluginHost: this.pluginHost,\n      };\n\n      const config = await this.baseCredentials.makeSdkConfig(services);\n      this.sdkProviderCache = new SdkProvider(config.credentialProvider, config.defaultRegion, services);\n    }\n\n    return this.sdkProviderCache;\n  }\n\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   * @internal\n   */\n  protected override async sourceBuilderServices(): Promise<ToolkitServices> {\n    return {\n      ioHelper: asIoHelper(this.ioHost, 'assembly'),\n      sdkProvider: await this.sdkProvider('assembly'),\n      pluginHost: this.pluginHost,\n    };\n  }\n\n  /**\n   * Bootstrap Action\n   */\n  public async bootstrap(environments: BootstrapEnvironments, options: BootstrapOptions): Promise<BootstrapResult> {\n    const startTime = Date.now();\n    const results: EnvironmentBootstrapResult[] = [];\n\n    const ioHelper = asIoHelper(this.ioHost, 'bootstrap');\n    const bootstrapEnvironments = await environments.getEnvironments(this.ioHost);\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\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        const envTime = await bootstrapSpan.end();\n        const result: EnvironmentBootstrapResult = {\n          environment,\n          status: bootstrapResult.noOp ? 'no-op' : 'success',\n          duration: envTime.asMs,\n        };\n        results.push(result);\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    return {\n      environments: results,\n      duration: Date.now() - startTime,\n    };\n  }\n\n  /**\n   * Synth Action\n   *\n   * The caller assumes ownership of the `CachedCloudAssembly` and is responsible for calling `dispose()` on\n   * it after use.\n   */\n  public async synth(cx: ICloudAssemblySource, options: SynthOptions = {}): Promise<CachedCloudAssembly> {\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\n    // NOTE: NOT 'await using' because we return ownership to the caller\n    const assembly = await assemblyFromSource(ioHelper, cx);\n\n    const stacks = await 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 CachedCloudAssembly(assembly);\n  }\n\n  /**\n   * Diff Action\n   */\n  public async diff(cx: ICloudAssemblySource, options: DiffOptions): Promise<{ [name: string]: TemplateDiff }> {\n    const ioHelper = asIoHelper(this.ioHost, 'diff');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const diffSpan = await ioHelper.span(SPAN.DIFF_STACK).begin({ stacks: selectStacks });\n    const deployments = await this.deploymentsForAction('diff');\n\n    const strict = !!options.strict;\n    const contextLines = options.contextLines || 3;\n\n    let diffs = 0;\n    let formattedSecurityDiff = '';\n    let formattedStackDiff = '';\n\n    const templateInfos = await prepareDiff(ioHelper, stacks, deployments, await this.sdkProvider('diff'), options);\n    const templateDiffs: { [name: string]: TemplateDiff } = {};\n    for (const templateInfo of templateInfos) {\n      const formatter = new DiffFormatter({\n        ioHelper,\n        templateInfo,\n      });\n\n      if (options.securityOnly) {\n        const securityDiff = formatter.formatSecurityDiff();\n        // In Diff, we only care about BROADENING security diffs\n        if (securityDiff.permissionChangeType == PermissionChangeType.BROADENING) {\n          const warningMessage = 'This deployment will make potentially sensitive changes according to your current security approval level.\\nPlease confirm you intend to make the following modifications:\\n';\n          await ioHelper.notify(IO.DEFAULT_TOOLKIT_WARN.msg(warningMessage));\n          formattedSecurityDiff = securityDiff.formattedDiff;\n          diffs = securityDiff.formattedDiff ? diffs + 1 : diffs;\n        }\n      } else {\n        const diff = formatter.formatStackDiff({\n          strict,\n          context: contextLines,\n        });\n        formattedStackDiff = diff.formattedDiff;\n        diffs = diff.numStacksWithChanges;\n      }\n      appendObject(templateDiffs, formatter.diffs);\n    }\n\n    await diffSpan.end(`✨ Number of stacks with differences: ${diffs}`, {\n      formattedSecurityDiff,\n      formattedStackDiff,\n    });\n\n    return templateDiffs;\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    await using assembly = await assemblyFromSource(ioHelper, 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<DeployResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'deploy');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await 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 = {}): Promise<DeployResult> {\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 = await assembly.selectStacksV2(selectStacks);\n    await this.validateStacksMetadata(stackCollection, ioHelper);\n    const synthDuration = await synthSpan.end();\n\n    const ret: DeployResult = {\n      stacks: [],\n    };\n\n    if (stackCollection.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E5001.msg('This app contains no stacks'));\n      return ret;\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.forceAssetPublishing,\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        });\n\n        return;\n      }\n\n      const currentTemplate = await deployments.readCurrentTemplate(stack);\n\n      const formatter = new DiffFormatter({\n        ioHelper,\n        templateInfo: {\n          oldTemplate: currentTemplate,\n          newTemplate: stack,\n        },\n      });\n\n      const securityDiff = formatter.formatSecurityDiff();\n\n      // Send a request response with the formatted security diff as part of the message,\n      // and the template diff as data\n      // (IoHost decides whether to print depending on permissionChangeType)\n      const deployMotivation = '\"--require-approval\" is enabled and stack includes security-sensitive updates.';\n      const deployQuestion = `${securityDiff.formattedDiff}\\n\\n${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: securityDiff.permissionChangeType,\n        templateDiffs: formatter.diffs,\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            forceDeployment: options.forceDeployment,\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              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              // Perform a rollback\n              await this._rollback(assembly, action, {\n                stacks: {\n                  patterns: [stack.hierarchicalId],\n                  strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE,\n                },\n                orphanFailedResources: options.orphanFailedResourcesDuringRollback,\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              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              // 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\n        ret.stacks.push({\n          stackName: stack.stackName,\n          environment: {\n            account: stack.environment.account,\n            region: stack.environment.region,\n          },\n          stackArn: deployResult.stackArn,\n          outputs: deployResult.outputs,\n          hierarchicalId: stack.hierarchicalId,\n        });\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.forceAssetPublishing) {\n      await removePublishedAssetsFromWorkGraph(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    return ret;\n  }\n\n  /**\n   * Watch Action\n   *\n   * Continuously observe project files and deploy the selected stacks\n   * automatically when changes are detected.  Implies hotswap deployments.\n   *\n   * This function returns immediately, starting a watcher in the background.\n   */\n  public async watch(cx: ICloudAssemblySource, options: WatchOptions): Promise<IWatcher> {\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    await using assembly = await assemblyFromSource(ioHelper, cx, false);\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 = assembly.directory;\n    const watchExcludes = patternsArrayForWatch(options.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    });\n\n    // only exclude the outdir if it is under the rootDir\n    const relativeOutDir = path.relative(rootDir, outdir);\n    if (Boolean(relativeOutDir && !relativeOutDir.startsWith('..' + path.sep) && !path.isAbsolute(relativeOutDir))) {\n      watchExcludes.push(`${relativeOutDir}/**`);\n    }\n\n    watchExcludes.push('**/.*', '**/.*/**', '**/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    const watcher = 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    const stoppedPromise = promiseWithResolvers<void>();\n\n    return {\n      async dispose() {\n        await watcher.close();\n        // Prevents Node from staying alive. There is no 'end' event that the watcher emits\n        // that we can know it's definitely done, so best we can do is tell it to stop watching,\n        // stop keeping Node alive, and then pretend that's everything we needed to do.\n        watcher.unref();\n        stoppedPromise.resolve();\n        return stoppedPromise.promise;\n      },\n      async waitForEnd() {\n        return stoppedPromise.promise;\n      },\n      async [Symbol.asyncDispose]() {\n        return this.dispose();\n      },\n    } satisfies IWatcher;\n  }\n\n  /**\n   * Rollback Action\n   *\n   * Rolls back the selected stacks.\n   */\n  public async rollback(cx: ICloudAssemblySource, options: RollbackOptions): Promise<RollbackResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'rollback');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await 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<RollbackResult> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    const stacks = await assembly.selectStacksV2(options.stacks);\n    await this.validateStacksMetadata(stacks, ioHelper);\n    await synthSpan.end();\n\n    const ret: RollbackResult = {\n      stacks: [],\n    };\n\n    if (stacks.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E6001.msg('No stacks selected'));\n      return ret;\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          orphanFailedResources: options.orphanFailedResources,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!stackResult.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        await rollbackSpan.end();\n\n        ret.stacks.push({\n          environment: {\n            account: stack.environment.account,\n            region: stack.environment.region,\n          },\n          stackName: stack.stackName,\n          stackArn: stackResult.stackArn,\n          result: stackResult.notInRollbackableState ? 'already-stable' : 'rolled-back',\n        });\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 ToolkitError.withCause('Rollback failed (use --force to orphan failing resources)', e);\n      }\n    }\n    if (!anyRollbackable) {\n      throw new ToolkitError('No stacks were in a state that could be rolled back');\n    }\n\n    return ret;\n  }\n\n  /**\n   * Refactor Action. Moves resources from one location (stack + logical ID) to another.\n   */\n  public async refactor(cx: ICloudAssemblySource, options: RefactorOptions = {}): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'refactor');\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    return this._refactor(assembly, ioHelper, options);\n  }\n\n  private async _refactor(assembly: StackAssembly, ioHelper: IoHelper, options: RefactorOptions = {}): Promise<void> {\n    if (options.mappings && options.exclude) {\n      throw new ToolkitError(\"Cannot use both 'exclude' and 'mappings'.\");\n    }\n\n    if (options.revert && !options.mappings) {\n      throw new ToolkitError(\"The 'revert' options can only be used with the 'mappings' option.\");\n    }\n\n    if (!options.dryRun) {\n      throw new ToolkitError('Refactor is not available yet. Too see the proposed changes, use the --dry-run flag.');\n    }\n\n    const sdkProvider = await this.sdkProvider('refactor');\n    try {\n      const mappings = await getMappings();\n      const typedMappings = mappings.map(m => m.toTypedMapping());\n      await ioHelper.notify(IO.CDK_TOOLKIT_I8900.msg(formatTypedMappings(typedMappings), {\n        typedMappings,\n      }));\n    } catch (e) {\n      if (e instanceof AmbiguityError) {\n        const paths = e.paths();\n        await ioHelper.notify(IO.CDK_TOOLKIT_I8900.msg(formatAmbiguousMappings(paths), {\n          ambiguousPaths: paths,\n        }));\n      } else {\n        throw e;\n      }\n    }\n\n    async function getMappings(): Promise<ResourceMapping[]> {\n      if (options.revert) {\n        return usePrescribedMappings(revert(options.mappings ?? []), sdkProvider);\n      }\n      if (options.mappings != null) {\n        return usePrescribedMappings(options.mappings ?? [], sdkProvider);\n      } else {\n        const stacks = await assembly.selectStacksV2(ALL_STACKS);\n        const exclude = fromManifestAndExclusionList(assembly.cloudAssembly.manifest, options.exclude);\n        const movements = await findResourceMovements(stacks.stackArtifacts, sdkProvider, exclude);\n        const ambiguous = ambiguousMovements(movements);\n        if (ambiguous.length === 0) {\n          const filteredStacks = await assembly.selectStacksV2(options.stacks ?? ALL_STACKS);\n          return resourceMappings(movements, filteredStacks.stackArtifacts);\n        } else {\n          throw new AmbiguityError(ambiguous);\n        }\n      }\n    }\n\n    function revert(mappings: MappingGroup[]): MappingGroup[] {\n      return mappings.map(group => ({\n        ...group,\n        resources: Object.fromEntries(Object.entries(group.resources).map(([src, dst]) => ([dst, src]))),\n      }));\n    }\n  }\n\n  /**\n   * Destroy Action\n   *\n   * Destroys the selected Stacks.\n   */\n  public async destroy(cx: ICloudAssemblySource, options: DestroyOptions): Promise<DestroyResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'destroy');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await 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<DestroyResult> {\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 ret: DestroyResult = {\n      stacks: [],\n    };\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      await ioHelper.notify(IO.CDK_TOOLKIT_E7010.msg('Aborted by user'));\n      return ret;\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          const result = await deployments.destroyStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n          });\n\n          ret.stacks.push({\n            environment: {\n              account: stack.environment.account,\n              region: stack.environment.region,\n            },\n            stackName: stack.stackName,\n            stackArn: result.stackArn,\n            stackExisted: result.stackArn !== undefined,\n          });\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\n      return ret;\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':\n          return IO.CDK_ASSEMBLY_E9999;\n        case 'warn':\n          return IO.CDK_ASSEMBLY_W9999;\n        default:\n          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      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\n/**\n * The result of a `cdk.watch()` operation.\n */\nexport interface IWatcher extends AsyncDisposable {\n  /**\n   * Stop the watcher and wait for the current watch iteration to complete.\n   *\n   * An alias for `[Symbol.asyncDispose]`, as a more readable alternative for\n   * environments that don't support the Disposable APIs yet.\n   */\n  dispose(): Promise<void>;\n\n  /**\n   * Wait for the watcher to stop.\n   *\n   * The watcher will only stop if `dispose()` or `[Symbol.asyncDispose]()` are called.\n   *\n   * If neither of those is called, awaiting this promise will wait forever.\n   */\n  waitForEnd(): Promise<void>;\n}\n"]}
1122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit.js","sourceRoot":"","sources":["toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import '../private/dispose-polyfill';\nimport * as path from 'node:path';\nimport type { TemplateDiff } from '@aws-cdk/cloudformation-diff';\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 { NonInteractiveIoHost } from './non-interactive-io-host';\nimport type { ToolkitServices } from './private';\nimport { assemblyFromSource } from './private';\nimport { ToolkitError } from './toolkit-error';\nimport type { DeployResult, DestroyResult, RollbackResult } from './types';\nimport type {\n  BootstrapEnvironments,\n  BootstrapOptions,\n  BootstrapResult,\n  EnvironmentBootstrapResult,\n} from '../actions/bootstrap';\nimport { BootstrapSource } from '../actions/bootstrap';\nimport { AssetBuildTime, type DeployOptions } from '../actions/deploy';\nimport {\n  buildParameterMap,\n  type PrivateDeployOptions,\n  removePublishedAssetsFromWorkGraph,\n} from '../actions/deploy/private';\nimport { type DestroyOptions } from '../actions/destroy';\nimport type { DiffOptions } from '../actions/diff';\nimport { appendObject, prepareDiff } from '../actions/diff/private';\nimport type { DriftOptions, DriftResult } from '../actions/drift';\nimport { type ListOptions } from '../actions/list';\nimport type { MappingGroup, RefactorOptions } from '../actions/refactor';\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 SdkBaseClientConfig, type IBaseCredentialsProvider, type SdkConfig, BaseCredentials } from '../api/aws-auth';\nimport { sdkRequestHandler } from '../api/aws-auth/awscli-compatible';\nimport { SdkProvider, IoHostSdkLogger } from '../api/aws-auth/private';\nimport { Bootstrapper } from '../api/bootstrap';\nimport type { ICloudAssemblySource } from '../api/cloud-assembly';\nimport { CachedCloudAssembly, StackSelectionStrategy } from '../api/cloud-assembly';\nimport type { StackAssembly } from '../api/cloud-assembly/private';\nimport { ALL_STACKS } from '../api/cloud-assembly/private';\nimport { CloudAssemblySourceBuilder } from '../api/cloud-assembly/source-builder';\nimport type { StackCollection } from '../api/cloud-assembly/stack-collection';\nimport { Deployments } from '../api/deployments';\nimport { DiffFormatter } from '../api/diff';\nimport { detectStackDrift } from '../api/drift';\nimport { DriftFormatter } from '../api/drift/drift-formatter';\nimport type { IIoHost, IoMessageLevel, ToolkitAction } from '../api/io';\nimport type { IoHelper } from '../api/io/private';\nimport { asIoHelper, IO, SPAN, withoutColor, withoutEmojis, withTrimmedWhitespace } from '../api/io/private';\nimport { CloudWatchLogEventMonitor, findCloudWatchLogGroups } from '../api/logs-monitor';\nimport { Mode, PluginHost } from '../api/plugin';\nimport {\n  AmbiguityError,\n  ambiguousMovements,\n  findResourceMovements,\n  formatAmbiguousMappings,\n  formatTypedMappings,\n  fromManifestAndExclusionList,\n  resourceMappings,\n  usePrescribedMappings,\n} from '../api/refactoring';\nimport type { ResourceMapping } from '../api/refactoring/cloudformation';\nimport { ResourceMigrator } from '../api/resource-import';\nimport { tagsForStack } from '../api/tags';\nimport { DEFAULT_TOOLKIT_STACK_NAME } from '../api/toolkit-info';\nimport type { AssetBuildNode, AssetPublishNode, Concurrency, StackNode } from '../api/work-graph';\nimport { WorkGraphBuilder } from '../api/work-graph';\nimport type { AssemblyData, StackDetails, SuccessfulDeployStackResult } from '../payloads';\nimport { PermissionChangeType } from '../payloads';\nimport { formatErrorMessage, formatTime, obscureTemplate, serializeStructure, validateSnsTopicArn } from '../util';\nimport { pLimit } from '../util/concurrency';\nimport { promiseWithResolvers } from '../util/promises';\n\nexport interface ToolkitOptions {\n  /**\n   * The IoHost implementation, handling the inline interactions between the Toolkit and an integration.\n   */\n  readonly ioHost?: IIoHost;\n\n  /**\n   * Allow emojis in messages sent to the IoHost.\n   *\n   * @default true\n   */\n  readonly 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  readonly color?: boolean;\n\n  /**\n   * Configuration options for the SDK.\n   */\n  readonly sdkConfig?: SdkConfig;\n\n  /**\n   * Name of the toolkit stack to be used.\n   *\n   * @default \"CDKToolkit\"\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Fail Cloud Assemblies\n   *\n   * @default \"error\"\n   */\n  readonly assemblyFailureAt?: 'error' | 'warn' | 'none';\n\n  /**\n   * The plugin host to use for loading and querying plugins\n   *\n   * By default, a unique instance of a plugin managing class will be used.\n   *\n   * Use `toolkit.pluginHost.load()` to load plugins into the plugin host from disk.\n   *\n   * @default - A fresh plugin host\n   */\n  readonly pluginHost?: PluginHost;\n}\n\n/**\n * The AWS CDK Programmatic Toolkit\n */\nexport class Toolkit extends CloudAssemblySourceBuilder {\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\n  /**\n   * The plugin host for loading and managing plugins\n   */\n  public readonly pluginHost: PluginHost;\n\n  /**\n   * Cache of the internal SDK Provider instance\n   */\n  private sdkProviderCache?: SdkProvider;\n\n  private baseCredentials: IBaseCredentialsProvider;\n\n  public constructor(private readonly props: ToolkitOptions = {}) {\n    super();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n\n    this.pluginHost = props.pluginHost ?? new PluginHost();\n\n    let ioHost = props.ioHost ?? new NonInteractiveIoHost();\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    this.baseCredentials = props.sdkConfig?.baseCredentials ?? BaseCredentials.awsCliCompatible();\n  }\n\n  /**\n   * Access to the AWS SDK\n   * @internal\n   */\n  protected async sdkProvider(action: ToolkitAction): Promise<SdkProvider> {\n    // @todo this needs to be different instance per action\n    if (!this.sdkProviderCache) {\n      const ioHelper = asIoHelper(this.ioHost, action);\n      const clientConfig: SdkBaseClientConfig = {\n        requestHandler: sdkRequestHandler(this.props.sdkConfig?.httpOptions?.agent),\n      };\n\n      const config = await this.baseCredentials.sdkBaseConfig(ioHelper, clientConfig);\n      this.sdkProviderCache = new SdkProvider(config.credentialProvider, config.defaultRegion, {\n        ioHelper,\n        logger: new IoHostSdkLogger(ioHelper),\n        pluginHost: this.pluginHost,\n        requestHandler: clientConfig.requestHandler,\n      });\n    }\n\n    return this.sdkProviderCache;\n  }\n\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   * @internal\n   */\n  protected override async sourceBuilderServices(): Promise<ToolkitServices> {\n    return {\n      ioHelper: asIoHelper(this.ioHost, 'assembly'),\n      sdkProvider: await this.sdkProvider('assembly'),\n      pluginHost: this.pluginHost,\n    };\n  }\n\n  /**\n   * Bootstrap Action\n   */\n  public async bootstrap(environments: BootstrapEnvironments, options: BootstrapOptions = {}): Promise<BootstrapResult> {\n    const startTime = Date.now();\n    const results: EnvironmentBootstrapResult[] = [];\n\n    const ioHelper = asIoHelper(this.ioHost, 'bootstrap');\n    const bootstrapEnvironments = await environments.getEnvironments(this.ioHost);\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\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        const envTime = await bootstrapSpan.end();\n        const result: EnvironmentBootstrapResult = {\n          environment,\n          status: bootstrapResult.noOp ? 'no-op' : 'success',\n          duration: envTime.asMs,\n        };\n        results.push(result);\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    return {\n      environments: results,\n      duration: Date.now() - startTime,\n    };\n  }\n\n  /**\n   * Synth Action\n   *\n   * The caller assumes ownership of the `CachedCloudAssembly` and is responsible for calling `dispose()` on\n   * it after use.\n   */\n  public async synth(cx: ICloudAssemblySource, options: SynthOptions = {}): Promise<CachedCloudAssembly> {\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\n    // NOTE: NOT 'await using' because we return ownership to the caller\n    const assembly = await assemblyFromSource(synthSpan.asHelper, cx);\n\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];\n    await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), synthSpan.asHelper);\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.defaults.info(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`);\n    }\n\n    return new CachedCloudAssembly(assembly);\n  }\n\n  /**\n   * Diff Action\n   */\n  public async diff(cx: ICloudAssemblySource, options: DiffOptions = {}): Promise<{ [name: string]: TemplateDiff }> {\n    const ioHelper = asIoHelper(this.ioHost, 'diff');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    await using assembly = await assemblyFromSource(synthSpan.asHelper, cx);\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const diffSpan = await ioHelper.span(SPAN.DIFF_STACK).begin({ stacks: selectStacks });\n    const deployments = await this.deploymentsForAction('diff');\n\n    const strict = !!options.strict;\n    const contextLines = options.contextLines || 3;\n\n    let diffs = 0;\n\n    const templateInfos = await prepareDiff(diffSpan.asHelper, stacks, deployments, await this.sdkProvider('diff'), options);\n    const templateDiffs: { [name: string]: TemplateDiff } = {};\n    for (const templateInfo of templateInfos) {\n      const formatter = new DiffFormatter({ templateInfo });\n      const stackDiff = formatter.formatStackDiff({ strict, contextLines });\n\n      // Security Diff\n      const securityDiff = formatter.formatSecurityDiff();\n      const formattedSecurityDiff = securityDiff.permissionChangeType !== PermissionChangeType.NONE ? stackDiff.formattedDiff : undefined;\n      // We only warn about BROADENING changes\n      if (securityDiff.permissionChangeType == PermissionChangeType.BROADENING) {\n        const warningMessage = 'This deployment will make potentially sensitive changes according to your current security approval level.\\nPlease confirm you intend to make the following modifications:\\n';\n        await diffSpan.defaults.warn(warningMessage);\n        await diffSpan.defaults.info(securityDiff.formattedDiff);\n      }\n\n      // Stack Diff\n      diffs += stackDiff.numStacksWithChanges;\n      appendObject(templateDiffs, formatter.diffs);\n      await diffSpan.notify(IO.CDK_TOOLKIT_I4002.msg(stackDiff.formattedDiff, {\n        stack: templateInfo.newTemplate,\n        diffs: formatter.diffs,\n        numStacksWithChanges: stackDiff.numStacksWithChanges,\n        permissionChanges: securityDiff.permissionChangeType,\n        formattedDiff: {\n          diff: stackDiff.formattedDiff,\n          security: formattedSecurityDiff,\n        },\n      }));\n    }\n\n    await diffSpan.end(`✨ Number of stacks with differences: ${diffs}`, {\n      numStacksWithChanges: diffs,\n      diffs: templateDiffs,\n    });\n\n    return templateDiffs;\n  }\n\n  /**\n   * Drift Action\n   */\n  public async drift(cx: ICloudAssemblySource, options: DriftOptions): Promise<{ [name: string]: DriftResult }> {\n    const ioHelper = asIoHelper(this.ioHost, 'drift');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    await using assembly = await assemblyFromSource(synthSpan.asHelper, cx);\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const driftSpan = await ioHelper.span(SPAN.DRIFT_APP).begin({ stacks: selectStacks });\n    const allDriftResults: { [name: string]: DriftResult } = {};\n    const unavailableDrifts = [];\n    const sdkProvider = await this.sdkProvider('drift');\n\n    for (const stack of stacks.stackArtifacts) {\n      const cfn = (await sdkProvider.forEnvironment(stack.environment, Mode.ForReading)).sdk.cloudFormation();\n      const driftResults = await detectStackDrift(cfn, driftSpan.asHelper, stack.stackName);\n\n      if (!driftResults.StackResourceDrifts) {\n        const stackName = stack.displayName ?? stack.stackName;\n        unavailableDrifts.push(stackName);\n        await driftSpan.notify(IO.CDK_TOOLKIT_W4591.msg(`${stackName}: No drift results available`, { stack }));\n        continue;\n      }\n\n      const formatter = new DriftFormatter({ stack, resourceDrifts: driftResults.StackResourceDrifts });\n      const driftOutput = formatter.formatStackDrift();\n      const stackDrift = {\n        numResourcesWithDrift: driftOutput.numResourcesWithDrift,\n        numResourcesUnchecked: driftOutput.numResourcesUnchecked,\n        formattedDrift: {\n          unchanged: driftOutput.unchanged,\n          unchecked: driftOutput.unchecked,\n          modified: driftOutput.modified,\n          deleted: driftOutput.deleted,\n        },\n      };\n      allDriftResults[formatter.stackName] = stackDrift;\n\n      // header\n      await driftSpan.defaults.info(driftOutput.stackHeader);\n\n      // print the different sections at different levels\n      if (driftOutput.unchanged) {\n        await driftSpan.defaults.debug(driftOutput.unchanged);\n      }\n      if (driftOutput.unchecked) {\n        await driftSpan.defaults.debug(driftOutput.unchecked);\n      }\n      if (driftOutput.modified) {\n        await driftSpan.defaults.info(driftOutput.modified);\n      }\n      if (driftOutput.deleted) {\n        await driftSpan.defaults.info(driftOutput.deleted);\n      }\n\n      // main stack result\n      await driftSpan.notify(IO.CDK_TOOLKIT_I4590.msg(driftOutput.summary, {\n        stack,\n        drift: stackDrift,\n      }));\n    }\n\n    // print summary\n    const totalDrifts = Object.values(allDriftResults).reduce((total, current) => total + (current.numResourcesWithDrift ?? 0), 0);\n    const totalUnchecked = Object.values(allDriftResults).reduce((total, current) => total + (current.numResourcesUnchecked ?? 0), 0);\n    await driftSpan.end(`\\n✨  Number of resources with drift: ${totalDrifts}${totalUnchecked ? ` (${totalUnchecked} unchecked)` : ''}`);\n    if (unavailableDrifts.length) {\n      await driftSpan.defaults.warn(`\\n⚠️  Failed to check drift for ${unavailableDrifts.length} stack(s). Check log for more details.`);\n    }\n\n    return allDriftResults;\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    await using assembly = await assemblyFromSource(ioHelper, 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<DeployResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'deploy');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await 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: PrivateDeployOptions = {}): Promise<DeployResult> {\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 = await assembly.selectStacksV2(selectStacks);\n    await this.validateStacksMetadata(stackCollection, ioHelper);\n    const synthDuration = await synthSpan.end();\n\n    const ret: DeployResult = {\n      stacks: [],\n    };\n\n    if (stackCollection.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E5001.msg('This app contains no stacks'));\n      return ret;\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    if (options.deploymentMethod?.method === 'hotswap' ) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_W5400.msg([\n        '⚠️ Hotswap deployments 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.forceAssetPublishing,\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.defaults.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 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        });\n\n        return;\n      }\n\n      const currentTemplate = await deployments.readCurrentTemplate(stack);\n\n      const formatter = new DiffFormatter({\n        templateInfo: {\n          oldTemplate: currentTemplate,\n          newTemplate: stack,\n        },\n      });\n\n      const securityDiff = formatter.formatSecurityDiff();\n\n      // Send a request response with the formatted security diff as part of the message,\n      // and the template diff as data\n      // (IoHost decides whether to print depending on permissionChangeType)\n      const deployMotivation = '\"--require-approval\" is enabled and stack includes security-sensitive updates.';\n      const deployQuestion = `${securityDiff.formattedDiff}\\n\\n${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: securityDiff.permissionChangeType,\n        templateDiffs: formatter.diffs,\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            forceDeployment: options.forceDeployment,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.parameters?.keepExistingParameters,\n            rollback,\n            extraUserAgent: options.extraUserAgent,\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              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              // Perform a rollback\n              await this._rollback(assembly, action, {\n                stacks: {\n                  patterns: [stack.hierarchicalId],\n                  strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE,\n                },\n                orphanFailedResources: options.orphanFailedResourcesDuringRollback,\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              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              // 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\n        ret.stacks.push({\n          stackName: stack.stackName,\n          environment: {\n            account: stack.environment.account,\n            region: stack.environment.region,\n          },\n          stackArn: deployResult.stackArn,\n          outputs: deployResult.outputs,\n          hierarchicalId: stack.hierarchicalId,\n        });\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.forceAssetPublishing) {\n      await removePublishedAssetsFromWorkGraph(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    return ret;\n  }\n\n  /**\n   * Watch Action\n   *\n   * Continuously observe project files and deploy the selected stacks\n   * automatically when changes are detected. Defaults to hotswap deployments.\n   *\n   * This function returns immediately, starting a watcher in the background.\n   */\n  public async watch(cx: ICloudAssemblySource, options: WatchOptions = {}): Promise<IWatcher> {\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    await using assembly = await assemblyFromSource(ioHelper, cx, false);\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 = assembly.directory;\n    const watchExcludes = patternsArrayForWatch(options.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    });\n\n    // only exclude the outdir if it is under the rootDir\n    const relativeOutDir = path.relative(rootDir, outdir);\n    if (Boolean(relativeOutDir && !relativeOutDir.startsWith('..' + path.sep) && !path.isAbsolute(relativeOutDir))) {\n      watchExcludes.push(`${relativeOutDir}/**`);\n    }\n\n    watchExcludes.push('**/.*', '**/.*/**', '**/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    const watcher = chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        await ioHelper.defaults.debug(\"'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    const stoppedPromise = promiseWithResolvers<void>();\n\n    return {\n      async dispose() {\n        await watcher.close();\n        // Prevents Node from staying alive. There is no 'end' event that the watcher emits\n        // that we can know it's definitely done, so best we can do is tell it to stop watching,\n        // stop keeping Node alive, and then pretend that's everything we needed to do.\n        watcher.unref();\n        stoppedPromise.resolve();\n        return stoppedPromise.promise;\n      },\n      async waitForEnd() {\n        return stoppedPromise.promise;\n      },\n      async [Symbol.asyncDispose]() {\n        return this.dispose();\n      },\n    } satisfies IWatcher;\n  }\n\n  /**\n   * Rollback Action\n   *\n   * Rolls back the selected stacks.\n   */\n  public async rollback(cx: ICloudAssemblySource, options: RollbackOptions = {}): Promise<RollbackResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'rollback');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await 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<RollbackResult> {\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    await this.validateStacksMetadata(stacks, ioHelper);\n    await synthSpan.end();\n\n    const ret: RollbackResult = {\n      stacks: [],\n    };\n\n    if (stacks.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E6001.msg('No stacks selected'));\n      return ret;\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          orphanFailedResources: options.orphanFailedResources,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!stackResult.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        await rollbackSpan.end();\n\n        ret.stacks.push({\n          environment: {\n            account: stack.environment.account,\n            region: stack.environment.region,\n          },\n          stackName: stack.stackName,\n          stackArn: stackResult.stackArn,\n          result: stackResult.notInRollbackableState ? 'already-stable' : 'rolled-back',\n        });\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 ToolkitError.withCause('Rollback failed (use --force to orphan failing resources)', e);\n      }\n    }\n    if (!anyRollbackable) {\n      throw new ToolkitError('No stacks were in a state that could be rolled back');\n    }\n\n    return ret;\n  }\n\n  /**\n   * Refactor Action. Moves resources from one location (stack + logical ID) to another.\n   */\n  public async refactor(cx: ICloudAssemblySource, options: RefactorOptions = {}): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'refactor');\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    return this._refactor(assembly, ioHelper, options);\n  }\n\n  private async _refactor(assembly: StackAssembly, ioHelper: IoHelper, options: RefactorOptions = {}): Promise<void> {\n    if (options.mappings && options.exclude) {\n      throw new ToolkitError(\"Cannot use both 'exclude' and 'mappings'.\");\n    }\n\n    if (options.revert && !options.mappings) {\n      throw new ToolkitError(\"The 'revert' options can only be used with the 'mappings' option.\");\n    }\n\n    if (!options.dryRun) {\n      throw new ToolkitError('Refactor is not available yet. Too see the proposed changes, use the --dry-run flag.');\n    }\n\n    const sdkProvider = await this.sdkProvider('refactor');\n    try {\n      const mappings = await getMappings();\n      const typedMappings = mappings.map(m => m.toTypedMapping());\n      await ioHelper.notify(IO.CDK_TOOLKIT_I8900.msg(formatTypedMappings(typedMappings), {\n        typedMappings,\n      }));\n    } catch (e) {\n      if (e instanceof AmbiguityError) {\n        const paths = e.paths();\n        await ioHelper.notify(IO.CDK_TOOLKIT_I8900.msg(formatAmbiguousMappings(paths), {\n          ambiguousPaths: paths,\n        }));\n      } else {\n        throw e;\n      }\n    }\n\n    async function getMappings(): Promise<ResourceMapping[]> {\n      if (options.revert) {\n        return usePrescribedMappings(revert(options.mappings ?? []), sdkProvider);\n      }\n      if (options.mappings != null) {\n        return usePrescribedMappings(options.mappings ?? [], sdkProvider);\n      } else {\n        const stacks = await assembly.selectStacksV2(ALL_STACKS);\n        const exclude = fromManifestAndExclusionList(assembly.cloudAssembly.manifest, options.exclude);\n        const movements = await findResourceMovements(stacks.stackArtifacts, sdkProvider, exclude);\n        const ambiguous = ambiguousMovements(movements);\n        if (ambiguous.length === 0) {\n          const filteredStacks = await assembly.selectStacksV2(options.stacks ?? ALL_STACKS);\n          return resourceMappings(movements, filteredStacks.stackArtifacts);\n        } else {\n          throw new AmbiguityError(ambiguous);\n        }\n      }\n    }\n\n    function revert(mappings: MappingGroup[]): MappingGroup[] {\n      return mappings.map(group => ({\n        ...group,\n        resources: Object.fromEntries(Object.entries(group.resources).map(([src, dst]) => ([dst, src]))),\n      }));\n    }\n  }\n\n  /**\n   * Destroy Action\n   *\n   * Destroys the selected Stacks.\n   */\n  public async destroy(cx: ICloudAssemblySource, options: DestroyOptions = {}): Promise<DestroyResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'destroy');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await 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<DestroyResult> {\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    const stacks = (await assembly.selectStacksV2(selectStacks)).reversed();\n    await synthSpan.end();\n\n    const ret: DestroyResult = {\n      stacks: [],\n    };\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      await ioHelper.notify(IO.CDK_TOOLKIT_E7010.msg('Aborted by user'));\n      return ret;\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          const result = await deployments.destroyStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n          });\n\n          ret.stacks.push({\n            environment: {\n              account: stack.environment.account,\n              region: stack.environment.region,\n            },\n            stackName: stack.stackName,\n            stackArn: result.stackArn,\n            stackExisted: result.stackArn !== undefined,\n          });\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\n      return ret;\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':\n          return IO.CDK_ASSEMBLY_E9999;\n        case 'warn':\n          return IO.CDK_ASSEMBLY_W9999;\n        default:\n          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 to hotswap deployment\n    const deploymentMethod = options.deploymentMethod ?? { method: 'hotswap' };\n    const deployOptions: PrivateDeployOptions = {\n      ...options,\n      cloudWatchLogMonitor,\n      deploymentMethod,\n      extraUserAgent: `cdk-watch/hotswap-${deploymentMethod.method === 'hotswap' ? 'on' : 'off'}`,\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\n/**\n * The result of a `cdk.watch()` operation.\n */\nexport interface IWatcher extends AsyncDisposable {\n  /**\n   * Stop the watcher and wait for the current watch iteration to complete.\n   *\n   * An alias for `[Symbol.asyncDispose]`, as a more readable alternative for\n   * environments that don't support the Disposable APIs yet.\n   */\n  dispose(): Promise<void>;\n\n  /**\n   * Wait for the watcher to stop.\n   *\n   * The watcher will only stop if `dispose()` or `[Symbol.asyncDispose]()` are called.\n   *\n   * If neither of those is called, awaiting this promise will wait forever.\n   */\n  waitForEnd(): Promise<void>;\n}\n"]}