@aws-cdk/toolkit-lib 0.1.6 → 0.1.8

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.
@@ -6,10 +6,12 @@ const cxapi = require("@aws-cdk/cx-api");
6
6
  const chalk = require("chalk");
7
7
  const chokidar = require("chokidar");
8
8
  const fs = require("fs-extra");
9
+ const uuid = require("uuid");
9
10
  const private_1 = require("./private");
10
11
  const bootstrap_1 = require("../actions/bootstrap");
11
12
  const deploy_1 = require("../actions/deploy");
12
13
  const private_2 = require("../actions/deploy/private");
14
+ const diff_1 = require("../actions/diff");
13
15
  const private_3 = require("../actions/diff/private");
14
16
  const private_4 = require("../actions/watch/private");
15
17
  const aws_cdk_1 = require("../api/aws-cdk");
@@ -86,8 +88,10 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
86
88
  * Bootstrap Action
87
89
  */
88
90
  async bootstrap(environments, options) {
91
+ const startTime = Date.now();
92
+ const results = [];
89
93
  const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'bootstrap');
90
- const bootstrapEnvironments = await environments.getEnvironments();
94
+ const bootstrapEnvironments = await environments.getEnvironments(this.ioHost);
91
95
  const source = options.source ?? bootstrap_1.BootstrapSource.default();
92
96
  const parameters = options.parameters;
93
97
  const bootstrapper = new aws_cdk_1.Bootstrapper(source, ioHelper);
@@ -113,13 +117,23 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
113
117
  ? ` ✅ ${environment.name} (no changes)`
114
118
  : ` ✅ ${environment.name}`;
115
119
  await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I9900.msg(chalk.green('\n' + message), { environment }));
116
- await bootstrapSpan.end();
120
+ const envTime = await bootstrapSpan.end();
121
+ const result = {
122
+ environment,
123
+ status: bootstrapResult.noOp ? 'no-op' : 'success',
124
+ duration: envTime.asMs,
125
+ };
126
+ results.push(result);
117
127
  }
118
128
  catch (e) {
119
129
  await ioHelper.notify(private_6.IO.CDK_TOOLKIT_E9900.msg(`\n ❌ ${chalk.bold(environment.name)} failed: ${(0, util_1.formatErrorMessage)(e)}`, { error: e }));
120
130
  throw e;
121
131
  }
122
132
  })));
133
+ return {
134
+ environments: results,
135
+ duration: Date.now() - startTime,
136
+ };
123
137
  }
124
138
  /**
125
139
  * Synth Action
@@ -128,8 +142,8 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
128
142
  const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'synth');
129
143
  const selectStacks = options.stacks ?? private_5.ALL_STACKS;
130
144
  const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
131
- const assembly = await (0, private_1.assemblyFromSource)(cx);
132
- const stacks = assembly.selectStacksV2(selectStacks);
145
+ const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
146
+ const stacks = await assembly.selectStacksV2(selectStacks);
133
147
  const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];
134
148
  await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHelper);
135
149
  await synthSpan.end();
@@ -162,6 +176,132 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
162
176
  }
163
177
  return new private_5.IdentityCloudAssemblySource(assembly.assembly);
164
178
  }
179
+ /**
180
+ * Diff Action
181
+ */
182
+ async diff(cx, options) {
183
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'diff');
184
+ const selectStacks = options.stacks ?? private_5.ALL_STACKS;
185
+ const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
186
+ const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
187
+ const stacks = await assembly.selectStacksV2(selectStacks);
188
+ await synthSpan.end();
189
+ const diffSpan = await ioHelper.span(private_6.SPAN.DIFF_STACK).begin({ stacks: selectStacks });
190
+ const deployments = await this.deploymentsForAction('diff');
191
+ const strict = !!options.strict;
192
+ const contextLines = options.contextLines || 3;
193
+ const diffMethod = options.method ?? diff_1.DiffMethod.ChangeSet();
194
+ let diffs = 0;
195
+ let formattedSecurityDiff = '';
196
+ let formattedStackDiff = '';
197
+ if (diffMethod.method === 'local-file') {
198
+ const methodOptions = diffMethod.options;
199
+ // Compare single stack against fixed template
200
+ if (stacks.stackCount !== 1) {
201
+ throw new shared_public_1.ToolkitError('Can only select one stack when comparing to fixed template. Use --exclusively to avoid selecting multiple stacks.');
202
+ }
203
+ if (!(await fs.pathExists(methodOptions.path))) {
204
+ throw new shared_public_1.ToolkitError(`There is no file at ${path}`);
205
+ }
206
+ const file = fs.readFileSync(methodOptions.path).toString();
207
+ const template = (0, util_1.deserializeStructure)(file);
208
+ const formatter = new shared_public_1.DiffFormatter({
209
+ ioHelper,
210
+ oldTemplate: template,
211
+ newTemplate: stacks.firstStack,
212
+ });
213
+ if (options.securityOnly) {
214
+ const securityDiff = formatter.formatSecurityDiff({
215
+ requireApproval: shared_public_1.RequireApproval.BROADENING,
216
+ });
217
+ formattedSecurityDiff = securityDiff.formattedDiff ?? '';
218
+ diffs = securityDiff.formattedDiff ? diffs + 1 : diffs;
219
+ }
220
+ else {
221
+ const diff = formatter.formatStackDiff({
222
+ strict,
223
+ context: contextLines,
224
+ });
225
+ formattedStackDiff = diff.formattedDiff;
226
+ diffs = diff.numStacksWithChanges;
227
+ }
228
+ }
229
+ else {
230
+ const methodOptions = diffMethod.options;
231
+ // Compare N stacks against deployed templates
232
+ for (const stack of stacks.stackArtifacts) {
233
+ const templateWithNestedStacks = await deployments.readCurrentTemplateWithNestedStacks(stack, methodOptions.compareAgainstProcessedTemplate);
234
+ const currentTemplate = templateWithNestedStacks.deployedRootTemplate;
235
+ const nestedStacks = templateWithNestedStacks.nestedStacks;
236
+ const formatter = new shared_public_1.DiffFormatter({
237
+ ioHelper,
238
+ oldTemplate: currentTemplate,
239
+ newTemplate: stack,
240
+ });
241
+ const migrator = new aws_cdk_1.ResourceMigrator({ deployments, ioHelper });
242
+ const resourcesToImport = await migrator.tryGetResources(await deployments.resolveEnvironment(stack));
243
+ if (resourcesToImport) {
244
+ (0, shared_public_1.removeNonImportResources)(stack);
245
+ }
246
+ let changeSet = undefined;
247
+ if (diffMethod.method === 'change-set') {
248
+ let stackExists = false;
249
+ try {
250
+ stackExists = await deployments.stackExists({
251
+ stack,
252
+ deployName: stack.stackName,
253
+ tryLookupRole: true,
254
+ });
255
+ }
256
+ catch (e) {
257
+ await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_DEBUG.msg(`Checking if the stack ${stack.stackName} exists before creating the changeset has failed, will base the diff on template differences.\n`));
258
+ await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_DEBUG.msg((0, util_1.formatErrorMessage)(e)));
259
+ stackExists = false;
260
+ }
261
+ if (stackExists) {
262
+ changeSet = await (0, aws_cdk_1.createDiffChangeSet)(ioHelper, {
263
+ stack,
264
+ uuid: uuid.v4(),
265
+ deployments,
266
+ willExecute: false,
267
+ sdkProvider: await this.sdkProvider('diff'),
268
+ parameters: methodOptions.parameters ?? {},
269
+ resourcesToImport,
270
+ });
271
+ }
272
+ else {
273
+ await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_DEBUG.msg(`the stack '${stack.stackName}' has not been deployed to CloudFormation or describeStacks call failed, skipping changeset creation.`));
274
+ }
275
+ }
276
+ if (options.securityOnly) {
277
+ const securityDiff = formatter.formatSecurityDiff({
278
+ requireApproval: shared_public_1.RequireApproval.BROADENING,
279
+ stackName: stack.displayName,
280
+ changeSet,
281
+ });
282
+ formattedSecurityDiff = securityDiff.formattedDiff ?? '';
283
+ diffs = securityDiff.formattedDiff ? diffs + 1 : diffs;
284
+ }
285
+ else {
286
+ const diff = formatter.formatStackDiff({
287
+ strict,
288
+ context: contextLines,
289
+ stackName: stack.displayName,
290
+ changeSet,
291
+ isImport: !!resourcesToImport,
292
+ nestedStackTemplates: nestedStacks,
293
+ });
294
+ formattedStackDiff = diff.formattedDiff;
295
+ diffs = diff.numStacksWithChanges;
296
+ }
297
+ }
298
+ }
299
+ await diffSpan.end(`✨ Number of stacks with differences: ${diffs}`, {
300
+ formattedSecurityDiff,
301
+ formattedStackDiff,
302
+ });
303
+ return;
304
+ }
165
305
  /**
166
306
  * List Action
167
307
  *
@@ -171,7 +311,7 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
171
311
  const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'list');
172
312
  const selectStacks = options.stacks ?? private_5.ALL_STACKS;
173
313
  const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
174
- const assembly = await (0, private_1.assemblyFromSource)(cx);
314
+ const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
175
315
  const stackCollection = await assembly.selectStacksV2(selectStacks);
176
316
  await synthSpan.end();
177
317
  const stacks = stackCollection.withDependencies();
@@ -185,7 +325,8 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
185
325
  * Deploys the selected stacks into an AWS account
186
326
  */
187
327
  async deploy(cx, options = {}) {
188
- const assembly = await (0, private_1.assemblyFromSource)(cx);
328
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'deploy');
329
+ const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
189
330
  return this._deploy(assembly, 'deploy', options);
190
331
  }
191
332
  /**
@@ -195,7 +336,7 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
195
336
  const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, action);
196
337
  const selectStacks = options.stacks ?? private_5.ALL_STACKS;
197
338
  const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
198
- const stackCollection = assembly.selectStacksV2(selectStacks);
339
+ const stackCollection = await assembly.selectStacksV2(selectStacks);
199
340
  await this.validateStacksMetadata(stackCollection, ioHelper);
200
341
  const synthDuration = await synthSpan.end();
201
342
  if (stackCollection.stackCount === 0) {
@@ -453,8 +594,8 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
453
594
  * Implies hotswap deployments.
454
595
  */
455
596
  async watch(cx, options) {
456
- const assembly = await (0, private_1.assemblyFromSource)(cx, false);
457
597
  const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'watch');
598
+ const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx, false);
458
599
  const rootDir = options.watchDir ?? process.cwd();
459
600
  if (options.include === undefined && options.exclude === undefined) {
460
601
  throw new shared_public_1.ToolkitError("Cannot use the 'watch' command without specifying at least one directory to monitor. " +
@@ -544,7 +685,8 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
544
685
  * Rolls back the selected stacks.
545
686
  */
546
687
  async rollback(cx, options) {
547
- const assembly = await (0, private_1.assemblyFromSource)(cx);
688
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'rollback');
689
+ const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
548
690
  return this._rollback(assembly, 'rollback', options);
549
691
  }
550
692
  /**
@@ -553,7 +695,7 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
553
695
  async _rollback(assembly, action, options) {
554
696
  const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, action);
555
697
  const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });
556
- const stacks = assembly.selectStacksV2(options.stacks);
698
+ const stacks = await assembly.selectStacksV2(options.stacks);
557
699
  await this.validateStacksMetadata(stacks, ioHelper);
558
700
  await synthSpan.end();
559
701
  if (stacks.stackCount === 0) {
@@ -597,7 +739,8 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
597
739
  * Destroys the selected Stacks.
598
740
  */
599
741
  async destroy(cx, options) {
600
- const assembly = await (0, private_1.assemblyFromSource)(cx);
742
+ const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'destroy');
743
+ const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
601
744
  return this._destroy(assembly, 'destroy', options);
602
745
  }
