aws-cdk 2.1005.0 → 2.1007.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 (178) hide show
  1. package/README.md +1 -1
  2. package/THIRD_PARTY_LICENSES +86 -86
  3. package/build-info.json +2 -2
  4. package/db.json.gz +0 -0
  5. package/lib/api/aws-auth/awscli-compatible.js +9 -10
  6. package/lib/api/aws-auth/credential-plugins.js +6 -7
  7. package/lib/api/aws-auth/sdk-logger.js +3 -4
  8. package/lib/api/aws-auth/sdk-provider.js +11 -13
  9. package/lib/api/aws-auth/sdk.js +8 -9
  10. package/lib/api/aws-auth/tracing.js +3 -4
  11. package/lib/api/aws-auth/user-agent.js +4 -5
  12. package/lib/api/bootstrap/bootstrap-environment.d.ts +1 -1
  13. package/lib/api/bootstrap/bootstrap-environment.js +42 -46
  14. package/lib/api/bootstrap/bootstrap-props.d.ts +1 -1
  15. package/lib/api/bootstrap/bootstrap-props.js +1 -1
  16. package/lib/api/bootstrap/deploy-bootstrap.d.ts +1 -1
  17. package/lib/api/bootstrap/deploy-bootstrap.js +11 -14
  18. package/lib/api/{evaluate-cloudformation-template.d.ts → cloudformation/evaluate-cloudformation-template.d.ts} +4 -8
  19. package/lib/api/{evaluate-cloudformation-template.js → cloudformation/evaluate-cloudformation-template.js} +16 -25
  20. package/lib/api/cloudformation/index.d.ts +4 -0
  21. package/lib/api/cloudformation/index.js +21 -0
  22. package/lib/api/{deployments → cloudformation}/nested-stack-helpers.d.ts +3 -9
  23. package/lib/api/cloudformation/nested-stack-helpers.js +86 -0
  24. package/lib/api/cloudformation/stack-helpers.d.ts +88 -0
  25. package/lib/api/cloudformation/stack-helpers.js +158 -0
  26. package/lib/api/{util → cloudformation}/template-body-parameter.d.ts +3 -2
  27. package/lib/api/cloudformation/template-body-parameter.js +104 -0
  28. package/lib/api/context.js +3 -3
  29. package/lib/api/cxapp/cloud-assembly.d.ts +6 -4
  30. package/lib/api/cxapp/cloud-assembly.js +25 -26
  31. package/lib/api/cxapp/cloud-executable.d.ts +5 -0
  32. package/lib/api/cxapp/cloud-executable.js +9 -10
  33. package/lib/api/cxapp/environments.js +4 -4
  34. package/lib/api/cxapp/exec.d.ts +5 -4
  35. package/lib/api/cxapp/exec.js +76 -72
  36. package/lib/api/deployments/asset-publishing.d.ts +0 -2
  37. package/lib/api/deployments/asset-publishing.js +24 -31
  38. package/lib/api/deployments/assets.d.ts +1 -1
  39. package/lib/api/deployments/assets.js +12 -13
  40. package/lib/api/deployments/{cloudformation.d.ts → cfn-api.d.ts} +5 -102
  41. package/lib/api/deployments/cfn-api.js +438 -0
  42. package/lib/api/deployments/checks.d.ts +1 -1
  43. package/lib/api/deployments/checks.js +12 -13
  44. package/lib/api/deployments/deploy-stack.d.ts +2 -3
  45. package/lib/api/deployments/deploy-stack.js +34 -45
  46. package/lib/api/deployments/deployment-result.js +3 -3
  47. package/lib/api/deployments/deployments.d.ts +3 -3
  48. package/lib/api/deployments/deployments.js +35 -42
  49. package/lib/api/deployments/hotswap-deployments.d.ts +2 -2
  50. package/lib/api/deployments/hotswap-deployments.js +122 -69
  51. package/lib/api/deployments/index.d.ts +1 -2
  52. package/lib/api/deployments/index.js +2 -3
  53. package/lib/api/environment/environment-access.d.ts +2 -2
  54. package/lib/api/environment/environment-access.js +18 -20
  55. package/lib/api/environment/environment-resources.d.ts +1 -1
  56. package/lib/api/environment/environment-resources.js +17 -19
  57. package/lib/api/environment/index.d.ts +1 -0
  58. package/lib/api/environment/index.js +2 -1
  59. package/lib/api/environment/placeholders.js +23 -0
  60. package/lib/api/garbage-collection/garbage-collector.d.ts +1 -1
  61. package/lib/api/garbage-collection/garbage-collector.js +56 -66
  62. package/lib/api/garbage-collection/progress-printer.d.ts +1 -1
  63. package/lib/api/garbage-collection/progress-printer.js +7 -7
  64. package/lib/api/garbage-collection/stack-refresh.d.ts +1 -1
  65. package/lib/api/garbage-collection/stack-refresh.js +12 -15
  66. package/lib/api/hotswap/appsync-mapping-templates.d.ts +3 -3
  67. package/lib/api/hotswap/appsync-mapping-templates.js +25 -22
  68. package/lib/api/hotswap/code-build-projects.d.ts +3 -3
  69. package/lib/api/hotswap/code-build-projects.js +12 -7
  70. package/lib/api/hotswap/common.d.ts +13 -61
  71. package/lib/api/hotswap/common.js +40 -70
  72. package/lib/api/hotswap/ecs-services.d.ts +4 -4
  73. package/lib/api/hotswap/ecs-services.js +38 -21
  74. package/lib/api/hotswap/lambda-functions.d.ts +3 -3
  75. package/lib/api/hotswap/lambda-functions.js +23 -19
  76. package/lib/api/hotswap/s3-bucket-deployments.d.ts +3 -3
  77. package/lib/api/hotswap/s3-bucket-deployments.js +11 -7
  78. package/lib/api/hotswap/stepfunctions-state-machines.d.ts +3 -3
  79. package/lib/api/hotswap/stepfunctions-state-machines.js +8 -4
  80. package/lib/api/logs/find-cloudwatch-logs.js +6 -7
  81. package/lib/api/logs/logs-monitor.js +5 -8
  82. package/lib/api/plugin/plugin.js +6 -10
  83. package/lib/api/resource-import/importer.d.ts +8 -8
  84. package/lib/api/resource-import/importer.js +27 -42
  85. package/lib/api/resource-import/migrator.d.ts +3 -3
  86. package/lib/api/resource-import/migrator.js +6 -6
  87. package/lib/api/settings.d.ts +0 -3
  88. package/lib/api/settings.js +4 -40
  89. package/lib/api/stack-events/stack-activity-monitor.d.ts +1 -1
  90. package/lib/api/stack-events/stack-activity-monitor.js +12 -15
  91. package/lib/api/stack-events/stack-event-poller.js +9 -10
  92. package/lib/api/toolkit-info.d.ts +2 -2
  93. package/lib/api/toolkit-info.js +20 -24
  94. package/lib/{tree.d.ts → api/tree.d.ts} +2 -2
  95. package/lib/api/tree.js +37 -0
  96. package/lib/api/util/rwlock.js +4 -4
  97. package/lib/api/work-graph/work-graph-builder.js +4 -4
  98. package/lib/api/work-graph/work-graph.d.ts +1 -1
  99. package/lib/api/work-graph/work-graph.js +13 -15
  100. package/lib/cli/activity-printer/base.d.ts +2 -2
  101. package/lib/cli/activity-printer/base.js +6 -8
  102. package/lib/cli/activity-printer/current.js +7 -11
  103. package/lib/cli/activity-printer/history.js +2 -3
  104. package/lib/cli/cdk-toolkit.d.ts +16 -19
  105. package/lib/cli/cdk-toolkit.js +118 -74
  106. package/lib/cli/ci-systems.js +2 -3
  107. package/lib/cli/cli-config.js +4 -4
  108. package/lib/cli/cli.js +49 -50
  109. package/lib/cli/convert-to-user-input.js +110 -111
  110. package/lib/{toolkit → cli/io-host}/cli-io-host.d.ts +6 -2
  111. package/lib/cli/io-host/cli-io-host.js +356 -0
  112. package/lib/cli/io-host/index.d.ts +1 -0
  113. package/lib/{toolkit/error.js → cli/io-host/index.js} +2 -2
  114. package/lib/cli/messages.d.ts +1 -1
  115. package/lib/cli/messages.js +2 -3
  116. package/lib/cli/pretty-print-error.d.ts +1 -0
  117. package/lib/cli/pretty-print-error.js +35 -0
  118. package/lib/cli/root-dir.js +4 -4
  119. package/lib/cli/user-configuration.js +57 -14
  120. package/lib/cli/util/npm.js +3 -3
  121. package/lib/cli/util/yargs-helpers.d.ts +1 -1
  122. package/lib/cli/util/yargs-helpers.js +3 -3
  123. package/lib/cli/version.js +4 -4
  124. package/lib/commands/context.js +7 -8
  125. package/lib/commands/diff.d.ts +1 -0
  126. package/lib/commands/diff.js +7 -0
  127. package/lib/commands/init/index.d.ts +1 -0
  128. package/lib/commands/init/index.js +18 -0
  129. package/lib/commands/init/init-hooks.js +63 -0
  130. package/lib/commands/init/init.js +435 -0
  131. package/lib/{os.js → commands/init/os.js} +4 -4
  132. package/lib/{list-stacks.d.ts → commands/list-stacks.d.ts} +1 -1
  133. package/lib/{list-stacks.js → commands/list-stacks.js} +2 -2
  134. package/lib/commands/migrate.js +29 -32
  135. package/lib/context-providers/ami.d.ts +3 -1
  136. package/lib/context-providers/ami.js +8 -8
  137. package/lib/context-providers/availability-zones.d.ts +3 -1
  138. package/lib/context-providers/availability-zones.js +4 -4
  139. package/lib/context-providers/cc-api-provider.d.ts +8 -12
  140. package/lib/context-providers/cc-api-provider.js +94 -66
  141. package/lib/context-providers/endpoint-service-availability-zones.d.ts +3 -1
  142. package/lib/context-providers/endpoint-service-availability-zones.js +6 -6
  143. package/lib/context-providers/hosted-zones.d.ts +3 -1
  144. package/lib/context-providers/hosted-zones.js +11 -11
  145. package/lib/context-providers/index.d.ts +19 -5
  146. package/lib/context-providers/index.js +35 -17
  147. package/lib/context-providers/keys.d.ts +3 -1
  148. package/lib/context-providers/keys.js +8 -8
  149. package/lib/context-providers/load-balancers.js +15 -18
  150. package/lib/context-providers/security-groups.js +10 -12
  151. package/lib/context-providers/ssm-parameters.d.ts +3 -1
  152. package/lib/context-providers/ssm-parameters.js +7 -7
  153. package/lib/context-providers/vpcs.d.ts +3 -1
  154. package/lib/context-providers/vpcs.js +14 -15
  155. package/lib/index.js +124098 -123198
  156. package/lib/init-templates/.init-version.json +1 -1
  157. package/lib/init-templates/.recommended-feature-flags.json +3 -1
  158. package/lib/legacy-exports-source.d.ts +4 -5
  159. package/lib/legacy-exports-source.js +6 -7
  160. package/lib/logging.js +2 -2
  161. package/lib/notices.d.ts +1 -1
  162. package/lib/notices.js +26 -32
  163. package/package.json +29 -29
  164. package/lib/api/deployments/cloudformation.js +0 -597
  165. package/lib/api/deployments/nested-stack-helpers.js +0 -88
  166. package/lib/api/util/placeholders.js +0 -24
  167. package/lib/api/util/template-body-parameter.js +0 -103
  168. package/lib/diff.d.ts +0 -28
  169. package/lib/diff.js +0 -165
  170. package/lib/init-hooks.js +0 -63
  171. package/lib/init.js +0 -437
  172. package/lib/toolkit/cli-io-host.js +0 -353
  173. package/lib/toolkit/error.d.ts +0 -1
  174. package/lib/tree.js +0 -40
  175. /package/lib/api/{util → environment}/placeholders.d.ts +0 -0
  176. /package/lib/{init-hooks.d.ts → commands/init/init-hooks.d.ts} +0 -0
  177. /package/lib/{init.d.ts → commands/init/init.d.ts} +0 -0
  178. /package/lib/{os.d.ts → commands/init/os.d.ts} +0 -0
@@ -11,12 +11,13 @@ const fs = require("fs-extra");
11
11
  const promptly = require("promptly");
12
12
  const uuid = require("uuid");
13
13
  const user_configuration_1 = require("./user-configuration");
14
+ const api_1 = require("../../../@aws-cdk/tmp-toolkit-helpers/src/api");
14
15
  const private_1 = require("../../../@aws-cdk/tmp-toolkit-helpers/src/api/io/private");
15
- const api_1 = require("../api");
16
+ const api_2 = require("../api");
16
17
  const bootstrap_1 = require("../api/bootstrap");
17
18
  const cloud_assembly_1 = require("../api/cxapp/cloud-assembly");
18
19
  const environments_1 = require("../api/cxapp/environments");
19
- const deployments_1 = require("../api/deployments");
20
+ const cfn_api_1 = require("../api/deployments/cfn-api");
20
21
  const garbage_collector_1 = require("../api/garbage-collection/garbage-collector");
21
22
  const common_1 = require("../api/hotswap/common");
22
23
  const find_cloudwatch_logs_1 = require("../api/logs/find-cloudwatch-logs");
@@ -25,12 +26,11 @@ const resource_import_1 = require("../api/resource-import");
25
26
  const tags_1 = require("../api/tags");
26
27
  const work_graph_builder_1 = require("../api/work-graph/work-graph-builder");
27
28
  const deploy_1 = require("../commands/deploy");
29
+ const diff_1 = require("../commands/diff");
30
+ const list_stacks_1 = require("../commands/list-stacks");
28
31
  const migrate_1 = require("../commands/migrate");
29
- const diff_1 = require("../diff");
30
- const list_stacks_1 = require("../list-stacks");
31
32
  const logging_1 = require("../logging");
32
- const cli_io_host_1 = require("../toolkit/cli-io-host");
33
- const error_1 = require("../toolkit/error");
33
+ const io_host_1 = require("./io-host");
34
34
  const util_2 = require("../util");
35
35
  // Must use a require() otherwise esbuild complains about calling a namespace
36
36
  // eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/consistent-type-imports
@@ -64,19 +64,16 @@ var AssetBuildTime;
64
64
  */
