@aws-cdk/toolkit-lib 0.2.0 → 0.3.1
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.
- package/build-info.json +2 -2
- package/lib/actions/bootstrap/index.js +69 -5
- package/lib/actions/diff/index.d.ts +8 -0
- package/lib/actions/diff/index.js +1 -1
- package/lib/actions/diff/private/helpers.d.ts +16 -0
- package/lib/actions/diff/private/helpers.js +31 -6
- package/lib/actions/index.d.ts +1 -0
- package/lib/actions/index.js +2 -1
- package/lib/actions/refactor/index.d.ts +15 -0
- package/lib/actions/refactor/index.js +3 -0
- package/lib/api/cloud-assembly/cached-source.d.ts +37 -0
- package/lib/api/cloud-assembly/cached-source.js +53 -0
- package/lib/api/cloud-assembly/index.d.ts +1 -0
- package/lib/api/cloud-assembly/index.js +2 -1
- package/lib/api/cloud-assembly/private/borrowed-assembly.d.ts +15 -0
- package/lib/api/cloud-assembly/private/borrowed-assembly.js +23 -0
- package/lib/api/cloud-assembly/private/context-aware-source.d.ts +18 -5
- package/lib/api/cloud-assembly/private/context-aware-source.js +25 -8
- package/lib/api/cloud-assembly/private/index.d.ts +0 -2
- package/lib/api/cloud-assembly/private/index.js +1 -3
- package/lib/api/cloud-assembly/private/prepare-source.d.ts +38 -8
- package/lib/api/cloud-assembly/private/prepare-source.js +77 -17
- package/lib/api/cloud-assembly/private/readable-assembly.d.ts +26 -0
- package/lib/api/cloud-assembly/private/readable-assembly.js +34 -0
- package/lib/api/cloud-assembly/private/source-builder.d.ts +27 -0
- package/lib/api/cloud-assembly/private/source-builder.js +139 -30
- package/lib/api/cloud-assembly/private/stack-assembly.d.ts +10 -4
- package/lib/api/cloud-assembly/private/stack-assembly.js +18 -3
- package/lib/api/cloud-assembly/source-builder.d.ts +6 -0
- package/lib/api/cloud-assembly/source-builder.js +1 -1
- package/lib/api/cloud-assembly/types.d.ts +32 -1
- package/lib/api/cloud-assembly/types.js +1 -1
- package/lib/api/shared-private.js +373 -20
- package/lib/api/shared-private.js.map +4 -4
- package/lib/api/shared-public.d.ts +82 -61
- package/lib/index_bg.wasm +0 -0
- package/lib/toolkit/private/index.d.ts +4 -0
- package/lib/toolkit/private/index.js +7 -2
- package/lib/toolkit/toolkit.d.ts +16 -2
- package/lib/toolkit/toolkit.js +327 -162
- package/package.json +11 -11
- package/lib/api/cloud-assembly/private/cached-source.d.ts +0 -15
- package/lib/api/cloud-assembly/private/cached-source.js +0 -25
- package/lib/api/cloud-assembly/private/identity-source.d.ts +0 -10
- package/lib/api/cloud-assembly/private/identity-source.js +0 -17
package/lib/toolkit/toolkit.js
CHANGED
|
@@ -1,6 +1,59 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __addDisposableResource = (this && this.__addDisposableResource) || function (env, value, async) {
|
|
3
|
+
if (value !== null && value !== void 0) {
|
|
4
|
+
if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
|
|
5
|
+
var dispose, inner;
|
|
6
|
+
if (async) {
|
|
7
|
+
if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
|
|
8
|
+
dispose = value[Symbol.asyncDispose];
|
|
9
|
+
}
|
|
10
|
+
if (dispose === void 0) {
|
|
11
|
+
if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
|
|
12
|
+
dispose = value[Symbol.dispose];
|
|
13
|
+
if (async) inner = dispose;
|
|
14
|
+
}
|
|
15
|
+
if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
|
|
16
|
+
if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };
|
|
17
|
+
env.stack.push({ value: value, dispose: dispose, async: async });
|
|
18
|
+
}
|
|
19
|
+
else if (async) {
|
|
20
|
+
env.stack.push({ async: true });
|
|
21
|
+
}
|
|
22
|
+
return value;
|
|
23
|
+
};
|
|
24
|
+
var __disposeResources = (this && this.__disposeResources) || (function (SuppressedError) {
|
|
25
|
+
return function (env) {
|
|
26
|
+
function fail(e) {
|
|
27
|
+
env.error = env.hasError ? new SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
|
|
28
|
+
env.hasError = true;
|
|
29
|
+
}
|
|
30
|
+
var r, s = 0;
|
|
31
|
+
function next() {
|
|
32
|
+
while (r = env.stack.pop()) {
|
|
33
|
+
try {
|
|
34
|
+
if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);
|
|
35
|
+
if (r.dispose) {
|
|
36
|
+
var result = r.dispose.call(r.value);
|
|
37
|
+
if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
|
|
38
|
+
}
|
|
39
|
+
else s |= 1;
|
|
40
|
+
}
|
|
41
|
+
catch (e) {
|
|
42
|
+
fail(e);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();
|
|
46
|
+
if (env.hasError) throw env.error;
|
|
47
|
+
}
|
|
48
|
+
return next();
|
|
49
|
+
};
|
|
50
|
+
})(typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
|
|
51
|
+
var e = new Error(message);
|
|
52
|
+
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
53
|
+
});
|
|
2
54
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
55
|
exports.Toolkit = void 0;
|
|
56
|
+
require("../private/dispose-polyfill");
|
|
4
57
|
const path = require("node:path");
|
|
5
58
|
const cxapi = require("@aws-cdk/cx-api");
|
|
6
59
|
const chalk = require("chalk");
|
|
@@ -131,11 +184,15 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
|
|
|
131
184
|
}
|
|
132
185
|
/**
|
|
133
186
|
* Synth Action
|
|
187
|
+
*
|
|
188
|
+
* The caller assumes ownership of the `CachedCloudAssembly` and is responsible for calling `dispose()` on
|
|
189
|
+
* it after use.
|
|
134
190
|
*/
|
|
135
191
|
async synth(cx, options = {}) {
|
|
136
192
|
const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'synth');
|
|
137
193
|
const selectStacks = options.stacks ?? private_5.ALL_STACKS;
|
|
138
194
|
const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
|
|
195
|
+
// NOTE: NOT 'await using' because we return ownership to the caller
|
|
139
196
|
const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
|
|
140
197
|
const stacks = await assembly.selectStacksV2(selectStacks);
|
|
141
198
|
const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];
|
|
@@ -168,52 +225,66 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
|
|
|
168
225
|
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I1902.msg(chalk.green(message), assemblyData));
|
|
169
226
|
await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_INFO.msg(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));
|
|
170
227
|
}
|
|
171
|
-
return new
|
|
228
|
+
return new cloud_assembly_1.CachedCloudAssembly(assembly);
|
|
172
229
|
}
|
|
173
230
|
/**
|
|
174
231
|
* Diff Action
|
|
175
232
|
*/
|
|
176
233
|
async diff(cx, options) {
|
|
177
|
-
const
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
const
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
requireApproval: shared_private_1.RequireApproval.BROADENING,
|
|
199
|
-
});
|
|
200
|
-
formattedSecurityDiff = securityDiff.formattedDiff ?? '';
|
|
201
|
-
diffs = securityDiff.formattedDiff ? diffs + 1 : diffs;
|
|
202
|
-
}
|
|
203
|
-
else {
|
|
204
|
-
const diff = formatter.formatStackDiff({
|
|
205
|
-
strict,
|
|
206
|
-
context: contextLines,
|
|
234
|
+
const env_1 = { stack: [], error: void 0, hasError: false };
|
|
235
|
+
try {
|
|
236
|
+
const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'diff');
|
|
237
|
+
const selectStacks = options.stacks ?? private_5.ALL_STACKS;
|
|
238
|
+
const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
|
|
239
|
+
const assembly = __addDisposableResource(env_1, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
|
|
240
|
+
const stacks = await assembly.selectStacksV2(selectStacks);
|
|
241
|
+
await synthSpan.end();
|
|
242
|
+
const diffSpan = await ioHelper.span(private_6.SPAN.DIFF_STACK).begin({ stacks: selectStacks });
|
|
243
|
+
const deployments = await this.deploymentsForAction('diff');
|
|
244
|
+
const strict = !!options.strict;
|
|
245
|
+
const contextLines = options.contextLines || 3;
|
|
246
|
+
let diffs = 0;
|
|
247
|
+
let formattedSecurityDiff = '';
|
|
248
|
+
let formattedStackDiff = '';
|
|
249
|
+
const templateInfos = await (0, private_3.makeTemplateInfos)(ioHelper, stacks, deployments, await this.sdkProvider('diff'), options);
|
|
250
|
+
const templateDiffs = {};
|
|
251
|
+
for (const templateInfo of templateInfos) {
|
|
252
|
+
const formatter = new shared_private_1.DiffFormatter({
|
|
253
|
+
ioHelper,
|
|
254
|
+
templateInfo,
|
|
207
255
|
});
|
|
208
|
-
|
|
209
|
-
|
|
256
|
+
if (options.securityOnly) {
|
|
257
|
+
const securityDiff = formatter.formatSecurityDiff({
|
|
258
|
+
requireApproval: shared_private_1.RequireApproval.BROADENING,
|
|
259
|
+
});
|
|
260
|
+
formattedSecurityDiff = securityDiff.formattedDiff ?? '';
|
|
261
|
+
diffs = securityDiff.formattedDiff ? diffs + 1 : diffs;
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
const diff = formatter.formatStackDiff({
|
|
265
|
+
strict,
|
|
266
|
+
context: contextLines,
|
|
267
|
+
});
|
|
268
|
+
formattedStackDiff = diff.formattedDiff;
|
|
269
|
+
diffs = diff.numStacksWithChanges;
|
|
270
|
+
}
|
|
271
|
+
(0, private_3.appendObject)(templateDiffs, formatter.diffs);
|
|
210
272
|
}
|
|
273
|
+
await diffSpan.end(`✨ Number of stacks with differences: ${diffs}`, {
|
|
274
|
+
formattedSecurityDiff,
|
|
275
|
+
formattedStackDiff,
|
|
276
|
+
});
|
|
277
|
+
return templateDiffs;
|
|
278
|
+
}
|
|
279
|
+
catch (e_1) {
|
|
280
|
+
env_1.error = e_1;
|
|
281
|
+
env_1.hasError = true;
|
|
282
|
+
}
|
|
283
|
+
finally {
|
|
284
|
+
const result_1 = __disposeResources(env_1);
|
|
285
|
+
if (result_1)
|
|
286
|
+
await result_1;
|
|
211
287
|
}
|
|
212
|
-
await diffSpan.end(`✨ Number of stacks with differences: ${diffs}`, {
|
|
213
|
-
formattedSecurityDiff,
|
|
214
|
-
formattedStackDiff,
|
|
215
|
-
});
|
|
216
|
-
return;
|
|
217
288
|
}
|
|
218
289
|
/**
|
|
219
290
|
* List Action
|
|
@@ -221,16 +292,28 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
|
|
|
221
292
|
* List selected stacks and their dependencies
|
|
222
293
|
*/
|
|
223
294
|
async list(cx, options = {}) {
|
|
224
|
-
const
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
295
|
+
const env_2 = { stack: [], error: void 0, hasError: false };
|
|
296
|
+
try {
|
|
297
|
+
const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'list');
|
|
298
|
+
const selectStacks = options.stacks ?? private_5.ALL_STACKS;
|
|
299
|
+
const synthSpan = await ioHelper.span(private_6.SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });
|
|
300
|
+
const assembly = __addDisposableResource(env_2, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
|
|
301
|
+
const stackCollection = await assembly.selectStacksV2(selectStacks);
|
|
302
|
+
await synthSpan.end();
|
|
303
|
+
const stacks = stackCollection.withDependencies();
|
|
304
|
+
const message = stacks.map(s => s.id).join('\n');
|
|
305
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I2901.msg(message, { stacks }));
|
|
306
|
+
return stacks;
|
|
307
|
+
}
|
|
308
|
+
catch (e_2) {
|
|
309
|
+
env_2.error = e_2;
|
|
310
|
+
env_2.hasError = true;
|
|
311
|
+
}
|
|
312
|
+
finally {
|
|
313
|
+
const result_2 = __disposeResources(env_2);
|
|
314
|
+
if (result_2)
|
|
315
|
+
await result_2;
|
|
316
|
+
}
|
|
234
317
|
}
|
|
235
318
|
/**
|
|
236
319
|
* Deploy Action
|
|
@@ -238,9 +321,21 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
|
|
|
238
321
|
* Deploys the selected stacks into an AWS account
|
|
239
322
|
*/
|
|
240
323
|
async deploy(cx, options = {}) {
|
|
241
|
-
const
|
|
242
|
-
|
|
243
|
-
|
|
324
|
+
const env_3 = { stack: [], error: void 0, hasError: false };
|
|
325
|
+
try {
|
|
326
|
+
const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'deploy');
|
|
327
|
+
const assembly = __addDisposableResource(env_3, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
|
|
328
|
+
return await this._deploy(assembly, 'deploy', options);
|
|
329
|
+
}
|
|
330
|
+
catch (e_3) {
|
|
331
|
+
env_3.error = e_3;
|
|
332
|
+
env_3.hasError = true;
|
|
333
|
+
}
|
|
334
|
+
finally {
|
|
335
|
+
const result_3 = __disposeResources(env_3);
|
|
336
|
+
if (result_3)
|
|
337
|
+
await result_3;
|
|
338
|
+
}
|
|
244
339
|
}
|
|
245
340
|
/**
|
|
246
341
|
* Helper to allow deploy being called as part of the watch action.
|
|
@@ -511,114 +606,126 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
|
|
|
511
606
|
* This function returns immediately, starting a watcher in the background.
|
|
512
607
|
*/
|
|
513
608
|
async watch(cx, options) {
|
|
514
|
-
const
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);
|
|
563
|
-
// If latch is still 'deploying' after the 'await', that's fine,
|
|
564
|
-
// but if it's 'queued', that means we need to deploy again
|
|
565
|
-
while (latch === 'queued') {
|
|
566
|
-
// TypeScript doesn't realize latch can change between 'awaits',
|
|
567
|
-
// and thinks the above 'while' condition is always 'false' without the cast
|
|
609
|
+
const env_4 = { stack: [], error: void 0, hasError: false };
|
|
610
|
+
try {
|
|
611
|
+
const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'watch');
|
|
612
|
+
const assembly = __addDisposableResource(env_4, await (0, private_1.assemblyFromSource)(ioHelper, cx, false), true);
|
|
613
|
+
const rootDir = options.watchDir ?? process.cwd();
|
|
614
|
+
if (options.include === undefined && options.exclude === undefined) {
|
|
615
|
+
throw new shared_private_1.ToolkitError("Cannot use the 'watch' command without specifying at least one directory to monitor. " +
|
|
616
|
+
'Make sure to add a "watch" key to your cdk.json');
|
|
617
|
+
}
|
|
618
|
+
// For the "include" subkey under the "watch" key, the behavior is:
|
|
619
|
+
// 1. No "watch" setting? We error out.
|
|
620
|
+
// 2. "watch" setting without an "include" key? We default to observing "./**".
|
|
621
|
+
// 3. "watch" setting with an empty "include" key? We default to observing "./**".
|
|
622
|
+
// 4. Non-empty "include" key? Just use the "include" key.
|
|
623
|
+
const watchIncludes = (0, private_4.patternsArrayForWatch)(options.include, {
|
|
624
|
+
rootDir,
|
|
625
|
+
returnRootDirIfEmpty: true,
|
|
626
|
+
});
|
|
627
|
+
// For the "exclude" subkey under the "watch" key,
|
|
628
|
+
// the behavior is to add some default excludes in addition to the ones specified by the user:
|
|
629
|
+
// 1. The CDK output directory.
|
|
630
|
+
// 2. Any file whose name starts with a dot.
|
|
631
|
+
// 3. Any directory's content whose name starts with a dot.
|
|
632
|
+
// 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)
|
|
633
|
+
const outdir = assembly.directory;
|
|
634
|
+
const watchExcludes = (0, private_4.patternsArrayForWatch)(options.exclude, {
|
|
635
|
+
rootDir,
|
|
636
|
+
returnRootDirIfEmpty: false,
|
|
637
|
+
});
|
|
638
|
+
// only exclude the outdir if it is under the rootDir
|
|
639
|
+
const relativeOutDir = path.relative(rootDir, outdir);
|
|
640
|
+
if (Boolean(relativeOutDir && !relativeOutDir.startsWith('..' + path.sep) && !path.isAbsolute(relativeOutDir))) {
|
|
641
|
+
watchExcludes.push(`${relativeOutDir}/**`);
|
|
642
|
+
}
|
|
643
|
+
watchExcludes.push('**/.*', '**/.*/**', '**/node_modules/**');
|
|
644
|
+
// Print some debug information on computed settings
|
|
645
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5310.msg([
|
|
646
|
+
`root directory used for 'watch' is: ${rootDir}`,
|
|
647
|
+
`'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`,
|
|
648
|
+
`'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`,
|
|
649
|
+
].join('\n'), {
|
|
650
|
+
watchDir: rootDir,
|
|
651
|
+
includes: watchIncludes,
|
|
652
|
+
excludes: watchExcludes,
|
|
653
|
+
}));
|
|
654
|
+
let latch = 'pre-ready';
|
|
655
|
+
const cloudWatchLogMonitor = options.traceLogs ? new shared_private_1.CloudWatchLogEventMonitor({ ioHelper }) : undefined;
|
|
656
|
+
const deployAndWatch = async () => {
|
|
568
657
|
latch = 'deploying';
|
|
569
|
-
await
|
|
658
|
+
await cloudWatchLogMonitor?.deactivate();
|
|
570
659
|
await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_DEBUG.msg("'watch' received the 'ready' event. From now on, all file changes will trigger a deployment"));
|
|
583
|
-
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5314.msg("Triggering initial 'cdk deploy'"));
|
|
584
|
-
await deployAndWatch();
|
|
585
|
-
})
|
|
586
|
-
.on('all', async (event, filePath) => {
|
|
587
|
-
const watchEvent = {
|
|
588
|
-
event,
|
|
589
|
-
path: filePath,
|
|
660
|
+
// If latch is still 'deploying' after the 'await', that's fine,
|
|
661
|
+
// but if it's 'queued', that means we need to deploy again
|
|
662
|
+
while (latch === 'queued') {
|
|
663
|
+
// TypeScript doesn't realize latch can change between 'awaits',
|
|
664
|
+
// and thinks the above 'while' condition is always 'false' without the cast
|
|
665
|
+
latch = 'deploying';
|
|
666
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5315.msg("Detected file changes during deployment. Invoking 'cdk deploy' again"));
|
|
667
|
+
await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);
|
|
668
|
+
}
|
|
669
|
+
latch = 'open';
|
|
670
|
+
await cloudWatchLogMonitor?.activate();
|
|
590
671
|
};
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
672
|
+
const watcher = chokidar
|
|
673
|
+
.watch(watchIncludes, {
|
|
674
|
+
ignored: watchExcludes,
|
|
675
|
+
cwd: rootDir,
|
|
676
|
+
})
|
|
677
|
+
.on('ready', async () => {
|
|
678
|
+
latch = 'open';
|
|
679
|
+
await ioHelper.notify(private_6.IO.DEFAULT_TOOLKIT_DEBUG.msg("'watch' received the 'ready' event. From now on, all file changes will trigger a deployment"));
|
|
680
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5314.msg("Triggering initial 'cdk deploy'"));
|
|
596
681
|
await deployAndWatch();
|
|
597
|
-
}
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
682
|
+
})
|
|
683
|
+
.on('all', async (event, filePath) => {
|
|
684
|
+
const watchEvent = {
|
|
685
|
+
event,
|
|
686
|
+
path: filePath,
|
|
687
|
+
};
|
|
688
|
+
if (latch === 'pre-ready') {
|
|
689
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5311.msg(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`, watchEvent));
|
|
690
|
+
}
|
|
691
|
+
else if (latch === 'open') {
|
|
692
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5312.msg(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`, watchEvent));
|
|
693
|
+
await deployAndWatch();
|
|
694
|
+
}
|
|
695
|
+
else {
|
|
696
|
+
// this means latch is either 'deploying' or 'queued'
|
|
697
|
+
latch = 'queued';
|
|
698
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I5313.msg(`Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`, watchEvent));
|
|
699
|
+
}
|
|
700
|
+
});
|
|
701
|
+
const stoppedPromise = (0, promises_1.promiseWithResolvers)();
|
|
702
|
+
return {
|
|
703
|
+
async dispose() {
|
|
704
|
+
await watcher.close();
|
|
705
|
+
// Prevents Node from staying alive. There is no 'end' event that the watcher emits
|
|
706
|
+
// that we can know it's definitely done, so best we can do is tell it to stop watching,
|
|
707
|
+
// stop keeping Node alive, and then pretend that's everything we needed to do.
|
|
708
|
+
watcher.unref();
|
|
709
|
+
stoppedPromise.resolve();
|
|
710
|
+
return stoppedPromise.promise;
|
|
711
|
+
},
|
|
712
|
+
async waitForEnd() {
|
|
713
|
+
return stoppedPromise.promise;
|
|
714
|
+
},
|
|
715
|
+
async [Symbol.asyncDispose]() {
|
|
716
|
+
return this.dispose();
|
|
717
|
+
},
|
|
718
|
+
};
|
|
719
|
+
}
|
|
720
|
+
catch (e_4) {
|
|
721
|
+
env_4.error = e_4;
|
|
722
|
+
env_4.hasError = true;
|
|
723
|
+
}
|
|
724
|
+
finally {
|
|
725
|
+
const result_4 = __disposeResources(env_4);
|
|
726
|
+
if (result_4)
|
|
727
|
+
await result_4;
|
|
728
|
+
}
|
|
622
729
|
}
|
|
623
730
|
/**
|
|
624
731
|
* Rollback Action
|
|
@@ -626,9 +733,21 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
|
|
|
626
733
|
* Rolls back the selected stacks.
|
|
627
734
|
*/
|
|
628
735
|
async rollback(cx, options) {
|
|
629
|
-
const
|
|
630
|
-
|
|
631
|
-
|
|
736
|
+
const env_5 = { stack: [], error: void 0, hasError: false };
|
|
737
|
+
try {
|
|
738
|
+
const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'rollback');
|
|
739
|
+
const assembly = __addDisposableResource(env_5, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
|
|
740
|
+
return await this._rollback(assembly, 'rollback', options);
|
|
741
|
+
}
|
|
742
|
+
catch (e_5) {
|
|
743
|
+
env_5.error = e_5;
|
|
744
|
+
env_5.hasError = true;
|
|
745
|
+
}
|
|
746
|
+
finally {
|
|
747
|
+
const result_5 = __disposeResources(env_5);
|
|
748
|
+
if (result_5)
|
|
749
|
+
await result_5;
|
|
750
|
+
}
|
|
632
751
|
}
|
|
633
752
|
/**
|
|
634
753
|
* Helper to allow rollback being called as part of the deploy or watch action.
|
|
@@ -687,15 +806,61 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
|
|
|
687
806
|
}
|
|
688
807
|
return ret;
|
|
689
808
|
}
|
|
809
|
+
/**
|
|
810
|
+
* Refactor Action. Moves resources from one location (stack + logical ID) to another.
|
|
811
|
+
*/
|
|
812
|
+
async refactor(cx, options = {}) {
|
|
813
|
+
const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'refactor');
|
|
814
|
+
const assembly = await (0, private_1.assemblyFromSource)(ioHelper, cx);
|
|
815
|
+
return this._refactor(assembly, ioHelper, options);
|
|
816
|
+
}
|
|
817
|
+
async _refactor(assembly, ioHelper, options = {}) {
|
|
818
|
+
if (!options.dryRun) {
|
|
819
|
+
throw new shared_private_1.ToolkitError('Refactor is not available yet. Too see the proposed changes, use the --dry-run flag.');
|
|
820
|
+
}
|
|
821
|
+
const strategy = options.stacks?.strategy ?? cloud_assembly_1.StackSelectionStrategy.ALL_STACKS;
|
|
822
|
+
if (strategy !== cloud_assembly_1.StackSelectionStrategy.ALL_STACKS) {
|
|
823
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_W8010.msg('Refactor does not yet support stack selection. Proceeding with the default behavior (considering all stacks).'));
|
|
824
|
+
}
|
|
825
|
+
const stacks = await assembly.selectStacksV2(private_5.ALL_STACKS);
|
|
826
|
+
const sdkProvider = await this.sdkProvider('refactor');
|
|
827
|
+
const movements = await (0, shared_private_1.findResourceMovements)(stacks.stackArtifacts, sdkProvider);
|
|
828
|
+
const ambiguous = (0, shared_private_1.ambiguousMovements)(movements);
|
|
829
|
+
if (ambiguous.length === 0) {
|
|
830
|
+
const typedMappings = (0, shared_private_1.resourceMappings)(movements).map(m => m.toTypedMapping());
|
|
831
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I8900.msg((0, shared_private_1.formatTypedMappings)(typedMappings), {
|
|
832
|
+
typedMappings,
|
|
833
|
+
}));
|
|
834
|
+
}
|
|
835
|
+
else {
|
|
836
|
+
const error = new shared_private_1.AmbiguityError(ambiguous);
|
|
837
|
+
const paths = error.paths();
|
|
838
|
+
await ioHelper.notify(private_6.IO.CDK_TOOLKIT_I8900.msg((0, shared_private_1.formatAmbiguousMappings)(paths), {
|
|
839
|
+
ambiguousPaths: paths,
|
|
840
|
+
}));
|
|
841
|
+
}
|
|
842
|
+
}
|
|
690
843
|
/**
|
|
691
844
|
* Destroy Action
|
|
692
845
|
*
|
|
693
846
|
* Destroys the selected Stacks.
|
|
694
847
|
*/
|
|
695
848
|
async destroy(cx, options) {
|
|
696
|
-
const
|
|
697
|
-
|
|
698
|
-
|
|
849
|
+
const env_6 = { stack: [], error: void 0, hasError: false };
|
|
850
|
+
try {
|
|
851
|
+
const ioHelper = (0, shared_private_1.asIoHelper)(this.ioHost, 'destroy');
|
|
852
|
+
const assembly = __addDisposableResource(env_6, await (0, private_1.assemblyFromSource)(ioHelper, cx), true);
|
|
853
|
+
return await this._destroy(assembly, 'destroy', options);
|
|
854
|
+
}
|
|
855
|
+
catch (e_6) {
|
|
856
|
+
env_6.error = e_6;
|
|
857
|
+
env_6.hasError = true;
|
|
858
|
+
}
|
|
859
|
+
finally {
|
|
860
|
+
const result_6 = __disposeResources(env_6);
|
|
861
|
+
if (result_6)
|
|
862
|
+
await result_6;
|
|
863
|
+
}
|
|
699
864
|
}
|
|
700
865
|
/**
|
|
701
866
|
* Helper to allow destroy being called as part of the deploy action.
|
|
@@ -798,4 +963,4 @@ class Toolkit extends private_5.CloudAssemblySourceBuilder {
|
|
|
798
963
|
}
|
|
799
964
|
}
|
|
800
965
|
exports.Toolkit = Toolkit;
|
|
801
|
-
//# 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 { NonInteractiveIoHost } from './non-interactive-io-host';\nimport type { ToolkitServices } from './private';\nimport { assemblyFromSource } from './private';\nimport type { DeployResult, DestroyResult, RollbackResult } from './types';\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, removePublishedAssetsFromWorkGraph } from '../actions/deploy/private';\nimport { type DestroyOptions } from '../actions/destroy';\nimport type { DiffOptions } from '../actions/diff';\nimport { determinePermissionType, makeTemplateInfos as prepareDiff } 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 { 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 { SuccessfulDeployStackResult, Concurrency, AssetBuildNode, AssetPublishNode, StackNode, IoHelper, StackCollection } from '../api/shared-private';\nimport { CloudWatchLogEventMonitor, findCloudWatchLogGroups, DEFAULT_TOOLKIT_STACK_NAME, Bootstrapper, Deployments, ResourceMigrator, WorkGraphBuilder, HotswapMode, SdkProvider, asIoHelper, DiffFormatter, RequireApproval, ToolkitError, tagsForStack } from '../api/shared-private';\nimport type { ToolkitAction, AssemblyData, StackDetails } from '../api/shared-public';\nimport { obscureTemplate, serializeStructure, validateSnsTopicArn, formatTime, formatErrorMessage } from '../private/util';\nimport { pLimit } from '../util/concurrency';\nimport { promiseWithResolvers } from '../util/promises';\n\nexport interface ToolkitOptions {\n  /**\n   * The IoHost implementation, handling the inline interactions between the Toolkit and an integration.\n   */\n  readonly ioHost?: IIoHost;\n\n  /**\n   * Allow emojis in messages sent to the IoHost.\n   *\n   * @default true\n   */\n  readonly emojis?: boolean;\n\n  /**\n   * Whether to allow ANSI colors and formatting in IoHost messages.\n   * Setting this value to `false` enforces that no color or style shows up\n   * in messages sent to the IoHost.\n   * Setting this value to true is a no-op; it is equivalent to the default.\n   *\n   * @default - detects color from the TTY status of the IoHost\n   */\n  readonly color?: boolean;\n\n  /**\n   * Configuration options for the SDK.\n   */\n  readonly sdkConfig?: SdkConfig;\n\n  /**\n   * Name of the toolkit stack to be used.\n   *\n   * @default \"CDKToolkit\"\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Fail Cloud Assemblies\n   *\n   * @default \"error\"\n   */\n  readonly assemblyFailureAt?: 'error' | 'warn' | 'none';\n}\n\n/**\n * The AWS CDK Programmatic Toolkit\n */\nexport class Toolkit extends CloudAssemblySourceBuilder {\n  /**\n   * The toolkit stack name used for bootstrapping resources.\n   */\n  public readonly toolkitStackName: string;\n\n  /**\n   * The IoHost of this Toolkit\n   */\n  public readonly ioHost: IIoHost;\n\n  /**\n   * Cache of the internal SDK Provider instance\n   */\n  private sdkProviderCache?: SdkProvider;\n\n  public constructor(private readonly props: ToolkitOptions = {}) {\n    super();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n\n    let ioHost = props.ioHost ?? new NonInteractiveIoHost();\n    if (props.emojis === false) {\n      ioHost = withoutEmojis(ioHost);\n    }\n    if (props.color === false) {\n      ioHost = withoutColor(ioHost);\n    }\n    // After removing emojis and color, we might end up with floating whitespace at either end of the message\n    // This also removes newlines that we currently emit for CLI backwards compatibility.\n    this.ioHost = withTrimmedWhitespace(ioHost);\n  }\n\n  /**\n   * Access to the AWS SDK\n   * @internal\n   */\n  protected async sdkProvider(action: ToolkitAction): Promise<SdkProvider> {\n    // @todo this needs to be different instance per action\n    if (!this.sdkProviderCache) {\n      const ioHelper = asIoHelper(this.ioHost, action);\n      this.sdkProviderCache = await SdkProvider.withAwsCliCompatibleDefaults({\n        ...this.props.sdkConfig,\n        ioHelper,\n        logger: asSdkLogger(ioHelper),\n      });\n    }\n\n    return this.sdkProviderCache;\n  }\n\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   * @internal\n   */\n  protected override async sourceBuilderServices(): Promise<ToolkitServices> {\n    return {\n      ioHelper: asIoHelper(this.ioHost, 'assembly'),\n      sdkProvider: await this.sdkProvider('assembly'),\n    };\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\n    let diffs = 0;\n    let formattedSecurityDiff = '';\n    let formattedStackDiff = '';\n\n    const templateInfos = await prepareDiff(ioHelper, stacks, deployments, await this.sdkProvider('diff'), options);\n\n    for (const templateInfo of templateInfos) {\n      const formatter = new DiffFormatter({\n        ioHelper,\n        templateInfo,\n      });\n\n      if (options.securityOnly) {\n        const securityDiff = formatter.formatSecurityDiff({\n          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    }\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<DeployResult> {\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 = {}): Promise<DeployResult> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const stackCollection = await assembly.selectStacksV2(selectStacks);\n    await this.validateStacksMetadata(stackCollection, ioHelper);\n    const synthDuration = await synthSpan.end();\n\n    const ret: DeployResult = {\n      stacks: [],\n    };\n\n    if (stackCollection.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E5001.msg('This app contains no stacks'));\n      return ret;\n    }\n\n    const deployments = await this.deploymentsForAction('deploy');\n    const migrator = new ResourceMigrator({ deployments, ioHelper });\n\n    await migrator.tryMigrateResources(stackCollection, options);\n\n    const parameterMap = buildParameterMap(options.parameters?.parameters);\n\n    const hotswapMode = options.hotswap ?? HotswapMode.FULL_DEPLOYMENT;\n    if (hotswapMode !== HotswapMode.FULL_DEPLOYMENT) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_W5400.msg([\n        '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',\n        '⚠️ They should only be used for development - never use them for your production Stacks!',\n      ].join('\\n')));\n    }\n\n    const stacks = stackCollection.stackArtifacts;\n    const stackOutputs: { [key: string]: any } = {};\n    const outputsFile = options.outputsFile;\n\n    const buildAsset = async (assetNode: AssetBuildNode) => {\n      const buildAssetSpan = await ioHelper.span(SPAN.BUILD_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.buildSingleAsset(\n        assetNode.assetManifestArtifact,\n        assetNode.assetManifest,\n        assetNode.asset,\n        {\n          stack: assetNode.parentStack,\n          roleArn: options.roleArn,\n          stackName: assetNode.parentStack.stackName,\n        },\n      );\n      await buildAssetSpan.end();\n    };\n\n    const publishAsset = async (assetNode: AssetPublishNode) => {\n      const publishAssetSpan = await ioHelper.span(SPAN.PUBLISH_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {\n        stack: assetNode.parentStack,\n        roleArn: options.roleArn,\n        stackName: assetNode.parentStack.stackName,\n        forcePublish: options.forceAssetPublishing,\n      });\n      await publishAssetSpan.end();\n    };\n\n    const deployStack = async (stackNode: StackNode) => {\n      const stack = stackNode.stack;\n      if (stackCollection.stackCount !== 1) {\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(chalk.bold(stack.displayName)));\n      }\n\n      if (!stack.environment) {\n        throw new ToolkitError(\n          `Stack ${stack.displayName} does not define an environment, and AWS credentials could not be obtained from standard locations or no region was configured.`,\n        );\n      }\n\n      // The generated stack has no resources\n      if (Object.keys(stack.template.Resources || {}).length === 0) {\n        // stack is empty and doesn't exist => do nothing\n        const stackExists = await deployments.stackExists({ stack });\n        if (!stackExists) {\n          return ioHelper.notify(IO.CDK_TOOLKIT_W5021.msg(`${chalk.bold(stack.displayName)}: stack has no resources, skipping deployment.`));\n        }\n\n        // stack is empty, but exists => delete\n        await ioHelper.notify(IO.CDK_TOOLKIT_W5022.msg(`${chalk.bold(stack.displayName)}: stack has no resources, deleting existing stack.`));\n        await this._destroy(assembly, 'deploy', {\n          stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n          roleArn: options.roleArn,\n        });\n\n        return;\n      }\n\n      const currentTemplate = await deployments.readCurrentTemplate(stack);\n      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            forceDeployment: options.forceDeployment,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.parameters?.keepExistingParameters,\n            rollback,\n            hotswap: hotswapMode,\n            extraUserAgent: options.extraUserAgent,\n            hotswapPropertyOverrides: options.hotswapProperties ? createHotswapPropertyOverrides(options.hotswapProperties) : undefined,\n            assetParallelism: options.assetParallelism,\n          });\n\n          switch (r.type) {\n            case 'did-deploy-stack':\n              deployResult = r;\n              break;\n\n            case 'failpaused-need-rollback-first': {\n              const motivation = r.reason === 'replacement'\n                ? `Stack is in a paused fail state (${r.status}) and change includes a replacement which cannot be deployed with \"--no-rollback\"`\n                : `Stack is in a paused fail state (${r.status}) and command line arguments do not include \"--no-rollback\"`;\n              const question = `${motivation}. Perform a regular deployment`;\n\n              const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                motivation,\n                concurrency,\n              }));\n              if (!confirmed) {\n                throw new ToolkitError('Aborted by user');\n              }\n\n              // Perform a rollback\n              await this._rollback(assembly, action, {\n                stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n                orphanFailedResources: options.orphanFailedResourcesDuringRollback,\n              });\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            case 'replacement-requires-rollback': {\n              const motivation = 'Change includes a replacement which cannot be deployed with \"--no-rollback\"';\n              const question = `${motivation}. Perform a regular deployment`;\n\n              const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                motivation,\n                concurrency,\n              }));\n              if (!confirmed) {\n                throw new ToolkitError('Aborted by user');\n              }\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            default:\n              throw new ToolkitError(`Unexpected result type from deployStack: ${JSON.stringify(r)}. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose`);\n          }\n        }\n\n        const message = deployResult.noOp\n          ? ` ✅  ${stack.displayName} (no changes)`\n          : ` ✅  ${stack.displayName}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5900.msg(chalk.green('\\n' + message), deployResult));\n        deployDuration = await deploySpan.timing(IO.CDK_TOOLKIT_I5000);\n\n        if (Object.keys(deployResult.outputs).length > 0) {\n          const buffer = ['Outputs:'];\n          stackOutputs[stack.stackName] = deployResult.outputs;\n\n          for (const name of Object.keys(deployResult.outputs).sort()) {\n            const value = deployResult.outputs[name];\n            buffer.push(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);\n          }\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(buffer.join('\\n')));\n        }\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(`Stack ARN:\\n${deployResult.stackArn}`));\n\n        ret.stacks.push({\n          stackName: stack.stackName,\n          environment: {\n            account: stack.environment.account,\n            region: stack.environment.region,\n          },\n          stackArn: deployResult.stackArn,\n          outputs: deployResult.outputs,\n          hierarchicalId: stack.hierarchicalId,\n        });\n      } catch (e: any) {\n        // It has to be exactly this string because an integration test tests for\n        // \"bold(stackname) failed: ResourceNotReady: <error>\"\n        throw new ToolkitError(\n          [`❌  ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), e.message].join(' '),\n        );\n      } finally {\n        if (options.traceLogs) {\n          // deploy calls that originate from watch will come with their own cloudWatchLogMonitor\n          const cloudWatchLogMonitor = options.cloudWatchLogMonitor ?? new CloudWatchLogEventMonitor({ ioHelper });\n          const foundLogGroupsResult = await findCloudWatchLogGroups(await this.sdkProvider('deploy'), ioHelper, stack);\n          cloudWatchLogMonitor.addLogGroups(\n            foundLogGroupsResult.env,\n            foundLogGroupsResult.sdk,\n            foundLogGroupsResult.logGroupNames,\n          );\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5031.msg(`The following log groups are added: ${foundLogGroupsResult.logGroupNames}`));\n        }\n\n        // If an outputs file has been specified, create the file path and write stack outputs to it once.\n        // Outputs are written after all stacks have been deployed. If a stack deployment fails,\n        // all of the outputs from successfully deployed stacks before the failure will still be written.\n        if (outputsFile) {\n          fs.ensureFileSync(outputsFile);\n          await fs.writeJson(outputsFile, stackOutputs, {\n            spaces: 2,\n            encoding: 'utf8',\n          });\n        }\n      }\n      const duration = synthDuration.asMs + (deployDuration?.asMs ?? 0);\n      await deploySpan.end(`\\n✨  Total time: ${formatTime(duration)}s\\n`, { duration });\n    };\n\n    const assetBuildTime = options.assetBuildTime ?? AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const prebuildAssets = assetBuildTime === AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const concurrency = options.concurrency || 1;\n\n    const stacksAndTheirAssetManifests = stacks.flatMap((stack) => [\n      stack,\n      ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),\n    ]);\n    const workGraph = new WorkGraphBuilder(ioHelper, prebuildAssets).build(stacksAndTheirAssetManifests);\n\n    // Unless we are running with '--force', skip already published assets\n    if (!options.forceAssetPublishing) {\n      await removePublishedAssetsFromWorkGraph(workGraph, deployments, options);\n    }\n\n    const graphConcurrency: Concurrency = {\n      'stack': concurrency,\n      'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds\n      'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable\n    };\n\n    await workGraph.doParallel(graphConcurrency, {\n      deployStack,\n      buildAsset,\n      publishAsset,\n    });\n\n    return ret;\n  }\n\n  /**\n   * Watch Action\n   *\n   * Continuously observe project files and deploy the selected stacks\n   * automatically when changes are detected.  Implies hotswap deployments.\n   *\n   * This function returns immediately, starting a watcher in the background.\n   */\n  public async watch(cx: ICloudAssemblySource, options: WatchOptions): Promise<IWatcher> {\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    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 = assembly.directory;\n    const watchExcludes = patternsArrayForWatch(options.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    });\n\n    // only exclude the outdir if it is under the rootDir\n    const relativeOutDir = path.relative(rootDir, outdir);\n    if (Boolean(relativeOutDir && !relativeOutDir.startsWith('..' + path.sep) && !path.isAbsolute(relativeOutDir))) {\n      watchExcludes.push(`${relativeOutDir}/**`);\n    }\n\n    watchExcludes.push('**/.*', '**/.*/**', '**/node_modules/**');\n\n    // Print some debug information on computed settings\n    await ioHelper.notify(IO.CDK_TOOLKIT_I5310.msg([\n      `root directory used for 'watch' is: ${rootDir}`,\n      `'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`,\n      `'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`,\n    ].join('\\n'), {\n      watchDir: rootDir,\n      includes: watchIncludes,\n      excludes: watchExcludes,\n    }));\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    type LatchState = 'pre-ready' | 'open' | 'deploying' | 'queued';\n    let latch: LatchState = 'pre-ready';\n\n    const cloudWatchLogMonitor = options.traceLogs ? new CloudWatchLogEventMonitor({ ioHelper }) : undefined;\n    const deployAndWatch = async () => {\n      latch = 'deploying' as LatchState;\n      await cloudWatchLogMonitor?.deactivate();\n\n      await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while (latch === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5315.msg(\"Detected file changes during deployment. Invoking 'cdk deploy' again\"));\n        await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n      }\n      latch = 'open';\n      await cloudWatchLogMonitor?.activate();\n    };\n\n    const watcher = chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_DEBUG.msg(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\"));\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5314.msg(\"Triggering initial 'cdk deploy'\"));\n        await deployAndWatch();\n      })\n      .on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath: string) => {\n        const watchEvent = {\n          event,\n          path: filePath,\n        };\n        if (latch === 'pre-ready') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5311.msg(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`, watchEvent));\n        } else if (latch === 'open') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5312.msg(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`, watchEvent));\n          await deployAndWatch();\n        } else {\n          // this means latch is either 'deploying' or 'queued'\n          latch = 'queued';\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5313.msg(\n            `Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`,\n            watchEvent,\n          ));\n        }\n      });\n\n    const stoppedPromise = promiseWithResolvers<void>();\n\n    return {\n      async dispose() {\n        await watcher.close();\n        // Prevents Node from staying alive. There is no 'end' event that the watcher emits\n        // that we can know it's definitely done, so best we can do is tell it to stop watching,\n        // stop keeping Node alive, and then pretend that's everything we needed to do.\n        watcher.unref();\n        stoppedPromise.resolve();\n        return stoppedPromise.promise;\n      },\n      async waitForEnd() {\n        return stoppedPromise.promise;\n      },\n      async [Symbol.asyncDispose]() {\n        return this.dispose();\n      },\n    } satisfies IWatcher;\n  }\n\n  /**\n   * Rollback Action\n   *\n   * Rolls back the selected stacks.\n   */\n  public async rollback(cx: ICloudAssemblySource, options: RollbackOptions): Promise<RollbackResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'rollback');\n    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<RollbackResult> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    const stacks = await assembly.selectStacksV2(options.stacks);\n    await this.validateStacksMetadata(stacks, ioHelper);\n    await synthSpan.end();\n\n    const ret: RollbackResult = {\n      stacks: [],\n    };\n\n    if (stacks.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E6001.msg('No stacks selected'));\n      return ret;\n    }\n\n    let anyRollbackable = false;\n\n    for (const [index, stack] of stacks.stackArtifacts.entries()) {\n      const rollbackSpan = await ioHelper.span(SPAN.ROLLBACK_STACK).begin(`Rolling back ${chalk.bold(stack.displayName)}`, {\n        total: stacks.stackCount,\n        current: index + 1,\n        stack,\n      });\n      const deployments = await this.deploymentsForAction('rollback');\n      try {\n        const stackResult = await deployments.rollbackStack({\n          stack,\n          roleArn: options.roleArn,\n          toolkitStackName: this.toolkitStackName,\n          orphanFailedResources: options.orphanFailedResources,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!stackResult.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        await rollbackSpan.end();\n\n        ret.stacks.push({\n          environment: {\n            account: stack.environment.account,\n            region: stack.environment.region,\n          },\n          stackName: stack.stackName,\n          stackArn: stackResult.stackArn,\n          result: stackResult.notInRollbackableState ? 'already-stable' : 'rolled-back',\n        });\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E6900.msg(`\\n ❌  ${chalk.bold(stack.displayName)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw 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    return ret;\n  }\n\n  /**\n   * Destroy Action\n   *\n   * Destroys the selected Stacks.\n   */\n  public async destroy(cx: ICloudAssemblySource, options: DestroyOptions): Promise<DestroyResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'destroy');\n    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<DestroyResult> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    const stacks = (await assembly.selectStacksV2(options.stacks)).reversed();\n    await synthSpan.end();\n\n    const ret: DestroyResult = {\n      stacks: [],\n    };\n\n    const motivation = 'Destroying stacks is an irreversible action';\n    const question = `Are you sure you want to delete: ${chalk.red(stacks.hierarchicalIds.join(', '))}`;\n    const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I7010.req(question, { motivation }));\n    if (!confirmed) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E7010.msg('Aborted by user'));\n      return ret;\n    }\n\n    const destroySpan = await ioHelper.span(SPAN.DESTROY_ACTION).begin({\n      stacks: stacks.stackArtifacts,\n    });\n    try {\n      for (const [index, stack] of stacks.stackArtifacts.entries()) {\n        try {\n          const singleDestroySpan = await ioHelper.span(SPAN.DESTROY_STACK)\n            .begin(chalk.green(`${chalk.blue(stack.displayName)}: destroying... [${index + 1}/${stacks.stackCount}]`), {\n              total: stacks.stackCount,\n              current: index + 1,\n              stack,\n            });\n          const deployments = await this.deploymentsForAction(action);\n          const result = await deployments.destroyStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n          });\n\n          ret.stacks.push({\n            environment: {\n              account: stack.environment.account,\n              region: stack.environment.region,\n            },\n            stackName: stack.stackName,\n            stackArn: result.stackArn,\n            stackExisted: result.stackArn !== undefined,\n          });\n\n          await ioHelper.notify(IO.CDK_TOOLKIT_I7900.msg(chalk.green(`\\n ✅  ${chalk.blue(stack.displayName)}: ${action}ed`), stack));\n          await singleDestroySpan.end();\n        } catch (e: any) {\n          await ioHelper.notify(IO.CDK_TOOLKIT_E7900.msg(`\\n ❌  ${chalk.blue(stack.displayName)}: ${action} failed ${e}`, { error: e }));\n          throw e;\n        }\n      }\n\n      return ret;\n    } finally {\n      await destroySpan.end();\n    }\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private async validateStacksMetadata(stacks: StackCollection, ioHost: IoHelper) {\n    const builder = (level: IoMessageLevel) => {\n      switch (level) {\n        case 'error': 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      cloudWatchLogMonitor,\n      hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${hotswap === HotswapMode.FULL_DEPLOYMENT ? 'off' : 'on'}`,\n    };\n\n    try {\n      await this._deploy(assembly, 'watch', deployOptions);\n    } catch {\n      // just continue - deploy will show the error\n    }\n  }\n}\n\n/**\n * The result of a `cdk.watch()` operation.\n */\nexport interface IWatcher extends AsyncDisposable {\n  /**\n   * Stop the watcher and wait for the current watch iteration to complete.\n   *\n   * An alias for `[Symbol.asyncDispose]`, as a more readable alternative for\n   * environments that don't support the Disposable APIs yet.\n   */\n  dispose(): Promise<void>;\n\n  /**\n   * Wait for the watcher to stop.\n   *\n   * The watcher will only stop if `dispose()` or `[Symbol.asyncDispose]()` are called.\n   *\n   * If neither of those is called, awaiting this promise will wait forever.\n   */\n  waitForEnd(): Promise<void>;\n}\n"]}
|
|
966
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolkit.js","sourceRoot":"","sources":["toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import '../private/dispose-polyfill';\nimport * as path from 'node:path';\nimport type { TemplateDiff } from '@aws-cdk/cloudformation-diff';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport * as chokidar from 'chokidar';\nimport * as fs from 'fs-extra';\nimport { NonInteractiveIoHost } from './non-interactive-io-host';\nimport type { ToolkitServices } from './private';\nimport { assemblyFromSource } from './private';\nimport type { DeployResult, DestroyResult, RollbackResult } from './types';\nimport type {\n  BootstrapEnvironments,\n  BootstrapOptions,\n  BootstrapResult,\n  EnvironmentBootstrapResult,\n} from '../actions/bootstrap';\nimport { BootstrapSource } from '../actions/bootstrap';\nimport { AssetBuildTime, type DeployOptions } from '../actions/deploy';\nimport {\n  buildParameterMap,\n  createHotswapPropertyOverrides,\n  type ExtendedDeployOptions,\n  removePublishedAssetsFromWorkGraph,\n} from '../actions/deploy/private';\nimport { type DestroyOptions } from '../actions/destroy';\nimport type { DiffOptions } from '../actions/diff';\nimport { appendObject, determinePermissionType, makeTemplateInfos as prepareDiff } from '../actions/diff/private';\nimport { type ListOptions } from '../actions/list';\nimport type { RefactorOptions } from '../actions/refactor';\nimport { type RollbackOptions } from '../actions/rollback';\nimport { type SynthOptions } from '../actions/synth';\nimport type { WatchOptions } from '../actions/watch';\nimport { patternsArrayForWatch } from '../actions/watch/private';\nimport { type SdkConfig } from '../api/aws-auth';\nimport type { ICloudAssemblySource } from '../api/cloud-assembly';\nimport { CachedCloudAssembly, StackSelectionStrategy } from '../api/cloud-assembly';\nimport type { StackAssembly } from '../api/cloud-assembly/private';\nimport { ALL_STACKS, CloudAssemblySourceBuilder } from '../api/cloud-assembly/private';\nimport type { IIoHost, IoMessageLevel } from '../api/io';\nimport { asSdkLogger, IO, SPAN, withoutColor, withoutEmojis, withTrimmedWhitespace } from '../api/io/private';\nimport type {\n  AssetBuildNode,\n  AssetPublishNode,\n  Concurrency,\n  IoHelper,\n  StackCollection,\n  StackNode,\n  SuccessfulDeployStackResult,\n} from '../api/shared-private';\nimport {\n  AmbiguityError,\n  ambiguousMovements,\n  asIoHelper,\n  Bootstrapper,\n  CloudWatchLogEventMonitor,\n  DEFAULT_TOOLKIT_STACK_NAME,\n  Deployments,\n  DiffFormatter,\n  findResourceMovements,\n  findCloudWatchLogGroups,\n  formatAmbiguousMappings,\n  formatTypedMappings,\n  HotswapMode,\n  RequireApproval,\n  ResourceMigrator,\n  SdkProvider,\n  tagsForStack,\n  ToolkitError,\n  resourceMappings,\n  WorkGraphBuilder,\n} from '../api/shared-private';\nimport type { AssemblyData, StackDetails, ToolkitAction } from '../api/shared-public';\nimport {\n  formatErrorMessage,\n  formatTime,\n  obscureTemplate,\n  serializeStructure,\n  validateSnsTopicArn,\n} from '../private/util';\nimport { pLimit } from '../util/concurrency';\nimport { promiseWithResolvers } from '../util/promises';\n\nexport interface ToolkitOptions {\n  /**\n   * The IoHost implementation, handling the inline interactions between the Toolkit and an integration.\n   */\n  readonly ioHost?: IIoHost;\n\n  /**\n   * Allow emojis in messages sent to the IoHost.\n   *\n   * @default true\n   */\n  readonly emojis?: boolean;\n\n  /**\n   * Whether to allow ANSI colors and formatting in IoHost messages.\n   * Setting this value to `false` enforces that no color or style shows up\n   * in messages sent to the IoHost.\n   * Setting this value to true is a no-op; it is equivalent to the default.\n   *\n   * @default - detects color from the TTY status of the IoHost\n   */\n  readonly color?: boolean;\n\n  /**\n   * Configuration options for the SDK.\n   */\n  readonly sdkConfig?: SdkConfig;\n\n  /**\n   * Name of the toolkit stack to be used.\n   *\n   * @default \"CDKToolkit\"\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Fail Cloud Assemblies\n   *\n   * @default \"error\"\n   */\n  readonly assemblyFailureAt?: 'error' | 'warn' | 'none';\n}\n\n/**\n * The AWS CDK Programmatic Toolkit\n */\nexport class Toolkit extends CloudAssemblySourceBuilder {\n  /**\n   * The toolkit stack name used for bootstrapping resources.\n   */\n  public readonly toolkitStackName: string;\n\n  /**\n   * The IoHost of this Toolkit\n   */\n  public readonly ioHost: IIoHost;\n\n  /**\n   * Cache of the internal SDK Provider instance\n   */\n  private sdkProviderCache?: SdkProvider;\n\n  public constructor(private readonly props: ToolkitOptions = {}) {\n    super();\n    this.toolkitStackName = props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME;\n\n    let ioHost = props.ioHost ?? new NonInteractiveIoHost();\n    if (props.emojis === false) {\n      ioHost = withoutEmojis(ioHost);\n    }\n    if (props.color === false) {\n      ioHost = withoutColor(ioHost);\n    }\n    // After removing emojis and color, we might end up with floating whitespace at either end of the message\n    // This also removes newlines that we currently emit for CLI backwards compatibility.\n    this.ioHost = withTrimmedWhitespace(ioHost);\n  }\n\n  /**\n   * Access to the AWS SDK\n   * @internal\n   */\n  protected async sdkProvider(action: ToolkitAction): Promise<SdkProvider> {\n    // @todo this needs to be different instance per action\n    if (!this.sdkProviderCache) {\n      const ioHelper = asIoHelper(this.ioHost, action);\n      this.sdkProviderCache = await SdkProvider.withAwsCliCompatibleDefaults({\n        ...this.props.sdkConfig,\n        ioHelper,\n        logger: asSdkLogger(ioHelper),\n      });\n    }\n\n    return this.sdkProviderCache;\n  }\n\n  /**\n   * Helper to provide the CloudAssemblySourceBuilder with required toolkit services\n   * @internal\n   */\n  protected override async sourceBuilderServices(): Promise<ToolkitServices> {\n    return {\n      ioHelper: asIoHelper(this.ioHost, 'assembly'),\n      sdkProvider: await this.sdkProvider('assembly'),\n    };\n  }\n\n  /**\n   * Bootstrap Action\n   */\n  public async bootstrap(environments: BootstrapEnvironments, options: BootstrapOptions): Promise<BootstrapResult> {\n    const startTime = Date.now();\n    const results: EnvironmentBootstrapResult[] = [];\n\n    const ioHelper = asIoHelper(this.ioHost, 'bootstrap');\n    const bootstrapEnvironments = await environments.getEnvironments(this.ioHost);\n    const source = options.source ?? BootstrapSource.default();\n    const parameters = options.parameters;\n    const bootstrapper = new Bootstrapper(source, ioHelper);\n    const sdkProvider = await this.sdkProvider('bootstrap');\n    const limit = pLimit(20);\n\n    // eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism\n    await Promise.all(bootstrapEnvironments.map((environment: cxapi.Environment, currentIdx) => limit(async () => {\n      const bootstrapSpan = await ioHelper.span(SPAN.BOOTSTRAP_SINGLE)\n        .begin(`${chalk.bold(environment.name)}: bootstrapping...`, {\n          total: bootstrapEnvironments.length,\n          current: currentIdx+1,\n          environment,\n        });\n\n      try {\n        const bootstrapResult = await bootstrapper.bootstrapEnvironment(\n          environment,\n          sdkProvider,\n          {\n            ...options,\n            toolkitStackName: this.toolkitStackName,\n            source,\n            parameters: parameters?.parameters,\n            usePreviousParameters: parameters?.keepExistingParameters,\n          },\n        );\n\n        const message = bootstrapResult.noOp\n          ? ` ✅  ${environment.name} (no changes)`\n          : ` ✅  ${environment.name}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I9900.msg(chalk.green('\\n' + message), { environment }));\n        const envTime = await bootstrapSpan.end();\n        const result: EnvironmentBootstrapResult = {\n          environment,\n          status: bootstrapResult.noOp ? 'no-op' : 'success',\n          duration: envTime.asMs,\n        };\n        results.push(result);\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E9900.msg(`\\n ❌  ${chalk.bold(environment.name)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw e;\n      }\n    })));\n\n    return {\n      environments: results,\n      duration: Date.now() - startTime,\n    };\n  }\n\n  /**\n   * Synth Action\n   *\n   * The caller assumes ownership of the `CachedCloudAssembly` and is responsible for calling `dispose()` on\n   * it after use.\n   */\n  public async synth(cx: ICloudAssemblySource, options: SynthOptions = {}): Promise<CachedCloudAssembly> {\n    const ioHelper = asIoHelper(this.ioHost, 'synth');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n\n    // NOTE: NOT 'await using' because we return ownership to the caller\n    const assembly = await assemblyFromSource(ioHelper, cx);\n\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    const autoValidateStacks = options.validateStacks ? [assembly.selectStacksForValidation()] : [];\n    await this.validateStacksMetadata(stacks.concat(...autoValidateStacks), ioHelper);\n    await synthSpan.end();\n\n    // if we have a single stack, print it to STDOUT\n    const message = `Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`;\n    const assemblyData: AssemblyData = {\n      assemblyDirectory: stacks.assembly.directory,\n      stacksCount: stacks.stackCount,\n      stackIds: stacks.hierarchicalIds,\n    };\n\n    if (stacks.stackCount === 1) {\n      const firstStack = stacks.firstStack!;\n      const template = firstStack.template;\n      const obscuredTemplate = obscureTemplate(template);\n      await ioHelper.notify(IO.CDK_TOOLKIT_I1901.msg(message, {\n        ...assemblyData,\n        stack: {\n          stackName: firstStack.stackName,\n          hierarchicalId: firstStack.hierarchicalId,\n          template,\n          stringifiedJson: serializeStructure(obscuredTemplate, true),\n          stringifiedYaml: serializeStructure(obscuredTemplate, false),\n        },\n      }));\n    } else {\n      // not outputting template to stdout, let's explain things to the user a little bit...\n      await ioHelper.notify(IO.CDK_TOOLKIT_I1902.msg(chalk.green(message), assemblyData));\n      await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(`Supply a stack id (${stacks.stackArtifacts.map((s) => chalk.green(s.hierarchicalId)).join(', ')}) to display its template.`));\n    }\n\n    return new CachedCloudAssembly(assembly);\n  }\n\n  /**\n   * Diff Action\n   */\n  public async diff(cx: ICloudAssemblySource, options: DiffOptions): Promise<{ [name: string]: TemplateDiff}> {\n    const ioHelper = asIoHelper(this.ioHost, 'diff');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    const stacks = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const diffSpan = await ioHelper.span(SPAN.DIFF_STACK).begin({ stacks: selectStacks });\n    const deployments = await this.deploymentsForAction('diff');\n\n    const strict = !!options.strict;\n    const contextLines = options.contextLines || 3;\n\n    let diffs = 0;\n    let formattedSecurityDiff = '';\n    let formattedStackDiff = '';\n\n    const templateInfos = await prepareDiff(ioHelper, stacks, deployments, await this.sdkProvider('diff'), options);\n    const templateDiffs: { [name: string]: TemplateDiff } = {};\n    for (const templateInfo of templateInfos) {\n      const formatter = new DiffFormatter({\n        ioHelper,\n        templateInfo,\n      });\n\n      if (options.securityOnly) {\n        const securityDiff = formatter.formatSecurityDiff({\n          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      appendObject(templateDiffs, formatter.diffs);\n    }\n\n    await diffSpan.end(`✨ Number of stacks with differences: ${diffs}`, {\n      formattedSecurityDiff,\n      formattedStackDiff,\n    });\n\n    return templateDiffs;\n  }\n\n  /**\n   * List Action\n   *\n   * List selected stacks and their dependencies\n   */\n  public async list(cx: ICloudAssemblySource, options: ListOptions = {}): Promise<StackDetails[]> {\n    const ioHelper = asIoHelper(this.ioHost, 'list');\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    const stackCollection = await assembly.selectStacksV2(selectStacks);\n    await synthSpan.end();\n\n    const stacks = stackCollection.withDependencies();\n    const message = stacks.map(s => s.id).join('\\n');\n\n    await ioHelper.notify(IO.CDK_TOOLKIT_I2901.msg(message, { stacks }));\n    return stacks;\n  }\n\n  /**\n   * Deploy Action\n   *\n   * Deploys the selected stacks into an AWS account\n   */\n  public async deploy(cx: ICloudAssemblySource, options: DeployOptions = {}): Promise<DeployResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'deploy');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await this._deploy(assembly, 'deploy', options);\n  }\n\n  /**\n   * Helper to allow deploy being called as part of the watch action.\n   */\n  private async _deploy(assembly: StackAssembly, action: 'deploy' | 'watch', options: ExtendedDeployOptions = {}): Promise<DeployResult> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const selectStacks = options.stacks ?? ALL_STACKS;\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: selectStacks });\n    const stackCollection = await assembly.selectStacksV2(selectStacks);\n    await this.validateStacksMetadata(stackCollection, ioHelper);\n    const synthDuration = await synthSpan.end();\n\n    const ret: DeployResult = {\n      stacks: [],\n    };\n\n    if (stackCollection.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E5001.msg('This app contains no stacks'));\n      return ret;\n    }\n\n    const deployments = await this.deploymentsForAction('deploy');\n    const migrator = new ResourceMigrator({ deployments, ioHelper });\n\n    await migrator.tryMigrateResources(stackCollection, options);\n\n    const parameterMap = buildParameterMap(options.parameters?.parameters);\n\n    const hotswapMode = options.hotswap ?? HotswapMode.FULL_DEPLOYMENT;\n    if (hotswapMode !== HotswapMode.FULL_DEPLOYMENT) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_W5400.msg([\n        '⚠️ The --hotswap and --hotswap-fallback flags deliberately introduce CloudFormation drift to speed up deployments',\n        '⚠️ They should only be used for development - never use them for your production Stacks!',\n      ].join('\\n')));\n    }\n\n    const stacks = stackCollection.stackArtifacts;\n    const stackOutputs: { [key: string]: any } = {};\n    const outputsFile = options.outputsFile;\n\n    const buildAsset = async (assetNode: AssetBuildNode) => {\n      const buildAssetSpan = await ioHelper.span(SPAN.BUILD_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.buildSingleAsset(\n        assetNode.assetManifestArtifact,\n        assetNode.assetManifest,\n        assetNode.asset,\n        {\n          stack: assetNode.parentStack,\n          roleArn: options.roleArn,\n          stackName: assetNode.parentStack.stackName,\n        },\n      );\n      await buildAssetSpan.end();\n    };\n\n    const publishAsset = async (assetNode: AssetPublishNode) => {\n      const publishAssetSpan = await ioHelper.span(SPAN.PUBLISH_ASSET).begin({\n        asset: assetNode.asset,\n      });\n      await deployments.publishSingleAsset(assetNode.assetManifest, assetNode.asset, {\n        stack: assetNode.parentStack,\n        roleArn: options.roleArn,\n        stackName: assetNode.parentStack.stackName,\n        forcePublish: options.forceAssetPublishing,\n      });\n      await publishAssetSpan.end();\n    };\n\n    const deployStack = async (stackNode: StackNode) => {\n      const stack = stackNode.stack;\n      if (stackCollection.stackCount !== 1) {\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_INFO.msg(chalk.bold(stack.displayName)));\n      }\n\n      if (!stack.environment) {\n        throw new ToolkitError(\n          `Stack ${stack.displayName} does not define an environment, and AWS credentials could not be obtained from standard locations or no region was configured.`,\n        );\n      }\n\n      // The generated stack has no resources\n      if (Object.keys(stack.template.Resources || {}).length === 0) {\n        // stack is empty and doesn't exist => do nothing\n        const stackExists = await deployments.stackExists({ stack });\n        if (!stackExists) {\n          return ioHelper.notify(IO.CDK_TOOLKIT_W5021.msg(`${chalk.bold(stack.displayName)}: stack has no resources, skipping deployment.`));\n        }\n\n        // stack is empty, but exists => delete\n        await ioHelper.notify(IO.CDK_TOOLKIT_W5022.msg(`${chalk.bold(stack.displayName)}: stack has no resources, deleting existing stack.`));\n        await this._destroy(assembly, 'deploy', {\n          stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n          roleArn: options.roleArn,\n        });\n\n        return;\n      }\n\n      const currentTemplate = await deployments.readCurrentTemplate(stack);\n      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            forceDeployment: options.forceDeployment,\n            parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n            usePreviousParameters: options.parameters?.keepExistingParameters,\n            rollback,\n            hotswap: hotswapMode,\n            extraUserAgent: options.extraUserAgent,\n            hotswapPropertyOverrides: options.hotswapProperties ? createHotswapPropertyOverrides(options.hotswapProperties) : undefined,\n            assetParallelism: options.assetParallelism,\n          });\n\n          switch (r.type) {\n            case 'did-deploy-stack':\n              deployResult = r;\n              break;\n\n            case 'failpaused-need-rollback-first': {\n              const motivation = r.reason === 'replacement'\n                ? `Stack is in a paused fail state (${r.status}) and change includes a replacement which cannot be deployed with \"--no-rollback\"`\n                : `Stack is in a paused fail state (${r.status}) and command line arguments do not include \"--no-rollback\"`;\n              const question = `${motivation}. Perform a regular deployment`;\n\n              const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                motivation,\n                concurrency,\n              }));\n              if (!confirmed) {\n                throw new ToolkitError('Aborted by user');\n              }\n\n              // Perform a rollback\n              await this._rollback(assembly, action, {\n                stacks: { patterns: [stack.hierarchicalId], strategy: StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE },\n                orphanFailedResources: options.orphanFailedResourcesDuringRollback,\n              });\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            case 'replacement-requires-rollback': {\n              const motivation = 'Change includes a replacement which cannot be deployed with \"--no-rollback\"';\n              const question = `${motivation}. Perform a regular deployment`;\n\n              const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I5050.req(question, {\n                motivation,\n                concurrency,\n              }));\n              if (!confirmed) {\n                throw new ToolkitError('Aborted by user');\n              }\n\n              // Go around through the 'while' loop again but switch rollback to true.\n              rollback = true;\n              break;\n            }\n\n            default:\n              throw new ToolkitError(`Unexpected result type from deployStack: ${JSON.stringify(r)}. If you are seeing this error, please report it at https://github.com/aws/aws-cdk/issues/new/choose`);\n          }\n        }\n\n        const message = deployResult.noOp\n          ? ` ✅  ${stack.displayName} (no changes)`\n          : ` ✅  ${stack.displayName}`;\n\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5900.msg(chalk.green('\\n' + message), deployResult));\n        deployDuration = await deploySpan.timing(IO.CDK_TOOLKIT_I5000);\n\n        if (Object.keys(deployResult.outputs).length > 0) {\n          const buffer = ['Outputs:'];\n          stackOutputs[stack.stackName] = deployResult.outputs;\n\n          for (const name of Object.keys(deployResult.outputs).sort()) {\n            const value = deployResult.outputs[name];\n            buffer.push(`${chalk.cyan(stack.id)}.${chalk.cyan(name)} = ${chalk.underline(chalk.cyan(value))}`);\n          }\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(buffer.join('\\n')));\n        }\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5901.msg(`Stack ARN:\\n${deployResult.stackArn}`));\n\n        ret.stacks.push({\n          stackName: stack.stackName,\n          environment: {\n            account: stack.environment.account,\n            region: stack.environment.region,\n          },\n          stackArn: deployResult.stackArn,\n          outputs: deployResult.outputs,\n          hierarchicalId: stack.hierarchicalId,\n        });\n      } catch (e: any) {\n        // It has to be exactly this string because an integration test tests for\n        // \"bold(stackname) failed: ResourceNotReady: <error>\"\n        throw new ToolkitError(\n          [`❌  ${chalk.bold(stack.stackName)} failed:`, ...(e.name ? [`${e.name}:`] : []), e.message].join(' '),\n        );\n      } finally {\n        if (options.traceLogs) {\n          // deploy calls that originate from watch will come with their own cloudWatchLogMonitor\n          const cloudWatchLogMonitor = options.cloudWatchLogMonitor ?? new CloudWatchLogEventMonitor({ ioHelper });\n          const foundLogGroupsResult = await findCloudWatchLogGroups(await this.sdkProvider('deploy'), ioHelper, stack);\n          cloudWatchLogMonitor.addLogGroups(\n            foundLogGroupsResult.env,\n            foundLogGroupsResult.sdk,\n            foundLogGroupsResult.logGroupNames,\n          );\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5031.msg(`The following log groups are added: ${foundLogGroupsResult.logGroupNames}`));\n        }\n\n        // If an outputs file has been specified, create the file path and write stack outputs to it once.\n        // Outputs are written after all stacks have been deployed. If a stack deployment fails,\n        // all of the outputs from successfully deployed stacks before the failure will still be written.\n        if (outputsFile) {\n          fs.ensureFileSync(outputsFile);\n          await fs.writeJson(outputsFile, stackOutputs, {\n            spaces: 2,\n            encoding: 'utf8',\n          });\n        }\n      }\n      const duration = synthDuration.asMs + (deployDuration?.asMs ?? 0);\n      await deploySpan.end(`\\n✨  Total time: ${formatTime(duration)}s\\n`, { duration });\n    };\n\n    const assetBuildTime = options.assetBuildTime ?? AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const prebuildAssets = assetBuildTime === AssetBuildTime.ALL_BEFORE_DEPLOY;\n    const concurrency = options.concurrency || 1;\n\n    const stacksAndTheirAssetManifests = stacks.flatMap((stack) => [\n      stack,\n      ...stack.dependencies.filter(x => cxapi.AssetManifestArtifact.isAssetManifestArtifact(x)),\n    ]);\n    const workGraph = new WorkGraphBuilder(ioHelper, prebuildAssets).build(stacksAndTheirAssetManifests);\n\n    // Unless we are running with '--force', skip already published assets\n    if (!options.forceAssetPublishing) {\n      await removePublishedAssetsFromWorkGraph(workGraph, deployments, options);\n    }\n\n    const graphConcurrency: Concurrency = {\n      'stack': concurrency,\n      'asset-build': 1, // This will be CPU-bound/memory bound, mostly matters for Docker builds\n      'asset-publish': (options.assetParallelism ?? true) ? 8 : 1, // This will be I/O-bound, 8 in parallel seems reasonable\n    };\n\n    await workGraph.doParallel(graphConcurrency, {\n      deployStack,\n      buildAsset,\n      publishAsset,\n    });\n\n    return ret;\n  }\n\n  /**\n   * Watch Action\n   *\n   * Continuously observe project files and deploy the selected stacks\n   * automatically when changes are detected.  Implies hotswap deployments.\n   *\n   * This function returns immediately, starting a watcher in the background.\n   */\n  public async watch(cx: ICloudAssemblySource, options: WatchOptions): Promise<IWatcher> {\n    const ioHelper = asIoHelper(this.ioHost, 'watch');\n    await using assembly = await assemblyFromSource(ioHelper, cx, false);\n    const rootDir = options.watchDir ?? process.cwd();\n\n    if (options.include === undefined && options.exclude === undefined) {\n      throw new ToolkitError(\n        \"Cannot use the 'watch' command without specifying at least one directory to monitor. \" +\n          'Make sure to add a \"watch\" key to your cdk.json',\n      );\n    }\n\n    // For the \"include\" subkey under the \"watch\" key, the behavior is:\n    // 1. No \"watch\" setting? We error out.\n    // 2. \"watch\" setting without an \"include\" key? We default to observing \"./**\".\n    // 3. \"watch\" setting with an empty \"include\" key? We default to observing \"./**\".\n    // 4. Non-empty \"include\" key? Just use the \"include\" key.\n    const watchIncludes = patternsArrayForWatch(options.include, {\n      rootDir,\n      returnRootDirIfEmpty: true,\n    });\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outdir = assembly.directory;\n    const watchExcludes = patternsArrayForWatch(options.exclude, {\n      rootDir,\n      returnRootDirIfEmpty: false,\n    });\n\n    // only exclude the outdir if it is under the rootDir\n    const relativeOutDir = path.relative(rootDir, outdir);\n    if (Boolean(relativeOutDir && !relativeOutDir.startsWith('..' + path.sep) && !path.isAbsolute(relativeOutDir))) {\n      watchExcludes.push(`${relativeOutDir}/**`);\n    }\n\n    watchExcludes.push('**/.*', '**/.*/**', '**/node_modules/**');\n\n    // Print some debug information on computed settings\n    await ioHelper.notify(IO.CDK_TOOLKIT_I5310.msg([\n      `root directory used for 'watch' is: ${rootDir}`,\n      `'include' patterns for 'watch': ${JSON.stringify(watchIncludes)}`,\n      `'exclude' patterns for 'watch': ${JSON.stringify(watchExcludes)}`,\n    ].join('\\n'), {\n      watchDir: rootDir,\n      includes: watchIncludes,\n      excludes: watchExcludes,\n    }));\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    type LatchState = 'pre-ready' | 'open' | 'deploying' | 'queued';\n    let latch: LatchState = 'pre-ready';\n\n    const cloudWatchLogMonitor = options.traceLogs ? new CloudWatchLogEventMonitor({ ioHelper }) : undefined;\n    const deployAndWatch = async () => {\n      latch = 'deploying' as LatchState;\n      await cloudWatchLogMonitor?.deactivate();\n\n      await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while (latch === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5315.msg(\"Detected file changes during deployment. Invoking 'cdk deploy' again\"));\n        await this.invokeDeployFromWatch(assembly, options, cloudWatchLogMonitor);\n      }\n      latch = 'open';\n      await cloudWatchLogMonitor?.activate();\n    };\n\n    const watcher = chokidar\n      .watch(watchIncludes, {\n        ignored: watchExcludes,\n        cwd: rootDir,\n      })\n      .on('ready', async () => {\n        latch = 'open';\n        await ioHelper.notify(IO.DEFAULT_TOOLKIT_DEBUG.msg(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\"));\n        await ioHelper.notify(IO.CDK_TOOLKIT_I5314.msg(\"Triggering initial 'cdk deploy'\"));\n        await deployAndWatch();\n      })\n      .on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath: string) => {\n        const watchEvent = {\n          event,\n          path: filePath,\n        };\n        if (latch === 'pre-ready') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5311.msg(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '${filePath}' for changes`, watchEvent));\n        } else if (latch === 'open') {\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5312.msg(`Detected change to '${filePath}' (type: ${event}). Triggering 'cdk deploy'`, watchEvent));\n          await deployAndWatch();\n        } else {\n          // this means latch is either 'deploying' or 'queued'\n          latch = 'queued';\n          await ioHelper.notify(IO.CDK_TOOLKIT_I5313.msg(\n            `Detected change to '${filePath}' (type: ${event}) while 'cdk deploy' is still running. Will queue for another deployment after this one finishes'`,\n            watchEvent,\n          ));\n        }\n      });\n\n    const stoppedPromise = promiseWithResolvers<void>();\n\n    return {\n      async dispose() {\n        await watcher.close();\n        // Prevents Node from staying alive. There is no 'end' event that the watcher emits\n        // that we can know it's definitely done, so best we can do is tell it to stop watching,\n        // stop keeping Node alive, and then pretend that's everything we needed to do.\n        watcher.unref();\n        stoppedPromise.resolve();\n        return stoppedPromise.promise;\n      },\n      async waitForEnd() {\n        return stoppedPromise.promise;\n      },\n      async [Symbol.asyncDispose]() {\n        return this.dispose();\n      },\n    } satisfies IWatcher;\n  }\n\n  /**\n   * Rollback Action\n   *\n   * Rolls back the selected stacks.\n   */\n  public async rollback(cx: ICloudAssemblySource, options: RollbackOptions): Promise<RollbackResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'rollback');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await this._rollback(assembly, 'rollback', options);\n  }\n\n  /**\n   * Helper to allow rollback being called as part of the deploy or watch action.\n   */\n  private async _rollback(assembly: StackAssembly, action: 'rollback' | 'deploy' | 'watch', options: RollbackOptions): Promise<RollbackResult> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    const stacks = await assembly.selectStacksV2(options.stacks);\n    await this.validateStacksMetadata(stacks, ioHelper);\n    await synthSpan.end();\n\n    const ret: RollbackResult = {\n      stacks: [],\n    };\n\n    if (stacks.stackCount === 0) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E6001.msg('No stacks selected'));\n      return ret;\n    }\n\n    let anyRollbackable = false;\n\n    for (const [index, stack] of stacks.stackArtifacts.entries()) {\n      const rollbackSpan = await ioHelper.span(SPAN.ROLLBACK_STACK).begin(`Rolling back ${chalk.bold(stack.displayName)}`, {\n        total: stacks.stackCount,\n        current: index + 1,\n        stack,\n      });\n      const deployments = await this.deploymentsForAction('rollback');\n      try {\n        const stackResult = await deployments.rollbackStack({\n          stack,\n          roleArn: options.roleArn,\n          toolkitStackName: this.toolkitStackName,\n          orphanFailedResources: options.orphanFailedResources,\n          validateBootstrapStackVersion: options.validateBootstrapStackVersion,\n          orphanLogicalIds: options.orphanLogicalIds,\n        });\n        if (!stackResult.notInRollbackableState) {\n          anyRollbackable = true;\n        }\n        await rollbackSpan.end();\n\n        ret.stacks.push({\n          environment: {\n            account: stack.environment.account,\n            region: stack.environment.region,\n          },\n          stackName: stack.stackName,\n          stackArn: stackResult.stackArn,\n          result: stackResult.notInRollbackableState ? 'already-stable' : 'rolled-back',\n        });\n      } catch (e: any) {\n        await ioHelper.notify(IO.CDK_TOOLKIT_E6900.msg(`\\n ❌  ${chalk.bold(stack.displayName)} failed: ${formatErrorMessage(e)}`, { error: e }));\n        throw 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    return ret;\n  }\n\n  /**\n   * Refactor Action. Moves resources from one location (stack + logical ID) to another.\n   */\n  public async refactor(cx: ICloudAssemblySource, options: RefactorOptions = {}): Promise<void> {\n    const ioHelper = asIoHelper(this.ioHost, 'refactor');\n    const assembly = await assemblyFromSource(ioHelper, cx);\n    return this._refactor(assembly, ioHelper, options);\n  }\n\n  private async _refactor(assembly: StackAssembly, ioHelper: IoHelper, options: RefactorOptions = {}): Promise<void> {\n    if (!options.dryRun) {\n      throw new ToolkitError('Refactor is not available yet. Too see the proposed changes, use the --dry-run flag.');\n    }\n\n    const strategy = options.stacks?.strategy ?? StackSelectionStrategy.ALL_STACKS;\n    if (strategy !== StackSelectionStrategy.ALL_STACKS) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_W8010.msg(\n        'Refactor does not yet support stack selection. Proceeding with the default behavior (considering all stacks).',\n      ));\n    }\n    const stacks = await assembly.selectStacksV2(ALL_STACKS);\n\n    const sdkProvider = await this.sdkProvider('refactor');\n    const movements = await findResourceMovements(stacks.stackArtifacts, sdkProvider);\n    const ambiguous = ambiguousMovements(movements);\n    if (ambiguous.length === 0) {\n      const typedMappings = resourceMappings(movements).map(m => m.toTypedMapping());\n      await ioHelper.notify(IO.CDK_TOOLKIT_I8900.msg(formatTypedMappings(typedMappings), {\n        typedMappings,\n      }));\n    } else {\n      const error = new AmbiguityError(ambiguous);\n      const paths = error.paths();\n      await ioHelper.notify(IO.CDK_TOOLKIT_I8900.msg(formatAmbiguousMappings(paths), {\n        ambiguousPaths: paths,\n      }));\n    }\n  }\n\n  /**\n   * Destroy Action\n   *\n   * Destroys the selected Stacks.\n   */\n  public async destroy(cx: ICloudAssemblySource, options: DestroyOptions): Promise<DestroyResult> {\n    const ioHelper = asIoHelper(this.ioHost, 'destroy');\n    await using assembly = await assemblyFromSource(ioHelper, cx);\n    return await this._destroy(assembly, 'destroy', options);\n  }\n\n  /**\n   * Helper to allow destroy being called as part of the deploy action.\n   */\n  private async _destroy(assembly: StackAssembly, action: 'deploy' | 'destroy', options: DestroyOptions): Promise<DestroyResult> {\n    const ioHelper = asIoHelper(this.ioHost, action);\n    const synthSpan = await ioHelper.span(SPAN.SYNTH_ASSEMBLY).begin({ stacks: options.stacks });\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    const stacks = (await assembly.selectStacksV2(options.stacks)).reversed();\n    await synthSpan.end();\n\n    const ret: DestroyResult = {\n      stacks: [],\n    };\n\n    const motivation = 'Destroying stacks is an irreversible action';\n    const question = `Are you sure you want to delete: ${chalk.red(stacks.hierarchicalIds.join(', '))}`;\n    const confirmed = await ioHelper.requestResponse(IO.CDK_TOOLKIT_I7010.req(question, { motivation }));\n    if (!confirmed) {\n      await ioHelper.notify(IO.CDK_TOOLKIT_E7010.msg('Aborted by user'));\n      return ret;\n    }\n\n    const destroySpan = await ioHelper.span(SPAN.DESTROY_ACTION).begin({\n      stacks: stacks.stackArtifacts,\n    });\n    try {\n      for (const [index, stack] of stacks.stackArtifacts.entries()) {\n        try {\n          const singleDestroySpan = await ioHelper.span(SPAN.DESTROY_STACK)\n            .begin(chalk.green(`${chalk.blue(stack.displayName)}: destroying... [${index + 1}/${stacks.stackCount}]`), {\n              total: stacks.stackCount,\n              current: index + 1,\n              stack,\n            });\n          const deployments = await this.deploymentsForAction(action);\n          const result = await deployments.destroyStack({\n            stack,\n            deployName: stack.stackName,\n            roleArn: options.roleArn,\n          });\n\n          ret.stacks.push({\n            environment: {\n              account: stack.environment.account,\n              region: stack.environment.region,\n            },\n            stackName: stack.stackName,\n            stackArn: result.stackArn,\n            stackExisted: result.stackArn !== undefined,\n          });\n\n          await ioHelper.notify(IO.CDK_TOOLKIT_I7900.msg(chalk.green(`\\n ✅  ${chalk.blue(stack.displayName)}: ${action}ed`), stack));\n          await singleDestroySpan.end();\n        } catch (e: any) {\n          await ioHelper.notify(IO.CDK_TOOLKIT_E7900.msg(`\\n ❌  ${chalk.blue(stack.displayName)}: ${action} failed ${e}`, { error: e }));\n          throw e;\n        }\n      }\n\n      return ret;\n    } finally {\n      await destroySpan.end();\n    }\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private async validateStacksMetadata(stacks: StackCollection, ioHost: IoHelper) {\n    const builder = (level: IoMessageLevel) => {\n      switch (level) {\n        case 'error': 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      cloudWatchLogMonitor,\n      hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${hotswap === HotswapMode.FULL_DEPLOYMENT ? 'off' : 'on'}`,\n    };\n\n    try {\n      await this._deploy(assembly, 'watch', deployOptions);\n    } catch {\n      // just continue - deploy will show the error\n    }\n  }\n}\n\n/**\n * The result of a `cdk.watch()` operation.\n */\nexport interface IWatcher extends AsyncDisposable {\n  /**\n   * Stop the watcher and wait for the current watch iteration to complete.\n   *\n   * An alias for `[Symbol.asyncDispose]`, as a more readable alternative for\n   * environments that don't support the Disposable APIs yet.\n   */\n  dispose(): Promise<void>;\n\n  /**\n   * Wait for the watcher to stop.\n   *\n   * The watcher will only stop if `dispose()` or `[Symbol.asyncDispose]()` are called.\n   *\n   * If neither of those is called, awaiting this promise will wait forever.\n   */\n  waitForEnd(): Promise<void>;\n}\n"]}
|