603
746
  /**
@@ -607,7 +750,7 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
607
750
  const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, action);
608
751
  const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });
609
752
  // The stacks will have been ordered for deployment, so reverse them for deletion.
610
- const stacks = await assembly.selectStacksV2(options.stacks).reversed();
753
+ const stacks = (await assembly.selectStacksV2(options.stacks)).reversed();
611
754
  await synthSpan.end();
612
755
  const motivation = 'Destroying stacks is an irreversible action';
613
756
  const question = `Are you sure you want to delete: ${chalk.red(stacks.hierarchicalIds.join(', '))}`;
@@ -688,4 +831,4 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
688
831
  }
689
832
  }
690
833
  exports.Toolkit = Toolkit;
691
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit.js","sourceRoot":"","sources":["toolkit.ts"],"names":[],"mappings":";;;AAAA,kCAAkC;AAClC,yCAAyC;AACzC,+BAA+B;AAC/B,qCAAqC;AACrC,+BAA+B;AAE/B,uCAA+C;AAE/C,oDAAuD;AACvD,8CAAuE;AACvE,uDAAiJ;AAEjJ,qDAAkE;AAKlE,sDAAiE;AAGjE,4CAAkO;AAElO,0DAA+D;AAE/D,2DAAoH;AAEpH,+CAA8G;AAE9G,0DAAmD;AAEnD,wDAAqE;AACrE,0CAA2H;AAC3H,qDAA6C;AA6C7C;;GAEG;AACH,MAAa,OAAQ,SAAQ,oCAA0B;IAYjB;IAXpC;;OAEG;IACa,gBAAgB,CAAS;IAEzC;;OAEG;IACa,MAAM,CAAU;IACxB,YAAY,CAAe;IAEnC,YAAoC,QAAwB,EAAE;QAC5D,KAAK,EAAE,CAAC;QAD0B,UAAK,GAAL,KAAK,CAAqB;QAE5D,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,gBAAgB,IAAI,oCAA0B,CAAC;QAE7E,oFAAoF;QACpF,MAAM,YAAY,GAAG,mBAAS,CAAC,QAAQ,EAAE,CAAC;QAC1C,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;YACjB,YAAY,CAAC,cAAc,CAAC,KAAK,CAAC,MAAa,CAAC,CAAC;QACnD,CAAC;QACD,IAAI,MAAM,GAAG,YAAuB,CAAC;QACrC,IAAI,KAAK,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC;YAC3B,MAAM,GAAG,IAAA,uBAAa,EAAC,MAAM,CAAC,CAAC;QACjC,CAAC;QACD,IAAI,KAAK,CAAC,KAAK,KAAK,KAAK,EAAE,CAAC;YAC1B,MAAM,GAAG,IAAA,sBAAY,EAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QACD,yGAAyG;QACzG,qFAAqF;QACrF,IAAI,CAAC,MAAM,GAAG,IAAA,+BAAqB,EAAC,MAAM,CAAC,CAAC;IAC9C,CAAC;IAEM,KAAK,CAAC,OAAO;QAClB,oBAAoB;IACtB,CAAC;IAEM,KAAK,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;QAChC,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,WAAW,CAAC,MAAqB;QAC7C,uDAAuD;QACvD,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,YAAY,GAAG,MAAM,qBAAW,CAAC,4BAA4B,CAAC;gBACjE,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS;gBACvB,MAAM,EAAE,IAAA,qBAAW,EAAC,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;aACrD,CAAC,CAAC;QACL,CAAC;QAED,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED;;OAEG;IACgB,KAAK,CAAC,qBAAqB;QAC5C,OAAO;YACL,QAAQ,EAAE,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC;YAC7C,WAAW,EAAE,MAAM,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;SAChD,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,SAAS,CAAC,YAAmC,EAAE,OAAyB;QACnF,MAAM,QAAQ,GAAG,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACtD,MAAM,qBAAqB,GAAG,MAAM,YAAY,CAAC,eAAe,EAAE,CAAC;QACnE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,2BAAe,CAAC,OAAO,EAAE,CAAC;QAC3D,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QACtC,MAAM,YAAY,GAAG,IAAI,sBAAY,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QACxD,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QACxD,MAAM,KAAK,GAAG,IAAA,oBAAM,EAAC,EAAE,CAAC,CAAC;QAEzB,wEAAwE;QACxE,MAAM,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,WAA8B,EAAE,UAAU,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE;YAC3G,MAAM,aAAa,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,gBAAgB,CAAC;iBAC7D,KAAK,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,oBAAoB,EAAE;gBAC1D,KAAK,EAAE,qBAAqB,CAAC,MAAM;gBACnC,OAAO,EAAE,UAAU,GAAC,CAAC;gBACrB,WAAW;aACZ,CAAC,CAAC;YAEL,IAAI,CAAC;gBACH,MAAM,eAAe,GAAG,MAAM,YAAY,CAAC,oBAAoB,CAC7D,WAAW,EACX,WAAW,EACX;oBACE,GAAG,OAAO;oBACV,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;oBACvC,MAAM;oBACN,UAAU,EAAE,UAAU,EAAE,UAAU;oBAClC,qBAAqB,EAAE,UAAU,EAAE,sBAAsB;iBAC1D,CACF,CAAC;gBACF,MAAM,OAAO,GAAG,eAAe,CAAC,IAAI;oBAClC,CAAC,CAAC,OAAO,WAAW,CAAC,IAAI,eAAe;oBACxC,CAAC,CAAC,OAAO,WAAW,CAAC,IAAI,EAAE,CAAC;gBAE9B,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;gBAC9F,MAAM,aAAa,CAAC,GAAG,EAAE,CAAC;YAC5B,CAAC;YAAC,OAAO,CAAM,EAAE,CAAC;gBAChB,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,IAAA,yBAAkB,EAAC,CAAC,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;gBACxI,MAAM,CAAC,CAAC;YACV,CAAC;QACH,CAAC,CAAC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,KAAK,CAAC,EAAwB,EAAE,UAAwB,EAAE;QACrE,MAAM,QAAQ,GAAG,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAClD,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,IAAI,oBAAU,CAAC;QAClD,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,CAAC;QAC3F,MAAM,QAAQ,GAAG,MAAM,IAAA,4BAAkB,EAAC,EAAE,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;QACrD,MAAM,kBAAkB,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,yBAAyB,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAChG,MAAM,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,kBAAkB,CAAC,EAAE,QAAQ,CAAC,CAAC;QAClF,MAAM,SAAS,CAAC,GAAG,EAAE,CAAC;QAEtB,gDAAgD;QAChD,MAAM,OAAO,GAAG,+BAA+B,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;QACrG,MAAM,YAAY,GAAiB;YACjC,iBAAiB,EAAE,MAAM,CAAC,QAAQ,CAAC,SAAS;YAC5C,WAAW,EAAE,MAAM,CAAC,UAAU;YAC9B,QAAQ,EAAE,MAAM,CAAC,eAAe;SACjC,CAAC;QAEF,IAAI,MAAM,CAAC,UAAU,KAAK,CAAC,EAAE,CAAC;YAC5B,MAAM,UAAU,GAAG,MAAM,CAAC,UAAW,CAAC;YACtC,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC;YACrC,MAAM,gBAAgB,GAAG,IAAA,sBAAe,EAAC,QAAQ,CAAC,CAAC;YACnD,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,OAAO,EAAE;gBACtD,GAAG,YAAY;gBACf,KAAK,EAAE;oBACL,SAAS,EAAE,UAAU,CAAC,SAAS;oBAC/B,cAAc,EAAE,UAAU,CAAC,cAAc;oBACzC,QAAQ;oBACR,eAAe,EAAE,IAAA,yBAAkB,EAAC,gBAAgB,EAAE,IAAI,CAAC;oBAC3D,eAAe,EAAE,IAAA,yBAAkB,EAAC,gBAAgB,EAAE,KAAK,CAAC;iBAC7D;aACF,CAAC,CAAC,CAAC;QACN,CAAC;aAAM,CAAC;YACN,sFAAsF;YACtF,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC;YACpF,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,oBAAoB,CAAC,GAAG,CAAC,sBAAsB,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC,CAAC;QACnL,CAAC;QAED,OAAO,IAAI,qCAA2B,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC5D,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,IAAI,CAAC,EAAwB,EAAE,UAAuB,EAAE;QACnE,MAAM,QAAQ,GAAG,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACjD,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,IAAI,oBAAU,CAAC;QAClD,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,CAAC;QAC3F,MAAM,QAAQ,GAAG,MAAM,IAAA,4BAAkB,EAAC,EAAE,CAAC,CAAC;QAC9C,MAAM,eAAe,GAAG,MAAM,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;QACpE,MAAM,SAAS,CAAC,GAAG,EAAE,CAAC;QAEtB,MAAM,MAAM,GAAG,eAAe,CAAC,gBAAgB,EAAE,CAAC;QAClD,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEjD,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;QACrE,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,MAAM,CAAC,EAAwB,EAAE,UAAyB,EAAE;QACvE,MAAM,QAAQ,GAAG,MAAM,IAAA,4BAAkB,EAAC,EAAE,CAAC,CAAC;QAC9C,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IACnD,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,OAAO,CAAC,QAAuB,EAAE,MAA0B,EAAE,UAAiC,EAAE;QAC5G,MAAM,QAAQ,GAAG,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACjD,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,IAAI,oBAAU,CAAC;QAClD,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC,CAAC;QAC3F,MAAM,eAAe,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;QAC9D,MAAM,IAAI,CAAC,sBAAsB,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;QAC7D,MAAM,aAAa,GAAG,MAAM,SAAS,CAAC,GAAG,EAAE,CAAC;QAE5C,IAAI,eAAe,CAAC,UAAU,KAAK,CAAC,EAAE,CAAC;YACrC,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,CAAC;YAC/E,OAAO;QACT,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;QAC9D,MAAM,QAAQ,GAAG,IAAI,0BAAgB,CAAC,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,CAAC;QAEjE,MAAM,QAAQ,CAAC,mBAAmB,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;QAE7D,MAAM,YAAY,GAAG,IAAA,2BAAiB,EAAC,OAAO,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAEvE,MAAM,WAAW,GAAG,OAAO,CAAC,OAAO,IAAI,qBAAW,CAAC,eAAe,CAAC;QACnE,IAAI,WAAW,KAAK,qBAAW,CAAC,eAAe,EAAE,CAAC;YAChD,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC;gBAC7C,mHAAmH;gBACnH,0FAA0F;aAC3F,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjB,CAAC;QAED,MAAM,MAAM,GAAG,eAAe,CAAC,cAAc,CAAC;QAC9C,MAAM,YAAY,GAA2B,EAAE,CAAC;QAChD,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;QAExC,MAAM,UAAU,GAAG,KAAK,EAAE,SAAyB,EAAE,EAAE;YACrD,MAAM,cAAc,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC;gBACjE,KAAK,EAAE,SAAS,CAAC,KAAK;aACvB,CAAC,CAAC;YACH,MAAM,WAAW,CAAC,gBAAgB,CAChC,SAAS,CAAC,qBAAqB,EAC/B,SAAS,CAAC,aAAa,EACvB,SAAS,CAAC,KAAK,EACf;gBACE,KAAK,EAAE,SAAS,CAAC,WAAW;gBAC5B,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,SAAS,EAAE,SAAS,CAAC,WAAW,CAAC,SAAS;aAC3C,CACF,CAAC;YACF,MAAM,cAAc,CAAC,GAAG,EAAE,CAAC;QAC7B,CAAC,CAAC;QAEF,MAAM,YAAY,GAAG,KAAK,EAAE,SAA2B,EAAE,EAAE;YACzD,MAAM,gBAAgB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC;gBACrE,KAAK,EAAE,SAAS,CAAC,KAAK;aACvB,CAAC,CAAC;YACH,MAAM,WAAW,CAAC,kBAAkB,CAAC,SAAS,CAAC,aAAa,EAAE,SAAS,CAAC,KAAK,EAAE;gBAC7E,KAAK,EAAE,SAAS,CAAC,WAAW;gBAC5B,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,SAAS,EAAE,SAAS,CAAC,WAAW,CAAC,SAAS;gBAC1C,YAAY,EAAE,OAAO,CAAC,KAAK;aAC5B,CAAC,CAAC;YACH,MAAM,gBAAgB,CAAC,GAAG,EAAE,CAAC;QAC/B,CAAC,CAAC;QAEF,MAAM,WAAW,GAAG,KAAK,EAAE,SAAoB,EAAE,EAAE;YACjD,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC;YAC9B,IAAI,eAAe,CAAC,UAAU,KAAK,CAAC,EAAE,CAAC;gBACrC,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,oBAAoB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACpF,CAAC;YAED,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;gBACvB,MAAM,IAAI,4BAAY,CACpB,SAAS,KAAK,CAAC,WAAW,iIAAiI,CAC5J,CAAC;YACJ,CAAC;YAED,uCAAuC;YACvC,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7D,iDAAiD;gBACjD,MAAM,WAAW,GAAG,MAAM,WAAW,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC7D,IAAI,CAAC,WAAW,EAAE,CAAC;oBACjB,OAAO,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,gDAAgD,CAAC,CAAC,CAAC;gBACrI,CAAC;gBAED,uCAAuC;gBACvC,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,oDAAoD,CAAC,CAAC,CAAC;gBACtI,MAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,EAAE;oBACtC,MAAM,EAAE,EAAE,QAAQ,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,uCAAsB,CAAC,yBAAyB,EAAE;oBACxG,OAAO,EAAE,OAAO,CAAC,OAAO;oBACxB,EAAE,EAAE,OAAO,CAAC,EAAE;iBACf,CAAC,CAAC;gBAEH,OAAO;YACT,CAAC;YAED,MAAM,eAAe,GAAG,MAAM,WAAW,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;YACrE,MAAM,oBAAoB,GAAG,IAAA,iCAAuB,EAAC,eAAe,EAAE,KAAK,CAAC,CAAC;YAC7E,MAAM,gBAAgB,GAAG,gFAAgF,CAAC;YAC1G,MAAM,cAAc,GAAG,GAAG,gBAAgB,uCAAuC,CAAC;YAClF,MAAM,eAAe,GAAG,MAAM,QAAQ,CAAC,eAAe,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,cAAc,EAAE;gBAC9F,UAAU,EAAE,gBAAgB;gBAC5B,WAAW;gBACX,oBAAoB;aACrB,CAAC,CAAC,CAAC;YACJ,IAAI,CAAC,eAAe,EAAE,CAAC;gBACrB,MAAM,IAAI,4BAAY,CAAC,iBAAiB,CAAC,CAAC;YAC5C,CAAC;YAED,oGAAoG;YACpG,EAAE;YACF,4FAA4F;YAC5F,uEAAuE;YACvE,+EAA+E;YAC/E,MAAM,gBAAgB,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,IAAI,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC;gBAC/E,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,gBAAgB,IAAI,EAAE,CAAC;gBACvE,CAAC,CAAC,SAAS,CAAC;YAEd,KAAK,MAAM,eAAe,IAAI,gBAAgB,IAAI,EAAE,EAAE,CAAC;gBACrD,IAAI,CAAC,IAAA,0BAAmB,EAAC,eAAe,CAAC,EAAE,CAAC;oBAC1C,MAAM,IAAI,4BAAY,CAAC,oBAAoB,eAAe,sCAAsC,CAAC,CAAC;gBACpG,CAAC;YACH,CAAC;YAED,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC7C,MAAM,UAAU,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,YAAY,CAAC;iBACtD,KAAK,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,mBAAmB,UAAU,IAAI,eAAe,CAAC,UAAU,GAAG,EAAE;gBACrG,KAAK,EAAE,eAAe,CAAC,UAAU;gBACjC,OAAO,EAAE,UAAU;gBACnB,KAAK;aACN,CAAC,CAAC;YAEL,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;YACxB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC/B,IAAI,GAAG,IAAA,sBAAY,EAAC,KAAK,CAAC,CAAC;YAC7B,CAAC;YAED,IAAI,cAAc,CAAC;YACnB,IAAI,CAAC;gBACH,IAAI,YAAqD,CAAC;gBAE1D,IAAI,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;gBAChC,IAAI,SAAS,GAAG,CAAC,CAAC;gBAClB,OAAO,CAAC,YAAY,EAAE,CAAC;oBACrB,IAAI,EAAE,SAAS,GAAG,CAAC,EAAE,CAAC;wBACpB,MAAM,IAAI,4BAAY,CAAC,mKAAmK,CAAC,CAAC;oBAC9L,CAAC;oBAED,MAAM,CAAC,GAAG,MAAM,WAAW,CAAC,WAAW,CAAC;wBACtC,KAAK;wBACL,UAAU,EAAE,KAAK,CAAC,SAAS;wBAC3B,OAAO,EAAE,OAAO,CAAC,OAAO;wBACxB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;wBACvC,WAAW,EAAE,OAAO,CAAC,WAAW;wBAChC,gBAAgB;wBAChB,IAAI;wBACJ,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;wBAC1C,KAAK,EAAE,OAAO,CAAC,KAAK;wBACpB,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,YAAY,CAAC,GAAG,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;wBAC/E,qBAAqB,EAAE,OAAO,CAAC,UAAU,EAAE,sBAAsB;wBACjE,QAAQ;wBACR,OAAO,EAAE,WAAW;wBACpB,cAAc,EAAE,OAAO,CAAC,cAAc;wBACtC,wBAAwB,EAAE,OAAO,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAA,wCAA8B,EAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,SAAS;wBAC3H,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;qBAC3C,CAAC,CAAC;oBAEH,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC;wBACf,KAAK,kBAAkB;4BACrB,YAAY,GAAG,CAAC,CAAC;4BACjB,MAAM;wBAER,KAAK,gCAAgC,CAAC,CAAC,CAAC;4BACtC,MAAM,UAAU,GAAG,CAAC,CAAC,MAAM,KAAK,aAAa;gCAC3C,CAAC,CAAC,oCAAoC,CAAC,CAAC,MAAM,mFAAmF;gCACjI,CAAC,CAAC,oCAAoC,CAAC,CAAC,MAAM,6DAA6D,CAAC;4BAC9G,MAAM,QAAQ,GAAG,GAAG,UAAU,gCAAgC,CAAC;4BAE/D,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;gCAClB,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,UAAU,iCAAiC,CAAC,CAAC,CAAC;4BACrG,CAAC;iCAAM,CAAC;gCACN,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,eAAe,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,EAAE;oCAClF,UAAU;oCACV,WAAW;iCACZ,CAAC,CAAC,CAAC;gCACJ,IAAI,CAAC,SAAS,EAAE,CAAC;oCACf,MAAM,IAAI,4BAAY,CAAC,iBAAiB,CAAC,CAAC;gCAC5C,CAAC;4BACH,CAAC;4BAED,qBAAqB;4BACrB,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE;gCACrC,MAAM,EAAE,EAAE,QAAQ,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,uCAAsB,CAAC,yBAAyB,EAAE;gCACxG,qBAAqB,EAAE,OAAO,CAAC,KAAK;6BACrC,CAAC,CAAC;4BAEH,wEAAwE;4BACxE,QAAQ,GAAG,IAAI,CAAC;4BAChB,MAAM;wBACR,CAAC;wBAED,KAAK,+BAA+B,CAAC,CAAC,CAAC;4BACrC,MAAM,UAAU,GAAG,6EAA6E,CAAC;4BACjG,MAAM,QAAQ,GAAG,GAAG,UAAU,gCAAgC,CAAC;4BAE/D,sBAAsB;4BACtB,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;gCAClB,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,UAAU,iDAAiD,CAAC,CAAC,CAAC;4BACrH,CAAC;iCAAM,CAAC;gCACN,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,eAAe,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,EAAE;oCAClF,UAAU;oCACV,WAAW;iCACZ,CAAC,CAAC,CAAC;gCACJ,IAAI,CAAC,SAAS,EAAE,CAAC;oCACf,MAAM,IAAI,4BAAY,CAAC,iBAAiB,CAAC,CAAC;gCAC5C,CAAC;4BACH,CAAC;4BAED,wEAAwE;4BACxE,QAAQ,GAAG,IAAI,CAAC;4BAChB,MAAM;wBACR,CAAC;wBAED;4BACE,MAAM,IAAI,4BAAY,CAAC,4CAA4C,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,sGAAsG,CAAC,CAAC;oBAChM,CAAC;gBACH,CAAC;gBAED,MAAM,OAAO,GAAG,YAAY,CAAC,IAAI;oBAC/B,CAAC,CAAC,OAAO,KAAK,CAAC,WAAW,eAAe;oBACzC,CAAC,CAAC,OAAO,KAAK,CAAC,WAAW,EAAE,CAAC;gBAE/B,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC;gBAC3F,cAAc,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,CAAC;gBAE/D,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACjD,MAAM,MAAM,GAAG,CAAC,UAAU,CAAC,CAAC;oBAC5B,YAAY,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,YAAY,CAAC,OAAO,CAAC;oBAErD,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC;wBAC5D,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;wBACzC,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;oBACrG,CAAC;oBACD,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACrE,CAAC;gBACD,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,eAAe,YAAY,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YAC1F,CAAC;YAAC,OAAO,CAAM,EAAE,CAAC;gBAChB,yEAAyE;gBACzE,sDAAsD;gBACtD,MAAM,IAAI,4BAAY,CACpB,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CACtG,CAAC;YACJ,CAAC;oBAAS,CAAC;gBACT,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;oBACtB,uFAAuF;oBACvF,MAAM,oBAAoB,GAAG,OAAO,CAAC,oBAAoB,IAAI,IAAI,mCAAyB,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;oBACzG,MAAM,oBAAoB,GAAG,MAAM,IAAA,iCAAuB,EAAC,MAAM,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;oBAC9G,oBAAoB,CAAC,YAAY,CAC/B,oBAAoB,CAAC,GAAG,EACxB,oBAAoB,CAAC,GAAG,EACxB,oBAAoB,CAAC,aAAa,CACnC,CAAC;oBACF,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,uCAAuC,oBAAoB,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;gBAC/H,CAAC;gBAED,kGAAkG;gBAClG,wFAAwF;gBACxF,iGAAiG;gBACjG,IAAI,WAAW,EAAE,CAAC;oBAChB,EAAE,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;oBAC/B,MAAM,EAAE,CAAC,SAAS,CAAC,WAAW,EAAE,YAAY,EAAE;wBAC5C,MAAM,EAAE,CAAC;wBACT,QAAQ,EAAE,MAAM;qBACjB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YACD,MAAM,QAAQ,GAAG,aAAa,CAAC,IAAI,GAAG,CAAC,cAAc,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC;YAClE,MAAM,UAAU,CAAC,GAAG,CAAC,oBAAoB,IAAA,iBAAU,EAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;QACpF,CAAC,CAAC;QAEF,MAAM,cAAc,GAAG,OAAO,CAAC,cAAc,IAAI,uBAAc,CAAC,iBAAiB,CAAC;QAClF,MAAM,cAAc,GAAG,cAAc,KAAK,uBAAc,CAAC,iBAAiB,CAAC;QAC3E,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,IAAI,CAAC,CAAC;QAE7C,MAAM,4BAA4B,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC;YAC7D,KAAK;YACL,GAAG,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,qBAAqB,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC;SAC1F,CAAC,CAAC;QACH,MAAM,SAAS,GAAG,IAAI,0BAAgB,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAErG,sEAAsE;QACtE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YACnB,MAAM,IAAA,+BAAqB,EAAC,SAAS,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;QAC/D,CAAC;QAED,MAAM,gBAAgB,GAAgB;YACpC,OAAO,EAAE,WAAW;YACpB,aAAa,EAAE,CAAC,EAAE,wEAAwE;YAC1F,eAAe,EAAE,CAAC,OAAO,CAAC,gBAAgB,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,yDAAyD;SACvH,CAAC;QAEF,MAAM,SAAS,CAAC,UAAU,CAAC,gBAAgB,EAAE;YAC3C,WAAW;YACX,UAAU;YACV,YAAY;SACb,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACI,KAAK,CAAC,KAAK,CAAC,EAAwB,EAAE,OAAqB;QAChE,MAAM,QAAQ,GAAG,MAAM,IAAA,4BAAkB,EAAC,EAAE,EAAE,KAAK,CAAC,CAAC;QACrD,MAAM,QAAQ,GAAG,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAClD,MAAM,OAAO,GAAG,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;QAElD,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YACnE,MAAM,IAAI,4BAAY,CACpB,uFAAuF;gBACrF,iDAAiD,CACpD,CAAC;QACJ,CAAC;QAED,mEAAmE;QACnE,uCAAuC;QACvC,+EAA+E;QAC/E,kFAAkF;QAClF,0DAA0D;QAC1D,MAAM,aAAa,GAAG,IAAA,+BAAqB,EAAC,OAAO,CAAC,OAAO,EAAE;YAC3D,OAAO;YACP,oBAAoB,EAAE,IAAI;SAC3B,CAAC,CAAC;QAEH,kDAAkD;QAClD,8FAA8F;QAC9F,+BAA+B;QAC/B,4CAA4C;QAC5C,2DAA2D;QAC3D,qHAAqH;QACrH,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,SAAS,CAAC;QAC3C,MAAM,aAAa,GAAG,IAAA,+BAAqB,EAAC,OAAO,CAAC,OAAO,EAAE;YAC3D,OAAO;YACP,oBAAoB,EAAE,KAAK;SAC5B,CAAC,CAAC,MAAM,CAAC,GAAG,MAAM,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,oBAAoB,CAAC,CAAC;QAErE,oDAAoD;QACpD,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC;YAC7C,uCAAuC,OAAO,EAAE;YAChD,mCAAmC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,EAAE;YAClE,mCAAmC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,EAAE;SACnE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;YACZ,QAAQ,EAAE,OAAO;YACjB,QAAQ,EAAE,aAAa;YACvB,QAAQ,EAAE,aAAa;SACxB,CAAC,CAAC,CAAC;QAcJ,IAAI,KAAK,GAAe,WAAW,CAAC;QAEpC,MAAM,oBAAoB,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,mCAAyB,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QACzG,MAAM,cAAc,GAAG,KAAK,IAAI,EAAE;YAChC,KAAK,GAAG,WAAyB,CAAC;YAClC,MAAM,oBAAoB,EAAE,UAAU,EAAE,CAAC;YAEzC,MAAM,IAAI,CAAC,qBAAqB,CAAC,QAAQ,EAAE,OAAO,EAAE,oBAAoB,CAAC,CAAC;YAE1E,gEAAgE;YAChE,2DAA2D;YAC3D,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBAC1B,gEAAgE;gBAChE,4EAA4E;gBAC5E,KAAK,GAAG,WAAW,CAAC;gBACpB,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,sEAAsE,CAAC,CAAC,CAAC;gBACxH,MAAM,IAAI,CAAC,qBAAqB,CAAC,QAAQ,EAAE,OAAO,EAAE,oBAAoB,CAAC,CAAC;YAC5E,CAAC;YACD,KAAK,GAAG,MAAM,CAAC;YACf,MAAM,oBAAoB,EAAE,QAAQ,EAAE,CAAC;QACzC,CAAC,CAAC;QAEF,QAAQ;aACL,KAAK,CAAC,aAAa,EAAE;YACpB,OAAO,EAAE,aAAa;YACtB,GAAG,EAAE,OAAO;SACb,CAAC;aACD,EAAE,CAAC,OAAO,EAAE,KAAK,IAAI,EAAE;YACtB,KAAK,GAAG,MAAM,CAAC;YACf,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,qBAAqB,CAAC,GAAG,CAAC,6FAA6F,CAAC,CAAC,CAAC;YACnJ,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,iCAAiC,CAAC,CAAC,CAAC;YACnF,MAAM,cAAc,EAAE,CAAC;QACzB,CAAC,CAAC;aACD,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,KAA2D,EAAE,QAAgB,EAAE,EAAE;YACjG,MAAM,UAAU,GAAG;gBACjB,KAAK;gBACL,IAAI,EAAE,QAAQ;aACf,CAAC;YACF,IAAI,KAAK,KAAK,WAAW,EAAE,CAAC;gBAC1B,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,wBAAwB,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,KAAK,QAAQ,eAAe,EAAE,UAAU,CAAC,CAAC,CAAC;YACjK,CAAC;iBAAM,IAAI,KAAK,KAAK,MAAM,EAAE,CAAC;gBAC5B,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,uBAAuB,QAAQ,YAAY,KAAK,4BAA4B,EAAE,UAAU,CAAC,CAAC,CAAC;gBAC1I,MAAM,cAAc,EAAE,CAAC;YACzB,CAAC;iBAAM,CAAC;gBACN,qDAAqD;gBACrD,KAAK,GAAG,QAAQ,CAAC;gBACjB,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAC5C,uBAAuB,QAAQ,YAAY,KAAK,mGAAmG,EACnJ,UAAU,CACX,CAAC,CAAC;YACL,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,QAAQ,CAAC,EAAwB,EAAE,OAAwB;QACtE,MAAM,QAAQ,GAAG,MAAM,IAAA,4BAAkB,EAAC,EAAE,CAAC,CAAC;QAC9C,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;IACvD,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,SAAS,CAAC,QAAuB,EAAE,MAAuC,EAAE,OAAwB;QAChH,MAAM,QAAQ,GAAG,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACjD,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QAC7F,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACvD,MAAM,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QACpD,MAAM,SAAS,CAAC,GAAG,EAAE,CAAC;QAEtB,IAAI,MAAM,CAAC,UAAU,KAAK,CAAC,EAAE,CAAC;YAC5B,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC,CAAC;YACtE,OAAO;QACT,CAAC;QAED,IAAI,eAAe,GAAG,KAAK,CAAC;QAE5B,KAAK,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE,EAAE,CAAC;YAC7D,MAAM,YAAY,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,gBAAgB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE,EAAE;gBACnH,KAAK,EAAE,MAAM,CAAC,UAAU;gBACxB,OAAO,EAAE,KAAK,GAAG,CAAC;gBAClB,KAAK;aACN,CAAC,CAAC;YACH,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;YAChE,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,MAAM,WAAW,CAAC,aAAa,CAAC;oBAClD,KAAK;oBACL,OAAO,EAAE,OAAO,CAAC,OAAO;oBACxB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;oBACvC,KAAK,EAAE,OAAO,CAAC,qBAAqB;oBACpC,6BAA6B,EAAE,OAAO,CAAC,6BAA6B;oBACpE,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;iBAC3C,CAAC,CAAC;gBACH,IAAI,CAAC,WAAW,CAAC,sBAAsB,EAAE,CAAC;oBACxC,eAAe,GAAG,IAAI,CAAC;gBACzB,CAAC;gBACD,MAAM,YAAY,CAAC,GAAG,EAAE,CAAC;YAC3B,CAAC;YAAC,OAAO,CAAM,EAAE,CAAC;gBAChB,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,YAAY,IAAA,yBAAkB,EAAC,CAAC,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;gBACzI,MAAM,IAAI,4BAAY,CAAC,2DAA2D,CAAC,CAAC;YACtF,CAAC;QACH,CAAC;QACD,IAAI,CAAC,eAAe,EAAE,CAAC;YACrB,MAAM,IAAI,4BAAY,CAAC,qDAAqD,CAAC,CAAC;QAChF,CAAC;IACH,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,OAAO,CAAC,EAAwB,EAAE,OAAuB;QACpE,MAAM,QAAQ,GAAG,MAAM,IAAA,4BAAkB,EAAC,EAAE,CAAC,CAAC;QAC9C,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IACrD,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,QAAQ,CAAC,QAAuB,EAAE,MAA4B,EAAE,OAAuB;QACnG,MAAM,QAAQ,GAAG,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACjD,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QAC7F,kFAAkF;QAClF,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAC;QACxE,MAAM,SAAS,CAAC,GAAG,EAAE,CAAC;QAEtB,MAAM,UAAU,GAAG,6CAA6C,CAAC;QACjE,MAAM,QAAQ,GAAG,oCAAoC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;QACpG,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,eAAe,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;QACrG,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,CAAC;QACtE,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,cAAc,CAAC,CAAC,KAAK,CAAC;YACjE,MAAM,EAAE,MAAM,CAAC,cAAc;SAC9B,CAAC,CAAC;QACH,IAAI,CAAC;YACH,KAAK,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE,EAAE,CAAC;gBAC7D,IAAI,CAAC;oBACH,MAAM,iBAAiB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,cAAI,CAAC,aAAa,CAAC;yBAC9D,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,oBAAoB,KAAK,GAAG,CAAC,IAAI,MAAM,CAAC,UAAU,GAAG,CAAC,EAAE;wBACzG,KAAK,EAAE,MAAM,CAAC,UAAU;wBACxB,OAAO,EAAE,KAAK,GAAG,CAAC;wBAClB,KAAK;qBACN,CAAC,CAAC;oBACL,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;oBAC5D,MAAM,WAAW,CAAC,YAAY,CAAC;wBAC7B,KAAK;wBACL,UAAU,EAAE,KAAK,CAAC,SAAS;wBAC3B,OAAO,EAAE,OAAO,CAAC,OAAO;qBACzB,CAAC,CAAC;oBACH,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,MAAM,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;oBAC3H,MAAM,iBAAiB,CAAC,GAAG,EAAE,CAAC;gBAChC,CAAC;gBAAC,OAAO,CAAM,EAAE,CAAC;oBAChB,MAAM,QAAQ,CAAC,MAAM,CAAC,YAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,MAAM,WAAW,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;oBAC/H,MAAM,CAAC,CAAC;gBACV,CAAC;YACH,CAAC;QACH,CAAC;gBAAS,CAAC;YACT,MAAM,WAAW,CAAC,GAAG,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,sBAAsB,CAAC,MAAuB,EAAE,MAAgB;QAC5E,MAAM,OAAO,GAAG,CAAC,KAAqB,EAAE,EAAE;YACxC,QAAQ,KAAK,EAAE,CAAC;gBACd,KAAK,OAAO,CAAC,CAAC,OAAO,YAAE,CAAC,kBAAkB,CAAC;gBAC3C,KAAK,MAAM,CAAC,CAAC,OAAO,YAAE,CAAC,kBAAkB,CAAC;gBAC1C,OAAO,CAAC,CAAC,OAAO,YAAE,CAAC,kBAAkB,CAAC;YACxC,CAAC;QACH,CAAC,CAAC;QACF,MAAM,MAAM,CAAC,gBAAgB,CAC3B,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAC5B,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,IAAI,KAAK,OAAO,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,CAAC,CAC1G,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,oBAAoB,CAAC,MAAqB;QACtD,OAAO,IAAI,qBAAW,CAAC;YACrB,WAAW,EAAE,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;YAC3C,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,QAAQ,EAAE,IAAA,2BAAU,EAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC;SAC1C,CAAC,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,qBAAqB,CACjC,QAAuB,EACvB,OAAqB,EACrB,oBAAgD;QAEhD,oCAAoC;QACpC,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,qBAAW,CAAC,YAAY,CAAC;QAC5D,MAAM,aAAa,GAA0B;YAC3C,GAAG,OAAO;YACV,eAAe,EAAE,+BAAe,CAAC,KAAK;YACtC,oBAAoB;YACpB,OAAO;YACP,cAAc,EAAE,qBAAqB,OAAO,KAAK,qBAAW,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE;SAC9F,CAAC;QAEF,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC;QACvD,CAAC;QAAC,MAAM,CAAC;YACP,6CAA6C;QAC/C,CAAC;IACH,CAAC;CACF;AAtwBD,0BAswBC","sourcesContent":["import * as path from 'node:path';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport * as chokidar from 'chokidar';\nimport * as fs from 'fs-extra';\nimport type { ToolkitServices } from './private';\nimport { assemblyFromSource } from './private';\nimport type { BootstrapEnvironments, BootstrapOptions } from '../actions/bootstrap';\nimport { BootstrapSource } from '../actions/bootstrap';\nimport { AssetBuildTime, type DeployOptions } from '../actions/deploy';\nimport { type ExtendedDeployOptions, buildParameterMap, createHotswapPropertyOverrides, removePublishedAssets } from '../actions/deploy/private';\nimport { type DestroyOptions } from '../actions/destroy';\nimport { determinePermissionType } from '../actions/diff/private';\nimport { type ListOptions } from '../actions/list';\nimport { type RollbackOptions } from '../actions/rollback';\nimport { type SynthOptions } from '../actions/synth';\nimport type { WatchOptions } from '../actions/watch';\nimport { patternsArrayForWatch } from '../actions/watch/private';\nimport { type SdkConfig } from '../api/aws-auth';\nimport type { SuccessfulDeployStackResult, StackCollection, Concurrency, AssetBuildNode, AssetPublishNode, StackNode } from '../api/aws-cdk';\nimport { DEFAULT_TOOLKIT_STACK_NAME, Bootstrapper, SdkProvider, Deployments, HotswapMode, ResourceMigrator, tagsForStack, CliIoHost, WorkGraphBuilder, CloudWatchLogEventMonitor, findCloudWatchLogGroups } from '../api/aws-cdk';\nimport type { ICloudAssemblySource } from '../api/cloud-assembly';\nimport { StackSelectionStrategy } from '../api/cloud-assembly';\nimport type { StackAssembly } from '../api/cloud-assembly/private';\nimport { ALL_STACKS, CloudAssemblySourceBuilder, IdentityCloudAssemblySource } from '../api/cloud-assembly/private';\nimport type { IIoHost, IoMessageLevel } from '../api/io';\nimport { IO, SPAN, asSdkLogger, withoutColor, withoutEmojis, withTrimmedWhitespace } from '../api/io/private';\nimport type { IoHelper } from '../api/shared-private';\nimport { asIoHelper } from '../api/shared-private';\nimport type { AssemblyData, StackDetails, ToolkitAction } from '../api/shared-public';\nimport { RequireApproval, ToolkitError } from '../api/shared-public';\nimport { obscureTemplate, serializeStructure, validateSnsTopicArn, formatTime, formatErrorMessage } from '../private/util';\nimport { pLimit } from '../util/concurrency';\n\nexport interface ToolkitOptions {\n  /**\n   * The IoHost implementation, handling the inline interactions between the Toolkit and an integration.\n   */\n  ioHost?: IIoHost;\n\n  /**\n   * Allow emojis in messages sent to the IoHost.\n   *\n   * @default true\n   */\n  emojis?: boolean;\n\n  /**\n   * Whether to allow ANSI colors and formatting in IoHost messages.\n   * Setting this value to `false` enforces that no color or style shows up\n   * in messages sent to the IoHost.\n   * Setting this value to true is a no-op; it is equivalent to the default.\n   *\n   * @default - detects color from the TTY status of the IoHost\n   */\n  color?: boolean;\n\n  /**\n   * Configuration options for the SDK.\n   */\n  sdkConfig?: SdkConfig;\n\n  /**\n   * Name of the toolkit stack to be used.\n   *\n   * @default \"CDKToolkit\"\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Fail Cloud Assemblies\n   *\n   * @default \"error\"\n   */\n  assemblyFailureAt?: 'error' | 'warn' | 'none';\n}\n\n/**\n * The AWS CDK Programmatic Toolkit\n */\nexport class Toolkit extends CloudAssemblySourceBuilder implements AsyncDisposable {\n  /**\n   * The toolkit stack name used for bootstrapping resources.\n   */\n  public readonly toolkitStackName: string;\n\n  /**\n   * The IoHost of this Toolkit\n   */\n  public readonly ioHost: IIoHost;\n  private _sdkProvider?: SdkProvider;\n\n  public constructor(private readonly props: ToolkitOptions = {}) {\n    super();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n\n    // Hacky way to re-use the global IoHost until we have fully removed the need for it\n    const globalIoHost = CliIoHost.instance();\n    if (props.ioHost) {\n      globalIoHost.registerIoHost(props.ioHost as any);\n    }\n    let ioHost = globalIoHost as IIoHost;\n    if (props.emojis === false) {\n      ioHost = withoutEmojis(ioHost);\n    }\n    if (props.color === false) {\n      ioHost = withoutColor(ioHost);\n    }\n    // After removing emojis and color, we might end up with floating whitespace at either end of the message\n    // This also removes newlines that we currently emit for CLI backwards compatibility.\n    this.ioHost = withTrimmedWhitespace(ioHost);\n  }\n\n  public async dispose(): Promise<void> {\n    // nothing to do yet\n  }\n\n  public async [Symbol.asyncDispose](): Promise<void> {\n    await this.dispose();\n  }\n\n  /**\n   * Access to the AWS SDK\n   */\n  private async sdkProvider(action: ToolkitAction): Promise<SdkProvider> {\n    // @todo this needs to be different instance per action\n    if (!this._sdkProvider) {\n      this._sdkProvider = await SdkProvider.withAwsCliCompatibleDefaults({\n        ...this.props.sdkConfig,\n        logger: asSdkLogger(asIoHelper(this.ioHost, action)),\n      });\n    }\n\n    return this._sdkProvider;\n  }\n\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   */\n  protected override async sourceBuilderServices(): Promise<ToolkitServices> {\n    return {\n      ioHelper: asIoHelper(this.ioHost, 'assembly'),\n      sdkProvider: await this.sdkProvider('assembly'),\n    };\n  }\n\n  /**\n   * Bootstrap Action\n   */\n  public async bootstrap(environments: BootstrapEnvironments, options: BootstrapOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'bootstrap');\n    const bootstrapEnvironments = await environments.getEnvironments();\n    const source = options.source ?? BootstrapSource.default();\n    const parameters = options.parameters;\n    const bootstrapper = new Bootstrapper(source, ioHelper);\n    const sdkProvider = await this.sdkProvider('bootstrap');\n    const limit = pLimit(20);\n\n    // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism\n    await Promise.all(bootstrapEnvironments.map((environment: cxapi.Environment, currentIdx) => limit(async () => {\n      const bootstrapSpan = await ioHelper.span(SPAN.BOOTSTRAP_SINGLE)\n        .begin(`${chalk.bold(environment.name)}: bootstrapping...`, {\n          total: bootstrapEnvironments.length,\n          current: currentIdx+1,\n          environment,\n        });\n\n      try {\n        const bootstrapResult = await bootstrapper.bootstrapEnvironment(\n          environment,\n          sdkProvider,\n          {\n            ...options,\n            toolkitStackName: this.toolkitStackName,\n            source,\n            parameters: parameters?.parameters,\n            usePreviousParameters: parameters?.keepExistingParameters,\n          },\n        );\n        const message = bootstrapResult.noOp\n          ? ` ✅  ${environment.name} (no changes)`\n          : ` ✅  ${environment.name}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I9900.msg(chalk.green('\\n' + message), { environment }));\n        await bootstrapSpan.end();\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E9900.msg(`\\n ❌  ${chalk.bold(environment.name)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw e;\n      }\n    })));\n  }\n\n  /**\n   * Synth Action\n   */\n  public async synth(cx: ICloudAssemblySource, options: SynthOptions = {}): Promise<ICloudAssemblySource> {\n    const ioHelper = asIoHelper(this.ioHost, 'synth');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const assembly = await assemblyFromSource(cx);\n    const stacks = assembly.selectStacksV2(selectStacks);\n    const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];\n    await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHelper);\n    await synthSpan.end();\n\n    // if we have a single stack, print it to STDOUT\n    const message = `Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`;\n    const assemblyData: AssemblyData = {\n      assemblyDirectory: stacks.assembly.directory,\n      stacksCount: stacks.stackCount,\n      stackIds: stacks.hierarchicalIds,\n    };\n\n    if (stacks.stackCount === 1) {\n      const firstStack = stacks.firstStack!;\n      const template = firstStack.template;\n      const obscuredTemplate = obscureTemplate(template);\n      await ioHelper.notify(IO.CDK_TOOLKIT_I1901.msg(message, {\n        ...assemblyData,\n        stack: {\n          stackName: firstStack.stackName,\n          hierarchicalId: firstStack.hierarchicalId,\n          template,\n          stringifiedJson: serializeStructure(obscuredTemplate, true),\n          stringifiedYaml: serializeStructure(obscuredTemplate, false),\n        },\n      }));\n    } else {\n      // not outputting template to stdout, let's explain things to the user a little bit...\n      await ioHelper.notify(IO.CDK_TOOLKIT_I1902.msg(chalk.green(message), assemblyData));\n      await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));\n    }\n\n    return new IdentityCloudAssemblySource(assembly.assembly);\n  }\n\n  /**\n   * List Action\n   *\n   * List selected stacks and their dependencies\n   */\n  public async list(cx: ICloudAssemblySource, options: ListOptions = {}): Promise<StackDetails[]> {\n    const ioHelper = asIoHelper(this.ioHost, 'list');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const assembly = await assemblyFromSource(cx);\n    const stackCollection = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const stacks = stackCollection.withDependencies();\n    const message = stacks.map(s => s.id).join('\\n');\n\n    await ioHelper.notify(IO.CDK_TOOLKIT_I2901.msg(message, { stacks }));\n    return stacks;\n  }\n\n  /**\n   * Deploy Action\n   *\n   * Deploys the selected stacks into an AWS account\n   */\n  public async deploy(cx: ICloudAssemblySource, options: DeployOptions = {}): Promise<void> {\n    const assembly = await assemblyFromSource(cx);\n    return this._deploy(assembly, 'deploy', options);\n  }\n\n  /**\n   * Helper to allow deploy being called as part of the watch action.\n   */\n  private async _deploy(assembly: StackAssembly, action: 'deploy' | 'watch', options: ExtendedDeployOptions = {}) {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const stackCollection = assembly.selectStacksV2(selectStacks);\n    await this.validateStacksMetadata(stackCollection, ioHelper);\n    const synthDuration = await synthSpan.end();\n\n    if (stackCollection.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E5001.msg('This app contains no stacks'));\n      return;\n    }\n\n    const deployments = await this.deploymentsForAction('deploy');\n    const migrator = new ResourceMigrator({ deployments, ioHelper });\n\n    await migrator.tryMigrateResources(stackCollection, options);\n\n    const parameterMap = buildParameterMap(options.parameters?.parameters);\n\n    const hotswapMode = options.hotswap ?? HotswapMode.FULL_DEPLOYMENT;\n    if (hotswapMode !== HotswapMode.FULL_DEPLOYMENT) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_W5400.msg([\n        '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',\n        '⚠️ They should only be used for development - never use them for your production Stacks!',\n      ].join('\\n')));\n    }\n\n    const stacks = stackCollection.stackArtifacts;\n    const stackOutputs: { [key: string]: any } = {};\n    const outputsFile = options.outputsFile;\n\n    const buildAsset = async (assetNode: AssetBuildNode) => {\n      const buildAssetSpan = await ioHelper.span(SPAN.BUILD_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.buildSingleAsset(\n        assetNode.assetManifestArtifact,\n        assetNode.assetManifest,\n        assetNode.asset,\n        {\n          stack: assetNode.parentStack,\n          roleArn: options.roleArn,\n          stackName: assetNode.parentStack.stackName,\n        },\n      );\n      await buildAssetSpan.end();\n    };\n\n    const publishAsset = async (assetNode: AssetPublishNode) => {\n      const publishAssetSpan = await ioHelper.span(SPAN.PUBLISH_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {\n        stack: assetNode.parentStack,\n        roleArn: options.roleArn,\n        stackName: assetNode.parentStack.stackName,\n        forcePublish: options.force,\n      });\n      await publishAssetSpan.end();\n    };\n\n    const deployStack = async (stackNode: StackNode) => {\n      const stack = stackNode.stack;\n      if (stackCollection.stackCount !== 1) {\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(chalk.bold(stack.displayName)));\n      }\n\n      if (!stack.environment) {\n        throw new ToolkitError(\n          `Stack ${stack.displayName} does not define an environment, and AWS credentials could not be obtained from standard locations or no region was configured.`,\n        );\n      }\n\n      // The generated stack has no resources\n      if (Object.keys(stack.template.Resources || {}).length === 0) {\n        // stack is empty and doesn't exist => do nothing\n        const stackExists = await deployments.stackExists({ stack });\n        if (!stackExists) {\n          return ioHelper.notify(IO.CDK_TOOLKIT_W5021.msg(`${chalk.bold(stack.displayName)}: stack has no resources, skipping deployment.`));\n        }\n\n        // stack is empty, but exists => delete\n        await ioHelper.notify(IO.CDK_TOOLKIT_W5022.msg(`${chalk.bold(stack.displayName)}: stack has no resources, deleting existing stack.`));\n        await this._destroy(assembly, 'deploy', {\n          stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n          roleArn: options.roleArn,\n          ci: options.ci,\n        });\n\n        return;\n      }\n\n      const currentTemplate = await deployments.readCurrentTemplate(stack);\n      const permissionChangeType = determinePermissionType(currentTemplate, stack);\n      const deployMotivation = '\"--require-approval\" is enabled and stack includes security-sensitive updates.';\n      const deployQuestion = `${deployMotivation}\\nDo you wish to deploy these changes`;\n      const deployConfirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5060.req(deployQuestion, {\n        motivation: deployMotivation,\n        concurrency,\n        permissionChangeType,\n      }));\n      if (!deployConfirmed) {\n        throw new ToolkitError('Aborted by user');\n      }\n\n      // Following are the same semantics we apply with respect to Notification ARNs (dictated by the SDK)\n      //\n      //  - undefined  =>  cdk ignores it, as if it wasn't supported (allows external management).\n      //  - []:        =>  cdk manages it, and the user wants to wipe it out.\n      //  - ['arn-1']  =>  cdk manages it, and the user wants to set it to ['arn-1'].\n      const notificationArns = (!!options.notificationArns || !!stack.notificationArns)\n        ? (options.notificationArns ?? []).concat(stack.notificationArns ?? [])\n        : undefined;\n\n      for (const notificationArn of notificationArns ?? []) {\n        if (!validateSnsTopicArn(notificationArn)) {\n          throw new ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);\n        }\n      }\n\n      const stackIndex = stacks.indexOf(stack) + 1;\n      const deploySpan = await ioHelper.span(SPAN.DEPLOY_STACK)\n        .begin(`${chalk.bold(stack.displayName)}: deploying... [${stackIndex}/${stackCollection.stackCount}]`, {\n          total: stackCollection.stackCount,\n          current: stackIndex,\n          stack,\n        });\n\n      let tags = options.tags;\n      if (!tags || tags.length === 0) {\n        tags = tagsForStack(stack);\n      }\n\n      let deployDuration;\n      try {\n        let deployResult: SuccessfulDeployStackResult | undefined;\n\n        let rollback = options.rollback;\n        let iteration = 0;\n        while (!deployResult) {\n          if (++iteration > 2) {\n            throw new ToolkitError('This loop should have stabilized in 2 iterations, but didn\\'t. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose');\n          }\n\n          const r = await deployments.deployStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n            toolkitStackName: this.toolkitStackName,\n            reuseAssets: options.reuseAssets,\n            notificationArns,\n            tags,\n            deploymentMethod: options.deploymentMethod,\n            force: options.force,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.parameters?.keepExistingParameters,\n            rollback,\n            hotswap: hotswapMode,\n            extraUserAgent: options.extraUserAgent,\n            hotswapPropertyOverrides: options.hotswapProperties ? createHotswapPropertyOverrides(options.hotswapProperties) : undefined,\n            assetParallelism: options.assetParallelism,\n          });\n\n          switch (r.type) {\n            case 'did-deploy-stack':\n              deployResult = r;\n              break;\n\n            case 'failpaused-need-rollback-first': {\n              const motivation = r.reason === 'replacement'\n                ? `Stack is in a paused fail state (${r.status}) and change includes a replacement which cannot be deployed with \"--no-rollback\"`\n                : `Stack is in a paused fail state (${r.status}) and command line arguments do not include \"--no-rollback\"`;\n              const question = `${motivation}. Perform a regular deployment`;\n\n              if (options.force) {\n                await ioHelper.notify(IO.DEFAULT_TOOLKIT_WARN.msg(`${motivation}. Rolling back first (--force).`));\n              } else {\n                const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                  motivation,\n                  concurrency,\n                }));\n                if (!confirmed) {\n                  throw new ToolkitError('Aborted by user');\n                }\n              }\n\n              // Perform a rollback\n              await this._rollback(assembly, action, {\n                stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n                orphanFailedResources: options.force,\n              });\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            case 'replacement-requires-rollback': {\n              const motivation = 'Change includes a replacement which cannot be deployed with \"--no-rollback\"';\n              const question = `${motivation}. Perform a regular deployment`;\n\n              // @todo no force here\n              if (options.force) {\n                await ioHelper.notify(IO.DEFAULT_TOOLKIT_WARN.msg(`${motivation}. Proceeding with regular deployment (--force).`));\n              } else {\n                const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                  motivation,\n                  concurrency,\n                }));\n                if (!confirmed) {\n                  throw new ToolkitError('Aborted by user');\n                }\n              }\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            default:\n              throw new ToolkitError(`Unexpected result type from deployStack: ${JSON.stringify(r)}. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose`);\n          }\n        }\n\n        const message = deployResult.noOp\n          ? ` ✅  ${stack.displayName} (no changes)`\n          : ` ✅  ${stack.displayName}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5900.msg(chalk.green('\\n' + message), deployResult));\n        deployDuration = await deploySpan.timing(IO.CDK_TOOLKIT_I5000);\n\n        if (Object.keys(deployResult.outputs).length > 0) {\n          const buffer = ['Outputs:'];\n          stackOutputs[stack.stackName] = deployResult.outputs;\n\n          for (const name of Object.keys(deployResult.outputs).sort()) {\n            const value = deployResult.outputs[name];\n            buffer.push(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);\n          }\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(buffer.join('\\n')));\n        }\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(`Stack ARN:\\n${deployResult.stackArn}`));\n      } catch (e: any) {\n        // It has to be exactly this string because an integration test tests for\n        // \"bold(stackname) failed: ResourceNotReady: <error>\"\n        throw new ToolkitError(\n          [`❌  ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), e.message].join(' '),\n        );\n      } finally {\n        if (options.traceLogs) {\n          // deploy calls that originate from watch will come with their own cloudWatchLogMonitor\n          const cloudWatchLogMonitor = options.cloudWatchLogMonitor ?? new CloudWatchLogEventMonitor({ ioHelper });\n          const foundLogGroupsResult = await findCloudWatchLogGroups(await this.sdkProvider('deploy'), ioHelper, stack);\n          cloudWatchLogMonitor.addLogGroups(\n            foundLogGroupsResult.env,\n            foundLogGroupsResult.sdk,\n            foundLogGroupsResult.logGroupNames,\n          );\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5031.msg(`The following log groups are added: ${foundLogGroupsResult.logGroupNames}`));\n        }\n\n        // If an outputs file has been specified, create the file path and write stack outputs to it once.\n        // Outputs are written after all stacks have been deployed. If a stack deployment fails,\n        // all of the outputs from successfully deployed stacks before the failure will still be written.\n        if (outputsFile) {\n          fs.ensureFileSync(outputsFile);\n          await fs.writeJson(outputsFile, stackOutputs, {\n            spaces: 2,\n            encoding: 'utf8',\n          });\n        }\n      }\n      const duration = synthDuration.asMs + (deployDuration?.asMs ?? 0);\n      await deploySpan.end(`\\n✨  Total time: ${formatTime(duration)}s\\n`, { duration });\n    };\n\n    const assetBuildTime = options.assetBuildTime ?? AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const prebuildAssets = assetBuildTime === AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const concurrency = options.concurrency || 1;\n\n    const stacksAndTheirAssetManifests = stacks.flatMap((stack) => [\n      stack,\n      ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),\n    ]);\n    const workGraph = new WorkGraphBuilder(ioHelper, prebuildAssets).build(stacksAndTheirAssetManifests);\n\n    // Unless we are running with '--force', skip already published assets\n    if (!options.force) {\n      await removePublishedAssets(workGraph, deployments, options);\n    }\n\n    const graphConcurrency: Concurrency = {\n      'stack': concurrency,\n      'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds\n      'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable\n    };\n\n    await workGraph.doParallel(graphConcurrency, {\n      deployStack,\n      buildAsset,\n      publishAsset,\n    });\n  }\n\n  /**\n   * Watch Action\n   *\n   * Continuously observe project files and deploy the selected stacks automatically when changes are detected.\n   * Implies hotswap deployments.\n   */\n  public async watch(cx: ICloudAssemblySource, options: WatchOptions): Promise<void> {\n    const assembly = await assemblyFromSource(cx, false);\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    const rootDir = options.watchDir ?? process.cwd();\n\n    if (options.include === undefined && options.exclude === undefined) {\n      throw new ToolkitError(\n        \"Cannot use the 'watch' command without specifying at least one directory to monitor. \" +\n          'Make sure to add a \"watch\" key to your cdk.json',\n      );\n    }\n\n    // For the \"include\" subkey under the \"watch\" key, the behavior is:\n    // 1. No \"watch\" setting? We error out.\n    // 2. \"watch\" setting without an \"include\" key? We default to observing \"./**\".\n    // 3. \"watch\" setting with an empty \"include\" key? We default to observing \"./**\".\n    // 4. Non-empty \"include\" key? Just use the \"include\" key.\n    const watchIncludes = patternsArrayForWatch(options.include, {\n      rootDir,\n      returnRootDirIfEmpty: true,\n    });\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outdir = options.outdir ?? 'cdk.out';\n    const watchExcludes = patternsArrayForWatch(options.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    }).concat(`${outdir}/**`, '**/.*', '**/.*/**', '**/node_modules/**');\n\n    // Print some debug information on computed settings\n    await ioHelper.notify(IO.CDK_TOOLKIT_I5310.msg([\n      `root directory used for 'watch' is: ${rootDir}`,\n      `'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`,\n      `'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`,\n    ].join('\\n'), {\n      watchDir: rootDir,\n      includes: watchIncludes,\n      excludes: watchExcludes,\n    }));\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    type LatchState = 'pre-ready' | 'open' | 'deploying' | 'queued';\n    let latch: LatchState = 'pre-ready';\n\n    const cloudWatchLogMonitor = options.traceLogs ? new CloudWatchLogEventMonitor({ ioHelper }) : undefined;\n    const deployAndWatch = async () => {\n      latch = 'deploying' as LatchState;\n      await cloudWatchLogMonitor?.deactivate();\n\n      await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while (latch === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5315.msg(\"Detected file changes during deployment. Invoking 'cdk deploy' again\"));\n        await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n      }\n      latch = 'open';\n      await cloudWatchLogMonitor?.activate();\n    };\n\n    chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_DEBUG.msg(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\"));\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5314.msg(\"Triggering initial 'cdk deploy'\"));\n        await deployAndWatch();\n      })\n      .on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath: string) => {\n        const watchEvent = {\n          event,\n          path: filePath,\n        };\n        if (latch === 'pre-ready') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5311.msg(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`, watchEvent));\n        } else if (latch === 'open') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5312.msg(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`, watchEvent));\n          await deployAndWatch();\n        } else {\n          // this means latch is either 'deploying' or 'queued'\n          latch = 'queued';\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5313.msg(\n            `Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`,\n            watchEvent,\n          ));\n        }\n      });\n  }\n\n  /**\n   * Rollback Action\n   *\n   * Rolls back the selected stacks.\n   */\n  public async rollback(cx: ICloudAssemblySource, options: RollbackOptions): Promise<void> {\n    const assembly = await assemblyFromSource(cx);\n    return this._rollback(assembly, 'rollback', options);\n  }\n\n  /**\n   * Helper to allow rollback being called as part of the deploy or watch action.\n   */\n  private async _rollback(assembly: StackAssembly, action: 'rollback' | 'deploy' | 'watch', options: RollbackOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    const stacks = assembly.selectStacksV2(options.stacks);\n    await this.validateStacksMetadata(stacks, ioHelper);\n    await synthSpan.end();\n\n    if (stacks.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E6001.msg('No stacks selected'));\n      return;\n    }\n\n    let anyRollbackable = false;\n\n    for (const [index, stack] of stacks.stackArtifacts.entries()) {\n      const rollbackSpan = await ioHelper.span(SPAN.ROLLBACK_STACK).begin(`Rolling back ${chalk.bold(stack.displayName)}`, {\n        total: stacks.stackCount,\n        current: index + 1,\n        stack,\n      });\n      const deployments = await this.deploymentsForAction('rollback');\n      try {\n        const stackResult = await deployments.rollbackStack({\n          stack,\n          roleArn: options.roleArn,\n          toolkitStackName: this.toolkitStackName,\n          force: options.orphanFailedResources,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!stackResult.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        await rollbackSpan.end();\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E6900.msg(`\\n ❌  ${chalk.bold(stack.displayName)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw new ToolkitError('Rollback failed (use --force to orphan failing resources)');\n      }\n    }\n    if (!anyRollbackable) {\n      throw new ToolkitError('No stacks were in a state that could be rolled back');\n    }\n  }\n\n  /**\n   * Destroy Action\n   *\n   * Destroys the selected Stacks.\n   */\n  public async destroy(cx: ICloudAssemblySource, options: DestroyOptions): Promise<void> {\n    const assembly = await assemblyFromSource(cx);\n    return this._destroy(assembly, 'destroy', options);\n  }\n\n  /**\n   * Helper to allow destroy being called as part of the deploy action.\n   */\n  private async _destroy(assembly: StackAssembly, action: 'deploy' | 'destroy', options: DestroyOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    const stacks = await assembly.selectStacksV2(options.stacks).reversed();\n    await synthSpan.end();\n\n    const motivation = 'Destroying stacks is an irreversible action';\n    const question = `Are you sure you want to delete: ${chalk.red(stacks.hierarchicalIds.join(', '))}`;\n    const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I7010.req(question, { motivation }));\n    if (!confirmed) {\n      return ioHelper.notify(IO.CDK_TOOLKIT_E7010.msg('Aborted by user'));\n    }\n\n    const destroySpan = await ioHelper.span(SPAN.DESTROY_ACTION).begin({\n      stacks: stacks.stackArtifacts,\n    });\n    try {\n      for (const [index, stack] of stacks.stackArtifacts.entries()) {\n        try {\n          const singleDestroySpan = await ioHelper.span(SPAN.DESTROY_STACK)\n            .begin(chalk.green(`${chalk.blue(stack.displayName)}: destroying... [${index + 1}/${stacks.stackCount}]`), {\n              total: stacks.stackCount,\n              current: index + 1,\n              stack,\n            });\n          const deployments = await this.deploymentsForAction(action);\n          await deployments.destroyStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n          });\n          await ioHelper.notify(IO.CDK_TOOLKIT_I7900.msg(chalk.green(`\\n ✅  ${chalk.blue(stack.displayName)}: ${action}ed`), stack));\n          await singleDestroySpan.end();\n        } catch (e: any) {\n          await ioHelper.notify(IO.CDK_TOOLKIT_E7900.msg(`\\n ❌  ${chalk.blue(stack.displayName)}: ${action} failed ${e}`, { error: e }));\n          throw e;\n        }\n      }\n    } finally {\n      await destroySpan.end();\n    }\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private async validateStacksMetadata(stacks: StackCollection, ioHost: IoHelper) {\n    const builder = (level: IoMessageLevel) => {\n      switch (level) {\n        case 'error': return IO.CDK_ASSEMBLY_E9999;\n        case 'warn': return IO.CDK_ASSEMBLY_W9999;\n        default: return IO.CDK_ASSEMBLY_I9999;\n      }\n    };\n    await stacks.validateMetadata(\n      this.props.assemblyFailureAt,\n      async (level, msg) => ioHost.notify(builder(level).msg(`[${level} at ${msg.id}] ${msg.entry.data}`, msg)),\n    );\n  }\n\n  /**\n   * Create a deployments class\n   */\n  private async deploymentsForAction(action: ToolkitAction): Promise<Deployments> {\n    return new Deployments({\n      sdkProvider: await this.sdkProvider(action),\n      toolkitStackName: this.toolkitStackName,\n      ioHelper: asIoHelper(this.ioHost, action),\n    });\n  }\n\n  private async invokeDeployFromWatch(\n    assembly: StackAssembly,\n    options: WatchOptions,\n    cloudWatchLogMonitor?: CloudWatchLogEventMonitor,\n  ): Promise<void> {\n    // watch defaults hotswap to enabled\n    const hotswap = options.hotswap ?? HotswapMode.HOTSWAP_ONLY;\n    const deployOptions: ExtendedDeployOptions = {\n      ...options,\n      requireApproval: RequireApproval.NEVER,\n      cloudWatchLogMonitor,\n      hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${hotswap === HotswapMode.FULL_DEPLOYMENT ? 'off' : 'on'}`,\n    };\n\n    try {\n      await this._deploy(assembly, 'watch', deployOptions);\n    } catch {\n      // just continue - deploy will show the error\n    }\n  }\n}\n"]}
834
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit.js","sourceRoot":"","sources":["toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'node:path';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport * as chokidar from 'chokidar';\nimport * as fs from 'fs-extra';\nimport * as uuid from 'uuid';\nimport type { ToolkitServices } from './private';\nimport { assemblyFromSource } from './private';\nimport type { BootstrapEnvironments, BootstrapOptions, BootstrapResult, EnvironmentBootstrapResult } from '../actions/bootstrap';\nimport { BootstrapSource } from '../actions/bootstrap';\nimport { AssetBuildTime, type DeployOptions } from '../actions/deploy';\nimport { type ExtendedDeployOptions, buildParameterMap, createHotswapPropertyOverrides, removePublishedAssets } from '../actions/deploy/private';\nimport { type DestroyOptions } from '../actions/destroy';\nimport type { ChangeSetDiffOptions, DiffOptions, LocalFileDiffOptions } from '../actions/diff';\nimport { DiffMethod } from '../actions/diff';\nimport { determinePermissionType } from '../actions/diff/private';\nimport { type ListOptions } from '../actions/list';\nimport { type RollbackOptions } from '../actions/rollback';\nimport { type SynthOptions } from '../actions/synth';\nimport type { WatchOptions } from '../actions/watch';\nimport { patternsArrayForWatch } from '../actions/watch/private';\nimport { type SdkConfig } from '../api/aws-auth';\nimport type { SuccessfulDeployStackResult, StackCollection, Concurrency, AssetBuildNode, AssetPublishNode, StackNode } from '../api/aws-cdk';\nimport { DEFAULT_TOOLKIT_STACK_NAME, Bootstrapper, SdkProvider, Deployments, HotswapMode, ResourceMigrator, tagsForStack, CliIoHost, WorkGraphBuilder, CloudWatchLogEventMonitor, findCloudWatchLogGroups, createDiffChangeSet } from '../api/aws-cdk';\nimport type { ICloudAssemblySource } from '../api/cloud-assembly';\nimport { StackSelectionStrategy } from '../api/cloud-assembly';\nimport type { StackAssembly } from '../api/cloud-assembly/private';\nimport { ALL_STACKS, CloudAssemblySourceBuilder, IdentityCloudAssemblySource } from '../api/cloud-assembly/private';\nimport type { IIoHost, IoMessageLevel } from '../api/io';\nimport { IO, SPAN, asSdkLogger, withoutColor, withoutEmojis, withTrimmedWhitespace } from '../api/io/private';\nimport type { IoHelper } from '../api/shared-private';\nimport { asIoHelper } from '../api/shared-private';\nimport type { AssemblyData, StackDetails, ToolkitAction } from '../api/shared-public';\nimport { DiffFormatter, RequireApproval, ToolkitError, removeNonImportResources } from '../api/shared-public';\nimport { obscureTemplate, serializeStructure, validateSnsTopicArn, formatTime, formatErrorMessage, deserializeStructure } from '../private/util';\nimport { pLimit } from '../util/concurrency';\n\nexport interface ToolkitOptions {\n  /**\n   * The IoHost implementation, handling the inline interactions between the Toolkit and an integration.\n   */\n  ioHost?: IIoHost;\n\n  /**\n   * Allow emojis in messages sent to the IoHost.\n   *\n   * @default true\n   */\n  emojis?: boolean;\n\n  /**\n   * Whether to allow ANSI colors and formatting in IoHost messages.\n   * Setting this value to `false` enforces that no color or style shows up\n   * in messages sent to the IoHost.\n   * Setting this value to true is a no-op; it is equivalent to the default.\n   *\n   * @default - detects color from the TTY status of the IoHost\n   */\n  color?: boolean;\n\n  /**\n   * Configuration options for the SDK.\n   */\n  sdkConfig?: SdkConfig;\n\n  /**\n   * Name of the toolkit stack to be used.\n   *\n   * @default \"CDKToolkit\"\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Fail Cloud Assemblies\n   *\n   * @default \"error\"\n   */\n  assemblyFailureAt?: 'error' | 'warn' | 'none';\n}\n\n/**\n * The AWS CDK Programmatic Toolkit\n */\nexport class Toolkit extends CloudAssemblySourceBuilder implements AsyncDisposable {\n  /**\n   * The toolkit stack name used for bootstrapping resources.\n   */\n  public readonly toolkitStackName: string;\n\n  /**\n   * The IoHost of this Toolkit\n   */\n  public readonly ioHost: IIoHost;\n  private _sdkProvider?: SdkProvider;\n\n  public constructor(private readonly props: ToolkitOptions = {}) {\n    super();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n\n    // Hacky way to re-use the global IoHost until we have fully removed the need for it\n    const globalIoHost = CliIoHost.instance();\n    if (props.ioHost) {\n      globalIoHost.registerIoHost(props.ioHost as any);\n    }\n    let ioHost = globalIoHost as IIoHost;\n    if (props.emojis === false) {\n      ioHost = withoutEmojis(ioHost);\n    }\n    if (props.color === false) {\n      ioHost = withoutColor(ioHost);\n    }\n    // After removing emojis and color, we might end up with floating whitespace at either end of the message\n    // This also removes newlines that we currently emit for CLI backwards compatibility.\n    this.ioHost = withTrimmedWhitespace(ioHost);\n  }\n\n  public async dispose(): Promise<void> {\n    // nothing to do yet\n  }\n\n  public async [Symbol.asyncDispose](): Promise<void> {\n    await this.dispose();\n  }\n\n  /**\n   * Access to the AWS SDK\n   */\n  private async sdkProvider(action: ToolkitAction): Promise<SdkProvider> {\n    // @todo this needs to be different instance per action\n    if (!this._sdkProvider) {\n      this._sdkProvider = await SdkProvider.withAwsCliCompatibleDefaults({\n        ...this.props.sdkConfig,\n        logger: asSdkLogger(asIoHelper(this.ioHost, action)),\n      });\n    }\n\n    return this._sdkProvider;\n  }\n\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   */\n  protected override async sourceBuilderServices(): Promise<ToolkitServices> {\n    return {\n      ioHelper: asIoHelper(this.ioHost, 'assembly'),\n      sdkProvider: await this.sdkProvider('assembly'),\n    };\n  }\n\n  /**\n   * Bootstrap Action\n   */\n  public async bootstrap(environments: BootstrapEnvironments, options: BootstrapOptions): Promise<BootstrapResult> {\n    const startTime = Date.now();\n    const results: EnvironmentBootstrapResult[] = [];\n\n    const ioHelper = asIoHelper(this.ioHost, 'bootstrap');\n    const bootstrapEnvironments = await environments.getEnvironments(this.ioHost);\n    const source = options.source ?? BootstrapSource.default();\n    const parameters = options.parameters;\n    const bootstrapper = new Bootstrapper(source, ioHelper);\n    const sdkProvider = await this.sdkProvider('bootstrap');\n    const limit = pLimit(20);\n\n    // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism\n    await Promise.all(bootstrapEnvironments.map((environment: cxapi.Environment, currentIdx) => limit(async () => {\n      const bootstrapSpan = await ioHelper.span(SPAN.BOOTSTRAP_SINGLE)\n        .begin(`${chalk.bold(environment.name)}: bootstrapping...`, {\n          total: bootstrapEnvironments.length,\n          current: currentIdx+1,\n          environment,\n        });\n\n      try {\n        const bootstrapResult = await bootstrapper.bootstrapEnvironment(\n          environment,\n          sdkProvider,\n          {\n            ...options,\n            toolkitStackName: this.toolkitStackName,\n            source,\n            parameters: parameters?.parameters,\n            usePreviousParameters: parameters?.keepExistingParameters,\n          },\n        );\n\n        const message = bootstrapResult.noOp\n          ? ` ✅  ${environment.name} (no changes)`\n          : ` ✅  ${environment.name}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I9900.msg(chalk.green('\\n' + message), { environment }));\n        const envTime = await bootstrapSpan.end();\n        const result: EnvironmentBootstrapResult = {\n          environment,\n          status: bootstrapResult.noOp ? 'no-op' : 'success',\n          duration: envTime.asMs,\n        };\n        results.push(result);\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E9900.msg(`\\n ❌  ${chalk.bold(environment.name)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw e;\n      }\n    })));\n\n    return {\n      environments: results,\n      duration: Date.now() - startTime,\n    };\n  }\n\n  /**\n   * Synth Action\n   */\n  public async synth(cx: ICloudAssemblySource, options: SynthOptions = {}): Promise<ICloudAssemblySource> {\n    const ioHelper = asIoHelper(this.ioHost, 'synth');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];\n    await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHelper);\n    await synthSpan.end();\n\n    // if we have a single stack, print it to STDOUT\n    const message = `Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`;\n    const assemblyData: AssemblyData = {\n      assemblyDirectory: stacks.assembly.directory,\n      stacksCount: stacks.stackCount,\n      stackIds: stacks.hierarchicalIds,\n    };\n\n    if (stacks.stackCount === 1) {\n      const firstStack = stacks.firstStack!;\n      const template = firstStack.template;\n      const obscuredTemplate = obscureTemplate(template);\n      await ioHelper.notify(IO.CDK_TOOLKIT_I1901.msg(message, {\n        ...assemblyData,\n        stack: {\n          stackName: firstStack.stackName,\n          hierarchicalId: firstStack.hierarchicalId,\n          template,\n          stringifiedJson: serializeStructure(obscuredTemplate, true),\n          stringifiedYaml: serializeStructure(obscuredTemplate, false),\n        },\n      }));\n    } else {\n      // not outputting template to stdout, let's explain things to the user a little bit...\n      await ioHelper.notify(IO.CDK_TOOLKIT_I1902.msg(chalk.green(message), assemblyData));\n      await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));\n    }\n\n    return new IdentityCloudAssemblySource(assembly.assembly);\n  }\n\n  /**\n   * Diff Action\n   */\n  public async diff(cx: ICloudAssemblySource, options: DiffOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'diff');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const diffSpan = await ioHelper.span(SPAN.DIFF_STACK).begin({ stacks: selectStacks });\n    const deployments = await this.deploymentsForAction('diff');\n\n    const strict = !!options.strict;\n    const contextLines = options.contextLines || 3;\n    const diffMethod = options.method ?? DiffMethod.ChangeSet();\n\n    let diffs = 0;\n    let formattedSecurityDiff = '';\n    let formattedStackDiff = '';\n\n    if (diffMethod.method === 'local-file') {\n      const methodOptions = diffMethod.options as LocalFileDiffOptions;\n\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(methodOptions.path))) {\n        throw new ToolkitError(`There is no file at ${path}`);\n      }\n\n      const file = fs.readFileSync(methodOptions.path).toString();\n      const template = deserializeStructure(file);\n      const formatter = new DiffFormatter({\n        ioHelper,\n        oldTemplate: template,\n        newTemplate: stacks.firstStack,\n      });\n      if (options.securityOnly) {\n        const securityDiff = formatter.formatSecurityDiff({\n          requireApproval: RequireApproval.BROADENING,\n        });\n        formattedSecurityDiff = securityDiff.formattedDiff ?? '';\n        diffs = securityDiff.formattedDiff ? diffs + 1 : diffs;\n      } else {\n        const diff = formatter.formatStackDiff({\n          strict,\n          context: contextLines,\n        });\n        formattedStackDiff = diff.formattedDiff;\n        diffs = diff.numStacksWithChanges;\n      }\n    } else {\n      const methodOptions = diffMethod.options as ChangeSetDiffOptions;\n      // Compare N stacks against deployed templates\n      for (const stack of stacks.stackArtifacts) {\n        const templateWithNestedStacks = await deployments.readCurrentTemplateWithNestedStacks(\n          stack,\n          methodOptions.compareAgainstProcessedTemplate,\n        );\n        const currentTemplate = templateWithNestedStacks.deployedRootTemplate;\n        const nestedStacks = templateWithNestedStacks.nestedStacks;\n\n        const formatter = new DiffFormatter({\n          ioHelper,\n          oldTemplate: currentTemplate,\n          newTemplate: stack,\n        });\n\n        const migrator = new ResourceMigrator({ deployments, ioHelper });\n        const resourcesToImport = await migrator.tryGetResources(await deployments.resolveEnvironment(stack));\n        if (resourcesToImport) {\n          removeNonImportResources(stack);\n        }\n\n        let changeSet = undefined;\n\n        if (diffMethod.method === 'change-set') {\n          let stackExists = false;\n          try {\n            stackExists = await deployments.stackExists({\n              stack,\n              deployName: stack.stackName,\n              tryLookupRole: true,\n            });\n          } catch (e: any) {\n            await ioHelper.notify(IO.DEFAULT_TOOLKIT_DEBUG.msg(`Checking if the stack ${stack.stackName} exists before creating the changeset has failed, will base the diff on template differences.\\n`));\n            await ioHelper.notify(IO.DEFAULT_TOOLKIT_DEBUG.msg(formatErrorMessage(e)));\n            stackExists = false;\n          }\n\n          if (stackExists) {\n            changeSet = await createDiffChangeSet(ioHelper, {\n              stack,\n              uuid: uuid.v4(),\n              deployments,\n              willExecute: false,\n              sdkProvider: await this.sdkProvider('diff'),\n              parameters: methodOptions.parameters ?? {},\n              resourcesToImport,\n            });\n          } else {\n            await ioHelper.notify(IO.DEFAULT_TOOLKIT_DEBUG.msg(`the stack '${stack.stackName}' has not been deployed to CloudFormation or describeStacks call failed, skipping changeset creation.`));\n          }\n        }\n\n        if (options.securityOnly) {\n          const securityDiff = formatter.formatSecurityDiff({\n            requireApproval: RequireApproval.BROADENING,\n            stackName: stack.displayName,\n            changeSet,\n          });\n          formattedSecurityDiff = securityDiff.formattedDiff ?? '';\n          diffs = securityDiff.formattedDiff ? diffs + 1 : diffs;\n        } else {\n          const diff = formatter.formatStackDiff({\n            strict,\n            context: contextLines,\n            stackName: stack.displayName,\n            changeSet,\n            isImport: !!resourcesToImport,\n            nestedStackTemplates: nestedStacks,\n          });\n          formattedStackDiff = diff.formattedDiff;\n          diffs = diff.numStacksWithChanges;\n        }\n      }\n    }\n\n    await diffSpan.end(`✨ Number of stacks with differences: ${diffs}`, {\n      formattedSecurityDiff,\n      formattedStackDiff,\n    });\n\n    return;\n  }\n\n  /**\n   * List Action\n   *\n   * List selected stacks and their dependencies\n   */\n  public async list(cx: ICloudAssemblySource, options: ListOptions = {}): Promise<StackDetails[]> {\n    const ioHelper = asIoHelper(this.ioHost, 'list');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    const stackCollection = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const stacks = stackCollection.withDependencies();\n    const message = stacks.map(s => s.id).join('\\n');\n\n    await ioHelper.notify(IO.CDK_TOOLKIT_I2901.msg(message, { stacks }));\n    return stacks;\n  }\n\n  /**\n   * Deploy Action\n   *\n   * Deploys the selected stacks into an AWS account\n   */\n  public async deploy(cx: ICloudAssemblySource, options: DeployOptions = {}): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'deploy');\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    return this._deploy(assembly, 'deploy', options);\n  }\n\n  /**\n   * Helper to allow deploy being called as part of the watch action.\n   */\n  private async _deploy(assembly: StackAssembly, action: 'deploy' | 'watch', options: ExtendedDeployOptions = {}) {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const stackCollection = await assembly.selectStacksV2(selectStacks);\n    await this.validateStacksMetadata(stackCollection, ioHelper);\n    const synthDuration = await synthSpan.end();\n\n    if (stackCollection.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E5001.msg('This app contains no stacks'));\n      return;\n    }\n\n    const deployments = await this.deploymentsForAction('deploy');\n    const migrator = new ResourceMigrator({ deployments, ioHelper });\n\n    await migrator.tryMigrateResources(stackCollection, options);\n\n    const parameterMap = buildParameterMap(options.parameters?.parameters);\n\n    const hotswapMode = options.hotswap ?? HotswapMode.FULL_DEPLOYMENT;\n    if (hotswapMode !== HotswapMode.FULL_DEPLOYMENT) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_W5400.msg([\n        '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',\n        '⚠️ They should only be used for development - never use them for your production Stacks!',\n      ].join('\\n')));\n    }\n\n    const stacks = stackCollection.stackArtifacts;\n    const stackOutputs: { [key: string]: any } = {};\n    const outputsFile = options.outputsFile;\n\n    const buildAsset = async (assetNode: AssetBuildNode) => {\n      const buildAssetSpan = await ioHelper.span(SPAN.BUILD_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.buildSingleAsset(\n        assetNode.assetManifestArtifact,\n        assetNode.assetManifest,\n        assetNode.asset,\n        {\n          stack: assetNode.parentStack,\n          roleArn: options.roleArn,\n          stackName: assetNode.parentStack.stackName,\n        },\n      );\n      await buildAssetSpan.end();\n    };\n\n    const publishAsset = async (assetNode: AssetPublishNode) => {\n      const publishAssetSpan = await ioHelper.span(SPAN.PUBLISH_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {\n        stack: assetNode.parentStack,\n        roleArn: options.roleArn,\n        stackName: assetNode.parentStack.stackName,\n        forcePublish: options.force,\n      });\n      await publishAssetSpan.end();\n    };\n\n    const deployStack = async (stackNode: StackNode) => {\n      const stack = stackNode.stack;\n      if (stackCollection.stackCount !== 1) {\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(chalk.bold(stack.displayName)));\n      }\n\n      if (!stack.environment) {\n        throw new ToolkitError(\n          `Stack ${stack.displayName} does not define an environment, and AWS credentials could not be obtained from standard locations or no region was configured.`,\n        );\n      }\n\n      // The generated stack has no resources\n      if (Object.keys(stack.template.Resources || {}).length === 0) {\n        // stack is empty and doesn't exist => do nothing\n        const stackExists = await deployments.stackExists({ stack });\n        if (!stackExists) {\n          return ioHelper.notify(IO.CDK_TOOLKIT_W5021.msg(`${chalk.bold(stack.displayName)}: stack has no resources, skipping deployment.`));\n        }\n\n        // stack is empty, but exists => delete\n        await ioHelper.notify(IO.CDK_TOOLKIT_W5022.msg(`${chalk.bold(stack.displayName)}: stack has no resources, deleting existing stack.`));\n        await this._destroy(assembly, 'deploy', {\n          stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n          roleArn: options.roleArn,\n          ci: options.ci,\n        });\n\n        return;\n      }\n\n      const currentTemplate = await deployments.readCurrentTemplate(stack);\n      const permissionChangeType = determinePermissionType(currentTemplate, stack);\n      const deployMotivation = '\"--require-approval\" is enabled and stack includes security-sensitive updates.';\n      const deployQuestion = `${deployMotivation}\\nDo you wish to deploy these changes`;\n      const deployConfirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5060.req(deployQuestion, {\n        motivation: deployMotivation,\n        concurrency,\n        permissionChangeType,\n      }));\n      if (!deployConfirmed) {\n        throw new ToolkitError('Aborted by user');\n      }\n\n      // Following are the same semantics we apply with respect to Notification ARNs (dictated by the SDK)\n      //\n      //  - undefined  =>  cdk ignores it, as if it wasn't supported (allows external management).\n      //  - []:        =>  cdk manages it, and the user wants to wipe it out.\n      //  - ['arn-1']  =>  cdk manages it, and the user wants to set it to ['arn-1'].\n      const notificationArns = (!!options.notificationArns || !!stack.notificationArns)\n        ? (options.notificationArns ?? []).concat(stack.notificationArns ?? [])\n        : undefined;\n\n      for (const notificationArn of notificationArns ?? []) {\n        if (!validateSnsTopicArn(notificationArn)) {\n          throw new ToolkitError(`Notification arn ${notificationArn} is not a valid arn for an SNS topic`);\n        }\n      }\n\n      const stackIndex = stacks.indexOf(stack) + 1;\n      const deploySpan = await ioHelper.span(SPAN.DEPLOY_STACK)\n        .begin(`${chalk.bold(stack.displayName)}: deploying... [${stackIndex}/${stackCollection.stackCount}]`, {\n          total: stackCollection.stackCount,\n          current: stackIndex,\n          stack,\n        });\n\n      let tags = options.tags;\n      if (!tags || tags.length === 0) {\n        tags = tagsForStack(stack);\n      }\n\n      let deployDuration;\n      try {\n        let deployResult: SuccessfulDeployStackResult | undefined;\n\n        let rollback = options.rollback;\n        let iteration = 0;\n        while (!deployResult) {\n          if (++iteration > 2) {\n            throw new ToolkitError('This loop should have stabilized in 2 iterations, but didn\\'t. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose');\n          }\n\n          const r = await deployments.deployStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n            toolkitStackName: this.toolkitStackName,\n            reuseAssets: options.reuseAssets,\n            notificationArns,\n            tags,\n            deploymentMethod: options.deploymentMethod,\n            force: options.force,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.parameters?.keepExistingParameters,\n            rollback,\n            hotswap: hotswapMode,\n            extraUserAgent: options.extraUserAgent,\n            hotswapPropertyOverrides: options.hotswapProperties ? createHotswapPropertyOverrides(options.hotswapProperties) : undefined,\n            assetParallelism: options.assetParallelism,\n          });\n\n          switch (r.type) {\n            case 'did-deploy-stack':\n              deployResult = r;\n              break;\n\n            case 'failpaused-need-rollback-first': {\n              const motivation = r.reason === 'replacement'\n                ? `Stack is in a paused fail state (${r.status}) and change includes a replacement which cannot be deployed with \"--no-rollback\"`\n                : `Stack is in a paused fail state (${r.status}) and command line arguments do not include \"--no-rollback\"`;\n              const question = `${motivation}. Perform a regular deployment`;\n\n              if (options.force) {\n                await ioHelper.notify(IO.DEFAULT_TOOLKIT_WARN.msg(`${motivation}. Rolling back first (--force).`));\n              } else {\n                const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                  motivation,\n                  concurrency,\n                }));\n                if (!confirmed) {\n                  throw new ToolkitError('Aborted by user');\n                }\n              }\n\n              // Perform a rollback\n              await this._rollback(assembly, action, {\n                stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n                orphanFailedResources: options.force,\n              });\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            case 'replacement-requires-rollback': {\n              const motivation = 'Change includes a replacement which cannot be deployed with \"--no-rollback\"';\n              const question = `${motivation}. Perform a regular deployment`;\n\n              // @todo no force here\n              if (options.force) {\n                await ioHelper.notify(IO.DEFAULT_TOOLKIT_WARN.msg(`${motivation}. Proceeding with regular deployment (--force).`));\n              } else {\n                const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                  motivation,\n                  concurrency,\n                }));\n                if (!confirmed) {\n                  throw new ToolkitError('Aborted by user');\n                }\n              }\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            default:\n              throw new ToolkitError(`Unexpected result type from deployStack: ${JSON.stringify(r)}. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose`);\n          }\n        }\n\n        const message = deployResult.noOp\n          ? ` ✅  ${stack.displayName} (no changes)`\n          : ` ✅  ${stack.displayName}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5900.msg(chalk.green('\\n' + message), deployResult));\n        deployDuration = await deploySpan.timing(IO.CDK_TOOLKIT_I5000);\n\n        if (Object.keys(deployResult.outputs).length > 0) {\n          const buffer = ['Outputs:'];\n          stackOutputs[stack.stackName] = deployResult.outputs;\n\n          for (const name of Object.keys(deployResult.outputs).sort()) {\n            const value = deployResult.outputs[name];\n            buffer.push(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);\n          }\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(buffer.join('\\n')));\n        }\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(`Stack ARN:\\n${deployResult.stackArn}`));\n      } catch (e: any) {\n        // It has to be exactly this string because an integration test tests for\n        // \"bold(stackname) failed: ResourceNotReady: <error>\"\n        throw new ToolkitError(\n          [`❌  ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), e.message].join(' '),\n        );\n      } finally {\n        if (options.traceLogs) {\n          // deploy calls that originate from watch will come with their own cloudWatchLogMonitor\n          const cloudWatchLogMonitor = options.cloudWatchLogMonitor ?? new CloudWatchLogEventMonitor({ ioHelper });\n          const foundLogGroupsResult = await findCloudWatchLogGroups(await this.sdkProvider('deploy'), ioHelper, stack);\n          cloudWatchLogMonitor.addLogGroups(\n            foundLogGroupsResult.env,\n            foundLogGroupsResult.sdk,\n            foundLogGroupsResult.logGroupNames,\n          );\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5031.msg(`The following log groups are added: ${foundLogGroupsResult.logGroupNames}`));\n        }\n\n        // If an outputs file has been specified, create the file path and write stack outputs to it once.\n        // Outputs are written after all stacks have been deployed. If a stack deployment fails,\n        // all of the outputs from successfully deployed stacks before the failure will still be written.\n        if (outputsFile) {\n          fs.ensureFileSync(outputsFile);\n          await fs.writeJson(outputsFile, stackOutputs, {\n            spaces: 2,\n            encoding: 'utf8',\n          });\n        }\n      }\n      const duration = synthDuration.asMs + (deployDuration?.asMs ?? 0);\n      await deploySpan.end(`\\n✨  Total time: ${formatTime(duration)}s\\n`, { duration });\n    };\n\n    const assetBuildTime = options.assetBuildTime ?? AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const prebuildAssets = assetBuildTime === AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const concurrency = options.concurrency || 1;\n\n    const stacksAndTheirAssetManifests = stacks.flatMap((stack) => [\n      stack,\n      ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),\n    ]);\n    const workGraph = new WorkGraphBuilder(ioHelper, prebuildAssets).build(stacksAndTheirAssetManifests);\n\n    // Unless we are running with '--force', skip already published assets\n    if (!options.force) {\n      await removePublishedAssets(workGraph, deployments, options);\n    }\n\n    const graphConcurrency: Concurrency = {\n      'stack': concurrency,\n      'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds\n      'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable\n    };\n\n    await workGraph.doParallel(graphConcurrency, {\n      deployStack,\n      buildAsset,\n      publishAsset,\n    });\n  }\n\n  /**\n   * Watch Action\n   *\n   * Continuously observe project files and deploy the selected stacks automatically when changes are detected.\n   * Implies hotswap deployments.\n   */\n  public async watch(cx: ICloudAssemblySource, options: WatchOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    const assembly = await assemblyFromSource(ioHelper, cx, false);\n    const rootDir = options.watchDir ?? process.cwd();\n\n    if (options.include === undefined && options.exclude === undefined) {\n      throw new ToolkitError(\n        \"Cannot use the 'watch' command without specifying at least one directory to monitor. \" +\n          'Make sure to add a \"watch\" key to your cdk.json',\n      );\n    }\n\n    // For the \"include\" subkey under the \"watch\" key, the behavior is:\n    // 1. No \"watch\" setting? We error out.\n    // 2. \"watch\" setting without an \"include\" key? We default to observing \"./**\".\n    // 3. \"watch\" setting with an empty \"include\" key? We default to observing \"./**\".\n    // 4. Non-empty \"include\" key? Just use the \"include\" key.\n    const watchIncludes = patternsArrayForWatch(options.include, {\n      rootDir,\n      returnRootDirIfEmpty: true,\n    });\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outdir = options.outdir ?? 'cdk.out';\n    const watchExcludes = patternsArrayForWatch(options.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    }).concat(`${outdir}/**`, '**/.*', '**/.*/**', '**/node_modules/**');\n\n    // Print some debug information on computed settings\n    await ioHelper.notify(IO.CDK_TOOLKIT_I5310.msg([\n      `root directory used for 'watch' is: ${rootDir}`,\n      `'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`,\n      `'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`,\n    ].join('\\n'), {\n      watchDir: rootDir,\n      includes: watchIncludes,\n      excludes: watchExcludes,\n    }));\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    type LatchState = 'pre-ready' | 'open' | 'deploying' | 'queued';\n    let latch: LatchState = 'pre-ready';\n\n    const cloudWatchLogMonitor = options.traceLogs ? new CloudWatchLogEventMonitor({ ioHelper }) : undefined;\n    const deployAndWatch = async () => {\n      latch = 'deploying' as LatchState;\n      await cloudWatchLogMonitor?.deactivate();\n\n      await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while (latch === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5315.msg(\"Detected file changes during deployment. Invoking 'cdk deploy' again\"));\n        await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n      }\n      latch = 'open';\n      await cloudWatchLogMonitor?.activate();\n    };\n\n    chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_DEBUG.msg(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\"));\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5314.msg(\"Triggering initial 'cdk deploy'\"));\n        await deployAndWatch();\n      })\n      .on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath: string) => {\n        const watchEvent = {\n          event,\n          path: filePath,\n        };\n        if (latch === 'pre-ready') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5311.msg(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`, watchEvent));\n        } else if (latch === 'open') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5312.msg(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`, watchEvent));\n          await deployAndWatch();\n        } else {\n          // this means latch is either 'deploying' or 'queued'\n          latch = 'queued';\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5313.msg(\n            `Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`,\n            watchEvent,\n          ));\n        }\n      });\n  }\n\n  /**\n   * Rollback Action\n   *\n   * Rolls back the selected stacks.\n   */\n  public async rollback(cx: ICloudAssemblySource, options: RollbackOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'rollback');\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    return this._rollback(assembly, 'rollback', options);\n  }\n\n  /**\n   * Helper to allow rollback being called as part of the deploy or watch action.\n   */\n  private async _rollback(assembly: StackAssembly, action: 'rollback' | 'deploy' | 'watch', options: RollbackOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    const stacks = await assembly.selectStacksV2(options.stacks);\n    await this.validateStacksMetadata(stacks, ioHelper);\n    await synthSpan.end();\n\n    if (stacks.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E6001.msg('No stacks selected'));\n      return;\n    }\n\n    let anyRollbackable = false;\n\n    for (const [index, stack] of stacks.stackArtifacts.entries()) {\n      const rollbackSpan = await ioHelper.span(SPAN.ROLLBACK_STACK).begin(`Rolling back ${chalk.bold(stack.displayName)}`, {\n        total: stacks.stackCount,\n        current: index + 1,\n        stack,\n      });\n      const deployments = await this.deploymentsForAction('rollback');\n      try {\n        const stackResult = await deployments.rollbackStack({\n          stack,\n          roleArn: options.roleArn,\n          toolkitStackName: this.toolkitStackName,\n          force: options.orphanFailedResources,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!stackResult.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        await rollbackSpan.end();\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E6900.msg(`\\n ❌  ${chalk.bold(stack.displayName)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw new ToolkitError('Rollback failed (use --force to orphan failing resources)');\n      }\n    }\n    if (!anyRollbackable) {\n      throw new ToolkitError('No stacks were in a state that could be rolled back');\n    }\n  }\n\n  /**\n   * Destroy Action\n   *\n   * Destroys the selected Stacks.\n   */\n  public async destroy(cx: ICloudAssemblySource, options: DestroyOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'destroy');\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    return this._destroy(assembly, 'destroy', options);\n  }\n\n  /**\n   * Helper to allow destroy being called as part of the deploy action.\n   */\n  private async _destroy(assembly: StackAssembly, action: 'deploy' | 'destroy', options: DestroyOptions): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    const stacks = (await assembly.selectStacksV2(options.stacks)).reversed();\n    await synthSpan.end();\n\n    const motivation = 'Destroying stacks is an irreversible action';\n    const question = `Are you sure you want to delete: ${chalk.red(stacks.hierarchicalIds.join(', '))}`;\n    const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I7010.req(question, { motivation }));\n    if (!confirmed) {\n      return ioHelper.notify(IO.CDK_TOOLKIT_E7010.msg('Aborted by user'));\n    }\n\n    const destroySpan = await ioHelper.span(SPAN.DESTROY_ACTION).begin({\n      stacks: stacks.stackArtifacts,\n    });\n    try {\n      for (const [index, stack] of stacks.stackArtifacts.entries()) {\n        try {\n          const singleDestroySpan = await ioHelper.span(SPAN.DESTROY_STACK)\n            .begin(chalk.green(`${chalk.blue(stack.displayName)}: destroying... [${index + 1}/${stacks.stackCount}]`), {\n              total: stacks.stackCount,\n              current: index + 1,\n              stack,\n            });\n          const deployments = await this.deploymentsForAction(action);\n          await deployments.destroyStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n          });\n          await ioHelper.notify(IO.CDK_TOOLKIT_I7900.msg(chalk.green(`\\n ✅  ${chalk.blue(stack.displayName)}: ${action}ed`), stack));\n          await singleDestroySpan.end();\n        } catch (e: any) {\n          await ioHelper.notify(IO.CDK_TOOLKIT_E7900.msg(`\\n ❌  ${chalk.blue(stack.displayName)}: ${action} failed ${e}`, { error: e }));\n          throw e;\n        }\n      }\n    } finally {\n      await destroySpan.end();\n    }\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private async validateStacksMetadata(stacks: StackCollection, ioHost: IoHelper) {\n    const builder = (level: IoMessageLevel) => {\n      switch (level) {\n        case 'error': return IO.CDK_ASSEMBLY_E9999;\n        case 'warn': return IO.CDK_ASSEMBLY_W9999;\n        default: return IO.CDK_ASSEMBLY_I9999;\n      }\n    };\n    await stacks.validateMetadata(\n      this.props.assemblyFailureAt,\n      async (level, msg) => ioHost.notify(builder(level).msg(`[${level} at ${msg.id}] ${msg.entry.data}`, msg)),\n    );\n  }\n\n  /**\n   * Create a deployments class\n   */\n  private async deploymentsForAction(action: ToolkitAction): Promise<Deployments> {\n    return new Deployments({\n      sdkProvider: await this.sdkProvider(action),\n      toolkitStackName: this.toolkitStackName,\n      ioHelper: asIoHelper(this.ioHost, action),\n    });\n  }\n\n  private async invokeDeployFromWatch(\n    assembly: StackAssembly,\n    options: WatchOptions,\n    cloudWatchLogMonitor?: CloudWatchLogEventMonitor,\n  ): Promise<void> {\n    // watch defaults hotswap to enabled\n    const hotswap = options.hotswap ?? HotswapMode.HOTSWAP_ONLY;\n    const deployOptions: ExtendedDeployOptions = {\n      ...options,\n      requireApproval: RequireApproval.NEVER,\n      cloudWatchLogMonitor,\n      hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${hotswap === HotswapMode.FULL_DEPLOYMENT ? 'off' : 'on'}`,\n    };\n\n    try {\n      await this._deploy(assembly, 'watch', deployOptions);\n    } catch {\n      // just continue - deploy will show the error\n    }\n  }\n}\n"]}