65
65
  class CdkToolkit {
66
66
  constructor(props) {
67
- var _a, _b;
68
67
  this.props = props;
69
- this.ioHost = (_a = props.ioHost) !== null && _a !== void 0 ? _a : cli_io_host_1.CliIoHost.instance();
70
- this.toolkitStackName = (_b = props.toolkitStackName) !== null && _b !== void 0 ? _b : api_1.DEFAULT_TOOLKIT_STACK_NAME;
68
+ this.ioHost = props.ioHost ?? io_host_1.CliIoHost.instance();
69
+ this.toolkitStackName = props.toolkitStackName ?? api_2.DEFAULT_TOOLKIT_STACK_NAME;
71
70
  }
72
71
  async metadata(stackName, json) {
73
- var _a;
74
72
  const stacks = await this.selectSingleStackByName(stackName);
75
- printSerializedObject((_a = stacks.firstStack.manifest.metadata) !== null && _a !== void 0 ? _a : {}, json);
73
+ printSerializedObject(stacks.firstStack.manifest.metadata ?? {}, json);
76
74
  }
77
75
  async acknowledge(noticeId) {
78
- var _a;
79
- const acks = (_a = this.props.configuration.context.get('acknowledged-issue-numbers')) !== null && _a !== void 0 ? _a : [];
76
+ const acks = this.props.configuration.context.get('acknowledged-issue-numbers') ?? [];
80
77
  acks.push(Number(noticeId));
81
78
  this.props.configuration.context.set('acknowledged-issue-numbers', acks);
82
79
  await this.props.configuration.saveContext();
@@ -85,22 +82,41 @@ class CdkToolkit {
85
82
  const stacks = await this.selectStacksForDiff(options.stackNames, options.exclusively);
86
83
  const strict = !!options.strict;
87
84
  const contextLines = options.contextLines || 3;
88
- const stream = options.stream || process.stderr;
89
85
  const quiet = options.quiet || false;
90
86
  let diffs = 0;
91
87
  const parameterMap = buildParameterMap(options.parameters);
92
88
  if (options.templatePath !== undefined) {
93
89
  // Compare single stack against fixed template
94
90
  if (stacks.stackCount !== 1) {
95
- throw new error_1.ToolkitError('Can only select one stack when comparing to fixed template. Use --exclusively to avoid selecting multiple stacks.');
91
+ throw new api_1.ToolkitError('Can only select one stack when comparing to fixed template. Use --exclusively to avoid selecting multiple stacks.');
96
92
  }
97
93
  if (!(await fs.pathExists(options.templatePath))) {
98
- throw new error_1.ToolkitError(`There is no file at ${options.templatePath}`);
94
+ throw new api_1.ToolkitError(`There is no file at ${options.templatePath}`);
99
95
  }
100
96
  const template = (0, util_2.deserializeStructure)(await fs.readFile(options.templatePath, { encoding: 'UTF-8' }));
101
- diffs = options.securityOnly
102
- ? (0, util_2.numberFromBool)((0, diff_1.printSecurityDiff)(template, stacks.firstStack, diff_1.RequireApproval.Broadening, quiet))
103
- : (0, diff_1.printStackDiff)(template, stacks.firstStack, strict, contextLines, quiet, undefined, undefined, false, stream);
97
+ const formatter = new diff_1.DiffFormatter({
98
+ ioHelper: (0, private_1.asIoHelper)(this.ioHost, 'diff'),
99
+ oldTemplate: template,
100
+ newTemplate: stacks.firstStack,
101
+ });
102
+ if (options.securityOnly) {
103
+ const securityDiff = formatter.formatSecurityDiff({
104
+ requireApproval: diff_1.RequireApproval.BROADENING,
105
+ });
106
+ if (securityDiff.formattedDiff) {
107
+ (0, logging_1.info)(securityDiff.formattedDiff);
108
+ diffs += 1;
109
+ }
110
+ }
111
+ else {
112
+ const diff = formatter.formatStackDiff({
113
+ strict,
114
+ context: contextLines,
115
+ quiet,
116
+ });
117
+ diffs = diff.numStacksWithChanges;
118
+ (0, logging_1.info)(diff.formattedDiff);
119
+ }
104
120
  }
105
121
  else {
106
122
  // Compare N stacks against deployed templates
@@ -108,6 +124,11 @@ class CdkToolkit {
108
124
  const templateWithNestedStacks = await this.props.deployments.readCurrentTemplateWithNestedStacks(stack, options.compareAgainstProcessedTemplate);
109
125
  const currentTemplate = templateWithNestedStacks.deployedRootTemplate;
110
126
  const nestedStacks = templateWithNestedStacks.nestedStacks;
127
+ const formatter = new diff_1.DiffFormatter({
128
+ ioHelper: (0, private_1.asIoHelper)(this.ioHost, 'diff'),
129
+ oldTemplate: currentTemplate,
130
+ newTemplate: stack,
131
+ });
111
132
  const migrator = new resource_import_1.ResourceMigrator({
112
133
  deployments: this.props.deployments,
113
134
  ioHelper: (0, private_1.asIoHelper)(this.ioHost, 'diff'),
@@ -129,12 +150,12 @@ class CdkToolkit {
129
150
  catch (e) {
130
151
  (0, logging_1.debug)((0, util_2.formatErrorMessage)(e));
131
152
  if (!quiet) {
132
- stream.write(`Checking if the stack ${stack.stackName} exists before creating the changeset has failed, will base the diff on template differences (run again with -v to see the reason)\n`);
153
+ (0, logging_1.info)(`Checking if the stack ${stack.stackName} exists before creating the changeset has failed, will base the diff on template differences (run again with -v to see the reason)\n`);
133
154
  }
134
155
  stackExists = false;
135
156
  }
136
157
  if (stackExists) {
137
- changeSet = await (0, deployments_1.createDiffChangeSet)((0, private_1.asIoHelper)(this.ioHost, 'diff'), {
158
+ changeSet = await (0, cfn_api_1.createDiffChangeSet)((0, private_1.asIoHelper)(this.ioHost, 'diff'), {
138
159
  stack,
139
160
  uuid: uuid.v4(),
140
161
  deployments: this.props.deployments,
@@ -142,24 +163,42 @@ class CdkToolkit {
142
163
  sdkProvider: this.props.sdkProvider,
143
164
  parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),
144
165
  resourcesToImport,
145
- stream,
146
166
  });
147
167
  }
148
168
  else {
149
169
  (0, logging_1.debug)(`the stack '${stack.stackName}' has not been deployed to CloudFormation or describeStacks call failed, skipping changeset creation.`);
150
170
  }
151
171
  }
152
- const stackCount = options.securityOnly
153
- ? (0, util_2.numberFromBool)((0, diff_1.printSecurityDiff)(currentTemplate, stack, diff_1.RequireApproval.Broadening, quiet, stack.displayName, changeSet))
154
- : (0, diff_1.printStackDiff)(currentTemplate, stack, strict, contextLines, quiet, stack.displayName, changeSet, !!resourcesToImport, stream, nestedStacks);
155
- diffs += stackCount;
172
+ if (options.securityOnly) {
173
+ const securityDiff = formatter.formatSecurityDiff({
174
+ requireApproval: diff_1.RequireApproval.BROADENING,
175
+ stackName: stack.displayName,
176
+ changeSet,
177
+ });
178
+ if (securityDiff.formattedDiff) {
179
+ (0, logging_1.info)(securityDiff.formattedDiff);
180
+ diffs += 1;
181
+ }
182
+ }
183
+ else {
184
+ const diff = formatter.formatStackDiff({
185
+ strict,
186
+ context: contextLines,
187
+ quiet,
188
+ stackName: stack.displayName,
189
+ changeSet,
190
+ isImport: !!resourcesToImport,
191
+ nestedStackTemplates: nestedStacks,
192
+ });
193
+ (0, logging_1.info)(diff.formattedDiff);
194
+ diffs += diff.numStacksWithChanges;
195
+ }
156
196
  }
157
197
  }
158
- stream.write((0, util_1.format)('\n✨ Number of stacks with differences: %s\n', diffs));
198
+ (0, logging_1.info)((0, util_1.format)('\n✨ Number of stacks with differences: %s\n', diffs));
159
199
  return diffs && options.fail ? 1 : 0;
160
200
  }
161
201
  async deploy(options) {
162
- var _a, _b, _c, _d, _e;
163
202
  if (options.watch) {
164
203
  return this.watch(options);
165
204
  }
@@ -183,7 +222,7 @@ class CdkToolkit {
183
222
  toolkitStackName: this.toolkitStackName,
184
223
  ...options,
185
224
  });
186
- const requireApproval = (_a = options.requireApproval) !== null && _a !== void 0 ? _a : diff_1.RequireApproval.Broadening;
225
+ const requireApproval = options.requireApproval ?? diff_1.RequireApproval.BROADENING;
187
226
  const parameterMap = buildParameterMap(options.parameters);
188
227
  if (options.hotswap !== common_1.HotswapMode.FULL_DEPLOYMENT) {
189
228
  (0, logging_1.warning)('⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments');
@@ -191,7 +230,7 @@ class CdkToolkit {
191
230
  }
192
231
  let hotswapPropertiesFromSettings = this.props.configuration.settings.get(['hotswap']) || {};
193
232
  let hotswapPropertyOverrides = new common_1.HotswapPropertyOverrides();
194
- hotswapPropertyOverrides.ecsHotswapProperties = new common_1.EcsHotswapProperties((_b = hotswapPropertiesFromSettings.ecs) === null || _b === void 0 ? void 0 : _b.minimumHealthyPercent, (_c = hotswapPropertiesFromSettings.ecs) === null || _c === void 0 ? void 0 : _c.maximumHealthyPercent);
233
+ hotswapPropertyOverrides.ecsHotswapProperties = new common_1.EcsHotswapProperties(hotswapPropertiesFromSettings.ecs?.minimumHealthyPercent, hotswapPropertiesFromSettings.ecs?.maximumHealthyPercent);
195
234
  const stacks = stackCollection.stackArtifacts;
196
235
  const stackOutputs = {};
197
236
  const outputsFile = options.outputsFile;
@@ -211,14 +250,13 @@ class CdkToolkit {
211
250
  });
212
251
  };
213
252
  const deployStack = async (stackNode) => {
214
- var _a, _b;
215
253
  const stack = stackNode.stack;
216
254
  if (stackCollection.stackCount !== 1) {
217
255
  (0, logging_1.highlight)(stack.displayName);
218
256
  }
219
257
  if (!stack.environment) {
220
258
  // eslint-disable-next-line max-len
221
- throw new 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.`);
259
+ throw new api_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.`);
222
260
  }
223
261
  if (Object.keys(stack.template.Resources || {}).length === 0) {
224
262
  // The generated stack has no resources
@@ -237,9 +275,18 @@ class CdkToolkit {
237
275
  }
238
276
  return;
239
277
  }
240
- if (requireApproval !== diff_1.RequireApproval.Never) {
278
+ if (requireApproval !== diff_1.RequireApproval.NEVER) {
241
279
  const currentTemplate = await this.props.deployments.readCurrentTemplate(stack);
242
- if ((0, diff_1.printSecurityDiff)(currentTemplate, stack, requireApproval)) {
280
+ const formatter = new diff_1.DiffFormatter({
281
+ ioHelper: (0, private_1.asIoHelper)(this.ioHost, 'deploy'),
282
+ oldTemplate: currentTemplate,
283
+ newTemplate: stack,
284
+ });
285
+ const securityDiff = formatter.formatSecurityDiff({
286
+ requireApproval,
287
+ });
288
+ if (securityDiff.formattedDiff) {
289
+ (0, logging_1.info)(securityDiff.formattedDiff);
243
290
  await askUserConfirmation(this.ioHost, concurrency, '"--require-approval" is enabled and stack includes security-sensitive updates', 'Do you wish to deploy these changes');
244
291
  }
245
292
  }
@@ -249,11 +296,11 @@ class CdkToolkit {
249
296
  // - []: => cdk manages it, and the user wants to wipe it out.
250
297
  // - ['arn-1'] => cdk manages it, and the user wants to set it to ['arn-1'].
251
298
  const notificationArns = (!!options.notificationArns || !!stack.notificationArns)
252
- ? ((_a = options.notificationArns) !== null && _a !== void 0 ? _a : []).concat((_b = stack.notificationArns) !== null && _b !== void 0 ? _b : [])
299
+ ? (options.notificationArns ?? []).concat(stack.notificationArns ?? [])
253
300
  : undefined;
254
- for (const notificationArn of notificationArns !== null && notificationArns !== void 0 ? notificationArns : []) {
301
+ for (const notificationArn of notificationArns ?? []) {
255
302
  if (!(0, util_2.validateSnsTopicArn)(notificationArn)) {
256
- throw new error_1.ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);
303
+ throw new api_1.ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);
257
304
  }
258
305
  }
259
306
  const stackIndex = stacks.indexOf(stack) + 1;
@@ -270,7 +317,7 @@ class CdkToolkit {
270
317
  let iteration = 0;
271
318
  while (!deployResult) {
272
319
  if (++iteration > 2) {
273
- throw new error_1.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');
320
+ throw new api_1.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');
274
321
  }
275
322
  const r = await this.props.deployments.deployStack({
276
323
  stack,
@@ -330,7 +377,7 @@ class CdkToolkit {
330
377
  break;
331
378
  }
332
379
  default:
333
- throw new error_1.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`);
380
+ throw new api_1.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`);
334
381
  }
335
382
  }
336
383
  const message = deployResult.noOp
@@ -353,7 +400,7 @@ class CdkToolkit {
353
400
  catch (e) {
354
401
  // It has to be exactly this string because an integration test tests for
355
402
  // "bold(stackname) failed: ResourceNotReady: <error>"
356
- throw new error_1.ToolkitError([`❌ ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), (0, util_2.formatErrorMessage)(e)].join(' '));
403
+ throw new api_1.ToolkitError([`❌ ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), (0, util_2.formatErrorMessage)(e)].join(' '));
357
404
  }
358
405
  finally {
359
406
  if (options.cloudWatchLogMonitor) {
@@ -373,7 +420,7 @@ class CdkToolkit {
373
420
  }
374
421
  (0, logging_1.info)(`\n✨ Total time: ${(0, util_2.formatTime)(elapsedSynthTime + elapsedDeployTime)}s\n`);
375
422
  };
376
- const assetBuildTime = (_d = options.assetBuildTime) !== null && _d !== void 0 ? _d : AssetBuildTime.ALL_BEFORE_DEPLOY;
423
+ const assetBuildTime = options.assetBuildTime ?? AssetBuildTime.ALL_BEFORE_DEPLOY;
377
424
  const prebuildAssets = assetBuildTime === AssetBuildTime.ALL_BEFORE_DEPLOY;
378
425
  const concurrency = options.concurrency || 1;
379
426
  if (concurrency > 1) {
@@ -396,7 +443,7 @@ class CdkToolkit {
396
443
  const graphConcurrency = {
397
444
  'stack': concurrency,
398
445
  'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds
399
- 'asset-publish': ((_e = options.assetParallelism) !== null && _e !== void 0 ? _e : true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable
446
+ 'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable
400
447
  };
401
448
  await workGraph.doParallel(graphConcurrency, {
402
449
  deployStack,
@@ -437,11 +484,11 @@ class CdkToolkit {
437
484
  }
438
485
  catch (e) {
439
486
  (0, logging_1.error)('\n ❌ %s failed: %s', chalk.bold(stack.displayName), (0, util_2.formatErrorMessage)(e));
440
- throw new error_1.ToolkitError('Rollback failed (use --force to orphan failing resources)');
487
+ throw new api_1.ToolkitError('Rollback failed (use --force to orphan failing resources)');
441
488
  }
442
489
  }
443
490
  if (!anyRollbackable) {
444
- throw new error_1.ToolkitError('No stacks were in a state that could be rolled back');
491
+ throw new api_1.ToolkitError('No stacks were in a state that could be rolled back');
445
492
  }
446
493
  }
447
494
  async watch(options) {
@@ -450,7 +497,7 @@ class CdkToolkit {
450
497
  (0, logging_1.debug)("root directory used for 'watch' is: %s", rootDir);
451
498
  const watchSettings = this.props.configuration.settings.get(['watch']);
452
499
  if (!watchSettings) {
453
- throw new error_1.ToolkitError("Cannot use the 'watch' command without specifying at least one directory to monitor. " +
500
+ throw new api_1.ToolkitError("Cannot use the 'watch' command without specifying at least one directory to monitor. " +
454
501
  'Make sure to add a "watch" key to your cdk.json');
455
502
  }
456
503
  // For the "include" subkey under the "watch" key, the behavior is:
@@ -492,7 +539,7 @@ class CdkToolkit {
492
539
  }) : undefined;
493
540
  const deployAndWatch = async () => {
494
541
  latch = 'deploying';
495
- await (cloudWatchLogMonitor === null || cloudWatchLogMonitor === void 0 ? void 0 : cloudWatchLogMonitor.deactivate());
542
+ await cloudWatchLogMonitor?.deactivate();
496
543
  await this.invokeDeployFromWatch(options, cloudWatchLogMonitor);
497
544
  // If latch is still 'deploying' after the 'await', that's fine,
498
545
  // but if it's 'queued', that means we need to deploy again
@@ -504,7 +551,7 @@ class CdkToolkit {
504
551
  await this.invokeDeployFromWatch(options, cloudWatchLogMonitor);
505
552
  }
506
553
  latch = 'open';
507
- await (cloudWatchLogMonitor === null || cloudWatchLogMonitor === void 0 ? void 0 : cloudWatchLogMonitor.activate());
554
+ await cloudWatchLogMonitor?.activate();
508
555
  };
509
556
  chokidar
510
557
  .watch(watchIncludes, {
@@ -540,10 +587,10 @@ class CdkToolkit {
540
587
  this.ioHost.stackProgress = options.progress;
541
588
  }
542
589
  if (stacks.stackCount > 1) {
543
- throw new error_1.ToolkitError(`Stack selection is ambiguous, please choose a specific stack for import [${stacks.stackArtifacts.map((x) => x.id).join(', ')}]`);
590
+ throw new api_1.ToolkitError(`Stack selection is ambiguous, please choose a specific stack for import [${stacks.stackArtifacts.map((x) => x.id).join(', ')}]`);
544
591
  }
545
592
  if (!process.stdout.isTTY && !options.resourceMappingFile) {
546
- throw new error_1.ToolkitError('--resource-mapping is required when input is not a terminal');
593
+ throw new api_1.ToolkitError('--resource-mapping is required when input is not a terminal');
547
594
  }
548
595
  const stack = stacks.stackArtifacts[0];
549
596
  (0, logging_1.highlight)(stack.displayName);
@@ -627,12 +674,11 @@ class CdkToolkit {
627
674
  }
628
675
  }
629
676
  async list(selectors, options = {}) {
630
- var _a, _b, _c;
631
677
  const stacks = await (0, list_stacks_1.listStacks)(this, {
632
678
  selectors: selectors,
633
679
  });
634
680
  if (options.long && options.showDeps) {
635
- printSerializedObject(stacks, (_a = options.json) !== null && _a !== void 0 ? _a : false);
681
+ printSerializedObject(stacks, options.json ?? false);
636
682
  return 0;
637
683
  }
638
684
  if (options.showDeps) {
@@ -643,7 +689,7 @@ class CdkToolkit {
643
689
  dependencies: stack.dependencies,
644
690
  });
645
691
  }
646
- printSerializedObject(stackDeps, (_b = options.json) !== null && _b !== void 0 ? _b : false);
692
+ printSerializedObject(stackDeps, options.json ?? false);
647
693
  return 0;
648
694
  }
649
695
  if (options.long) {
@@ -655,7 +701,7 @@ class CdkToolkit {
655
701
  environment: stack.environment,
656
702
  });
657
703
  }
658
- printSerializedObject(long, (_c = options.json) !== null && _c !== void 0 ? _c : false);
704
+ printSerializedObject(long, options.json ?? false);
659
705
  return 0;
660
706
  }
661
707
  // just print stack IDs
@@ -678,7 +724,7 @@ class CdkToolkit {
678
724
  // if we have a single stack, print it to STDOUT
679
725
  if (stacks.stackCount === 1) {
680
726
  if (!quiet) {
681
- printSerializedObject((0, util_2.obscureTemplate)(stacks.firstStack.template), json !== null && json !== void 0 ? json : false);
727
+ printSerializedObject((0, util_2.obscureTemplate)(stacks.firstStack.template), json ?? false);
682
728
  }
683
729
  return undefined;
684
730
  }
@@ -721,7 +767,6 @@ class CdkToolkit {
721
767
  * @param options Options for Garbage Collection
722
768
  */
723
769
  async garbageCollect(userEnvironmentSpecs, options) {
724
- var _a, _b, _c;
725
770
  const environments = await this.defineEnvironments(userEnvironmentSpecs);
726
771
  for (const environment of environments) {
727
772
  (0, logging_1.success)(' ⏳ Garbage Collecting environment %s...', chalk.blue(environment.name));
@@ -732,9 +777,9 @@ class CdkToolkit {
732
777
  bootstrapStackName: options.bootstrapStackName,
733
778
  rollbackBufferDays: options.rollbackBufferDays,
734
779
  createdBufferDays: options.createdBufferDays,
735
- action: (_a = options.action) !== null && _a !== void 0 ? _a : 'full',
736
- type: (_b = options.type) !== null && _b !== void 0 ? _b : 'all',
737
- confirm: (_c = options.confirm) !== null && _c !== void 0 ? _c : true,
780
+ action: options.action ?? 'full',
781
+ type: options.type ?? 'all',
782
+ confirm: options.confirm ?? true,
738
783
  });
739
784
  await gc.garbageCollect();
740
785
  }
@@ -747,11 +792,11 @@ class CdkToolkit {
747
792
  if (globSpecs.length > 0 && !this.props.cloudExecutable.hasApp) {
748
793
  if (userEnvironmentSpecs.length > 0) {
749
794
  // User did request this glob
750
- throw new error_1.ToolkitError(`'${globSpecs}' is not an environment name. Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json' to use wildcards.`);
795
+ throw new api_1.ToolkitError(`'${globSpecs}' is not an environment name. Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json' to use wildcards.`);
751
796
  }
752
797
  else {
753
798
  // User did not request anything
754
- throw new error_1.ToolkitError("Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json'.");
799
+ throw new api_1.ToolkitError("Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json'.");
755
800
  }
756
801
  }
757
802
  const environments = [...(0, environments_1.environmentsFromDescriptors)(environmentSpecs)];
@@ -766,9 +811,8 @@ class CdkToolkit {
766
811
  * @param options Options for CDK app creation
767
812
  */
768
813
  async migrate(options) {
769
- var _a, _b, _c, _d, _e;
770
814
  (0, logging_1.warning)('This command is an experimental feature.');
771
- const language = (_b = (_a = options.language) === null || _a === void 0 ? void 0 : _a.toLowerCase()) !== null && _b !== void 0 ? _b : 'typescript';
815
+ const language = options.language?.toLowerCase() ?? 'typescript';
772
816
  const environment = (0, migrate_1.setEnvironment)(options.account, options.region);
773
817
  let generateTemplateOutput;
774
818
  let cfn;
@@ -789,7 +833,7 @@ class CdkToolkit {
789
833
  else if (scanType == migrate_1.TemplateSourceOptions.PATH) {
790
834
  const templateBody = (0, migrate_1.readFromPath)(options.fromPath);
791
835
  const parsedTemplate = (0, util_2.deserializeStructure)(templateBody);
792
- const templateId = (_d = (_c = parsedTemplate.Metadata) === null || _c === void 0 ? void 0 : _c.TemplateId) === null || _d === void 0 ? void 0 : _d.toString();
836
+ const templateId = parsedTemplate.Metadata?.TemplateId?.toString();
793
837
  if (templateId) {
794
838
  // if we have a template id, we can call describe generated template to get the resource identifiers
795
839
  // resource metadata, and template source to generate the template
@@ -809,7 +853,7 @@ class CdkToolkit {
809
853
  else if (scanType == migrate_1.TemplateSourceOptions.STACK) {
810
854
  const template = await (0, migrate_1.readFromStack)(options.stackName, this.props.sdkProvider, environment);
811
855
  if (!template) {
812
- throw new error_1.ToolkitError(`No template found for stack-name: ${options.stackName}`);
856
+ throw new api_1.ToolkitError(`No template found for stack-name: ${options.stackName}`);
813
857
  }
814
858
  generateTemplateOutput = {
815
859
  migrateJson: {
@@ -820,7 +864,7 @@ class CdkToolkit {
820
864
  }
821
865
  else {
822
866
  // We shouldn't ever get here, but just in case.
823
- throw new error_1.ToolkitError(`Invalid source option provided: ${scanType}`);
867
+ throw new api_1.ToolkitError(`Invalid source option provided: ${scanType}`);
824
868
  }
825
869
  const stack = (0, migrate_1.generateStack)(generateTemplateOutput.migrateJson.templateBody, options.stackName, language);
826
870
  (0, logging_1.success)(' ⏳ Generating CDK app for %s...', chalk.blue(options.stackName));
@@ -830,7 +874,7 @@ class CdkToolkit {
830
874
  }
831
875
  if ((0, migrate_1.isThereAWarning)(generateTemplateOutput)) {
832
876
  (0, logging_1.warning)(' ⚠️ Some resources could not be migrated completely. Please review the README.md file for more information.');
833
- (0, migrate_1.appendWarningsToReadme)(`${path.join((_e = options.outputPath) !== null && _e !== void 0 ? _e : process.cwd(), options.stackName)}/README.md`, generateTemplateOutput.resources);
877
+ (0, migrate_1.appendWarningsToReadme)(`${path.join(options.outputPath ?? process.cwd(), options.stackName)}/README.md`, generateTemplateOutput.resources);
834
878
  }
835
879
  }
836
880
  catch (e) {
@@ -873,7 +917,7 @@ class CdkToolkit {
873
917
  });
874
918
  const allStacks = await this.selectStacksForList([]);
875
919
  const autoValidateStacks = autoValidate
876
- ? allStacks.filter((art) => { var _a; return (_a = art.validateOnSynth) !== null && _a !== void 0 ? _a : false; })
920
+ ? allStacks.filter((art) => art.validateOnSynth ?? false)
877
921
  : new cloud_assembly_1.StackCollection(assembly, []);
878
922
  this.validateStacksSelected(selectedForDiff.concat(autoValidateStacks), stackNames);
879
923
  await this.validateStacks(selectedForDiff.concat(autoValidateStacks));
@@ -906,7 +950,7 @@ class CdkToolkit {
906
950
  */
907
951
  validateStacksSelected(stacks, stackNames) {
908
952
  if (stackNames.length != 0 && stacks.stackCount == 0) {
909
- throw new error_1.ToolkitError(`No stacks match the name(s) ${stackNames}`);
953
+ throw new api_1.ToolkitError(`No stacks match the name(s) ${stackNames}`);
910
954
  }
911
955
  }
912
956
  /**
@@ -920,7 +964,7 @@ class CdkToolkit {
920
964
  });
921
965
  // Could have been a glob so check that we evaluated to exactly one
922
966
  if (stacks.stackCount > 1) {
923
- throw new error_1.ToolkitError(`This command requires exactly one stack and we matched more than one: ${stacks.stackIds}`);
967
+ throw new api_1.ToolkitError(`This command requires exactly one stack and we matched more than one: ${stacks.stackIds}`);
924
968
  }
925
969
  return assembly.stackById(stacks.firstStack.id);
926
970
  }
@@ -934,7 +978,7 @@ class CdkToolkit {
934
978
  async invokeDeployFromWatch(options, cloudWatchLogMonitor) {
935
979
  const deployOptions = {
936
980
  ...options,
937
- requireApproval: diff_1.RequireApproval.Never,
981
+ requireApproval: diff_1.RequireApproval.NEVER,
938
982
  // if 'watch' is called by invoking 'cdk deploy --watch',
939
983
  // we need to make sure to not call 'deploy' with 'watch' again,
940
984
  // as that would lead to a cycle
@@ -998,15 +1042,15 @@ async function askUserConfirmation(ioHost, concurrency, motivation, question) {
998
1042
  await ioHost.withCorkedLogging(async () => {
999
1043
  // only talk to user if STDIN is a terminal (otherwise, fail)
1000
1044
  if (!TESTING && !process.stdin.isTTY) {
1001
- throw new error_1.ToolkitError(`${motivation}, but terminal (TTY) is not attached so we are unable to get a confirmation from the user`);
1045
+ throw new api_1.ToolkitError(`${motivation}, but terminal (TTY) is not attached so we are unable to get a confirmation from the user`);
1002
1046
  }
1003
1047
  // only talk to user if concurrency is 1 (otherwise, fail)
1004
1048
  if (concurrency > 1) {
1005
- throw new error_1.ToolkitError(`${motivation}, but concurrency is greater than 1 so we are unable to get a confirmation from the user`);
1049
+ throw new api_1.ToolkitError(`${motivation}, but concurrency is greater than 1 so we are unable to get a confirmation from the user`);
1006
1050
  }
1007
1051
  const confirmed = await promptly.confirm(`${chalk.cyan(question)} (y/n)?`);
1008
1052
  if (!confirmed) {
1009
- throw new error_1.ToolkitError('Aborted by user');
1053
+ throw new api_1.ToolkitError('Aborted by user');
1010
1054
  }
1011
1055
  });
1012
1056
  }
@@ -1032,4 +1076,4 @@ function stackMetadataLogger(verbose) {
1032
1076
  }
1033
1077
  };
1034
1078
  }
1035
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-toolkit.js","sourceRoot":"","sources":["cdk-toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { format } from 'util';\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 * as promptly from 'promptly';\nimport * as uuid from 'uuid';\nimport type { Configuration } from './user-configuration';\nimport { PROJECT_CONFIG } from './user-configuration';\nimport { asIoHelper } from '../../../@aws-cdk/tmp-toolkit-helpers/src/api/io/private';\nimport { DEFAULT_TOOLKIT_STACK_NAME } from '../api';\nimport type { SdkProvider } from '../api/aws-auth';\nimport type { BootstrapEnvironmentOptions } from '../api/bootstrap';\nimport { Bootstrapper } from '../api/bootstrap';\nimport type {\n  CloudAssembly,\n  StackSelector,\n} from '../api/cxapp/cloud-assembly';\nimport {\n  DefaultSelection,\n  ExtendedStackSelection,\n  StackCollection,\n} from '../api/cxapp/cloud-assembly';\nimport type { CloudExecutable } from '../api/cxapp/cloud-executable';\nimport { environmentsFromDescriptors, globEnvironmentsFromStacks, looksLikeGlob } from '../api/cxapp/environments';\nimport type { DeploymentMethod, SuccessfulDeployStackResult, Deployments } from '../api/deployments';\nimport { createDiffChangeSet } from '../api/deployments';\nimport { GarbageCollector } from '../api/garbage-collection/garbage-collector';\nimport { HotswapMode, HotswapPropertyOverrides, EcsHotswapProperties } from '../api/hotswap/common';\nimport { findCloudWatchLogGroups } from '../api/logs/find-cloudwatch-logs';\nimport { CloudWatchLogEventMonitor } from '../api/logs/logs-monitor';\nimport { ResourceImporter, removeNonImportResources, ResourceMigrator } from '../api/resource-import';\nimport { tagsForStack, type Tag } from '../api/tags';\nimport type { AssetBuildNode, AssetPublishNode, Concurrency, StackNode, WorkGraph } from '../api/work-graph';\nimport { WorkGraphBuilder } from '../api/work-graph/work-graph-builder';\nimport { StackActivityProgress } from '../commands/deploy';\nimport type {\n  FromScan,\n  GenerateTemplateOutput,\n} from '../commands/migrate';\nimport {\n  generateCdkApp,\n  generateStack,\n  readFromPath,\n  readFromStack,\n  setEnvironment,\n  parseSourceOptions,\n  generateTemplate,\n  TemplateSourceOptions,\n  CfnTemplateGeneratorProvider,\n  writeMigrateJsonFile,\n  buildGenertedTemplateOutput,\n  appendWarningsToReadme,\n  isThereAWarning,\n  buildCfnClient,\n} from '../commands/migrate';\nimport { printSecurityDiff, printStackDiff, RequireApproval } from '../diff';\nimport { listStacks } from '../list-stacks';\nimport { result as logResult, debug, error, highlight, info, success, warning } from '../logging';\nimport { CliIoHost } from '../toolkit/cli-io-host';\nimport { ToolkitError } from '../toolkit/error';\nimport { numberFromBool, partition, validateSnsTopicArn, formatErrorMessage, deserializeStructure, obscureTemplate, serializeStructure, formatTime } from '../util';\n\n// Must use a require() otherwise esbuild complains about calling a namespace\n// eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/consistent-type-imports\nconst pLimit: typeof import('p-limit') = require('p-limit');\n\nlet TESTING = false;\n\nexport function markTesting() {\n  TESTING = true;\n}\n\nexport interface CdkToolkitProps {\n  /**\n   * The Cloud Executable\n   */\n  cloudExecutable: CloudExecutable;\n\n  /**\n   * The provisioning engine used to apply changes to the cloud\n   */\n  deployments: Deployments;\n\n  /**\n   * The CliIoHost that's used for I/O operations\n   */\n  ioHost?: CliIoHost;\n\n  /**\n   * Name of the toolkit stack to use/deploy\n   *\n   * @default CDKToolkit\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Whether to be verbose\n   *\n   * @default false\n   */\n  verbose?: boolean;\n\n  /**\n   * Don't stop on error metadata\n   *\n   * @default false\n   */\n  ignoreErrors?: boolean;\n\n  /**\n   * Treat warnings in metadata as errors\n   *\n   * @default false\n   */\n  strict?: boolean;\n\n  /**\n   * Application configuration (settings and context)\n   */\n  configuration: Configuration;\n\n  /**\n   * AWS object (used by synthesizer and contextprovider)\n   */\n  sdkProvider: SdkProvider;\n}\n\n/**\n * When to build assets\n */\nexport enum AssetBuildTime {\n  /**\n   * Build all assets before deploying the first stack\n   *\n   * This is intended for expensive Docker image builds; so that if the Docker image build\n   * fails, no stacks are unnecessarily deployed (with the attendant wait time).\n   */\n  ALL_BEFORE_DEPLOY = 'all-before-deploy',\n\n  /**\n   * Build assets just-in-time, before publishing\n   */\n  JUST_IN_TIME = 'just-in-time',\n}\n\n/**\n * Toolkit logic\n *\n * The toolkit runs the `cloudExecutable` to obtain a cloud assembly and\n * deploys applies them to `cloudFormation`.\n */\nexport class CdkToolkit {\n  private ioHost: CliIoHost;\n  private toolkitStackName: string;\n\n  constructor(private readonly props: CdkToolkitProps) {\n    this.ioHost = props.ioHost ?? CliIoHost.instance();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n  }\n\n  public async metadata(stackName: string, json: boolean) {\n    const stacks = await this.selectSingleStackByName(stackName);\n    printSerializedObject(stacks.firstStack.manifest.metadata ?? {}, json);\n  }\n\n  public async acknowledge(noticeId: string) {\n    const acks = this.props.configuration.context.get('acknowledged-issue-numbers') ?? [];\n    acks.push(Number(noticeId));\n    this.props.configuration.context.set('acknowledged-issue-numbers', acks);\n    await this.props.configuration.saveContext();\n  }\n\n  public async diff(options: DiffOptions): Promise<number> {\n    const stacks = await this.selectStacksForDiff(options.stackNames, options.exclusively);\n\n    const strict = !!options.strict;\n    const contextLines = options.contextLines || 3;\n    const stream = options.stream || process.stderr;\n    const quiet = options.quiet || false;\n\n    let diffs = 0;\n    const parameterMap = buildParameterMap(options.parameters);\n\n    if (options.templatePath !== undefined) {\n      // Compare single stack against fixed template\n      if (stacks.stackCount !== 1) {\n        throw new ToolkitError(\n          'Can only select one stack when comparing to fixed template. Use --exclusively to avoid selecting multiple stacks.',\n        );\n      }\n\n      if (!(await fs.pathExists(options.templatePath))) {\n        throw new ToolkitError(`There is no file at ${options.templatePath}`);\n      }\n\n      const template = deserializeStructure(await fs.readFile(options.templatePath, { encoding: 'UTF-8' }));\n      diffs = options.securityOnly\n        ? numberFromBool(printSecurityDiff(template, stacks.firstStack, RequireApproval.Broadening, quiet))\n        : printStackDiff(template, stacks.firstStack, strict, contextLines, quiet, undefined, undefined, false, stream);\n    } else {\n      // Compare N stacks against deployed templates\n      for (const stack of stacks.stackArtifacts) {\n        const templateWithNestedStacks = await this.props.deployments.readCurrentTemplateWithNestedStacks(\n          stack,\n          options.compareAgainstProcessedTemplate,\n        );\n        const currentTemplate = templateWithNestedStacks.deployedRootTemplate;\n        const nestedStacks = templateWithNestedStacks.nestedStacks;\n\n        const migrator = new ResourceMigrator({\n          deployments: this.props.deployments,\n          ioHelper: asIoHelper(this.ioHost, 'diff'),\n        });\n        const resourcesToImport = await migrator.tryGetResources(await this.props.deployments.resolveEnvironment(stack));\n        if (resourcesToImport) {\n          removeNonImportResources(stack);\n        }\n\n        let changeSet = undefined;\n\n        if (options.changeSet) {\n          let stackExists = false;\n          try {\n            stackExists = await this.props.deployments.stackExists({\n              stack,\n              deployName: stack.stackName,\n              tryLookupRole: true,\n            });\n          } catch (e: any) {\n            debug(formatErrorMessage(e));\n            if (!quiet) {\n              stream.write(\n                `Checking if the stack ${stack.stackName} exists before creating the changeset has failed, will base the diff on template differences (run again with -v to see the reason)\\n`,\n              );\n            }\n            stackExists = false;\n          }\n\n          if (stackExists) {\n            changeSet = await createDiffChangeSet(asIoHelper(this.ioHost, 'diff'), {\n              stack,\n              uuid: uuid.v4(),\n              deployments: this.props.deployments,\n              willExecute: false,\n              sdkProvider: this.props.sdkProvider,\n              parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n              resourcesToImport,\n              stream,\n            });\n          } else {\n            debug(\n              `the stack '${stack.stackName}' has not been deployed to CloudFormation or describeStacks call failed, skipping changeset creation.`,\n            );\n          }\n        }\n\n        const stackCount = options.securityOnly\n          ? numberFromBool(\n            printSecurityDiff(\n              currentTemplate,\n              stack,\n              RequireApproval.Broadening,\n              quiet,\n              stack.displayName,\n              changeSet,\n            ),\n          )\n          : printStackDiff(\n            currentTemplate,\n            stack,\n            strict,\n            contextLines,\n            quiet,\n            stack.displayName,\n            changeSet,\n            !!resourcesToImport,\n            stream,\n            nestedStacks,\n          );\n\n        diffs += stackCount;\n      }\n    }\n\n    stream.write(format('\\n✨  Number of stacks with differences: %s\\n', diffs));\n\n    return diffs && options.fail ? 1 : 0;\n  }\n\n  public async deploy(options: DeployOptions) {\n    if (options.watch) {\n      return this.watch(options);\n    }\n\n    // set progress from options, this includes user and app config\n    if (options.progress) {\n      this.ioHost.stackProgress = options.progress;\n    }\n\n    const startSynthTime = new Date().getTime();\n    const stackCollection = await this.selectStacksForDeploy(\n      options.selector,\n      options.exclusively,\n      options.cacheCloudAssembly,\n      options.ignoreNoStacks,\n    );\n    const elapsedSynthTime = new Date().getTime() - startSynthTime;\n    info(`\\n✨  Synthesis time: ${formatTime(elapsedSynthTime)}s\\n`);\n\n    if (stackCollection.stackCount === 0) {\n      error('This app contains no stacks');\n      return;\n    }\n\n    const migrator = new ResourceMigrator({\n      deployments: this.props.deployments,\n      ioHelper: asIoHelper(this.ioHost, 'deploy'),\n    });\n    await migrator.tryMigrateResources(stackCollection, {\n      toolkitStackName: this.toolkitStackName,\n      ...options,\n    });\n\n    const requireApproval = options.requireApproval ?? RequireApproval.Broadening;\n\n    const parameterMap = buildParameterMap(options.parameters);\n\n    if (options.hotswap !== HotswapMode.FULL_DEPLOYMENT) {\n      warning(\n        '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',\n      );\n      warning('⚠️ They should only be used for development - never use them for your production Stacks!\\n');\n    }\n\n    let hotswapPropertiesFromSettings = this.props.configuration.settings.get(['hotswap']) || {};\n\n    let hotswapPropertyOverrides = new HotswapPropertyOverrides();\n    hotswapPropertyOverrides.ecsHotswapProperties = new EcsHotswapProperties(\n      hotswapPropertiesFromSettings.ecs?.minimumHealthyPercent,\n      hotswapPropertiesFromSettings.ecs?.maximumHealthyPercent,\n    );\n\n    const stacks = stackCollection.stackArtifacts;\n\n    const stackOutputs: { [key: string]: any } = {};\n    const outputsFile = options.outputsFile;\n\n    const buildAsset = async (assetNode: AssetBuildNode) => {\n      await this.props.deployments.buildSingleAsset(\n        assetNode.assetManifestArtifact,\n        assetNode.assetManifest,\n        assetNode.asset,\n        {\n          stack: assetNode.parentStack,\n          roleArn: options.roleArn,\n          stackName: assetNode.parentStack.stackName,\n        },\n      );\n    };\n\n    const publishAsset = async (assetNode: AssetPublishNode) => {\n      await this.props.deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {\n        stack: assetNode.parentStack,\n        roleArn: options.roleArn,\n        stackName: assetNode.parentStack.stackName,\n        forcePublish: options.force,\n      });\n    };\n\n    const deployStack = async (stackNode: StackNode) => {\n      const stack = stackNode.stack;\n      if (stackCollection.stackCount !== 1) {\n        highlight(stack.displayName);\n      }\n\n      if (!stack.environment) {\n        // eslint-disable-next-line max-len\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      if (Object.keys(stack.template.Resources || {}).length === 0) {\n        // The generated stack has no resources\n        if (!(await this.props.deployments.stackExists({ stack }))) {\n          warning('%s: stack has no resources, skipping deployment.', chalk.bold(stack.displayName));\n        } else {\n          warning('%s: stack has no resources, deleting existing stack.', chalk.bold(stack.displayName));\n          await this.destroy({\n            selector: { patterns: [stack.hierarchicalId] },\n            exclusively: true,\n            force: true,\n            roleArn: options.roleArn,\n            fromDeploy: true,\n          });\n        }\n        return;\n      }\n\n      if (requireApproval !== RequireApproval.Never) {\n        const currentTemplate = await this.props.deployments.readCurrentTemplate(stack);\n        if (printSecurityDiff(currentTemplate, stack, requireApproval)) {\n          await askUserConfirmation(\n            this.ioHost,\n            concurrency,\n            '\"--require-approval\" is enabled and stack includes security-sensitive updates',\n            'Do you wish to deploy these changes',\n          );\n        }\n      }\n\n      // Following are the same semantics we apply with respect to Notification ARNs (dictated by the SDK)\n      //\n      //  - undefined  =>  cdk ignores it, as if it wasn't supported (allows external management).\n      //  - []:        =>  cdk manages it, and the user wants to wipe it out.\n      //  - ['arn-1']  =>  cdk manages it, and the user wants to set it to ['arn-1'].\n      const notificationArns = (!!options.notificationArns || !!stack.notificationArns)\n        ? (options.notificationArns ?? []).concat(stack.notificationArns ?? [])\n        : undefined;\n\n      for (const notificationArn of notificationArns ?? []) {\n        if (!validateSnsTopicArn(notificationArn)) {\n          throw new ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);\n        }\n      }\n\n      const stackIndex = stacks.indexOf(stack) + 1;\n      info(`${chalk.bold(stack.displayName)}: deploying... [${stackIndex}/${stackCollection.stackCount}]`);\n      const startDeployTime = new Date().getTime();\n\n      let tags = options.tags;\n      if (!tags || tags.length === 0) {\n        tags = tagsForStack(stack);\n      }\n\n      let elapsedDeployTime = 0;\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 this.props.deployments.deployStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n            toolkitStackName: options.toolkitStackName,\n            reuseAssets: options.reuseAssets,\n            notificationArns,\n            tags,\n            execute: options.execute,\n            changeSetName: options.changeSetName,\n            deploymentMethod: options.deploymentMethod,\n            force: options.force,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.usePreviousParameters,\n            rollback,\n            hotswap: options.hotswap,\n            hotswapPropertyOverrides: hotswapPropertyOverrides,\n            extraUserAgent: options.extraUserAgent,\n            assetParallelism: options.assetParallelism,\n            ignoreNoStacks: options.ignoreNoStacks,\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\n              if (options.force) {\n                warning(`${motivation}. Rolling back first (--force).`);\n              } else {\n                await askUserConfirmation(\n                  this.ioHost,\n                  concurrency,\n                  motivation,\n                  `${motivation}. Roll back first and then proceed with deployment`,\n                );\n              }\n\n              // Perform a rollback\n              await this.rollback({\n                selector: { patterns: [stack.hierarchicalId] },\n                toolkitStackName: options.toolkitStackName,\n                force: options.force,\n              });\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            case 'replacement-requires-rollback': {\n              const motivation = 'Change includes a replacement which cannot be deployed with \"--no-rollback\"';\n\n              if (options.force) {\n                warning(`${motivation}. Proceeding with regular deployment (--force).`);\n              } else {\n                await askUserConfirmation(\n                  this.ioHost,\n                  concurrency,\n                  motivation,\n                  `${motivation}. Perform a regular deployment`,\n                );\n              }\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            default:\n              throw new ToolkitError(`Unexpected result type from deployStack: ${JSON.stringify(r)}. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose`);\n          }\n        }\n\n        const message = deployResult.noOp\n          ? ' ✅  %s (no changes)'\n          : ' ✅  %s';\n\n        success('\\n' + message, stack.displayName);\n        elapsedDeployTime = new Date().getTime() - startDeployTime;\n        info(`\\n✨  Deployment time: ${formatTime(elapsedDeployTime)}s\\n`);\n\n        if (Object.keys(deployResult.outputs).length > 0) {\n          info('Outputs:');\n\n          stackOutputs[stack.stackName] = deployResult.outputs;\n        }\n\n        for (const name of Object.keys(deployResult.outputs).sort()) {\n          const value = deployResult.outputs[name];\n          info(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);\n        }\n\n        info('Stack ARN:');\n\n        logResult(deployResult.stackArn);\n      } catch (e: any) {\n        // It has to be exactly this string because an integration test tests for\n        // \"bold(stackname) failed: ResourceNotReady: <error>\"\n        throw new ToolkitError(\n          [`❌  ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), formatErrorMessage(e)].join(' '),\n        );\n      } finally {\n        if (options.cloudWatchLogMonitor) {\n          const foundLogGroupsResult = await findCloudWatchLogGroups(this.props.sdkProvider, asIoHelper(this.ioHost, 'deploy'), stack);\n          options.cloudWatchLogMonitor.addLogGroups(\n            foundLogGroupsResult.env,\n            foundLogGroupsResult.sdk,\n            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      info(`\\n✨  Total time: ${formatTime(elapsedSynthTime + elapsedDeployTime)}s\\n`);\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    if (concurrency > 1) {\n      // always force \"events\" progress output when we have concurrency\n      this.ioHost.stackProgress = StackActivityProgress.EVENTS;\n\n      // ...but only warn if the user explicitly requested \"bar\" progress\n      if (options.progress && options.progress != StackActivityProgress.EVENTS) {\n        warning('⚠️ The --concurrency flag only supports --progress \"events\". Switching to \"events\".');\n      }\n    }\n\n    const stacksAndTheirAssetManifests = stacks.flatMap((stack) => [\n      stack,\n      ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),\n    ]);\n    const workGraph = new WorkGraphBuilder(\n      asIoHelper(this.ioHost, 'deploy'),\n      prebuildAssets,\n    ).build(stacksAndTheirAssetManifests);\n\n    // Unless we are running with '--force', skip already published assets\n    if (!options.force) {\n      await this.removePublishedAssets(workGraph, options);\n    }\n\n    const graphConcurrency: Concurrency = {\n      'stack': concurrency,\n      'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds\n      'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable\n    };\n\n    await workGraph.doParallel(graphConcurrency, {\n      deployStack,\n      buildAsset,\n      publishAsset,\n    });\n  }\n\n  /**\n   * Roll back the given stack or stacks.\n   */\n  public async rollback(options: RollbackOptions) {\n    const startSynthTime = new Date().getTime();\n    const stackCollection = await this.selectStacksForDeploy(options.selector, true);\n    const elapsedSynthTime = new Date().getTime() - startSynthTime;\n    info(`\\n✨  Synthesis time: ${formatTime(elapsedSynthTime)}s\\n`);\n\n    if (stackCollection.stackCount === 0) {\n      error('No stacks selected');\n      return;\n    }\n\n    let anyRollbackable = false;\n\n    for (const stack of stackCollection.stackArtifacts) {\n      info('Rolling back %s', chalk.bold(stack.displayName));\n      const startRollbackTime = new Date().getTime();\n      try {\n        const result = await this.props.deployments.rollbackStack({\n          stack,\n          roleArn: options.roleArn,\n          toolkitStackName: options.toolkitStackName,\n          force: options.force,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!result.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        const elapsedRollbackTime = new Date().getTime() - startRollbackTime;\n        info(`\\n✨  Rollback time: ${formatTime(elapsedRollbackTime).toString()}s\\n`);\n      } catch (e: any) {\n        error('\\n ❌  %s failed: %s', chalk.bold(stack.displayName), formatErrorMessage(e));\n        throw new ToolkitError('Rollback failed (use --force to orphan failing resources)');\n      }\n    }\n    if (!anyRollbackable) {\n      throw new ToolkitError('No stacks were in a state that could be rolled back');\n    }\n  }\n\n  public async watch(options: WatchOptions) {\n    const rootDir = path.dirname(path.resolve(PROJECT_CONFIG));\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    debug(\"root directory used for 'watch' is: %s\", rootDir);\n\n    const watchSettings: { include?: string | string[]; exclude: string | string[] } | undefined =\n      this.props.configuration.settings.get(['watch']);\n    if (!watchSettings) {\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 = this.patternsArrayForWatch(watchSettings.include, {\n      rootDir,\n      returnRootDirIfEmpty: true,\n    });\n    debug(\"'include' patterns for 'watch': %s\", watchIncludes);\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outputDir = this.props.configuration.settings.get(['output']);\n    const watchExcludes = this.patternsArrayForWatch(watchSettings.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    }).concat(`${outputDir}/**`, '**/.*', '**/.*/**', '**/node_modules/**');\n    debug(\"'exclude' patterns for 'watch': %s\", watchExcludes);\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    let latch: 'pre-ready' | 'open' | 'deploying' | 'queued' = 'pre-ready';\n\n    const cloudWatchLogMonitor = options.traceLogs ? new CloudWatchLogEventMonitor({\n      ioHelper,\n    }) : undefined;\n    const deployAndWatch = async () => {\n      latch = 'deploying';\n      await cloudWatchLogMonitor?.deactivate();\n\n      await this.invokeDeployFromWatch(options, cloudWatchLogMonitor);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while ((latch as 'deploying' | 'queued') === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        info(\"Detected file changes during deployment. Invoking 'cdk deploy' again\");\n        await this.invokeDeployFromWatch(options, cloudWatchLogMonitor);\n      }\n      latch = 'open';\n      await cloudWatchLogMonitor?.activate();\n    };\n\n    chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        debug(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\");\n        info(\"Triggering initial 'cdk deploy'\");\n        await deployAndWatch();\n      })\n      .on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath?: string) => {\n        if (latch === 'pre-ready') {\n          info(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '%s' for changes`, filePath);\n        } else if (latch === 'open') {\n          info(\"Detected change to '%s' (type: %s). Triggering 'cdk deploy'\", filePath, event);\n          await deployAndWatch();\n        } else {\n          // this means latch is either 'deploying' or 'queued'\n          latch = 'queued';\n          info(\n            \"Detected change to '%s' (type: %s) while 'cdk deploy' is still running. \" +\n              'Will queue for another deployment after this one finishes',\n            filePath,\n            event,\n          );\n        }\n      });\n  }\n\n  public async import(options: ImportOptions) {\n    const stacks = await this.selectStacksForDeploy(options.selector, true, true, false);\n\n    // set progress from options, this includes user and app config\n    if (options.progress) {\n      this.ioHost.stackProgress = options.progress;\n    }\n\n    if (stacks.stackCount > 1) {\n      throw new ToolkitError(\n        `Stack selection is ambiguous, please choose a specific stack for import [${stacks.stackArtifacts.map((x) => x.id).join(', ')}]`,\n      );\n    }\n\n    if (!process.stdout.isTTY && !options.resourceMappingFile) {\n      throw new ToolkitError('--resource-mapping is required when input is not a terminal');\n    }\n\n    const stack = stacks.stackArtifacts[0];\n\n    highlight(stack.displayName);\n\n    const resourceImporter = new ResourceImporter(stack, {\n      deployments: this.props.deployments,\n      ioHelper: asIoHelper(this.ioHost, 'import'),\n    });\n    const { additions, hasNonAdditions } = await resourceImporter.discoverImportableResources(options.force);\n    if (additions.length === 0) {\n      warning(\n        '%s: no new resources compared to the currently deployed stack, skipping import.',\n        chalk.bold(stack.displayName),\n      );\n      return;\n    }\n\n    // Prepare a mapping of physical resources to CDK constructs\n    const actualImport = !options.resourceMappingFile\n      ? await resourceImporter.askForResourceIdentifiers(additions)\n      : await resourceImporter.loadResourceIdentifiers(additions, options.resourceMappingFile);\n\n    if (actualImport.importResources.length === 0) {\n      warning('No resources selected for import.');\n      return;\n    }\n\n    // If \"--create-resource-mapping\" option was passed, write the resource mapping to the given file and exit\n    if (options.recordResourceMapping) {\n      const outputFile = options.recordResourceMapping;\n      fs.ensureFileSync(outputFile);\n      await fs.writeJson(outputFile, actualImport.resourceMap, {\n        spaces: 2,\n        encoding: 'utf8',\n      });\n      info('%s: mapping file written.', outputFile);\n      return;\n    }\n\n    // Import the resources according to the given mapping\n    info('%s: importing resources into stack...', chalk.bold(stack.displayName));\n    const tags = tagsForStack(stack);\n    await resourceImporter.importResourcesFromMap(actualImport, {\n      roleArn: options.roleArn,\n      tags,\n      deploymentMethod: options.deploymentMethod,\n      usePreviousParameters: true,\n      rollback: options.rollback,\n    });\n\n    // Notify user of next steps\n    info(\n      `Import operation complete. We recommend you run a ${chalk.blueBright('drift detection')} operation ` +\n        'to confirm your CDK app resource definitions are up-to-date. Read more here: ' +\n        chalk.underline.blueBright(\n          'https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/detect-drift-stack.html',\n        ),\n    );\n    if (actualImport.importResources.length < additions.length) {\n      info('');\n      warning(\n        `Some resources were skipped. Run another ${chalk.blueBright('cdk import')} or a ${chalk.blueBright('cdk deploy')} to bring the stack up-to-date with your CDK app definition.`,\n      );\n    } else if (hasNonAdditions) {\n      info('');\n      warning(\n        `Your app has pending updates or deletes excluded from this import operation. Run a ${chalk.blueBright('cdk deploy')} to bring the stack up-to-date with your CDK app definition.`,\n      );\n    }\n  }\n\n  public async destroy(options: DestroyOptions) {\n    let stacks = await this.selectStacksForDestroy(options.selector, options.exclusively);\n\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    stacks = stacks.reversed();\n\n    if (!options.force) {\n      // eslint-disable-next-line max-len\n      const confirmed = await promptly.confirm(\n        `Are you sure you want to delete: ${chalk.blue(stacks.stackArtifacts.map((s) => s.hierarchicalId).join(', '))} (y/n)?`,\n      );\n      if (!confirmed) {\n        return;\n      }\n    }\n\n    const action = options.fromDeploy ? 'deploy' : 'destroy';\n    for (const [index, stack] of stacks.stackArtifacts.entries()) {\n      success('%s: destroying... [%s/%s]', chalk.blue(stack.displayName), index + 1, stacks.stackCount);\n      try {\n        await this.props.deployments.destroyStack({\n          stack,\n          deployName: stack.stackName,\n          roleArn: options.roleArn,\n        });\n        success(`\\n ✅  %s: ${action}ed`, chalk.blue(stack.displayName));\n      } catch (e) {\n        error(`\\n ❌  %s: ${action} failed`, chalk.blue(stack.displayName), e);\n        throw e;\n      }\n    }\n  }\n\n  public async list(\n    selectors: string[],\n    options: { long?: boolean; json?: boolean; showDeps?: boolean } = {},\n  ): Promise<number> {\n    const stacks = await listStacks(this, {\n      selectors: selectors,\n    });\n\n    if (options.long && options.showDeps) {\n      printSerializedObject(stacks, options.json ?? false);\n      return 0;\n    }\n\n    if (options.showDeps) {\n      const stackDeps = [];\n\n      for (const stack of stacks) {\n        stackDeps.push({\n          id: stack.id,\n          dependencies: stack.dependencies,\n        });\n      }\n\n      printSerializedObject(stackDeps, options.json ?? false);\n      return 0;\n    }\n\n    if (options.long) {\n      const long = [];\n\n      for (const stack of stacks) {\n        long.push({\n          id: stack.id,\n          name: stack.name,\n          environment: stack.environment,\n        });\n      }\n      printSerializedObject(long, options.json ?? false);\n      return 0;\n    }\n\n    // just print stack IDs\n    for (const stack of stacks) {\n      logResult(stack.id);\n    }\n\n    return 0; // exit-code\n  }\n\n  /**\n   * Synthesize the given set of stacks (called when the user runs 'cdk synth')\n   *\n   * INPUT: Stack names can be supplied using a glob filter. If no stacks are\n   * given, all stacks from the application are implicitly selected.\n   *\n   * OUTPUT: If more than one stack ends up being selected, an output directory\n   * should be supplied, where the templates will be written.\n   */\n  public async synth(\n    stackNames: string[],\n    exclusively: boolean,\n    quiet: boolean,\n    autoValidate?: boolean,\n    json?: boolean,\n  ): Promise<any> {\n    const stacks = await this.selectStacksForDiff(stackNames, exclusively, autoValidate);\n\n    // if we have a single stack, print it to STDOUT\n    if (stacks.stackCount === 1) {\n      if (!quiet) {\n        printSerializedObject(obscureTemplate(stacks.firstStack.template), json ?? false);\n      }\n      return undefined;\n    }\n\n    // not outputting template to stdout, let's explain things to the user a little bit...\n    success(`Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`);\n    info(\n      `Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`,\n    );\n\n    return undefined;\n  }\n\n  /**\n   * Bootstrap the CDK Toolkit stack in the accounts used by the specified stack(s).\n   *\n   * @param userEnvironmentSpecs environment names that need to have toolkit support\n   *             provisioned, as a glob filter. If none is provided, all stacks are implicitly selected.\n   * @param options The name, role ARN, bootstrapping parameters, etc. to be used for the CDK Toolkit stack.\n   */\n  public async bootstrap(\n    userEnvironmentSpecs: string[],\n    options: BootstrapEnvironmentOptions,\n  ): Promise<void> {\n    const bootstrapper = new Bootstrapper(options.source, asIoHelper(this.ioHost, 'bootstrap'));\n    // If there is an '--app' argument and an environment looks like a glob, we\n    // select the environments from the app. Otherwise, use what the user said.\n\n    const environments = await this.defineEnvironments(userEnvironmentSpecs);\n\n    const limit = pLimit(20);\n\n    // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism\n    await Promise.all(environments.map((environment) => limit(async () => {\n      success(' ⏳  Bootstrapping environment %s...', chalk.blue(environment.name));\n      try {\n        const result = await bootstrapper.bootstrapEnvironment(environment, this.props.sdkProvider, options);\n        const message = result.noOp\n          ? ' ✅  Environment %s bootstrapped (no changes).'\n          : ' ✅  Environment %s bootstrapped.';\n        success(message, chalk.blue(environment.name));\n      } catch (e) {\n        error(' ❌  Environment %s failed bootstrapping: %s', chalk.blue(environment.name), e);\n        throw e;\n      }\n    })));\n  }\n\n  /**\n   * Garbage collects assets from a CDK app's environment\n   * @param options Options for Garbage Collection\n   */\n  public async garbageCollect(userEnvironmentSpecs: string[], options: GarbageCollectionOptions) {\n    const environments = await this.defineEnvironments(userEnvironmentSpecs);\n\n    for (const environment of environments) {\n      success(' ⏳  Garbage Collecting environment %s...', chalk.blue(environment.name));\n      const gc = new GarbageCollector({\n        sdkProvider: this.props.sdkProvider,\n        ioHelper: asIoHelper(this.ioHost, 'gc'),\n        resolvedEnvironment: environment,\n        bootstrapStackName: options.bootstrapStackName,\n        rollbackBufferDays: options.rollbackBufferDays,\n        createdBufferDays: options.createdBufferDays,\n        action: options.action ?? 'full',\n        type: options.type ?? 'all',\n        confirm: options.confirm ?? true,\n      });\n      await gc.garbageCollect();\n    }\n  }\n\n  private async defineEnvironments(userEnvironmentSpecs: string[]): Promise<cxapi.Environment[]> {\n    // By default, glob for everything\n    const environmentSpecs = userEnvironmentSpecs.length > 0 ? [...userEnvironmentSpecs] : ['**'];\n\n    // Partition into globs and non-globs (this will mutate environmentSpecs).\n    const globSpecs = partition(environmentSpecs, looksLikeGlob);\n    if (globSpecs.length > 0 && !this.props.cloudExecutable.hasApp) {\n      if (userEnvironmentSpecs.length > 0) {\n        // User did request this glob\n        throw new ToolkitError(\n          `'${globSpecs}' is not an environment name. Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json' to use wildcards.`,\n        );\n      } else {\n        // User did not request anything\n        throw new ToolkitError(\n          \"Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json'.\",\n        );\n      }\n    }\n\n    const environments: cxapi.Environment[] = [...environmentsFromDescriptors(environmentSpecs)];\n\n    // If there is an '--app' argument, select the environments from the app.\n    if (this.props.cloudExecutable.hasApp) {\n      environments.push(\n        ...(await globEnvironmentsFromStacks(await this.selectStacksForList([]), globSpecs, this.props.sdkProvider)),\n      );\n    }\n\n    return environments;\n  }\n\n  /**\n   * Migrates a CloudFormation stack/template to a CDK app\n   * @param options Options for CDK app creation\n   */\n  public async migrate(options: MigrateOptions): Promise<void> {\n    warning('This command is an experimental feature.');\n    const language = options.language?.toLowerCase() ?? 'typescript';\n    const environment = setEnvironment(options.account, options.region);\n    let generateTemplateOutput: GenerateTemplateOutput | undefined;\n    let cfn: CfnTemplateGeneratorProvider | undefined;\n    let templateToDelete: string | undefined;\n\n    try {\n      // if neither fromPath nor fromStack is provided, generate a template using cloudformation\n      const scanType = parseSourceOptions(options.fromPath, options.fromStack, options.stackName).source;\n      if (scanType == TemplateSourceOptions.SCAN) {\n        generateTemplateOutput = await generateTemplate({\n          stackName: options.stackName,\n          filters: options.filter,\n          fromScan: options.fromScan,\n          sdkProvider: this.props.sdkProvider,\n          environment: environment,\n        });\n        templateToDelete = generateTemplateOutput.templateId;\n      } else if (scanType == TemplateSourceOptions.PATH) {\n        const templateBody = readFromPath(options.fromPath!);\n\n        const parsedTemplate = deserializeStructure(templateBody);\n        const templateId = parsedTemplate.Metadata?.TemplateId?.toString();\n        if (templateId) {\n          // if we have a template id, we can call describe generated template to get the resource identifiers\n          // resource metadata, and template source to generate the template\n          cfn = new CfnTemplateGeneratorProvider(await buildCfnClient(this.props.sdkProvider, environment));\n          const generatedTemplateSummary = await cfn.describeGeneratedTemplate(templateId);\n          generateTemplateOutput = buildGenertedTemplateOutput(\n            generatedTemplateSummary,\n            templateBody,\n            generatedTemplateSummary.GeneratedTemplateId!,\n          );\n        } else {\n          generateTemplateOutput = {\n            migrateJson: {\n              templateBody: templateBody,\n              source: 'localfile',\n            },\n          };\n        }\n      } else if (scanType == TemplateSourceOptions.STACK) {\n        const template = await readFromStack(options.stackName, this.props.sdkProvider, environment);\n        if (!template) {\n          throw new ToolkitError(`No template found for stack-name: ${options.stackName}`);\n        }\n        generateTemplateOutput = {\n          migrateJson: {\n            templateBody: template,\n            source: options.stackName,\n          },\n        };\n      } else {\n        // We shouldn't ever get here, but just in case.\n        throw new ToolkitError(`Invalid source option provided: ${scanType}`);\n      }\n      const stack = generateStack(generateTemplateOutput.migrateJson.templateBody, options.stackName, language);\n      success(' ⏳  Generating CDK app for %s...', chalk.blue(options.stackName));\n      await generateCdkApp(options.stackName, stack!, language, options.outputPath, options.compress);\n      if (generateTemplateOutput) {\n        writeMigrateJsonFile(options.outputPath, options.stackName, generateTemplateOutput.migrateJson);\n      }\n      if (isThereAWarning(generateTemplateOutput)) {\n        warning(\n          ' ⚠️  Some resources could not be migrated completely. Please review the README.md file for more information.',\n        );\n        appendWarningsToReadme(\n          `${path.join(options.outputPath ?? process.cwd(), options.stackName)}/README.md`,\n          generateTemplateOutput.resources!,\n        );\n      }\n    } catch (e) {\n      error(' ❌  Migrate failed for `%s`: %s', options.stackName, (e as Error).message);\n      throw e;\n    } finally {\n      if (templateToDelete) {\n        if (!cfn) {\n          cfn = new CfnTemplateGeneratorProvider(await buildCfnClient(this.props.sdkProvider, environment));\n        }\n        if (!process.env.MIGRATE_INTEG_TEST) {\n          await cfn.deleteGeneratedTemplate(templateToDelete);\n        }\n      }\n    }\n  }\n\n  private async selectStacksForList(patterns: string[]) {\n    const assembly = await this.assembly();\n    const stacks = await assembly.selectStacks({ patterns }, { defaultBehavior: DefaultSelection.AllStacks });\n\n    // No validation\n\n    return stacks;\n  }\n\n  private async selectStacksForDeploy(\n    selector: StackSelector,\n    exclusively?: boolean,\n    cacheCloudAssembly?: boolean,\n    ignoreNoStacks?: boolean,\n  ): Promise<StackCollection> {\n    const assembly = await this.assembly(cacheCloudAssembly);\n    const stacks = await assembly.selectStacks(selector, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Upstream,\n      defaultBehavior: DefaultSelection.OnlySingle,\n      ignoreNoStacks,\n    });\n\n    this.validateStacksSelected(stacks, selector.patterns);\n    await this.validateStacks(stacks);\n\n    return stacks;\n  }\n\n  private async selectStacksForDiff(\n    stackNames: string[],\n    exclusively?: boolean,\n    autoValidate?: boolean,\n  ): Promise<StackCollection> {\n    const assembly = await this.assembly();\n\n    const selectedForDiff = await assembly.selectStacks(\n      { patterns: stackNames },\n      {\n        extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Upstream,\n        defaultBehavior: DefaultSelection.MainAssembly,\n      },\n    );\n\n    const allStacks = await this.selectStacksForList([]);\n    const autoValidateStacks = autoValidate\n      ? allStacks.filter((art) => art.validateOnSynth ?? false)\n      : new StackCollection(assembly, []);\n\n    this.validateStacksSelected(selectedForDiff.concat(autoValidateStacks), stackNames);\n    await this.validateStacks(selectedForDiff.concat(autoValidateStacks));\n\n    return selectedForDiff;\n  }\n\n  private async selectStacksForDestroy(selector: StackSelector, exclusively?: boolean) {\n    const assembly = await this.assembly();\n    const stacks = await assembly.selectStacks(selector, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Downstream,\n      defaultBehavior: DefaultSelection.OnlySingle,\n    });\n\n    // No validation\n\n    return stacks;\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private async validateStacks(stacks: StackCollection) {\n    let failAt: 'warn' | 'error' | 'none' = 'error';\n    if (this.props.ignoreErrors) {\n      failAt = 'none';\n    }\n    if (this.props.strict) {\n      failAt = 'warn';\n    }\n\n    await stacks.validateMetadata(failAt, stackMetadataLogger(this.props.verbose));\n  }\n\n  /**\n   * Validate that if a user specified a stack name there exists at least 1 stack selected\n   */\n  private validateStacksSelected(stacks: StackCollection, stackNames: string[]) {\n    if (stackNames.length != 0 && stacks.stackCount == 0) {\n      throw new ToolkitError(`No stacks match the name(s) ${stackNames}`);\n    }\n  }\n\n  /**\n   * Select a single stack by its name\n   */\n  private async selectSingleStackByName(stackName: string) {\n    const assembly = await this.assembly();\n\n    const stacks = await assembly.selectStacks(\n      { patterns: [stackName] },\n      {\n        extend: ExtendedStackSelection.None,\n        defaultBehavior: DefaultSelection.None,\n      },\n    );\n\n    // Could have been a glob so check that we evaluated to exactly one\n    if (stacks.stackCount > 1) {\n      throw new ToolkitError(`This command requires exactly one stack and we matched more than one: ${stacks.stackIds}`);\n    }\n\n    return assembly.stackById(stacks.firstStack.id);\n  }\n\n  public assembly(cacheCloudAssembly?: boolean): Promise<CloudAssembly> {\n    return this.props.cloudExecutable.synthesize(cacheCloudAssembly);\n  }\n\n  private patternsArrayForWatch(\n    patterns: string | string[] | undefined,\n    options: { rootDir: string; returnRootDirIfEmpty: boolean },\n  ): string[] {\n    const patternsArray: string[] = patterns !== undefined ? (Array.isArray(patterns) ? patterns : [patterns]) : [];\n    return patternsArray.length > 0 ? patternsArray : options.returnRootDirIfEmpty ? [options.rootDir] : [];\n  }\n\n  private async invokeDeployFromWatch(\n    options: WatchOptions,\n    cloudWatchLogMonitor?: CloudWatchLogEventMonitor,\n  ): Promise<void> {\n    const deployOptions: DeployOptions = {\n      ...options,\n      requireApproval: RequireApproval.Never,\n      // if 'watch' is called by invoking 'cdk deploy --watch',\n      // we need to make sure to not call 'deploy' with 'watch' again,\n      // as that would lead to a cycle\n      watch: false,\n      cloudWatchLogMonitor,\n      cacheCloudAssembly: false,\n      hotswap: options.hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${options.hotswap !== HotswapMode.FALL_BACK ? 'on' : 'off'}`,\n      concurrency: options.concurrency,\n    };\n\n    try {\n      await this.deploy(deployOptions);\n    } catch {\n      // just continue - deploy will show the error\n    }\n  }\n\n  /**\n   * Remove the asset publishing and building from the work graph for assets that are already in place\n   */\n  private async removePublishedAssets(graph: WorkGraph, options: DeployOptions) {\n    await graph.removeUnnecessaryAssets(assetNode => this.props.deployments.isSingleAssetPublished(assetNode.assetManifest, assetNode.asset, {\n      stack: assetNode.parentStack,\n      roleArn: options.roleArn,\n      stackName: assetNode.parentStack.stackName,\n    }));\n  }\n}\n\n/**\n * Print a serialized object (YAML or JSON) to stdout.\n */\nfunction printSerializedObject(obj: any, json: boolean) {\n  logResult(serializeStructure(obj, json));\n}\n\nexport interface DiffOptions {\n  /**\n   * Stack names to diff\n   */\n  stackNames: string[];\n\n  /**\n   * Name of the toolkit stack, if not the default name\n   *\n   * @default 'CDKToolkit'\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Only select the given stack\n   *\n   * @default false\n   */\n  exclusively?: boolean;\n\n  /**\n   * Used a template from disk instead of from the server\n   *\n   * @default Use from the server\n   */\n  templatePath?: string;\n\n  /**\n   * Strict diff mode\n   *\n   * @default false\n   */\n  strict?: boolean;\n\n  /**\n   * How many lines of context to show in the diff\n   *\n   * @default 3\n   */\n  contextLines?: number;\n\n  /**\n   * Where to write the default\n   *\n   * @default stderr\n   */\n  stream?: NodeJS.WritableStream;\n\n  /**\n   * Whether to fail with exit code 1 in case of diff\n   *\n   * @default false\n   */\n  fail?: boolean;\n\n  /**\n   * Only run diff on broadened security changes\n   *\n   * @default false\n   */\n  securityOnly?: boolean;\n\n  /**\n   * Whether to run the diff against the template after the CloudFormation Transforms inside it have been executed\n   * (as opposed to the original template, the default, which contains the unprocessed Transforms).\n   *\n   * @default false\n   */\n  compareAgainstProcessedTemplate?: boolean;\n\n  /*\n   * Run diff in quiet mode without printing the diff statuses\n   *\n   * @default false\n   */\n  quiet?: boolean;\n\n  /**\n   * Additional parameters for CloudFormation at diff time, used to create a change set\n   * @default {}\n   */\n  parameters?: { [name: string]: string | undefined };\n\n  /**\n   * Whether or not to create, analyze, and subsequently delete a changeset\n   *\n   * @default true\n   */\n  changeSet?: boolean;\n}\n\ninterface CfnDeployOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  selector: StackSelector;\n\n  /**\n   * Name of the toolkit stack to use/deploy\n   *\n   * @default CDKToolkit\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Role to pass to CloudFormation for deployment\n   */\n  roleArn?: string;\n\n  /**\n   * Optional name to use for the CloudFormation change set.\n   * If not provided, a name will be generated automatically.\n   *\n   * @deprecated Use 'deploymentMethod' instead\n   */\n  changeSetName?: string;\n\n  /**\n   * Whether to execute the ChangeSet\n   * Not providing `execute` parameter will result in execution of ChangeSet\n   *\n   * @default true\n   * @deprecated Use 'deploymentMethod' instead\n   */\n  execute?: boolean;\n\n  /**\n   * Deployment method\n   */\n  readonly deploymentMethod?: DeploymentMethod;\n\n  /**\n   * Display mode for stack deployment progress.\n   *\n   * @default - StackActivityProgress.Bar - stack events will be displayed for\n   *   the resource currently being deployed.\n   */\n  progress?: StackActivityProgress;\n\n  /**\n   * Rollback failed deployments\n   *\n   * @default true\n   */\n  readonly rollback?: boolean;\n}\n\ninterface WatchOptions extends Omit<CfnDeployOptions, 'execute'> {\n  /**\n   * Only select the given stack\n   *\n   * @default false\n   */\n  exclusively?: boolean;\n\n  /**\n   * Reuse the assets with the given asset IDs\n   */\n  reuseAssets?: string[];\n\n  /**\n   * Always deploy, even if templates are identical.\n   * @default false\n   */\n  force?: boolean;\n\n  /**\n   * Whether to perform a 'hotswap' deployment.\n   * A 'hotswap' deployment will attempt to short-circuit CloudFormation\n   * and update the affected resources like Lambda functions directly.\n   *\n   * @default - `HotswapMode.FALL_BACK` for regular deployments, `HotswapMode.HOTSWAP_ONLY` for 'watch' deployments\n   */\n  readonly hotswap: HotswapMode;\n\n  /**\n   * The extra string to append to the User-Agent header when performing AWS SDK calls.\n   *\n   * @default - nothing extra is appended to the User-Agent header\n   */\n  readonly extraUserAgent?: string;\n\n  /**\n   * Whether to show CloudWatch logs for hotswapped resources\n   * locally in the users terminal\n   *\n   * @default - false\n   */\n  readonly traceLogs?: boolean;\n\n  /**\n   * Maximum number of simultaneous deployments (dependency permitting) to execute.\n   * The default is '1', which executes all deployments serially.\n   *\n   * @default 1\n   */\n  readonly concurrency?: number;\n}\n\nexport interface DeployOptions extends CfnDeployOptions, WatchOptions {\n  /**\n   * ARNs of SNS topics that CloudFormation will notify with stack related events\n   */\n  notificationArns?: string[];\n\n  /**\n   * What kind of security changes require approval\n   *\n   * @default RequireApproval.Broadening\n   */\n  requireApproval?: RequireApproval;\n\n  /**\n   * Tags to pass to CloudFormation for deployment\n   */\n  tags?: Tag[];\n\n  /**\n   * Additional parameters for CloudFormation at deploy time\n   * @default {}\n   */\n  parameters?: { [name: string]: string | undefined };\n\n  /**\n   * Use previous values for unspecified parameters\n   *\n   * If not set, all parameters must be specified for every deployment.\n   *\n   * @default true\n   */\n  usePreviousParameters?: boolean;\n\n  /**\n   * Path to file where stack outputs will be written after a successful deploy as JSON\n   * @default - Outputs are not written to any file\n   */\n  outputsFile?: string;\n\n  /**\n   * Whether we are on a CI system\n   *\n   * @default false\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Whether this 'deploy' command should actually delegate to the 'watch' command.\n   *\n   * @default false\n   */\n  readonly watch?: boolean;\n\n  /**\n   * Whether we should cache the Cloud Assembly after the first time it has been synthesized.\n   * The default is 'true', we only don't want to do it in case the deployment is triggered by\n   * 'cdk watch'.\n   *\n   * @default true\n   */\n  readonly cacheCloudAssembly?: boolean;\n\n  /**\n   * Allows adding CloudWatch log groups to the log monitor via\n   * cloudWatchLogMonitor.setLogGroups();\n   *\n   * @default - not monitoring CloudWatch logs\n   */\n  readonly cloudWatchLogMonitor?: CloudWatchLogEventMonitor;\n\n  /**\n   * Maximum number of simultaneous deployments (dependency permitting) to execute.\n   * The default is '1', which executes all deployments serially.\n   *\n   * @default 1\n   */\n  readonly concurrency?: number;\n\n  /**\n   * Build/publish assets for a single stack in parallel\n   *\n   * Independent of whether stacks are being done in parallel or no.\n   *\n   * @default true\n   */\n  readonly assetParallelism?: boolean;\n\n  /**\n   * When to build assets\n   *\n   * The default is the Docker-friendly default.\n   *\n   * @default AssetBuildTime.ALL_BEFORE_DEPLOY\n   */\n  readonly assetBuildTime?: AssetBuildTime;\n\n  /**\n   * Whether to deploy if the app contains no stacks.\n   *\n   * @default false\n   */\n  readonly ignoreNoStacks?: boolean;\n}\n\nexport interface RollbackOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  readonly selector: StackSelector;\n\n  /**\n   * Name of the toolkit stack to use/deploy\n   *\n   * @default CDKToolkit\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Role to pass to CloudFormation for deployment\n   *\n   * @default - Default stack role\n   */\n  readonly roleArn?: string;\n\n  /**\n   * Whether to force the rollback or not\n   *\n   * @default false\n   */\n  readonly force?: boolean;\n\n  /**\n   * Logical IDs of resources to orphan\n   *\n   * @default - No orphaning\n   */\n  readonly orphanLogicalIds?: string[];\n\n  /**\n   * Whether to validate the version of the bootstrap stack permissions\n   *\n   * @default true\n   */\n  readonly validateBootstrapStackVersion?: boolean;\n}\n\nexport interface ImportOptions extends CfnDeployOptions {\n  /**\n   * Build a physical resource mapping and write it to the given file, without performing the actual import operation\n   *\n   * @default - No file\n   */\n\n  readonly recordResourceMapping?: string;\n\n  /**\n   * Path to a file with the physical resource mapping to CDK constructs in JSON format\n   *\n   * @default - No mapping file\n   */\n  readonly resourceMappingFile?: string;\n\n  /**\n   * Allow non-addition changes to the template\n   *\n   * @default false\n   */\n  readonly force?: boolean;\n}\n\nexport interface DestroyOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  selector: StackSelector;\n\n  /**\n   * Whether to exclude stacks that depend on the stacks to be deleted\n   */\n  exclusively: boolean;\n\n  /**\n   * Whether to skip prompting for confirmation\n   */\n  force: boolean;\n\n  /**\n   * The arn of the IAM role to use\n   */\n  roleArn?: string;\n\n  /**\n   * Whether the destroy request came from a deploy.\n   */\n  fromDeploy?: boolean;\n}\n\n/**\n * Options for the garbage collection\n */\nexport interface GarbageCollectionOptions {\n  /**\n   * The action to perform.\n   *\n   * @default 'full'\n   */\n  readonly action: 'print' | 'tag' | 'delete-tagged' | 'full';\n\n  /**\n   * The type of the assets to be garbage collected.\n   *\n   * @default 'all'\n   */\n  readonly type: 's3' | 'ecr' | 'all';\n\n  /**\n   * Elapsed time between an asset being marked as isolated and actually deleted.\n   *\n   * @default 0\n   */\n  readonly rollbackBufferDays: number;\n\n  /**\n   * Refuse deletion of any assets younger than this number of days.\n   */\n  readonly createdBufferDays: number;\n\n  /**\n   * The stack name of the bootstrap stack.\n   *\n   * @default DEFAULT_TOOLKIT_STACK_NAME\n   */\n  readonly bootstrapStackName?: string;\n\n  /**\n   * Skips the prompt before actual deletion begins\n   *\n   * @default false\n   */\n  readonly confirm?: boolean;\n}\n\nexport interface MigrateOptions {\n  /**\n   * The name assigned to the generated stack. This is also used to get\n   * the stack from the user's account if `--from-stack` is used.\n   */\n  readonly stackName: string;\n\n  /**\n   * The target language for the generated the CDK app.\n   *\n   * @default typescript\n   */\n  readonly language?: string;\n\n  /**\n   * The local path of the template used to generate the CDK app.\n   *\n   * @default - Local path is not used for the template source.\n   */\n  readonly fromPath?: string;\n\n  /**\n   * Whether to get the template from an existing CloudFormation stack.\n   *\n   * @default false\n   */\n  readonly fromStack?: boolean;\n\n  /**\n   * The output path at which to create the CDK app.\n   *\n   * @default - The current directory\n   */\n  readonly outputPath?: string;\n\n  /**\n   * The account from which to retrieve the template of the CloudFormation stack.\n   *\n   * @default - Uses the account for the credentials in use by the user.\n   */\n  readonly account?: string;\n\n  /**\n   * The region from which to retrieve the template of the CloudFormation stack.\n   *\n   * @default - Uses the default region for the credentials in use by the user.\n   */\n  readonly region?: string;\n\n  /**\n   * Filtering criteria used to select the resources to be included in the generated CDK app.\n   *\n   * @default - Include all resources\n   */\n  readonly filter?: string[];\n\n  /**\n   * Whether to initiate a new account scan for generating the CDK app.\n   *\n   * @default false\n   */\n  readonly fromScan?: FromScan;\n\n  /**\n   * Whether to zip the generated cdk app folder.\n   *\n   * @default false\n   */\n  readonly compress?: boolean;\n}\n\nfunction buildParameterMap(\n  parameters:\n  | {\n    [name: string]: string | undefined;\n  }\n  | undefined,\n): { [name: string]: { [name: string]: string | undefined } } {\n  const parameterMap: {\n    [name: string]: { [name: string]: string | undefined };\n  } = { '*': {} };\n  for (const key in parameters) {\n    if (parameters.hasOwnProperty(key)) {\n      const [stack, parameter] = key.split(':', 2);\n      if (!parameter) {\n        parameterMap['*'][stack] = parameters[key];\n      } else {\n        if (!parameterMap[stack]) {\n          parameterMap[stack] = {};\n        }\n        parameterMap[stack][parameter] = parameters[key];\n      }\n    }\n  }\n\n  return parameterMap;\n}\n\n/**\n * Ask the user for a yes/no confirmation\n *\n * Automatically fail the confirmation in case we're in a situation where the confirmation\n * cannot be interactively obtained from a human at the keyboard.\n */\nasync function askUserConfirmation(\n  ioHost: CliIoHost,\n  concurrency: number,\n  motivation: string,\n  question: string,\n) {\n  await ioHost.withCorkedLogging(async () => {\n    // only talk to user if STDIN is a terminal (otherwise, fail)\n    if (!TESTING && !process.stdin.isTTY) {\n      throw new ToolkitError(`${motivation}, but terminal (TTY) is not attached so we are unable to get a confirmation from the user`);\n    }\n\n    // only talk to user if concurrency is 1 (otherwise, fail)\n    if (concurrency > 1) {\n      throw new ToolkitError(`${motivation}, but concurrency is greater than 1 so we are unable to get a confirmation from the user`);\n    }\n\n    const confirmed = await promptly.confirm(`${chalk.cyan(question)} (y/n)?`);\n    if (!confirmed) {\n      throw new ToolkitError('Aborted by user');\n    }\n  });\n}\n\n/**\n * Logger for processing stack metadata\n */\nfunction stackMetadataLogger(verbose?: boolean): (level: 'info' | 'error' | 'warn', msg: cxapi.SynthesisMessage) => Promise<void> {\n  const makeLogger = (level: string): [logger: (m: string) => void, prefix: string] => {\n    switch (level) {\n      case 'error':\n        return [error, 'Error'];\n      case 'warn':\n        return [warning, 'Warning'];\n      default:\n        return [info, 'Info'];\n    }\n  };\n\n  return async (level, msg) => {\n    const [logFn, prefix] = makeLogger(level);\n    logFn(`[${prefix} at ${msg.id}] ${msg.entry.data}`);\n\n    if (verbose && msg.entry.trace) {\n      logFn(`  ${msg.entry.trace.join('\\n  ')}`);\n    }\n  };\n}\n"]}
1079
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-toolkit.js","sourceRoot":"","sources":["cdk-toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { format } from 'util';\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 * as promptly from 'promptly';\nimport * as uuid from 'uuid';\nimport type { Configuration } from './user-configuration';\nimport { PROJECT_CONFIG } from './user-configuration';\nimport { ToolkitError } from '../../../@aws-cdk/tmp-toolkit-helpers/src/api';\nimport { asIoHelper } from '../../../@aws-cdk/tmp-toolkit-helpers/src/api/io/private';\nimport { DEFAULT_TOOLKIT_STACK_NAME } from '../api';\nimport type { SdkProvider } from '../api/aws-auth';\nimport type { BootstrapEnvironmentOptions } from '../api/bootstrap';\nimport { Bootstrapper } from '../api/bootstrap';\nimport type {\n  CloudAssembly,\n  StackSelector,\n} from '../api/cxapp/cloud-assembly';\nimport {\n  DefaultSelection,\n  ExtendedStackSelection,\n  StackCollection,\n} from '../api/cxapp/cloud-assembly';\nimport type { CloudExecutable } from '../api/cxapp/cloud-executable';\nimport { environmentsFromDescriptors, globEnvironmentsFromStacks, looksLikeGlob } from '../api/cxapp/environments';\nimport type { DeploymentMethod, SuccessfulDeployStackResult, Deployments } from '../api/deployments';\nimport { createDiffChangeSet } from '../api/deployments/cfn-api';\nimport { GarbageCollector } from '../api/garbage-collection/garbage-collector';\nimport { HotswapMode, HotswapPropertyOverrides, EcsHotswapProperties } from '../api/hotswap/common';\nimport { findCloudWatchLogGroups } from '../api/logs/find-cloudwatch-logs';\nimport { CloudWatchLogEventMonitor } from '../api/logs/logs-monitor';\nimport { ResourceImporter, removeNonImportResources, ResourceMigrator } from '../api/resource-import';\nimport { tagsForStack, type Tag } from '../api/tags';\nimport type { AssetBuildNode, AssetPublishNode, Concurrency, StackNode, WorkGraph } from '../api/work-graph';\nimport { WorkGraphBuilder } from '../api/work-graph/work-graph-builder';\nimport { StackActivityProgress } from '../commands/deploy';\nimport { DiffFormatter, RequireApproval } from '../commands/diff';\nimport { listStacks } from '../commands/list-stacks';\nimport type {\n  FromScan,\n  GenerateTemplateOutput,\n} from '../commands/migrate';\nimport {\n  generateCdkApp,\n  generateStack,\n  readFromPath,\n  readFromStack,\n  setEnvironment,\n  parseSourceOptions,\n  generateTemplate,\n  TemplateSourceOptions,\n  CfnTemplateGeneratorProvider,\n  writeMigrateJsonFile,\n  buildGenertedTemplateOutput,\n  appendWarningsToReadme,\n  isThereAWarning,\n  buildCfnClient,\n} from '../commands/migrate';\nimport { result as logResult, debug, error, highlight, info, success, warning } from '../logging';\nimport { CliIoHost } from './io-host';\nimport { partition, validateSnsTopicArn, formatErrorMessage, deserializeStructure, obscureTemplate, serializeStructure, formatTime } from '../util';\n\n// Must use a require() otherwise esbuild complains about calling a namespace\n// eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/consistent-type-imports\nconst pLimit: typeof import('p-limit') = require('p-limit');\n\nlet TESTING = false;\n\nexport function markTesting() {\n  TESTING = true;\n}\n\nexport interface CdkToolkitProps {\n  /**\n   * The Cloud Executable\n   */\n  cloudExecutable: CloudExecutable;\n\n  /**\n   * The provisioning engine used to apply changes to the cloud\n   */\n  deployments: Deployments;\n\n  /**\n   * The CliIoHost that's used for I/O operations\n   */\n  ioHost?: CliIoHost;\n\n  /**\n   * Name of the toolkit stack to use/deploy\n   *\n   * @default CDKToolkit\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Whether to be verbose\n   *\n   * @default false\n   */\n  verbose?: boolean;\n\n  /**\n   * Don't stop on error metadata\n   *\n   * @default false\n   */\n  ignoreErrors?: boolean;\n\n  /**\n   * Treat warnings in metadata as errors\n   *\n   * @default false\n   */\n  strict?: boolean;\n\n  /**\n   * Application configuration (settings and context)\n   */\n  configuration: Configuration;\n\n  /**\n   * AWS object (used by synthesizer and contextprovider)\n   */\n  sdkProvider: SdkProvider;\n}\n\n/**\n * When to build assets\n */\nexport enum AssetBuildTime {\n  /**\n   * Build all assets before deploying the first stack\n   *\n   * This is intended for expensive Docker image builds; so that if the Docker image build\n   * fails, no stacks are unnecessarily deployed (with the attendant wait time).\n   */\n  ALL_BEFORE_DEPLOY = 'all-before-deploy',\n\n  /**\n   * Build assets just-in-time, before publishing\n   */\n  JUST_IN_TIME = 'just-in-time',\n}\n\n/**\n * Toolkit logic\n *\n * The toolkit runs the `cloudExecutable` to obtain a cloud assembly and\n * deploys applies them to `cloudFormation`.\n */\nexport class CdkToolkit {\n  private ioHost: CliIoHost;\n  private toolkitStackName: string;\n\n  constructor(private readonly props: CdkToolkitProps) {\n    this.ioHost = props.ioHost ?? CliIoHost.instance();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n  }\n\n  public async metadata(stackName: string, json: boolean) {\n    const stacks = await this.selectSingleStackByName(stackName);\n    printSerializedObject(stacks.firstStack.manifest.metadata ?? {}, json);\n  }\n\n  public async acknowledge(noticeId: string) {\n    const acks = this.props.configuration.context.get('acknowledged-issue-numbers') ?? [];\n    acks.push(Number(noticeId));\n    this.props.configuration.context.set('acknowledged-issue-numbers', acks);\n    await this.props.configuration.saveContext();\n  }\n\n  public async diff(options: DiffOptions): Promise<number> {\n    const stacks = await this.selectStacksForDiff(options.stackNames, options.exclusively);\n\n    const strict = !!options.strict;\n    const contextLines = options.contextLines || 3;\n    const quiet = options.quiet || false;\n\n    let diffs = 0;\n    const parameterMap = buildParameterMap(options.parameters);\n\n    if (options.templatePath !== undefined) {\n      // Compare single stack against fixed template\n      if (stacks.stackCount !== 1) {\n        throw new ToolkitError(\n          'Can only select one stack when comparing to fixed template. Use --exclusively to avoid selecting multiple stacks.',\n        );\n      }\n\n      if (!(await fs.pathExists(options.templatePath))) {\n        throw new ToolkitError(`There is no file at ${options.templatePath}`);\n      }\n\n      const template = deserializeStructure(await fs.readFile(options.templatePath, { encoding: 'UTF-8' }));\n      const formatter = new DiffFormatter({\n        ioHelper: asIoHelper(this.ioHost, 'diff'),\n        oldTemplate: template,\n        newTemplate: stacks.firstStack,\n      });\n\n      if (options.securityOnly) {\n        const securityDiff = formatter.formatSecurityDiff({\n          requireApproval: RequireApproval.BROADENING,\n        });\n        if (securityDiff.formattedDiff) {\n          info(securityDiff.formattedDiff);\n          diffs += 1;\n        }\n      } else {\n        const diff = formatter.formatStackDiff({\n          strict,\n          context: contextLines,\n          quiet,\n        });\n        diffs = diff.numStacksWithChanges;\n        info(diff.formattedDiff);\n      }\n    } else {\n      // Compare N stacks against deployed templates\n      for (const stack of stacks.stackArtifacts) {\n        const templateWithNestedStacks = await this.props.deployments.readCurrentTemplateWithNestedStacks(\n          stack,\n          options.compareAgainstProcessedTemplate,\n        );\n        const currentTemplate = templateWithNestedStacks.deployedRootTemplate;\n        const nestedStacks = templateWithNestedStacks.nestedStacks;\n        const formatter = new DiffFormatter({\n          ioHelper: asIoHelper(this.ioHost, 'diff'),\n          oldTemplate: currentTemplate,\n          newTemplate: stack,\n        });\n\n        const migrator = new ResourceMigrator({\n          deployments: this.props.deployments,\n          ioHelper: asIoHelper(this.ioHost, 'diff'),\n        });\n        const resourcesToImport = await migrator.tryGetResources(await this.props.deployments.resolveEnvironment(stack));\n        if (resourcesToImport) {\n          removeNonImportResources(stack);\n        }\n\n        let changeSet = undefined;\n\n        if (options.changeSet) {\n          let stackExists = false;\n          try {\n            stackExists = await this.props.deployments.stackExists({\n              stack,\n              deployName: stack.stackName,\n              tryLookupRole: true,\n            });\n          } catch (e: any) {\n            debug(formatErrorMessage(e));\n            if (!quiet) {\n              info(\n                `Checking if the stack ${stack.stackName} exists before creating the changeset has failed, will base the diff on template differences (run again with -v to see the reason)\\n`,\n              );\n            }\n            stackExists = false;\n          }\n\n          if (stackExists) {\n            changeSet = await createDiffChangeSet(asIoHelper(this.ioHost, 'diff'), {\n              stack,\n              uuid: uuid.v4(),\n              deployments: this.props.deployments,\n              willExecute: false,\n              sdkProvider: this.props.sdkProvider,\n              parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n              resourcesToImport,\n            });\n          } else {\n            debug(\n              `the stack '${stack.stackName}' has not been deployed to CloudFormation or describeStacks call failed, skipping changeset creation.`,\n            );\n          }\n        }\n\n        if (options.securityOnly) {\n          const securityDiff = formatter.formatSecurityDiff({\n            requireApproval: RequireApproval.BROADENING,\n            stackName: stack.displayName,\n            changeSet,\n          });\n          if (securityDiff.formattedDiff) {\n            info(securityDiff.formattedDiff);\n            diffs += 1;\n          }\n        } else {\n          const diff = formatter.formatStackDiff({\n            strict,\n            context: contextLines,\n            quiet,\n            stackName: stack.displayName,\n            changeSet,\n            isImport: !!resourcesToImport,\n            nestedStackTemplates: nestedStacks,\n          });\n          info(diff.formattedDiff);\n          diffs += diff.numStacksWithChanges;\n        }\n      }\n    }\n\n    info(format('\\n✨  Number of stacks with differences: %s\\n', diffs));\n\n    return diffs && options.fail ? 1 : 0;\n  }\n\n  public async deploy(options: DeployOptions) {\n    if (options.watch) {\n      return this.watch(options);\n    }\n\n    // set progress from options, this includes user and app config\n    if (options.progress) {\n      this.ioHost.stackProgress = options.progress;\n    }\n\n    const startSynthTime = new Date().getTime();\n    const stackCollection = await this.selectStacksForDeploy(\n      options.selector,\n      options.exclusively,\n      options.cacheCloudAssembly,\n      options.ignoreNoStacks,\n    );\n    const elapsedSynthTime = new Date().getTime() - startSynthTime;\n    info(`\\n✨  Synthesis time: ${formatTime(elapsedSynthTime)}s\\n`);\n\n    if (stackCollection.stackCount === 0) {\n      error('This app contains no stacks');\n      return;\n    }\n\n    const migrator = new ResourceMigrator({\n      deployments: this.props.deployments,\n      ioHelper: asIoHelper(this.ioHost, 'deploy'),\n    });\n    await migrator.tryMigrateResources(stackCollection, {\n      toolkitStackName: this.toolkitStackName,\n      ...options,\n    });\n\n    const requireApproval = options.requireApproval ?? RequireApproval.BROADENING;\n\n    const parameterMap = buildParameterMap(options.parameters);\n\n    if (options.hotswap !== HotswapMode.FULL_DEPLOYMENT) {\n      warning(\n        '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',\n      );\n      warning('⚠️ They should only be used for development - never use them for your production Stacks!\\n');\n    }\n\n    let hotswapPropertiesFromSettings = this.props.configuration.settings.get(['hotswap']) || {};\n\n    let hotswapPropertyOverrides = new HotswapPropertyOverrides();\n    hotswapPropertyOverrides.ecsHotswapProperties = new EcsHotswapProperties(\n      hotswapPropertiesFromSettings.ecs?.minimumHealthyPercent,\n      hotswapPropertiesFromSettings.ecs?.maximumHealthyPercent,\n    );\n\n    const stacks = stackCollection.stackArtifacts;\n\n    const stackOutputs: { [key: string]: any } = {};\n    const outputsFile = options.outputsFile;\n\n    const buildAsset = async (assetNode: AssetBuildNode) => {\n      await this.props.deployments.buildSingleAsset(\n        assetNode.assetManifestArtifact,\n        assetNode.assetManifest,\n        assetNode.asset,\n        {\n          stack: assetNode.parentStack,\n          roleArn: options.roleArn,\n          stackName: assetNode.parentStack.stackName,\n        },\n      );\n    };\n\n    const publishAsset = async (assetNode: AssetPublishNode) => {\n      await this.props.deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {\n        stack: assetNode.parentStack,\n        roleArn: options.roleArn,\n        stackName: assetNode.parentStack.stackName,\n        forcePublish: options.force,\n      });\n    };\n\n    const deployStack = async (stackNode: StackNode) => {\n      const stack = stackNode.stack;\n      if (stackCollection.stackCount !== 1) {\n        highlight(stack.displayName);\n      }\n\n      if (!stack.environment) {\n        // eslint-disable-next-line max-len\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      if (Object.keys(stack.template.Resources || {}).length === 0) {\n        // The generated stack has no resources\n        if (!(await this.props.deployments.stackExists({ stack }))) {\n          warning('%s: stack has no resources, skipping deployment.', chalk.bold(stack.displayName));\n        } else {\n          warning('%s: stack has no resources, deleting existing stack.', chalk.bold(stack.displayName));\n          await this.destroy({\n            selector: { patterns: [stack.hierarchicalId] },\n            exclusively: true,\n            force: true,\n            roleArn: options.roleArn,\n            fromDeploy: true,\n          });\n        }\n        return;\n      }\n\n      if (requireApproval !== RequireApproval.NEVER) {\n        const currentTemplate = await this.props.deployments.readCurrentTemplate(stack);\n        const formatter = new DiffFormatter({\n          ioHelper: asIoHelper(this.ioHost, 'deploy'),\n          oldTemplate: currentTemplate,\n          newTemplate: stack,\n        });\n        const securityDiff = formatter.formatSecurityDiff({\n          requireApproval,\n        });\n        if (securityDiff.formattedDiff) {\n          info(securityDiff.formattedDiff);\n          await askUserConfirmation(\n            this.ioHost,\n            concurrency,\n            '\"--require-approval\" is enabled and stack includes security-sensitive updates',\n            'Do you wish to deploy these changes',\n          );\n        }\n      }\n\n      // Following are the same semantics we apply with respect to Notification ARNs (dictated by the SDK)\n      //\n      //  - undefined  =>  cdk ignores it, as if it wasn't supported (allows external management).\n      //  - []:        =>  cdk manages it, and the user wants to wipe it out.\n      //  - ['arn-1']  =>  cdk manages it, and the user wants to set it to ['arn-1'].\n      const notificationArns = (!!options.notificationArns || !!stack.notificationArns)\n        ? (options.notificationArns ?? []).concat(stack.notificationArns ?? [])\n        : undefined;\n\n      for (const notificationArn of notificationArns ?? []) {\n        if (!validateSnsTopicArn(notificationArn)) {\n          throw new ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);\n        }\n      }\n\n      const stackIndex = stacks.indexOf(stack) + 1;\n      info(`${chalk.bold(stack.displayName)}: deploying... [${stackIndex}/${stackCollection.stackCount}]`);\n      const startDeployTime = new Date().getTime();\n\n      let tags = options.tags;\n      if (!tags || tags.length === 0) {\n        tags = tagsForStack(stack);\n      }\n\n      let elapsedDeployTime = 0;\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 this.props.deployments.deployStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n            toolkitStackName: options.toolkitStackName,\n            reuseAssets: options.reuseAssets,\n            notificationArns,\n            tags,\n            execute: options.execute,\n            changeSetName: options.changeSetName,\n            deploymentMethod: options.deploymentMethod,\n            force: options.force,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.usePreviousParameters,\n            rollback,\n            hotswap: options.hotswap,\n            hotswapPropertyOverrides: hotswapPropertyOverrides,\n            extraUserAgent: options.extraUserAgent,\n            assetParallelism: options.assetParallelism,\n            ignoreNoStacks: options.ignoreNoStacks,\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\n              if (options.force) {\n                warning(`${motivation}. Rolling back first (--force).`);\n              } else {\n                await askUserConfirmation(\n                  this.ioHost,\n                  concurrency,\n                  motivation,\n                  `${motivation}. Roll back first and then proceed with deployment`,\n                );\n              }\n\n              // Perform a rollback\n              await this.rollback({\n                selector: { patterns: [stack.hierarchicalId] },\n                toolkitStackName: options.toolkitStackName,\n                force: options.force,\n              });\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            case 'replacement-requires-rollback': {\n              const motivation = 'Change includes a replacement which cannot be deployed with \"--no-rollback\"';\n\n              if (options.force) {\n                warning(`${motivation}. Proceeding with regular deployment (--force).`);\n              } else {\n                await askUserConfirmation(\n                  this.ioHost,\n                  concurrency,\n                  motivation,\n                  `${motivation}. Perform a regular deployment`,\n                );\n              }\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            default:\n              throw new ToolkitError(`Unexpected result type from deployStack: ${JSON.stringify(r)}. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose`);\n          }\n        }\n\n        const message = deployResult.noOp\n          ? ' ✅  %s (no changes)'\n          : ' ✅  %s';\n\n        success('\\n' + message, stack.displayName);\n        elapsedDeployTime = new Date().getTime() - startDeployTime;\n        info(`\\n✨  Deployment time: ${formatTime(elapsedDeployTime)}s\\n`);\n\n        if (Object.keys(deployResult.outputs).length > 0) {\n          info('Outputs:');\n\n          stackOutputs[stack.stackName] = deployResult.outputs;\n        }\n\n        for (const name of Object.keys(deployResult.outputs).sort()) {\n          const value = deployResult.outputs[name];\n          info(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);\n        }\n\n        info('Stack ARN:');\n\n        logResult(deployResult.stackArn);\n      } catch (e: any) {\n        // It has to be exactly this string because an integration test tests for\n        // \"bold(stackname) failed: ResourceNotReady: <error>\"\n        throw new ToolkitError(\n          [`❌  ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), formatErrorMessage(e)].join(' '),\n        );\n      } finally {\n        if (options.cloudWatchLogMonitor) {\n          const foundLogGroupsResult = await findCloudWatchLogGroups(this.props.sdkProvider, asIoHelper(this.ioHost, 'deploy'), stack);\n          options.cloudWatchLogMonitor.addLogGroups(\n            foundLogGroupsResult.env,\n            foundLogGroupsResult.sdk,\n            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      info(`\\n✨  Total time: ${formatTime(elapsedSynthTime + elapsedDeployTime)}s\\n`);\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    if (concurrency > 1) {\n      // always force \"events\" progress output when we have concurrency\n      this.ioHost.stackProgress = StackActivityProgress.EVENTS;\n\n      // ...but only warn if the user explicitly requested \"bar\" progress\n      if (options.progress && options.progress != StackActivityProgress.EVENTS) {\n        warning('⚠️ The --concurrency flag only supports --progress \"events\". Switching to \"events\".');\n      }\n    }\n\n    const stacksAndTheirAssetManifests = stacks.flatMap((stack) => [\n      stack,\n      ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),\n    ]);\n    const workGraph = new WorkGraphBuilder(\n      asIoHelper(this.ioHost, 'deploy'),\n      prebuildAssets,\n    ).build(stacksAndTheirAssetManifests);\n\n    // Unless we are running with '--force', skip already published assets\n    if (!options.force) {\n      await this.removePublishedAssets(workGraph, options);\n    }\n\n    const graphConcurrency: Concurrency = {\n      'stack': concurrency,\n      'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds\n      'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable\n    };\n\n    await workGraph.doParallel(graphConcurrency, {\n      deployStack,\n      buildAsset,\n      publishAsset,\n    });\n  }\n\n  /**\n   * Roll back the given stack or stacks.\n   */\n  public async rollback(options: RollbackOptions) {\n    const startSynthTime = new Date().getTime();\n    const stackCollection = await this.selectStacksForDeploy(options.selector, true);\n    const elapsedSynthTime = new Date().getTime() - startSynthTime;\n    info(`\\n✨  Synthesis time: ${formatTime(elapsedSynthTime)}s\\n`);\n\n    if (stackCollection.stackCount === 0) {\n      error('No stacks selected');\n      return;\n    }\n\n    let anyRollbackable = false;\n\n    for (const stack of stackCollection.stackArtifacts) {\n      info('Rolling back %s', chalk.bold(stack.displayName));\n      const startRollbackTime = new Date().getTime();\n      try {\n        const result = await this.props.deployments.rollbackStack({\n          stack,\n          roleArn: options.roleArn,\n          toolkitStackName: options.toolkitStackName,\n          force: options.force,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!result.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        const elapsedRollbackTime = new Date().getTime() - startRollbackTime;\n        info(`\\n✨  Rollback time: ${formatTime(elapsedRollbackTime).toString()}s\\n`);\n      } catch (e: any) {\n        error('\\n ❌  %s failed: %s', chalk.bold(stack.displayName), formatErrorMessage(e));\n        throw new ToolkitError('Rollback failed (use --force to orphan failing resources)');\n      }\n    }\n    if (!anyRollbackable) {\n      throw new ToolkitError('No stacks were in a state that could be rolled back');\n    }\n  }\n\n  public async watch(options: WatchOptions) {\n    const rootDir = path.dirname(path.resolve(PROJECT_CONFIG));\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    debug(\"root directory used for 'watch' is: %s\", rootDir);\n\n    const watchSettings: { include?: string | string[]; exclude: string | string[] } | undefined =\n      this.props.configuration.settings.get(['watch']);\n    if (!watchSettings) {\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 = this.patternsArrayForWatch(watchSettings.include, {\n      rootDir,\n      returnRootDirIfEmpty: true,\n    });\n    debug(\"'include' patterns for 'watch': %s\", watchIncludes);\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outputDir = this.props.configuration.settings.get(['output']);\n    const watchExcludes = this.patternsArrayForWatch(watchSettings.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    }).concat(`${outputDir}/**`, '**/.*', '**/.*/**', '**/node_modules/**');\n    debug(\"'exclude' patterns for 'watch': %s\", watchExcludes);\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    let latch: 'pre-ready' | 'open' | 'deploying' | 'queued' = 'pre-ready';\n\n    const cloudWatchLogMonitor = options.traceLogs ? new CloudWatchLogEventMonitor({\n      ioHelper,\n    }) : undefined;\n    const deployAndWatch = async () => {\n      latch = 'deploying';\n      await cloudWatchLogMonitor?.deactivate();\n\n      await this.invokeDeployFromWatch(options, cloudWatchLogMonitor);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while ((latch as 'deploying' | 'queued') === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        info(\"Detected file changes during deployment. Invoking 'cdk deploy' again\");\n        await this.invokeDeployFromWatch(options, cloudWatchLogMonitor);\n      }\n      latch = 'open';\n      await cloudWatchLogMonitor?.activate();\n    };\n\n    chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        debug(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\");\n        info(\"Triggering initial 'cdk deploy'\");\n        await deployAndWatch();\n      })\n      .on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath?: string) => {\n        if (latch === 'pre-ready') {\n          info(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '%s' for changes`, filePath);\n        } else if (latch === 'open') {\n          info(\"Detected change to '%s' (type: %s). Triggering 'cdk deploy'\", filePath, event);\n          await deployAndWatch();\n        } else {\n          // this means latch is either 'deploying' or 'queued'\n          latch = 'queued';\n          info(\n            \"Detected change to '%s' (type: %s) while 'cdk deploy' is still running. \" +\n              'Will queue for another deployment after this one finishes',\n            filePath,\n            event,\n          );\n        }\n      });\n  }\n\n  public async import(options: ImportOptions) {\n    const stacks = await this.selectStacksForDeploy(options.selector, true, true, false);\n\n    // set progress from options, this includes user and app config\n    if (options.progress) {\n      this.ioHost.stackProgress = options.progress;\n    }\n\n    if (stacks.stackCount > 1) {\n      throw new ToolkitError(\n        `Stack selection is ambiguous, please choose a specific stack for import [${stacks.stackArtifacts.map((x) => x.id).join(', ')}]`,\n      );\n    }\n\n    if (!process.stdout.isTTY && !options.resourceMappingFile) {\n      throw new ToolkitError('--resource-mapping is required when input is not a terminal');\n    }\n\n    const stack = stacks.stackArtifacts[0];\n\n    highlight(stack.displayName);\n\n    const resourceImporter = new ResourceImporter(stack, {\n      deployments: this.props.deployments,\n      ioHelper: asIoHelper(this.ioHost, 'import'),\n    });\n    const { additions, hasNonAdditions } = await resourceImporter.discoverImportableResources(options.force);\n    if (additions.length === 0) {\n      warning(\n        '%s: no new resources compared to the currently deployed stack, skipping import.',\n        chalk.bold(stack.displayName),\n      );\n      return;\n    }\n\n    // Prepare a mapping of physical resources to CDK constructs\n    const actualImport = !options.resourceMappingFile\n      ? await resourceImporter.askForResourceIdentifiers(additions)\n      : await resourceImporter.loadResourceIdentifiers(additions, options.resourceMappingFile);\n\n    if (actualImport.importResources.length === 0) {\n      warning('No resources selected for import.');\n      return;\n    }\n\n    // If \"--create-resource-mapping\" option was passed, write the resource mapping to the given file and exit\n    if (options.recordResourceMapping) {\n      const outputFile = options.recordResourceMapping;\n      fs.ensureFileSync(outputFile);\n      await fs.writeJson(outputFile, actualImport.resourceMap, {\n        spaces: 2,\n        encoding: 'utf8',\n      });\n      info('%s: mapping file written.', outputFile);\n      return;\n    }\n\n    // Import the resources according to the given mapping\n    info('%s: importing resources into stack...', chalk.bold(stack.displayName));\n    const tags = tagsForStack(stack);\n    await resourceImporter.importResourcesFromMap(actualImport, {\n      roleArn: options.roleArn,\n      tags,\n      deploymentMethod: options.deploymentMethod,\n      usePreviousParameters: true,\n      rollback: options.rollback,\n    });\n\n    // Notify user of next steps\n    info(\n      `Import operation complete. We recommend you run a ${chalk.blueBright('drift detection')} operation ` +\n        'to confirm your CDK app resource definitions are up-to-date. Read more here: ' +\n        chalk.underline.blueBright(\n          'https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/detect-drift-stack.html',\n        ),\n    );\n    if (actualImport.importResources.length < additions.length) {\n      info('');\n      warning(\n        `Some resources were skipped. Run another ${chalk.blueBright('cdk import')} or a ${chalk.blueBright('cdk deploy')} to bring the stack up-to-date with your CDK app definition.`,\n      );\n    } else if (hasNonAdditions) {\n      info('');\n      warning(\n        `Your app has pending updates or deletes excluded from this import operation. Run a ${chalk.blueBright('cdk deploy')} to bring the stack up-to-date with your CDK app definition.`,\n      );\n    }\n  }\n\n  public async destroy(options: DestroyOptions) {\n    let stacks = await this.selectStacksForDestroy(options.selector, options.exclusively);\n\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    stacks = stacks.reversed();\n\n    if (!options.force) {\n      // eslint-disable-next-line max-len\n      const confirmed = await promptly.confirm(\n        `Are you sure you want to delete: ${chalk.blue(stacks.stackArtifacts.map((s) => s.hierarchicalId).join(', '))} (y/n)?`,\n      );\n      if (!confirmed) {\n        return;\n      }\n    }\n\n    const action = options.fromDeploy ? 'deploy' : 'destroy';\n    for (const [index, stack] of stacks.stackArtifacts.entries()) {\n      success('%s: destroying... [%s/%s]', chalk.blue(stack.displayName), index + 1, stacks.stackCount);\n      try {\n        await this.props.deployments.destroyStack({\n          stack,\n          deployName: stack.stackName,\n          roleArn: options.roleArn,\n        });\n        success(`\\n ✅  %s: ${action}ed`, chalk.blue(stack.displayName));\n      } catch (e) {\n        error(`\\n ❌  %s: ${action} failed`, chalk.blue(stack.displayName), e);\n        throw e;\n      }\n    }\n  }\n\n  public async list(\n    selectors: string[],\n    options: { long?: boolean; json?: boolean; showDeps?: boolean } = {},\n  ): Promise<number> {\n    const stacks = await listStacks(this, {\n      selectors: selectors,\n    });\n\n    if (options.long && options.showDeps) {\n      printSerializedObject(stacks, options.json ?? false);\n      return 0;\n    }\n\n    if (options.showDeps) {\n      const stackDeps = [];\n\n      for (const stack of stacks) {\n        stackDeps.push({\n          id: stack.id,\n          dependencies: stack.dependencies,\n        });\n      }\n\n      printSerializedObject(stackDeps, options.json ?? false);\n      return 0;\n    }\n\n    if (options.long) {\n      const long = [];\n\n      for (const stack of stacks) {\n        long.push({\n          id: stack.id,\n          name: stack.name,\n          environment: stack.environment,\n        });\n      }\n      printSerializedObject(long, options.json ?? false);\n      return 0;\n    }\n\n    // just print stack IDs\n    for (const stack of stacks) {\n      logResult(stack.id);\n    }\n\n    return 0; // exit-code\n  }\n\n  /**\n   * Synthesize the given set of stacks (called when the user runs 'cdk synth')\n   *\n   * INPUT: Stack names can be supplied using a glob filter. If no stacks are\n   * given, all stacks from the application are implicitly selected.\n   *\n   * OUTPUT: If more than one stack ends up being selected, an output directory\n   * should be supplied, where the templates will be written.\n   */\n  public async synth(\n    stackNames: string[],\n    exclusively: boolean,\n    quiet: boolean,\n    autoValidate?: boolean,\n    json?: boolean,\n  ): Promise<any> {\n    const stacks = await this.selectStacksForDiff(stackNames, exclusively, autoValidate);\n\n    // if we have a single stack, print it to STDOUT\n    if (stacks.stackCount === 1) {\n      if (!quiet) {\n        printSerializedObject(obscureTemplate(stacks.firstStack.template), json ?? false);\n      }\n      return undefined;\n    }\n\n    // not outputting template to stdout, let's explain things to the user a little bit...\n    success(`Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`);\n    info(\n      `Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`,\n    );\n\n    return undefined;\n  }\n\n  /**\n   * Bootstrap the CDK Toolkit stack in the accounts used by the specified stack(s).\n   *\n   * @param userEnvironmentSpecs environment names that need to have toolkit support\n   *             provisioned, as a glob filter. If none is provided, all stacks are implicitly selected.\n   * @param options The name, role ARN, bootstrapping parameters, etc. to be used for the CDK Toolkit stack.\n   */\n  public async bootstrap(\n    userEnvironmentSpecs: string[],\n    options: BootstrapEnvironmentOptions,\n  ): Promise<void> {\n    const bootstrapper = new Bootstrapper(options.source, asIoHelper(this.ioHost, 'bootstrap'));\n    // If there is an '--app' argument and an environment looks like a glob, we\n    // select the environments from the app. Otherwise, use what the user said.\n\n    const environments = await this.defineEnvironments(userEnvironmentSpecs);\n\n    const limit = pLimit(20);\n\n    // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism\n    await Promise.all(environments.map((environment) => limit(async () => {\n      success(' ⏳  Bootstrapping environment %s...', chalk.blue(environment.name));\n      try {\n        const result = await bootstrapper.bootstrapEnvironment(environment, this.props.sdkProvider, options);\n        const message = result.noOp\n          ? ' ✅  Environment %s bootstrapped (no changes).'\n          : ' ✅  Environment %s bootstrapped.';\n        success(message, chalk.blue(environment.name));\n      } catch (e) {\n        error(' ❌  Environment %s failed bootstrapping: %s', chalk.blue(environment.name), e);\n        throw e;\n      }\n    })));\n  }\n\n  /**\n   * Garbage collects assets from a CDK app's environment\n   * @param options Options for Garbage Collection\n   */\n  public async garbageCollect(userEnvironmentSpecs: string[], options: GarbageCollectionOptions) {\n    const environments = await this.defineEnvironments(userEnvironmentSpecs);\n\n    for (const environment of environments) {\n      success(' ⏳  Garbage Collecting environment %s...', chalk.blue(environment.name));\n      const gc = new GarbageCollector({\n        sdkProvider: this.props.sdkProvider,\n        ioHelper: asIoHelper(this.ioHost, 'gc'),\n        resolvedEnvironment: environment,\n        bootstrapStackName: options.bootstrapStackName,\n        rollbackBufferDays: options.rollbackBufferDays,\n        createdBufferDays: options.createdBufferDays,\n        action: options.action ?? 'full',\n        type: options.type ?? 'all',\n        confirm: options.confirm ?? true,\n      });\n      await gc.garbageCollect();\n    }\n  }\n\n  private async defineEnvironments(userEnvironmentSpecs: string[]): Promise<cxapi.Environment[]> {\n    // By default, glob for everything\n    const environmentSpecs = userEnvironmentSpecs.length > 0 ? [...userEnvironmentSpecs] : ['**'];\n\n    // Partition into globs and non-globs (this will mutate environmentSpecs).\n    const globSpecs = partition(environmentSpecs, looksLikeGlob);\n    if (globSpecs.length > 0 && !this.props.cloudExecutable.hasApp) {\n      if (userEnvironmentSpecs.length > 0) {\n        // User did request this glob\n        throw new ToolkitError(\n          `'${globSpecs}' is not an environment name. Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json' to use wildcards.`,\n        );\n      } else {\n        // User did not request anything\n        throw new ToolkitError(\n          \"Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json'.\",\n        );\n      }\n    }\n\n    const environments: cxapi.Environment[] = [...environmentsFromDescriptors(environmentSpecs)];\n\n    // If there is an '--app' argument, select the environments from the app.\n    if (this.props.cloudExecutable.hasApp) {\n      environments.push(\n        ...(await globEnvironmentsFromStacks(await this.selectStacksForList([]), globSpecs, this.props.sdkProvider)),\n      );\n    }\n\n    return environments;\n  }\n\n  /**\n   * Migrates a CloudFormation stack/template to a CDK app\n   * @param options Options for CDK app creation\n   */\n  public async migrate(options: MigrateOptions): Promise<void> {\n    warning('This command is an experimental feature.');\n    const language = options.language?.toLowerCase() ?? 'typescript';\n    const environment = setEnvironment(options.account, options.region);\n    let generateTemplateOutput: GenerateTemplateOutput | undefined;\n    let cfn: CfnTemplateGeneratorProvider | undefined;\n    let templateToDelete: string | undefined;\n\n    try {\n      // if neither fromPath nor fromStack is provided, generate a template using cloudformation\n      const scanType = parseSourceOptions(options.fromPath, options.fromStack, options.stackName).source;\n      if (scanType == TemplateSourceOptions.SCAN) {\n        generateTemplateOutput = await generateTemplate({\n          stackName: options.stackName,\n          filters: options.filter,\n          fromScan: options.fromScan,\n          sdkProvider: this.props.sdkProvider,\n          environment: environment,\n        });\n        templateToDelete = generateTemplateOutput.templateId;\n      } else if (scanType == TemplateSourceOptions.PATH) {\n        const templateBody = readFromPath(options.fromPath!);\n\n        const parsedTemplate = deserializeStructure(templateBody);\n        const templateId = parsedTemplate.Metadata?.TemplateId?.toString();\n        if (templateId) {\n          // if we have a template id, we can call describe generated template to get the resource identifiers\n          // resource metadata, and template source to generate the template\n          cfn = new CfnTemplateGeneratorProvider(await buildCfnClient(this.props.sdkProvider, environment));\n          const generatedTemplateSummary = await cfn.describeGeneratedTemplate(templateId);\n          generateTemplateOutput = buildGenertedTemplateOutput(\n            generatedTemplateSummary,\n            templateBody,\n            generatedTemplateSummary.GeneratedTemplateId!,\n          );\n        } else {\n          generateTemplateOutput = {\n            migrateJson: {\n              templateBody: templateBody,\n              source: 'localfile',\n            },\n          };\n        }\n      } else if (scanType == TemplateSourceOptions.STACK) {\n        const template = await readFromStack(options.stackName, this.props.sdkProvider, environment);\n        if (!template) {\n          throw new ToolkitError(`No template found for stack-name: ${options.stackName}`);\n        }\n        generateTemplateOutput = {\n          migrateJson: {\n            templateBody: template,\n            source: options.stackName,\n          },\n        };\n      } else {\n        // We shouldn't ever get here, but just in case.\n        throw new ToolkitError(`Invalid source option provided: ${scanType}`);\n      }\n      const stack = generateStack(generateTemplateOutput.migrateJson.templateBody, options.stackName, language);\n      success(' ⏳  Generating CDK app for %s...', chalk.blue(options.stackName));\n      await generateCdkApp(options.stackName, stack!, language, options.outputPath, options.compress);\n      if (generateTemplateOutput) {\n        writeMigrateJsonFile(options.outputPath, options.stackName, generateTemplateOutput.migrateJson);\n      }\n      if (isThereAWarning(generateTemplateOutput)) {\n        warning(\n          ' ⚠️  Some resources could not be migrated completely. Please review the README.md file for more information.',\n        );\n        appendWarningsToReadme(\n          `${path.join(options.outputPath ?? process.cwd(), options.stackName)}/README.md`,\n          generateTemplateOutput.resources!,\n        );\n      }\n    } catch (e) {\n      error(' ❌  Migrate failed for `%s`: %s', options.stackName, (e as Error).message);\n      throw e;\n    } finally {\n      if (templateToDelete) {\n        if (!cfn) {\n          cfn = new CfnTemplateGeneratorProvider(await buildCfnClient(this.props.sdkProvider, environment));\n        }\n        if (!process.env.MIGRATE_INTEG_TEST) {\n          await cfn.deleteGeneratedTemplate(templateToDelete);\n        }\n      }\n    }\n  }\n\n  private async selectStacksForList(patterns: string[]) {\n    const assembly = await this.assembly();\n    const stacks = await assembly.selectStacks({ patterns }, { defaultBehavior: DefaultSelection.AllStacks });\n\n    // No validation\n\n    return stacks;\n  }\n\n  private async selectStacksForDeploy(\n    selector: StackSelector,\n    exclusively?: boolean,\n    cacheCloudAssembly?: boolean,\n    ignoreNoStacks?: boolean,\n  ): Promise<StackCollection> {\n    const assembly = await this.assembly(cacheCloudAssembly);\n    const stacks = await assembly.selectStacks(selector, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Upstream,\n      defaultBehavior: DefaultSelection.OnlySingle,\n      ignoreNoStacks,\n    });\n\n    this.validateStacksSelected(stacks, selector.patterns);\n    await this.validateStacks(stacks);\n\n    return stacks;\n  }\n\n  private async selectStacksForDiff(\n    stackNames: string[],\n    exclusively?: boolean,\n    autoValidate?: boolean,\n  ): Promise<StackCollection> {\n    const assembly = await this.assembly();\n\n    const selectedForDiff = await assembly.selectStacks(\n      { patterns: stackNames },\n      {\n        extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Upstream,\n        defaultBehavior: DefaultSelection.MainAssembly,\n      },\n    );\n\n    const allStacks = await this.selectStacksForList([]);\n    const autoValidateStacks = autoValidate\n      ? allStacks.filter((art) => art.validateOnSynth ?? false)\n      : new StackCollection(assembly, []);\n\n    this.validateStacksSelected(selectedForDiff.concat(autoValidateStacks), stackNames);\n    await this.validateStacks(selectedForDiff.concat(autoValidateStacks));\n\n    return selectedForDiff;\n  }\n\n  private async selectStacksForDestroy(selector: StackSelector, exclusively?: boolean) {\n    const assembly = await this.assembly();\n    const stacks = await assembly.selectStacks(selector, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Downstream,\n      defaultBehavior: DefaultSelection.OnlySingle,\n    });\n\n    // No validation\n\n    return stacks;\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private async validateStacks(stacks: StackCollection) {\n    let failAt: 'warn' | 'error' | 'none' = 'error';\n    if (this.props.ignoreErrors) {\n      failAt = 'none';\n    }\n    if (this.props.strict) {\n      failAt = 'warn';\n    }\n\n    await stacks.validateMetadata(failAt, stackMetadataLogger(this.props.verbose));\n  }\n\n  /**\n   * Validate that if a user specified a stack name there exists at least 1 stack selected\n   */\n  private validateStacksSelected(stacks: StackCollection, stackNames: string[]) {\n    if (stackNames.length != 0 && stacks.stackCount == 0) {\n      throw new ToolkitError(`No stacks match the name(s) ${stackNames}`);\n    }\n  }\n\n  /**\n   * Select a single stack by its name\n   */\n  private async selectSingleStackByName(stackName: string) {\n    const assembly = await this.assembly();\n\n    const stacks = await assembly.selectStacks(\n      { patterns: [stackName] },\n      {\n        extend: ExtendedStackSelection.None,\n        defaultBehavior: DefaultSelection.None,\n      },\n    );\n\n    // Could have been a glob so check that we evaluated to exactly one\n    if (stacks.stackCount > 1) {\n      throw new ToolkitError(`This command requires exactly one stack and we matched more than one: ${stacks.stackIds}`);\n    }\n\n    return assembly.stackById(stacks.firstStack.id);\n  }\n\n  public assembly(cacheCloudAssembly?: boolean): Promise<CloudAssembly> {\n    return this.props.cloudExecutable.synthesize(cacheCloudAssembly);\n  }\n\n  private patternsArrayForWatch(\n    patterns: string | string[] | undefined,\n    options: { rootDir: string; returnRootDirIfEmpty: boolean },\n  ): string[] {\n    const patternsArray: string[] = patterns !== undefined ? (Array.isArray(patterns) ? patterns : [patterns]) : [];\n    return patternsArray.length > 0 ? patternsArray : options.returnRootDirIfEmpty ? [options.rootDir] : [];\n  }\n\n  private async invokeDeployFromWatch(\n    options: WatchOptions,\n    cloudWatchLogMonitor?: CloudWatchLogEventMonitor,\n  ): Promise<void> {\n    const deployOptions: DeployOptions = {\n      ...options,\n      requireApproval: RequireApproval.NEVER,\n      // if 'watch' is called by invoking 'cdk deploy --watch',\n      // we need to make sure to not call 'deploy' with 'watch' again,\n      // as that would lead to a cycle\n      watch: false,\n      cloudWatchLogMonitor,\n      cacheCloudAssembly: false,\n      hotswap: options.hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${options.hotswap !== HotswapMode.FALL_BACK ? 'on' : 'off'}`,\n      concurrency: options.concurrency,\n    };\n\n    try {\n      await this.deploy(deployOptions);\n    } catch {\n      // just continue - deploy will show the error\n    }\n  }\n\n  /**\n   * Remove the asset publishing and building from the work graph for assets that are already in place\n   */\n  private async removePublishedAssets(graph: WorkGraph, options: DeployOptions) {\n    await graph.removeUnnecessaryAssets(assetNode => this.props.deployments.isSingleAssetPublished(assetNode.assetManifest, assetNode.asset, {\n      stack: assetNode.parentStack,\n      roleArn: options.roleArn,\n      stackName: assetNode.parentStack.stackName,\n    }));\n  }\n}\n\n/**\n * Print a serialized object (YAML or JSON) to stdout.\n */\nfunction printSerializedObject(obj: any, json: boolean) {\n  logResult(serializeStructure(obj, json));\n}\n\n/**\n * Options for the diff command\n */\nexport interface DiffOptions {\n  /**\n   * Stack names to diff\n   */\n  readonly stackNames: string[];\n\n  /**\n   * Name of the toolkit stack, if not the default name\n   *\n   * @default 'CDKToolkit'\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Only select the given stack\n   *\n   * @default false\n   */\n  readonly exclusively?: boolean;\n\n  /**\n   * Used a template from disk instead of from the server\n   *\n   * @default Use from the server\n   */\n  readonly templatePath?: string;\n\n  /**\n   * Strict diff mode\n   *\n   * @default false\n   */\n  readonly strict?: boolean;\n\n  /**\n   * How many lines of context to show in the diff\n   *\n   * @default 3\n   */\n  readonly contextLines?: number;\n\n  /**\n   * Whether to fail with exit code 1 in case of diff\n   *\n   * @default false\n   */\n  readonly fail?: boolean;\n\n  /**\n   * Only run diff on broadened security changes\n   *\n   * @default false\n   */\n  readonly securityOnly?: boolean;\n\n  /**\n   * Whether to run the diff against the template after the CloudFormation Transforms inside it have been executed\n   * (as opposed to the original template, the default, which contains the unprocessed Transforms).\n   *\n   * @default false\n   */\n  readonly compareAgainstProcessedTemplate?: boolean;\n\n  /*\n   * Run diff in quiet mode without printing the diff statuses\n   *\n   * @default false\n   */\n  readonly quiet?: boolean;\n\n  /**\n   * Additional parameters for CloudFormation at diff time, used to create a change set\n   * @default {}\n   */\n  readonly parameters?: { [name: string]: string | undefined };\n\n  /**\n   * Whether or not to create, analyze, and subsequently delete a changeset\n   *\n   * @default true\n   */\n  readonly changeSet?: boolean;\n}\n\ninterface CfnDeployOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  selector: StackSelector;\n\n  /**\n   * Name of the toolkit stack to use/deploy\n   *\n   * @default CDKToolkit\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Role to pass to CloudFormation for deployment\n   */\n  roleArn?: string;\n\n  /**\n   * Optional name to use for the CloudFormation change set.\n   * If not provided, a name will be generated automatically.\n   *\n   * @deprecated Use 'deploymentMethod' instead\n   */\n  changeSetName?: string;\n\n  /**\n   * Whether to execute the ChangeSet\n   * Not providing `execute` parameter will result in execution of ChangeSet\n   *\n   * @default true\n   * @deprecated Use 'deploymentMethod' instead\n   */\n  execute?: boolean;\n\n  /**\n   * Deployment method\n   */\n  readonly deploymentMethod?: DeploymentMethod;\n\n  /**\n   * Display mode for stack deployment progress.\n   *\n   * @default - StackActivityProgress.Bar - stack events will be displayed for\n   *   the resource currently being deployed.\n   */\n  progress?: StackActivityProgress;\n\n  /**\n   * Rollback failed deployments\n   *\n   * @default true\n   */\n  readonly rollback?: boolean;\n}\n\ninterface WatchOptions extends Omit<CfnDeployOptions, 'execute'> {\n  /**\n   * Only select the given stack\n   *\n   * @default false\n   */\n  exclusively?: boolean;\n\n  /**\n   * Reuse the assets with the given asset IDs\n   */\n  reuseAssets?: string[];\n\n  /**\n   * Always deploy, even if templates are identical.\n   * @default false\n   */\n  force?: boolean;\n\n  /**\n   * Whether to perform a 'hotswap' deployment.\n   * A 'hotswap' deployment will attempt to short-circuit CloudFormation\n   * and update the affected resources like Lambda functions directly.\n   *\n   * @default - `HotswapMode.FALL_BACK` for regular deployments, `HotswapMode.HOTSWAP_ONLY` for 'watch' deployments\n   */\n  readonly hotswap: HotswapMode;\n\n  /**\n   * The extra string to append to the User-Agent header when performing AWS SDK calls.\n   *\n   * @default - nothing extra is appended to the User-Agent header\n   */\n  readonly extraUserAgent?: string;\n\n  /**\n   * Whether to show CloudWatch logs for hotswapped resources\n   * locally in the users terminal\n   *\n   * @default - false\n   */\n  readonly traceLogs?: boolean;\n\n  /**\n   * Maximum number of simultaneous deployments (dependency permitting) to execute.\n   * The default is '1', which executes all deployments serially.\n   *\n   * @default 1\n   */\n  readonly concurrency?: number;\n}\n\nexport interface DeployOptions extends CfnDeployOptions, WatchOptions {\n  /**\n   * ARNs of SNS topics that CloudFormation will notify with stack related events\n   */\n  notificationArns?: string[];\n\n  /**\n   * What kind of security changes require approval\n   *\n   * @default RequireApproval.Broadening\n   */\n  requireApproval?: RequireApproval;\n\n  /**\n   * Tags to pass to CloudFormation for deployment\n   */\n  tags?: Tag[];\n\n  /**\n   * Additional parameters for CloudFormation at deploy time\n   * @default {}\n   */\n  parameters?: { [name: string]: string | undefined };\n\n  /**\n   * Use previous values for unspecified parameters\n   *\n   * If not set, all parameters must be specified for every deployment.\n   *\n   * @default true\n   */\n  usePreviousParameters?: boolean;\n\n  /**\n   * Path to file where stack outputs will be written after a successful deploy as JSON\n   * @default - Outputs are not written to any file\n   */\n  outputsFile?: string;\n\n  /**\n   * Whether we are on a CI system\n   *\n   * @default false\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Whether this 'deploy' command should actually delegate to the 'watch' command.\n   *\n   * @default false\n   */\n  readonly watch?: boolean;\n\n  /**\n   * Whether we should cache the Cloud Assembly after the first time it has been synthesized.\n   * The default is 'true', we only don't want to do it in case the deployment is triggered by\n   * 'cdk watch'.\n   *\n   * @default true\n   */\n  readonly cacheCloudAssembly?: boolean;\n\n  /**\n   * Allows adding CloudWatch log groups to the log monitor via\n   * cloudWatchLogMonitor.setLogGroups();\n   *\n   * @default - not monitoring CloudWatch logs\n   */\n  readonly cloudWatchLogMonitor?: CloudWatchLogEventMonitor;\n\n  /**\n   * Maximum number of simultaneous deployments (dependency permitting) to execute.\n   * The default is '1', which executes all deployments serially.\n   *\n   * @default 1\n   */\n  readonly concurrency?: number;\n\n  /**\n   * Build/publish assets for a single stack in parallel\n   *\n   * Independent of whether stacks are being done in parallel or no.\n   *\n   * @default true\n   */\n  readonly assetParallelism?: boolean;\n\n  /**\n   * When to build assets\n   *\n   * The default is the Docker-friendly default.\n   *\n   * @default AssetBuildTime.ALL_BEFORE_DEPLOY\n   */\n  readonly assetBuildTime?: AssetBuildTime;\n\n  /**\n   * Whether to deploy if the app contains no stacks.\n   *\n   * @default false\n   */\n  readonly ignoreNoStacks?: boolean;\n}\n\nexport interface RollbackOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  readonly selector: StackSelector;\n\n  /**\n   * Name of the toolkit stack to use/deploy\n   *\n   * @default CDKToolkit\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Role to pass to CloudFormation for deployment\n   *\n   * @default - Default stack role\n   */\n  readonly roleArn?: string;\n\n  /**\n   * Whether to force the rollback or not\n   *\n   * @default false\n   */\n  readonly force?: boolean;\n\n  /**\n   * Logical IDs of resources to orphan\n   *\n   * @default - No orphaning\n   */\n  readonly orphanLogicalIds?: string[];\n\n  /**\n   * Whether to validate the version of the bootstrap stack permissions\n   *\n   * @default true\n   */\n  readonly validateBootstrapStackVersion?: boolean;\n}\n\nexport interface ImportOptions extends CfnDeployOptions {\n  /**\n   * Build a physical resource mapping and write it to the given file, without performing the actual import operation\n   *\n   * @default - No file\n   */\n\n  readonly recordResourceMapping?: string;\n\n  /**\n   * Path to a file with the physical resource mapping to CDK constructs in JSON format\n   *\n   * @default - No mapping file\n   */\n  readonly resourceMappingFile?: string;\n\n  /**\n   * Allow non-addition changes to the template\n   *\n   * @default false\n   */\n  readonly force?: boolean;\n}\n\nexport interface DestroyOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  selector: StackSelector;\n\n  /**\n   * Whether to exclude stacks that depend on the stacks to be deleted\n   */\n  exclusively: boolean;\n\n  /**\n   * Whether to skip prompting for confirmation\n   */\n  force: boolean;\n\n  /**\n   * The arn of the IAM role to use\n   */\n  roleArn?: string;\n\n  /**\n   * Whether the destroy request came from a deploy.\n   */\n  fromDeploy?: boolean;\n}\n\n/**\n * Options for the garbage collection\n */\nexport interface GarbageCollectionOptions {\n  /**\n   * The action to perform.\n   *\n   * @default 'full'\n   */\n  readonly action: 'print' | 'tag' | 'delete-tagged' | 'full';\n\n  /**\n   * The type of the assets to be garbage collected.\n   *\n   * @default 'all'\n   */\n  readonly type: 's3' | 'ecr' | 'all';\n\n  /**\n   * Elapsed time between an asset being marked as isolated and actually deleted.\n   *\n   * @default 0\n   */\n  readonly rollbackBufferDays: number;\n\n  /**\n   * Refuse deletion of any assets younger than this number of days.\n   */\n  readonly createdBufferDays: number;\n\n  /**\n   * The stack name of the bootstrap stack.\n   *\n   * @default DEFAULT_TOOLKIT_STACK_NAME\n   */\n  readonly bootstrapStackName?: string;\n\n  /**\n   * Skips the prompt before actual deletion begins\n   *\n   * @default false\n   */\n  readonly confirm?: boolean;\n}\n\nexport interface MigrateOptions {\n  /**\n   * The name assigned to the generated stack. This is also used to get\n   * the stack from the user's account if `--from-stack` is used.\n   */\n  readonly stackName: string;\n\n  /**\n   * The target language for the generated the CDK app.\n   *\n   * @default typescript\n   */\n  readonly language?: string;\n\n  /**\n   * The local path of the template used to generate the CDK app.\n   *\n   * @default - Local path is not used for the template source.\n   */\n  readonly fromPath?: string;\n\n  /**\n   * Whether to get the template from an existing CloudFormation stack.\n   *\n   * @default false\n   */\n  readonly fromStack?: boolean;\n\n  /**\n   * The output path at which to create the CDK app.\n   *\n   * @default - The current directory\n   */\n  readonly outputPath?: string;\n\n  /**\n   * The account from which to retrieve the template of the CloudFormation stack.\n   *\n   * @default - Uses the account for the credentials in use by the user.\n   */\n  readonly account?: string;\n\n  /**\n   * The region from which to retrieve the template of the CloudFormation stack.\n   *\n   * @default - Uses the default region for the credentials in use by the user.\n   */\n  readonly region?: string;\n\n  /**\n   * Filtering criteria used to select the resources to be included in the generated CDK app.\n   *\n   * @default - Include all resources\n   */\n  readonly filter?: string[];\n\n  /**\n   * Whether to initiate a new account scan for generating the CDK app.\n   *\n   * @default false\n   */\n  readonly fromScan?: FromScan;\n\n  /**\n   * Whether to zip the generated cdk app folder.\n   *\n   * @default false\n   */\n  readonly compress?: boolean;\n}\n\nfunction buildParameterMap(\n  parameters:\n  | {\n    [name: string]: string | undefined;\n  }\n  | undefined,\n): { [name: string]: { [name: string]: string | undefined } } {\n  const parameterMap: {\n    [name: string]: { [name: string]: string | undefined };\n  } = { '*': {} };\n  for (const key in parameters) {\n    if (parameters.hasOwnProperty(key)) {\n      const [stack, parameter] = key.split(':', 2);\n      if (!parameter) {\n        parameterMap['*'][stack] = parameters[key];\n      } else {\n        if (!parameterMap[stack]) {\n          parameterMap[stack] = {};\n        }\n        parameterMap[stack][parameter] = parameters[key];\n      }\n    }\n  }\n\n  return parameterMap;\n}\n\n/**\n * Ask the user for a yes/no confirmation\n *\n * Automatically fail the confirmation in case we're in a situation where the confirmation\n * cannot be interactively obtained from a human at the keyboard.\n */\nasync function askUserConfirmation(\n  ioHost: CliIoHost,\n  concurrency: number,\n  motivation: string,\n  question: string,\n) {\n  await ioHost.withCorkedLogging(async () => {\n    // only talk to user if STDIN is a terminal (otherwise, fail)\n    if (!TESTING && !process.stdin.isTTY) {\n      throw new ToolkitError(`${motivation}, but terminal (TTY) is not attached so we are unable to get a confirmation from the user`);\n    }\n\n    // only talk to user if concurrency is 1 (otherwise, fail)\n    if (concurrency > 1) {\n      throw new ToolkitError(`${motivation}, but concurrency is greater than 1 so we are unable to get a confirmation from the user`);\n    }\n\n    const confirmed = await promptly.confirm(`${chalk.cyan(question)} (y/n)?`);\n    if (!confirmed) {\n      throw new ToolkitError('Aborted by user');\n    }\n  });\n}\n\n/**\n * Logger for processing stack metadata\n */\nfunction stackMetadataLogger(verbose?: boolean): (level: 'info' | 'error' | 'warn', msg: cxapi.SynthesisMessage) => Promise<void> {\n  const makeLogger = (level: string): [logger: (m: string) => void, prefix: string] => {\n    switch (level) {\n      case 'error':\n        return [error, 'Error'];\n      case 'warn':\n        return [warning, 'Warning'];\n      default:\n        return [info, 'Info'];\n    }\n  };\n\n  return async (level, msg) => {\n    const [logFn, prefix] = makeLogger(level);\n    logFn(`[${prefix} at ${msg.id}] ${msg.entry.data}`);\n\n    if (verbose && msg.entry.trace) {\n      logFn(`  ${msg.entry.trace.join('\\n  ')}`);\n    }\n  };\n}\n"]}