aws-cdk 2.3.0 → 2.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (77) hide show
  1. package/LICENSE +1 -1
  2. package/NOTICE +1 -1
  3. package/README.md +4 -1
  4. package/bin/cdk.js +7 -6
  5. package/build-info.json +2 -2
  6. package/lib/api/aws-auth/sdk-provider.d.ts +26 -1
  7. package/lib/api/aws-auth/sdk-provider.js +14 -24
  8. package/lib/api/aws-auth/sdk.d.ts +2 -0
  9. package/lib/api/aws-auth/sdk.js +4 -1
  10. package/lib/api/bootstrap/bootstrap-template.yaml +3 -1
  11. package/lib/api/bootstrap/deploy-bootstrap.js +2 -2
  12. package/lib/api/cloudformation-deployments.d.ts +63 -1
  13. package/lib/api/cloudformation-deployments.js +66 -3
  14. package/lib/api/cxapp/cloud-assembly.js +5 -5
  15. package/lib/api/deploy-stack.js +10 -4
  16. package/lib/api/hotswap/code-build-projects.d.ts +3 -0
  17. package/lib/api/hotswap/code-build-projects.js +53 -0
  18. package/lib/api/hotswap/common.d.ts +17 -1
  19. package/lib/api/hotswap/common.js +30 -6
  20. package/lib/api/hotswap/ecs-services.js +4 -18
  21. package/lib/api/hotswap/lambda-functions.js +169 -44
  22. package/lib/api/hotswap/s3-bucket-deployments.js +3 -10
  23. package/lib/api/hotswap/stepfunctions-state-machines.js +2 -1
  24. package/lib/api/hotswap-deployments.d.ts +0 -7
  25. package/lib/api/hotswap-deployments.js +85 -13
  26. package/lib/api/toolkit-info.d.ts +5 -5
  27. package/lib/api/toolkit-info.js +10 -10
  28. package/lib/api/util/cloudformation/stack-activity-monitor.js +22 -22
  29. package/lib/assets.js +3 -3
  30. package/lib/cdk-toolkit.js +66 -32
  31. package/lib/commands/context.js +7 -7
  32. package/lib/commands/docs.js +5 -5
  33. package/lib/commands/doctor.js +6 -6
  34. package/lib/context-providers/ami.js +2 -2
  35. package/lib/context-providers/availability-zones.js +2 -2
  36. package/lib/context-providers/endpoint-service-availability-zones.js +2 -2
  37. package/lib/context-providers/hosted-zones.js +2 -2
  38. package/lib/context-providers/keys.js +2 -2
  39. package/lib/context-providers/load-balancers.js +3 -3
  40. package/lib/context-providers/security-groups.js +2 -2
  41. package/lib/context-providers/ssm-parameters.js +2 -2
  42. package/lib/context-providers/vpcs.js +2 -2
  43. package/lib/diff.js +3 -3
  44. package/lib/init.js +15 -14
  45. package/lib/logging.js +7 -7
  46. package/lib/os.js +3 -3
  47. package/lib/plugin.js +4 -4
  48. package/lib/util/asset-publishing.js +3 -3
  49. package/lib/util/console-formatters.js +4 -3
  50. package/lib/util/npm.d.ts +1 -0
  51. package/lib/util/npm.js +21 -0
  52. package/lib/version.d.ts +1 -1
  53. package/lib/version.js +23 -20
  54. package/npm-shrinkwrap.json +229 -101
  55. package/package.json +19 -18
  56. package/test/api/cloudformation-deployments.test.js +2 -2
  57. package/test/api/hotswap/{lambda-hotswap-deployments.test.d.ts → code-build-projects-hotswap-deployments.test.d.ts} +0 -0
  58. package/test/api/hotswap/code-build-projects-hotswap-deployments.test.js +576 -0
  59. package/test/api/hotswap/hotswap-deployments.test.js +4 -2
  60. package/test/api/hotswap/hotswap-test-setup.d.ts +3 -1
  61. package/test/api/hotswap/hotswap-test-setup.js +7 -4
  62. package/test/api/hotswap/lambda-functions-hotswap-deployments.test.d.ts +1 -0
  63. package/test/api/hotswap/lambda-functions-hotswap-deployments.test.js +502 -0
  64. package/test/api/hotswap/lambda-versions-aliases-hotswap-deployments.test.d.ts +1 -0
  65. package/test/api/hotswap/lambda-versions-aliases-hotswap-deployments.test.js +197 -0
  66. package/test/api/sdk-provider.test.js +11 -11
  67. package/test/api/stack-activity-monitor.test.js +13 -13
  68. package/test/cdk-toolkit.test.js +240 -13
  69. package/test/context-providers/load-balancers.test.js +4 -4
  70. package/test/init.test.js +5 -4
  71. package/test/util/cloudformation.test.js +2 -2
  72. package/test/util/console-formatters.test.js +6 -6
  73. package/test/util/mock-sdk.d.ts +4 -2
  74. package/test/util/mock-sdk.js +6 -2
  75. package/test/util/mock-toolkitinfo.js +2 -2
  76. package/test/version.test.js +45 -3
  77. package/test/api/hotswap/lambda-hotswap-deployments.test.js +0 -418
@@ -4,7 +4,7 @@ exports.CdkToolkit = void 0;
4
4
  const path = require("path");
5
5
  const util_1 = require("util");
6
6
  const chokidar = require("chokidar");
7
- const colors = require("colors/safe");
7
+ const chalk = require("chalk");
8
8
  const fs = require("fs-extra");
9
9
  const promptly = require("promptly");
10
10
  const environments_1 = require("../lib/api/cxapp/environments");
@@ -51,7 +51,7 @@ class CdkToolkit {
51
51
  else {
52
52
  // Compare N stacks against deployed templates
53
53
  for (const stack of stacks.stackArtifacts) {
54
- stream.write(util_1.format('Stack %s\n', colors.bold(stack.displayName)));
54
+ stream.write(util_1.format('Stack %s\n', chalk.bold(stack.displayName)));
55
55
  const currentTemplate = await this.props.cloudFormation.readCurrentTemplate(stack);
56
56
  diffs += options.securityOnly
57
57
  ? util_2.numberFromBool(diff_1.printSecurityDiff(currentTemplate, stack, diff_1.RequireApproval.Broadening))
@@ -65,7 +65,10 @@ class CdkToolkit {
65
65
  if (options.watch) {
66
66
  return this.watch(options);
67
67
  }
68
+ const startSynthTime = new Date().getTime();
68
69
  const stacks = await this.selectStacksForDeploy(options.selector, options.exclusively, options.cacheCloudAssembly);
70
+ const elapsedSynthTime = new Date().getTime() - startSynthTime;
71
+ logging_1.print('\n✨ Synthesis time: %ss\n', formatTime(elapsedSynthTime));
69
72
  const requireApproval = (_a = options.requireApproval) !== null && _a !== void 0 ? _a : diff_1.RequireApproval.Broadening;
70
73
  const parameterMap = { '*': {} };
71
74
  for (const key in options.parameters) {
@@ -98,10 +101,10 @@ class CdkToolkit {
98
101
  }
99
102
  if (Object.keys(stack.template.Resources || {}).length === 0) { // The generated stack has no resources
100
103
  if (!await this.props.cloudFormation.stackExists({ stack })) {
101
- logging_1.warning('%s: stack has no resources, skipping deployment.', colors.bold(stack.displayName));
104
+ logging_1.warning('%s: stack has no resources, skipping deployment.', chalk.bold(stack.displayName));
102
105
  }
103
106
  else {
104
- logging_1.warning('%s: stack has no resources, deleting existing stack.', colors.bold(stack.displayName));
107
+ logging_1.warning('%s: stack has no resources, deleting existing stack.', chalk.bold(stack.displayName));
105
108
  await this.destroy({
106
109
  selector: { patterns: [stack.stackName] },
107
110
  exclusively: true,
@@ -126,11 +129,13 @@ class CdkToolkit {
126
129
  }
127
130
  }
128
131
  }
129
- logging_1.print('%s: deploying...', colors.bold(stack.displayName));
132
+ logging_1.print('%s: deploying...', chalk.bold(stack.displayName));
133
+ const startDeployTime = new Date().getTime();
130
134
  let tags = options.tags;
131
135
  if (!tags || tags.length === 0) {
132
136
  tags = tagsForStack(stack);
133
137
  }
138
+ let elapsedDeployTime = 0;
134
139
  try {
135
140
  const result = await this.props.cloudFormation.deployStack({
136
141
  stack,
@@ -155,19 +160,21 @@ class CdkToolkit {
155
160
  ? ' ✅ %s (no changes)'
156
161
  : ' ✅ %s';
157
162
  logging_1.success('\n' + message, stack.displayName);
163
+ elapsedDeployTime = new Date().getTime() - startDeployTime;
164
+ logging_1.print('\n✨ Deployment time: %ss\n', formatTime(elapsedDeployTime));
158
165
  if (Object.keys(result.outputs).length > 0) {
159
- logging_1.print('\nOutputs:');
166
+ logging_1.print('Outputs:');
160
167
  stackOutputs[stack.stackName] = result.outputs;
161
168
  }
162
169
  for (const name of Object.keys(result.outputs).sort()) {
163
170
  const value = result.outputs[name];
164
- logging_1.print('%s.%s = %s', colors.cyan(stack.id), colors.cyan(name), colors.underline(colors.cyan(value)));
171
+ logging_1.print('%s.%s = %s', chalk.cyan(stack.id), chalk.cyan(name), chalk.underline(chalk.cyan(value)));
165
172
  }
166
- logging_1.print('\nStack ARN:');
173
+ logging_1.print('Stack ARN:');
167
174
  logging_1.data(result.stackArn);
168
175
  }
169
176
  catch (e) {
170
- logging_1.error('\n ❌ %s failed: %s', colors.bold(stack.displayName), e);
177
+ logging_1.error('\n ❌ %s failed: %s', chalk.bold(stack.displayName), e);
171
178
  throw e;
172
179
  }
173
180
  finally {
@@ -182,6 +189,7 @@ class CdkToolkit {
182
189
  });
183
190
  }
184
191
  }
192
+ logging_1.print('\n✨ Total time: %ss\n', formatTime(elapsedSynthTime + elapsedDeployTime));
185
193
  }
186
194
  }
187
195
  async watch(options) {
@@ -220,30 +228,35 @@ class CdkToolkit {
220
228
  // | | | | <------------------ | | <------------------ | | <-------------|
221
229
  // -------------- -------- 'cdk deploy' done -------------- 'cdk deploy' done --------------
222
230
  let latch = 'pre-ready';
231
+ const deployAndWatch = async () => {
232
+ latch = 'deploying';
233
+ await this.invokeDeployFromWatch(options);
234
+ // If latch is still 'deploying' after the 'await', that's fine,
235
+ // but if it's 'queued', that means we need to deploy again
236
+ while (latch === 'queued') {
237
+ // TypeScript doesn't realize latch can change between 'awaits',
238
+ // and thinks the above 'while' condition is always 'false' without the cast
239
+ latch = 'deploying';
240
+ logging_1.print("Detected file changes during deployment. Invoking 'cdk deploy' again");
241
+ await this.invokeDeployFromWatch(options);
242
+ }
243
+ latch = 'open';
244
+ };
223
245
  chokidar.watch(watchIncludes, {
224
246
  ignored: watchExcludes,
225
247
  cwd: rootDir,
226
- }).on('ready', () => {
248
+ }).on('ready', async () => {
227
249
  latch = 'open';
228
250
  logging_1.debug("'watch' received the 'ready' event. From now on, all file changes will trigger a deployment");
251
+ logging_1.print("Triggering initial 'cdk deploy'");
252
+ await deployAndWatch();
229
253
  }).on('all', async (event, filePath) => {
230
254
  if (latch === 'pre-ready') {
231
255
  logging_1.print(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '%s' for changes`, filePath);
232
256
  }
233
257
  else if (latch === 'open') {
234
- latch = 'deploying';
235
258
  logging_1.print("Detected change to '%s' (type: %s). Triggering 'cdk deploy'", filePath, event);
236
- await this.invokeDeployFromWatch(options);
237
- // If latch is still 'deploying' after the 'await', that's fine,
238
- // but if it's 'queued', that means we need to deploy again
239
- while (latch === 'queued') {
240
- // TypeScript doesn't realize latch can change between 'awaits',
241
- // and thinks the above 'while' condition is always 'false' without the cast
242
- latch = 'deploying';
243
- logging_1.print("Detected file changes during deployment. Invoking 'cdk deploy' again");
244
- await this.invokeDeployFromWatch(options);
245
- }
246
- latch = 'open';
259
+ await deployAndWatch();
247
260
  }
248
261
  else { // this means latch is either 'deploying' or 'queued'
249
262
  latch = 'queued';
@@ -258,24 +271,24 @@ class CdkToolkit {
258
271
  stacks = stacks.reversed();
259
272
  if (!options.force) {
260
273
  // eslint-disable-next-line max-len
261
- const confirmed = await promptly.confirm(`Are you sure you want to delete: ${colors.blue(stacks.stackArtifacts.map(s => s.hierarchicalId).join(', '))} (y/n)?`);
274
+ const confirmed = await promptly.confirm(`Are you sure you want to delete: ${chalk.blue(stacks.stackArtifacts.map(s => s.hierarchicalId).join(', '))} (y/n)?`);
262
275
  if (!confirmed) {
263
276
  return;
264
277
  }
265
278
  }
266
279
  const action = options.fromDeploy ? 'deploy' : 'destroy';
267
280
  for (const stack of stacks.stackArtifacts) {
268
- logging_1.success('%s: destroying...', colors.blue(stack.displayName));
281
+ logging_1.success('%s: destroying...', chalk.blue(stack.displayName));
269
282
  try {
270
283
  await this.props.cloudFormation.destroyStack({
271
284
  stack,
272
285
  deployName: stack.stackName,
273
286
  roleArn: options.roleArn,
274
287
  });
275
- logging_1.success(`\n ✅ %s: ${action}ed`, colors.blue(stack.displayName));
288
+ logging_1.success(`\n ✅ %s: ${action}ed`, chalk.blue(stack.displayName));
276
289
  }
277
290
  catch (e) {
278
- logging_1.error(`\n ❌ %s: ${action} failed`, colors.blue(stack.displayName), e);
291
+ logging_1.error(`\n ❌ %s: ${action} failed`, chalk.blue(stack.displayName), e);
279
292
  throw e;
280
293
  }
281
294
  }
@@ -330,8 +343,8 @@ class CdkToolkit {
330
343
  return stacks.stackArtifacts.map(s => s.template);
331
344
  }
332
345
  // not outputting template to stdout, let's explain things to the user a little bit...
333
- logging_1.success(`Successfully synthesized to ${colors.blue(path.resolve(stacks.assembly.directory))}`);
334
- logging_1.print(`Supply a stack id (${stacks.stackArtifacts.map(s => colors.green(s.id)).join(', ')}) to display its template.`);
346
+ logging_1.success(`Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`);
347
+ logging_1.print(`Supply a stack id (${stacks.stackArtifacts.map(s => chalk.green(s.id)).join(', ')}) to display its template.`);
335
348
  return undefined;
336
349
  }
337
350
  /**
@@ -367,16 +380,16 @@ class CdkToolkit {
367
380
  environments.push(...await environments_1.globEnvironmentsFromStacks(await this.selectStacksForList([]), globSpecs, this.props.sdkProvider));
368
381
  }
369
382
  await Promise.all(environments.map(async (environment) => {
370
- logging_1.success(' ⏳ Bootstrapping environment %s...', colors.blue(environment.name));
383
+ logging_1.success(' ⏳ Bootstrapping environment %s...', chalk.blue(environment.name));
371
384
  try {
372
385
  const result = await bootstrapper.bootstrapEnvironment(environment, this.props.sdkProvider, options);
373
386
  const message = result.noOp
374
387
  ? ' ✅ Environment %s bootstrapped (no changes).'
375
388
  : ' ✅ Environment %s bootstrapped.';
376
- logging_1.success(message, colors.blue(environment.name));
389
+ logging_1.success(message, chalk.blue(environment.name));
377
390
  }
378
391
  catch (e) {
379
- logging_1.error(' ❌ Environment %s failed bootstrapping: %s', colors.blue(environment.name), e);
392
+ logging_1.error(' ❌ Environment %s failed bootstrapping: %s', chalk.blue(environment.name), e);
380
393
  throw e;
381
394
  }
382
395
  }));
@@ -493,4 +506,25 @@ exports.CdkToolkit = CdkToolkit;
493
506
  function tagsForStack(stack) {
494
507
  return Object.entries(stack.tags).map(([Key, Value]) => ({ Key, Value }));
495
508
  }
496
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-toolkit.js","sourceRoot":"","sources":["cdk-toolkit.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { format } from 'util';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chokidar from 'chokidar';\nimport * as colors from 'colors/safe';\nimport * as fs from 'fs-extra';\nimport * as promptly from 'promptly';\nimport { environmentsFromDescriptors, globEnvironmentsFromStacks, looksLikeGlob } from '../lib/api/cxapp/environments';\nimport { SdkProvider } from './api/aws-auth';\nimport { Bootstrapper, BootstrapEnvironmentOptions } from './api/bootstrap';\nimport { CloudFormationDeployments } from './api/cloudformation-deployments';\nimport { CloudAssembly, DefaultSelection, ExtendedStackSelection, StackCollection, StackSelector } from './api/cxapp/cloud-assembly';\nimport { CloudExecutable } from './api/cxapp/cloud-executable';\nimport { StackActivityProgress } from './api/util/cloudformation/stack-activity-monitor';\nimport { printSecurityDiff, printStackDiff, RequireApproval } from './diff';\nimport { data, debug, error, highlight, print, success, warning } from './logging';\nimport { deserializeStructure } from './serialize';\nimport { Configuration, PROJECT_CONFIG } from './settings';\nimport { numberFromBool, partition } from './util';\n\nexport interface CdkToolkitProps {\n\n  /**\n   * The Cloud Executable\n   */\n  cloudExecutable: CloudExecutable;\n\n  /**\n   * The provisioning engine used to apply changes to the cloud\n   */\n  cloudFormation: CloudFormationDeployments;\n\n  /**\n   * Whether to be verbose\n   *\n   * @default false\n   */\n  verbose?: boolean;\n\n  /**\n   * Don't stop on error metadata\n   *\n   * @default false\n   */\n  ignoreErrors?: boolean;\n\n  /**\n   * Treat warnings in metadata as errors\n   *\n   * @default false\n   */\n  strict?: boolean;\n\n  /**\n   * Application configuration (settings and context)\n   */\n  configuration: Configuration;\n\n  /**\n   * AWS object (used by synthesizer and contextprovider)\n   */\n  sdkProvider: SdkProvider;\n}\n\n/**\n * Toolkit logic\n *\n * The toolkit runs the `cloudExecutable` to obtain a cloud assembly and\n * deploys applies them to `cloudFormation`.\n */\nexport class CdkToolkit {\n  constructor(private readonly props: CdkToolkitProps) {\n  }\n\n  public async metadata(stackName: string) {\n    const stacks = await this.selectSingleStackByName(stackName);\n    return stacks.firstStack.manifest.metadata ?? {};\n  }\n\n  public async diff(options: DiffOptions): Promise<number> {\n    const stacks = await this.selectStacksForDiff(options.stackNames, options.exclusively);\n\n    const strict = !!options.strict;\n    const contextLines = options.contextLines || 3;\n    const stream = options.stream || process.stderr;\n\n    let diffs = 0;\n    if (options.templatePath !== undefined) {\n      // Compare single stack against fixed template\n      if (stacks.stackCount !== 1) {\n        throw new Error('Can only select one stack when comparing to fixed template. Use --exclusively to avoid selecting multiple stacks.');\n      }\n\n      if (!await fs.pathExists(options.templatePath)) {\n        throw new Error(`There is no file at ${options.templatePath}`);\n      }\n      const template = deserializeStructure(await fs.readFile(options.templatePath, { encoding: 'UTF-8' }));\n      diffs = options.securityOnly\n        ? numberFromBool(printSecurityDiff(template, stacks.firstStack, RequireApproval.Broadening))\n        : printStackDiff(template, stacks.firstStack, strict, contextLines, stream);\n    } else {\n      // Compare N stacks against deployed templates\n      for (const stack of stacks.stackArtifacts) {\n        stream.write(format('Stack %s\\n', colors.bold(stack.displayName)));\n        const currentTemplate = await this.props.cloudFormation.readCurrentTemplate(stack);\n        diffs += options.securityOnly\n          ? numberFromBool(printSecurityDiff(currentTemplate, stack, RequireApproval.Broadening))\n          : printStackDiff(currentTemplate, stack, strict, contextLines, stream);\n      }\n    }\n\n    return diffs && options.fail ? 1 : 0;\n  }\n\n  public async deploy(options: DeployOptions) {\n    if (options.watch) {\n      return this.watch(options);\n    }\n\n    const stacks = await this.selectStacksForDeploy(options.selector, options.exclusively, options.cacheCloudAssembly);\n\n    const requireApproval = options.requireApproval ?? RequireApproval.Broadening;\n\n    const parameterMap: { [name: string]: { [name: string]: string | undefined } } = { '*': {} };\n    for (const key in options.parameters) {\n      if (options.parameters.hasOwnProperty(key)) {\n        const [stack, parameter] = key.split(':', 2);\n        if (!parameter) {\n          parameterMap['*'][stack] = options.parameters[key];\n        } else {\n          if (!parameterMap[stack]) {\n            parameterMap[stack] = {};\n          }\n          parameterMap[stack][parameter] = options.parameters[key];\n        }\n      }\n    }\n\n    if (options.hotswap) {\n      warning('⚠️ The --hotswap flag deliberately introduces CloudFormation drift to speed up deployments');\n      warning('⚠️ It should only be used for development - never use it for your production Stacks!');\n    }\n\n    const stackOutputs: { [key: string]: any } = { };\n    const outputsFile = options.outputsFile;\n\n    for (const stack of stacks.stackArtifacts) {\n      if (stacks.stackCount !== 1) { highlight(stack.displayName); }\n      if (!stack.environment) {\n        // eslint-disable-next-line max-len\n        throw new Error(`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      if (Object.keys(stack.template.Resources || {}).length === 0) { // The generated stack has no resources\n        if (!await this.props.cloudFormation.stackExists({ stack })) {\n          warning('%s: stack has no resources, skipping deployment.', colors.bold(stack.displayName));\n        } else {\n          warning('%s: stack has no resources, deleting existing stack.', colors.bold(stack.displayName));\n          await this.destroy({\n            selector: { patterns: [stack.stackName] },\n            exclusively: true,\n            force: true,\n            roleArn: options.roleArn,\n            fromDeploy: true,\n          });\n        }\n        continue;\n      }\n\n      if (requireApproval !== RequireApproval.Never) {\n        const currentTemplate = await this.props.cloudFormation.readCurrentTemplate(stack);\n        if (printSecurityDiff(currentTemplate, stack, requireApproval)) {\n\n          // only talk to user if STDIN is a terminal (otherwise, fail)\n          if (!process.stdin.isTTY) {\n            throw new Error(\n              '\"--require-approval\" is enabled and stack includes security-sensitive updates, ' +\n              'but terminal (TTY) is not attached so we are unable to get a confirmation from the user');\n          }\n\n          const confirmed = await promptly.confirm('Do you wish to deploy these changes (y/n)?');\n          if (!confirmed) { throw new Error('Aborted by user'); }\n        }\n      }\n\n      print('%s: deploying...', colors.bold(stack.displayName));\n\n      let tags = options.tags;\n      if (!tags || tags.length === 0) {\n        tags = tagsForStack(stack);\n      }\n\n      try {\n        const result = await this.props.cloudFormation.deployStack({\n          stack,\n          deployName: stack.stackName,\n          roleArn: options.roleArn,\n          toolkitStackName: options.toolkitStackName,\n          reuseAssets: options.reuseAssets,\n          notificationArns: options.notificationArns,\n          tags,\n          execute: options.execute,\n          changeSetName: options.changeSetName,\n          force: options.force,\n          parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n          usePreviousParameters: options.usePreviousParameters,\n          progress: options.progress,\n          ci: options.ci,\n          rollback: options.rollback,\n          hotswap: options.hotswap,\n          extraUserAgent: options.extraUserAgent,\n        });\n\n        const message = result.noOp\n          ? ' ✅  %s (no changes)'\n          : ' ✅  %s';\n\n        success('\\n' + message, stack.displayName);\n\n        if (Object.keys(result.outputs).length > 0) {\n          print('\\nOutputs:');\n\n          stackOutputs[stack.stackName] = result.outputs;\n        }\n\n        for (const name of Object.keys(result.outputs).sort()) {\n          const value = result.outputs[name];\n          print('%s.%s = %s', colors.cyan(stack.id), colors.cyan(name), colors.underline(colors.cyan(value)));\n        }\n\n        print('\\nStack ARN:');\n\n        data(result.stackArn);\n      } catch (e) {\n        error('\\n ❌  %s failed: %s', colors.bold(stack.displayName), e);\n        throw e;\n      } finally {\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    }\n  }\n\n  public async watch(options: WatchOptions) {\n    const rootDir = path.dirname(path.resolve(PROJECT_CONFIG));\n    debug(\"root directory used for 'watch' is: %s\", rootDir);\n\n    const watchSettings: { include?: string | string[], exclude: string | string [] } | undefined =\n        this.props.configuration.settings.get(['watch']);\n    if (!watchSettings) {\n      throw new Error(\"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    // For the \"include\" subkey under the \"watch\" key, the behavior is:\n    // 1. No \"watch\" setting? We error out.\n    // 2. \"watch\" setting without an \"include\" key? We default to observing \"./**\".\n    // 3. \"watch\" setting with an empty \"include\" key? We default to observing \"./**\".\n    // 4. Non-empty \"include\" key? Just use the \"include\" key.\n    const watchIncludes = this.patternsArrayForWatch(watchSettings.include, { rootDir, returnRootDirIfEmpty: true });\n    debug(\"'include' patterns for 'watch': %s\", watchIncludes);\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outputDir = this.props.configuration.settings.get(['output']);\n    const watchExcludes = this.patternsArrayForWatch(watchSettings.exclude, { rootDir, returnRootDirIfEmpty: false }).concat(\n      `${outputDir}/**`,\n      '**/.*',\n      '**/.*/**',\n      '**/node_modules/**',\n    );\n    debug(\"'exclude' patterns for 'watch': %s\", watchExcludes);\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    let latch: 'pre-ready' | 'open' | 'deploying' | 'queued' = 'pre-ready';\n    chokidar.watch(watchIncludes, {\n      ignored: watchExcludes,\n      cwd: rootDir,\n      // ignoreInitial: true,\n    }).on('ready', () => {\n      latch = 'open';\n      debug(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\");\n    }).on('all', async (event, filePath) => {\n      if (latch === 'pre-ready') {\n        print(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '%s' for changes`, filePath);\n      } else if (latch === 'open') {\n        latch = 'deploying';\n        print(\"Detected change to '%s' (type: %s). Triggering 'cdk deploy'\", filePath, event);\n        await this.invokeDeployFromWatch(options);\n\n        // If latch is still 'deploying' after the 'await', that's fine,\n        // but if it's 'queued', that means we need to deploy again\n        while ((latch as 'deploying' | 'queued') === 'queued') {\n          // TypeScript doesn't realize latch can change between 'awaits',\n          // and thinks the above 'while' condition is always 'false' without the cast\n          latch = 'deploying';\n          print(\"Detected file changes during deployment. Invoking 'cdk deploy' again\");\n          await this.invokeDeployFromWatch(options);\n        }\n        latch = 'open';\n      } else { // this means latch is either 'deploying' or 'queued'\n        latch = 'queued';\n        print(\"Detected change to '%s' (type: %s) while 'cdk deploy' is still running. \" +\n            'Will queue for another deployment after this one finishes', filePath, event);\n      }\n    });\n  }\n\n  public async destroy(options: DestroyOptions) {\n    let stacks = await this.selectStacksForDestroy(options.selector, options.exclusively);\n\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    stacks = stacks.reversed();\n\n    if (!options.force) {\n      // eslint-disable-next-line max-len\n      const confirmed = await promptly.confirm(`Are you sure you want to delete: ${colors.blue(stacks.stackArtifacts.map(s => s.hierarchicalId).join(', '))} (y/n)?`);\n      if (!confirmed) {\n        return;\n      }\n    }\n\n    const action = options.fromDeploy ? 'deploy' : 'destroy';\n    for (const stack of stacks.stackArtifacts) {\n      success('%s: destroying...', colors.blue(stack.displayName));\n      try {\n        await this.props.cloudFormation.destroyStack({\n          stack,\n          deployName: stack.stackName,\n          roleArn: options.roleArn,\n        });\n        success(`\\n ✅  %s: ${action}ed`, colors.blue(stack.displayName));\n      } catch (e) {\n        error(`\\n ❌  %s: ${action} failed`, colors.blue(stack.displayName), e);\n        throw e;\n      }\n    }\n  }\n\n  public async list(selectors: string[], options: { long?: boolean } = { }) {\n    const stacks = await this.selectStacksForList(selectors);\n\n    // if we are in \"long\" mode, emit the array as-is (JSON/YAML)\n    if (options.long) {\n      const long = [];\n      for (const stack of stacks.stackArtifacts) {\n        long.push({\n          id: stack.hierarchicalId,\n          name: stack.stackName,\n          environment: stack.environment,\n        });\n      }\n      return long; // will be YAML formatted output\n    }\n\n    // just print stack IDs\n    for (const stack of stacks.stackArtifacts) {\n      data(stack.hierarchicalId);\n    }\n\n    return 0; // exit-code\n  }\n\n  /**\n   * Synthesize the given set of stacks (called when the user runs 'cdk synth')\n   *\n   * INPUT: Stack names can be supplied using a glob filter. If no stacks are\n   * given, all stacks from the application are implictly selected.\n   *\n   * OUTPUT: If more than one stack ends up being selected, an output directory\n   * should be supplied, where the templates will be written.\n   */\n  public async synth(stackNames: string[], exclusively: boolean, quiet: boolean, autoValidate?: boolean): Promise<any> {\n    const stacks = await this.selectStacksForDiff(stackNames, exclusively, autoValidate);\n\n    // if we have a single stack, print it to STDOUT\n    if (stacks.stackCount === 1) {\n      if (!quiet) {\n        return stacks.firstStack.template;\n      }\n      return undefined;\n    }\n\n    // This is a slight hack; in integ mode we allow multiple stacks to be synthesized to stdout sequentially.\n    // This is to make it so that we can support multi-stack integ test expectations, without so drastically\n    // having to change the synthesis format that we have to rerun all integ tests.\n    //\n    // Because this feature is not useful to consumers (the output is missing\n    // the stack names), it's not exposed as a CLI flag. Instead, it's hidden\n    // behind an environment variable.\n    const isIntegMode = process.env.CDK_INTEG_MODE === '1';\n    if (isIntegMode) {\n      return stacks.stackArtifacts.map(s => s.template);\n    }\n\n    // not outputting template to stdout, let's explain things to the user a little bit...\n    success(`Successfully synthesized to ${colors.blue(path.resolve(stacks.assembly.directory))}`);\n    print(`Supply a stack id (${stacks.stackArtifacts.map(s => colors.green(s.id)).join(', ')}) to display its template.`);\n\n    return undefined;\n  }\n\n  /**\n   * Bootstrap the CDK Toolkit stack in the accounts used by the specified stack(s).\n   *\n   * @param environmentSpecs environment names that need to have toolkit support\n   *             provisioned, as a glob filter. If none is provided,\n   *             all stacks are implicitly selected.\n   * @param toolkitStackName the name to be used for the CDK Toolkit stack.\n   */\n  public async bootstrap(userEnvironmentSpecs: string[], bootstrapper: Bootstrapper, options: BootstrapEnvironmentOptions): Promise<void> {\n    // If there is an '--app' argument and an environment looks like a glob, we\n    // select the environments from the app. Otherwise use what the user said.\n\n    // By default glob for everything\n    const environmentSpecs = userEnvironmentSpecs.length > 0 ? [...userEnvironmentSpecs] : ['**'];\n\n    // Partition into globs and non-globs (this will mutate environmentSpecs).\n    const globSpecs = partition(environmentSpecs, looksLikeGlob);\n    if (globSpecs.length > 0 && !this.props.cloudExecutable.hasApp) {\n      if (userEnvironmentSpecs.length > 0) {\n        // User did request this glob\n        throw new Error(`'${globSpecs}' is not an environment name. Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json' to use wildcards.`);\n      } else {\n        // User did not request anything\n        throw new Error('Specify an environment name like \\'aws://123456789012/us-east-1\\', or run in a directory with \\'cdk.json\\'.');\n      }\n    }\n\n    const environments: cxapi.Environment[] = [\n      ...environmentsFromDescriptors(environmentSpecs),\n    ];\n\n    // If there is an '--app' argument, select the environments from the app.\n    if (this.props.cloudExecutable.hasApp) {\n      environments.push(...await globEnvironmentsFromStacks(await this.selectStacksForList([]), globSpecs, this.props.sdkProvider));\n    }\n\n    await Promise.all(environments.map(async (environment) => {\n      success(' ⏳  Bootstrapping environment %s...', colors.blue(environment.name));\n      try {\n        const result = await bootstrapper.bootstrapEnvironment(environment, this.props.sdkProvider, options);\n        const message = result.noOp\n          ? ' ✅  Environment %s bootstrapped (no changes).'\n          : ' ✅  Environment %s bootstrapped.';\n        success(message, colors.blue(environment.name));\n      } catch (e) {\n        error(' ❌  Environment %s failed bootstrapping: %s', colors.blue(environment.name), e);\n        throw e;\n      }\n    }));\n  }\n\n  private async selectStacksForList(patterns: string[]) {\n    const assembly = await this.assembly();\n    const stacks = await assembly.selectStacks({ patterns }, { defaultBehavior: DefaultSelection.AllStacks });\n\n    // No validation\n\n    return stacks;\n  }\n\n  private async selectStacksForDeploy(selector: StackSelector, exclusively?: boolean, cacheCloudAssembly?: boolean): Promise<StackCollection> {\n    const assembly = await this.assembly(cacheCloudAssembly);\n    const stacks = await assembly.selectStacks(selector, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Upstream,\n      defaultBehavior: DefaultSelection.OnlySingle,\n    });\n\n    this.validateStacksSelected(stacks, selector.patterns);\n    this.validateStacks(stacks);\n\n    return stacks;\n  }\n\n  private async selectStacksForDiff(stackNames: string[], exclusively?: boolean, autoValidate?: boolean): Promise<StackCollection> {\n    const assembly = await this.assembly();\n\n    const selectedForDiff = await assembly.selectStacks({ patterns: stackNames }, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Upstream,\n      defaultBehavior: DefaultSelection.MainAssembly,\n    });\n\n    const allStacks = await this.selectStacksForList([]);\n    const autoValidateStacks = autoValidate\n      ? allStacks.filter(art => art.validateOnSynth ?? false)\n      : new StackCollection(assembly, []);\n\n    this.validateStacksSelected(selectedForDiff.concat(autoValidateStacks), stackNames);\n    this.validateStacks(selectedForDiff.concat(autoValidateStacks));\n\n    return selectedForDiff;\n  }\n\n  private async selectStacksForDestroy(selector: StackSelector, exclusively?: boolean) {\n    const assembly = await this.assembly();\n    const stacks = await assembly.selectStacks(selector, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Downstream,\n      defaultBehavior: DefaultSelection.OnlySingle,\n    });\n\n    // No validation\n\n    return stacks;\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private validateStacks(stacks: StackCollection) {\n    stacks.processMetadataMessages({\n      ignoreErrors: this.props.ignoreErrors,\n      strict: this.props.strict,\n      verbose: this.props.verbose,\n    });\n  }\n\n  /**\n   * Validate that if a user specified a stack name there exists at least 1 stack selected\n   */\n  private validateStacksSelected(stacks: StackCollection, stackNames: string[]) {\n    if (stackNames.length != 0 && stacks.stackCount == 0) {\n      throw new Error(`No stacks match the name(s) ${stackNames}`);\n    }\n  }\n\n  /**\n   * Select a single stack by its name\n   */\n  private async selectSingleStackByName(stackName: string) {\n    const assembly = await this.assembly();\n\n    const stacks = await assembly.selectStacks({ patterns: [stackName] }, {\n      extend: ExtendedStackSelection.None,\n      defaultBehavior: DefaultSelection.None,\n    });\n\n    // Could have been a glob so check that we evaluated to exactly one\n    if (stacks.stackCount > 1) {\n      throw new Error(`This command requires exactly one stack and we matched more than one: ${stacks.stackIds}`);\n    }\n\n    return assembly.stackById(stacks.firstStack.id);\n  }\n\n  private assembly(cacheCloudAssembly?: boolean): Promise<CloudAssembly> {\n    return this.props.cloudExecutable.synthesize(cacheCloudAssembly);\n  }\n\n  private patternsArrayForWatch(patterns: string | string[] | undefined, options: { rootDir: string, returnRootDirIfEmpty: boolean }): string[] {\n    const patternsArray: string[] = patterns !== undefined\n      ? (Array.isArray(patterns) ? patterns : [patterns])\n      : [];\n    return patternsArray.length > 0\n      ? patternsArray\n      : (options.returnRootDirIfEmpty ? [options.rootDir] : []);\n  }\n\n  private async invokeDeployFromWatch(options: WatchOptions): Promise<void> {\n    // 'watch' has different defaults than regular 'deploy'\n    const hotswap = options.hotswap === undefined ? true : options.hotswap;\n    const deployOptions: DeployOptions = {\n      ...options,\n      requireApproval: RequireApproval.Never,\n      // if 'watch' is called by invoking 'cdk deploy --watch',\n      // we need to make sure to not call 'deploy' with 'watch' again,\n      // as that would lead to a cycle\n      watch: false,\n      cacheCloudAssembly: false,\n      hotswap: hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${hotswap ? 'on' : 'off'}`,\n    };\n\n    try {\n      await this.deploy(deployOptions);\n    } catch (e) {\n      // just continue - deploy will show the error\n    }\n  }\n}\n\nexport interface DiffOptions {\n  /**\n   * Stack names to diff\n   */\n  stackNames: string[];\n\n  /**\n   * Only select the given stack\n   *\n   * @default false\n   */\n  exclusively?: boolean;\n\n  /**\n   * Used a template from disk instead of from the server\n   *\n   * @default Use from the server\n   */\n  templatePath?: string;\n\n  /**\n   * Strict diff mode\n   *\n   * @default false\n   */\n  strict?: boolean;\n\n  /**\n   * How many lines of context to show in the diff\n   *\n   * @default 3\n   */\n  contextLines?: number;\n\n  /**\n   * Where to write the default\n   *\n   * @default stderr\n   */\n  stream?: NodeJS.WritableStream;\n\n  /**\n   * Whether to fail with exit code 1 in case of diff\n   *\n   * @default false\n   */\n  fail?: boolean;\n\n  /**\n   * Only run diff on broadened security changes\n   *\n   * @default false\n   */\n  securityOnly?: boolean;\n}\n\ninterface WatchOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  selector: StackSelector;\n\n  /**\n   * Only select the given stack\n   *\n   * @default false\n   */\n  exclusively?: boolean;\n\n  /**\n   * Name of the toolkit stack to use/deploy\n   *\n   * @default CDKToolkit\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Role to pass to CloudFormation for deployment\n   */\n  roleArn?: string;\n\n  /**\n   * Reuse the assets with the given asset IDs\n   */\n  reuseAssets?: string[];\n\n  /**\n   * Optional name to use for the CloudFormation change set.\n   * If not provided, a name will be generated automatically.\n   */\n  changeSetName?: string;\n\n  /**\n   * Always deploy, even if templates are identical.\n   * @default false\n   */\n  force?: boolean;\n\n  /**\n   * Display mode for stack deployment progress.\n   *\n   * @default - StackActivityProgress.Bar - stack events will be displayed for\n   *   the resource currently being deployed.\n   */\n  progress?: StackActivityProgress;\n\n  /**\n   * Rollback failed deployments\n   *\n   * @default true\n   */\n  readonly rollback?: boolean;\n\n  /**\n   * Whether to perform a 'hotswap' deployment.\n   * A 'hotswap' deployment will attempt to short-circuit CloudFormation\n   * and update the affected resources like Lambda functions directly.\n   *\n   * @default - false for regular deployments, true for 'watch' deployments\n   */\n  readonly hotswap?: boolean;\n\n  /**\n   * The extra string to append to the User-Agent header when performing AWS SDK calls.\n   *\n   * @default - nothing extra is appended to the User-Agent header\n   */\n  readonly extraUserAgent?: string;\n}\n\nexport interface DeployOptions extends WatchOptions {\n  /**\n   * ARNs of SNS topics that CloudFormation will notify with stack related events\n   */\n  notificationArns?: string[];\n\n  /**\n   * What kind of security changes require approval\n   *\n   * @default RequireApproval.Broadening\n   */\n  requireApproval?: RequireApproval;\n\n  /**\n   * Tags to pass to CloudFormation for deployment\n   */\n  tags?: Tag[];\n\n  /**\n   * Whether to execute the ChangeSet\n   * Not providing `execute` parameter will result in execution of ChangeSet\n   * @default true\n   */\n  execute?: boolean;\n\n  /**\n   * Additional parameters for CloudFormation at deploy time\n   * @default {}\n   */\n  parameters?: { [name: string]: string | undefined };\n\n  /**\n   * Use previous values for unspecified parameters\n   *\n   * If not set, all parameters must be specified for every deployment.\n   *\n   * @default true\n   */\n  usePreviousParameters?: boolean;\n\n  /**\n   * Path to file where stack outputs will be written after a successful deploy as JSON\n   * @default - Outputs are not written to any file\n   */\n  outputsFile?: string;\n\n  /**\n   * Whether we are on a CI system\n   *\n   * @default false\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Whether this 'deploy' command should actually delegate to the 'watch' command.\n   *\n   * @default false\n   */\n  readonly watch?: boolean;\n\n  /**\n   * Whether we should cache the Cloud Assembly after the first time it has been synthesized.\n   * The default is 'true', we only don't want to do it in case the deployment is triggered by\n   * 'cdk watch'.\n   *\n   * @default true\n   */\n  readonly cacheCloudAssembly?: boolean;\n}\n\nexport interface DestroyOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  selector: StackSelector;\n\n  /**\n   * Whether to exclude stacks that depend on the stacks to be deleted\n   */\n  exclusively: boolean;\n\n  /**\n   * Whether to skip prompting for confirmation\n   */\n  force: boolean;\n\n  /**\n   * The arn of the IAM role to use\n   */\n  roleArn?: string;\n\n  /**\n   * Whether the destroy request came from a deploy.\n   */\n  fromDeploy?: boolean\n}\n\n/**\n * @returns an array with the tags available in the stack metadata.\n */\nfunction tagsForStack(stack: cxapi.CloudFormationStackArtifact): Tag[] {\n  return Object.entries(stack.tags).map(([Key, Value]) => ({ Key, Value }));\n}\n\nexport interface Tag {\n  readonly Key: string;\n  readonly Value: string;\n}\n"]}
509
+ /**
510
+ * Formats time in milliseconds (which we get from 'Date.getTime()')
511
+ * to a human-readable time; returns time in seconds rounded to 2
512
+ * decimal places.
513
+ */
514
+ function formatTime(num) {
515
+ return roundPercentage(millisecondsToSeconds(num));
516
+ }
517
+ /**
518
+ * Rounds a decimal number to two decimal points.
519
+ * The function is useful for fractions that need to be outputted as percentages.
520
+ */
521
+ function roundPercentage(num) {
522
+ return Math.round(100 * num) / 100;
523
+ }
524
+ /**
525
+ * Given a time in miliseconds, return an equivalent amount in seconds.
526
+ */
527
+ function millisecondsToSeconds(num) {
528
+ return num / 1000;
529
+ }
530
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-toolkit.js","sourceRoot":"","sources":["cdk-toolkit.ts"],"names":[],"mappings":";;;AAAA,6BAA6B;AAC7B,+BAA8B;AAE9B,qCAAqC;AACrC,+BAA+B;AAC/B,+BAA+B;AAC/B,qCAAqC;AACrC,gEAAuH;AAIvH,+DAAqI;AAGrI,iCAA4E;AAC5E,uCAAmF;AACnF,2CAAmD;AACnD,yCAA2D;AAC3D,iCAAmD;AA8CnD;;;;;GAKG;AACH,MAAa,UAAU;IACrB,YAA6B,KAAsB;QAAtB,UAAK,GAAL,KAAK,CAAiB;IACnD,CAAC;IAEM,KAAK,CAAC,QAAQ,CAAC,SAAiB;;QACrC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC;QAC7D,aAAO,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,mCAAI,EAAE,CAAC;IACnD,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,OAAoB;QACpC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;QAEvF,MAAM,MAAM,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;QAChC,MAAM,YAAY,GAAG,OAAO,CAAC,YAAY,IAAI,CAAC,CAAC;QAC/C,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,MAAM,CAAC;QAEhD,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,OAAO,CAAC,YAAY,KAAK,SAAS,EAAE;YACtC,8CAA8C;YAC9C,IAAI,MAAM,CAAC,UAAU,KAAK,CAAC,EAAE;gBAC3B,MAAM,IAAI,KAAK,CAAC,mHAAmH,CAAC,CAAC;aACtI;YAED,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE;gBAC9C,MAAM,IAAI,KAAK,CAAC,uBAAuB,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;aAChE;YACD,MAAM,QAAQ,GAAG,gCAAoB,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;YACtG,KAAK,GAAG,OAAO,CAAC,YAAY;gBAC1B,CAAC,CAAC,qBAAc,CAAC,wBAAiB,CAAC,QAAQ,EAAE,MAAM,CAAC,UAAU,EAAE,sBAAe,CAAC,UAAU,CAAC,CAAC;gBAC5F,CAAC,CAAC,qBAAc,CAAC,QAAQ,EAAE,MAAM,CAAC,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;SAC/E;aAAM;YACL,8CAA8C;YAC9C,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,cAAc,EAAE;gBACzC,MAAM,CAAC,KAAK,CAAC,aAAM,CAAC,YAAY,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBAClE,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;gBACnF,KAAK,IAAI,OAAO,CAAC,YAAY;oBAC3B,CAAC,CAAC,qBAAc,CAAC,wBAAiB,CAAC,eAAe,EAAE,KAAK,EAAE,sBAAe,CAAC,UAAU,CAAC,CAAC;oBACvF,CAAC,CAAC,qBAAc,CAAC,eAAe,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;aAC1E;SACF;QAED,OAAO,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,OAAsB;;QACxC,IAAI,OAAO,CAAC,KAAK,EAAE;YACjB,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;SAC5B;QAED,MAAM,cAAc,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;QAC5C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;QACnH,MAAM,gBAAgB,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,cAAc,CAAC;QAC/D,eAAK,CAAC,4BAA4B,EAAE,UAAU,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAElE,MAAM,eAAe,SAAG,OAAO,CAAC,eAAe,mCAAI,sBAAe,CAAC,UAAU,CAAC;QAE9E,MAAM,YAAY,GAA+D,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC;QAC7F,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,UAAU,EAAE;YACpC,IAAI,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;gBAC1C,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;gBAC7C,IAAI,CAAC,SAAS,EAAE;oBACd,YAAY,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;iBACpD;qBAAM;oBACL,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE;wBACxB,YAAY,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;qBAC1B;oBACD,YAAY,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;iBAC1D;aACF;SACF;QAED,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,iBAAO,CAAC,4FAA4F,CAAC,CAAC;YACtG,iBAAO,CAAC,sFAAsF,CAAC,CAAC;SACjG;QAED,MAAM,YAAY,GAA2B,EAAG,CAAC;QACjD,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;QAExC,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,cAAc,EAAE;YACzC,IAAI,MAAM,CAAC,UAAU,KAAK,CAAC,EAAE;gBAAE,mBAAS,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;aAAE;YAC9D,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;gBACtB,mCAAmC;gBACnC,MAAM,IAAI,KAAK,CAAC,SAAS,KAAK,CAAC,WAAW,iIAAiI,CAAC,CAAC;aAC9K;YAED,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,EAAE,uCAAuC;gBACrG,IAAI,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;oBAC3D,iBAAO,CAAC,kDAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;iBAC5F;qBAAM;oBACL,iBAAO,CAAC,sDAAsD,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;oBAC/F,MAAM,IAAI,CAAC,OAAO,CAAC;wBACjB,QAAQ,EAAE,EAAE,QAAQ,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;wBACzC,WAAW,EAAE,IAAI;wBACjB,KAAK,EAAE,IAAI;wBACX,OAAO,EAAE,OAAO,CAAC,OAAO;wBACxB,UAAU,EAAE,IAAI;qBACjB,CAAC,CAAC;iBACJ;gBACD,SAAS;aACV;YAED,IAAI,eAAe,KAAK,sBAAe,CAAC,KAAK,EAAE;gBAC7C,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;gBACnF,IAAI,wBAAiB,CAAC,eAAe,EAAE,KAAK,EAAE,eAAe,CAAC,EAAE;oBAE9D,6DAA6D;oBAC7D,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE;wBACxB,MAAM,IAAI,KAAK,CACb,iFAAiF;4BACjF,yFAAyF,CAAC,CAAC;qBAC9F;oBAED,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,4CAA4C,CAAC,CAAC;oBACvF,IAAI,CAAC,SAAS,EAAE;wBAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;qBAAE;iBACxD;aACF;YAED,eAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;YACzD,MAAM,eAAe,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;YAE7C,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;YACxB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;gBAC9B,IAAI,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;aAC5B;YAED,IAAI,iBAAiB,GAAG,CAAC,CAAC;YAC1B,IAAI;gBACF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC;oBACzD,KAAK;oBACL,UAAU,EAAE,KAAK,CAAC,SAAS;oBAC3B,OAAO,EAAE,OAAO,CAAC,OAAO;oBACxB,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;oBAC1C,WAAW,EAAE,OAAO,CAAC,WAAW;oBAChC,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;oBAC1C,IAAI;oBACJ,OAAO,EAAE,OAAO,CAAC,OAAO;oBACxB,aAAa,EAAE,OAAO,CAAC,aAAa;oBACpC,KAAK,EAAE,OAAO,CAAC,KAAK;oBACpB,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,YAAY,CAAC,GAAG,CAAC,EAAE,YAAY,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;oBAC/E,qBAAqB,EAAE,OAAO,CAAC,qBAAqB;oBACpD,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,EAAE,EAAE,OAAO,CAAC,EAAE;oBACd,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,OAAO,EAAE,OAAO,CAAC,OAAO;oBACxB,cAAc,EAAE,OAAO,CAAC,cAAc;iBACvC,CAAC,CAAC;gBAEH,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI;oBACzB,CAAC,CAAC,qBAAqB;oBACvB,CAAC,CAAC,QAAQ,CAAC;gBAEb,iBAAO,CAAC,IAAI,GAAG,OAAO,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC;gBAC3C,iBAAiB,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,eAAe,CAAC;gBAC3D,eAAK,CAAC,6BAA6B,EAAE,UAAU,CAAC,iBAAiB,CAAC,CAAC,CAAC;gBAEpE,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;oBAC1C,eAAK,CAAC,UAAU,CAAC,CAAC;oBAElB,YAAY,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC;iBAChD;gBAED,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;oBACrD,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;oBACnC,eAAK,CAAC,YAAY,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;iBACjG;gBAED,eAAK,CAAC,YAAY,CAAC,CAAC;gBAEpB,cAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;aACvB;YAAC,OAAO,CAAC,EAAE;gBACV,eAAK,CAAC,qBAAqB,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC/D,MAAM,CAAC,CAAC;aACT;oBAAS;gBACR,kGAAkG;gBAClG,wFAAwF;gBACxF,iGAAiG;gBACjG,IAAI,WAAW,EAAE;oBACf,EAAE,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;oBAC/B,MAAM,EAAE,CAAC,SAAS,CAAC,WAAW,EAAE,YAAY,EAAE;wBAC5C,MAAM,EAAE,CAAC;wBACT,QAAQ,EAAE,MAAM;qBACjB,CAAC,CAAC;iBACJ;aACF;YACD,eAAK,CAAC,wBAAwB,EAAE,UAAU,CAAC,gBAAgB,GAAG,iBAAiB,CAAC,CAAC,CAAC;SACnF;IACH,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,OAAqB;QACtC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,yBAAc,CAAC,CAAC,CAAC;QAC3D,eAAK,CAAC,wCAAwC,EAAE,OAAO,CAAC,CAAC;QAEzD,MAAM,aAAa,GACf,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,aAAa,EAAE;YAClB,MAAM,IAAI,KAAK,CAAC,uFAAuF;gBACrG,iDAAiD,CAAC,CAAC;SACtD;QAED,mEAAmE;QACnE,uCAAuC;QACvC,+EAA+E;QAC/E,kFAAkF;QAClF,0DAA0D;QAC1D,MAAM,aAAa,GAAG,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,oBAAoB,EAAE,IAAI,EAAE,CAAC,CAAC;QACjH,eAAK,CAAC,oCAAoC,EAAE,aAAa,CAAC,CAAC;QAE3D,kDAAkD;QAClD,8FAA8F;QAC9F,+BAA+B;QAC/B,4CAA4C;QAC5C,2DAA2D;QAC3D,qHAAqH;QACrH,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QACpE,MAAM,aAAa,GAAG,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,oBAAoB,EAAE,KAAK,EAAE,CAAC,CAAC,MAAM,CACtH,GAAG,SAAS,KAAK,EACjB,OAAO,EACP,UAAU,EACV,oBAAoB,CACrB,CAAC;QACF,eAAK,CAAC,oCAAoC,EAAE,aAAa,CAAC,CAAC;QAE3D,2EAA2E;QAC3E,uDAAuD;QACvD,iFAAiF;QACjF,uFAAuF;QACvF,2DAA2D;QAC3D,kDAAkD;QAClD,6HAA6H;QAC7H,+HAA+H;QAC/H,+HAA+H;QAC/H,+HAA+H;QAC/H,+GAA+G;QAC/G,IAAI,KAAK,GAAkD,WAAW,CAAC;QAEvE,MAAM,cAAc,GAAG,KAAK,IAAI,EAAE;YAChC,KAAK,GAAG,WAAW,CAAC;YAEpB,MAAM,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;YAE1C,gEAAgE;YAChE,2DAA2D;YAC3D,OAAQ,KAAgC,KAAK,QAAQ,EAAE;gBACrD,gEAAgE;gBAChE,4EAA4E;gBAC5E,KAAK,GAAG,WAAW,CAAC;gBACpB,eAAK,CAAC,sEAAsE,CAAC,CAAC;gBAC9E,MAAM,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;aAC3C;YACD,KAAK,GAAG,MAAM,CAAC;QACjB,CAAC,CAAC;QAEF,QAAQ,CAAC,KAAK,CAAC,aAAa,EAAE;YAC5B,OAAO,EAAE,aAAa;YACtB,GAAG,EAAE,OAAO;SAEb,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,KAAK,IAAI,EAAE;YACxB,KAAK,GAAG,MAAM,CAAC;YACf,eAAK,CAAC,6FAA6F,CAAC,CAAC;YACrG,eAAK,CAAC,iCAAiC,CAAC,CAAC;YACzC,MAAM,cAAc,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,KAA2D,EAAE,QAAiB,EAAE,EAAE;YACpG,IAAI,KAAK,KAAK,WAAW,EAAE;gBACzB,eAAK,CAAC,wBAAwB,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,mBAAmB,EAAE,QAAQ,CAAC,CAAC;aAC3G;iBAAM,IAAI,KAAK,KAAK,MAAM,EAAE;gBAC3B,eAAK,CAAC,6DAA6D,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;gBACtF,MAAM,cAAc,EAAE,CAAC;aACxB;iBAAM,EAAE,qDAAqD;gBAC5D,KAAK,GAAG,QAAQ,CAAC;gBACjB,eAAK,CAAC,0EAA0E;oBAC5E,2DAA2D,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;aACnF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,OAAuB;QAC1C,IAAI,MAAM,GAAG,MAAM,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;QAEtF,kFAAkF;QAClF,MAAM,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;QAE3B,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;YAClB,mCAAmC;YACnC,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,oCAAoC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC;YAC/J,IAAI,CAAC,SAAS,EAAE;gBACd,OAAO;aACR;SACF;QAED,MAAM,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;QACzD,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,cAAc,EAAE;YACzC,iBAAO,CAAC,mBAAmB,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;YAC5D,IAAI;gBACF,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,YAAY,CAAC;oBAC3C,KAAK;oBACL,UAAU,EAAE,KAAK,CAAC,SAAS;oBAC3B,OAAO,EAAE,OAAO,CAAC,OAAO;iBACzB,CAAC,CAAC;gBACH,iBAAO,CAAC,aAAa,MAAM,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;aACjE;YAAC,OAAO,CAAC,EAAE;gBACV,eAAK,CAAC,aAAa,MAAM,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;gBACtE,MAAM,CAAC,CAAC;aACT;SACF;IACH,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,SAAmB,EAAE,UAA8B,EAAG;QACtE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC;QAEzD,6DAA6D;QAC7D,IAAI,OAAO,CAAC,IAAI,EAAE;YAChB,MAAM,IAAI,GAAG,EAAE,CAAC;YAChB,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,cAAc,EAAE;gBACzC,IAAI,CAAC,IAAI,CAAC;oBACR,EAAE,EAAE,KAAK,CAAC,cAAc;oBACxB,IAAI,EAAE,KAAK,CAAC,SAAS;oBACrB,WAAW,EAAE,KAAK,CAAC,WAAW;iBAC/B,CAAC,CAAC;aACJ;YACD,OAAO,IAAI,CAAC,CAAC,gCAAgC;SAC9C;QAED,uBAAuB;QACvB,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,cAAc,EAAE;YACzC,cAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;SAC5B;QAED,OAAO,CAAC,CAAC,CAAC,YAAY;IACxB,CAAC;IAED;;;;;;;;OAQG;IACI,KAAK,CAAC,KAAK,CAAC,UAAoB,EAAE,WAAoB,EAAE,KAAc,EAAE,YAAsB;QACnG,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;QAErF,gDAAgD;QAChD,IAAI,MAAM,CAAC,UAAU,KAAK,CAAC,EAAE;YAC3B,IAAI,CAAC,KAAK,EAAE;gBACV,OAAO,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;aACnC;YACD,OAAO,SAAS,CAAC;SAClB;QAED,0GAA0G;QAC1G,wGAAwG;QACxG,+EAA+E;QAC/E,EAAE;QACF,yEAAyE;QACzE,yEAAyE;QACzE,kCAAkC;QAClC,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,KAAK,GAAG,CAAC;QACvD,IAAI,WAAW,EAAE;YACf,OAAO,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;SACnD;QAED,sFAAsF;QACtF,iBAAO,CAAC,+BAA+B,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;QAC9F,eAAK,CAAC,sBAAsB,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;QAEtH,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;;;;;OAOG;IACI,KAAK,CAAC,SAAS,CAAC,oBAA8B,EAAE,YAA0B,EAAE,OAAoC;QACrH,2EAA2E;QAC3E,0EAA0E;QAE1E,iCAAiC;QACjC,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAE9F,0EAA0E;QAC1E,MAAM,SAAS,GAAG,gBAAS,CAAC,gBAAgB,EAAE,4BAAa,CAAC,CAAC;QAC7D,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,EAAE;YAC9D,IAAI,oBAAoB,CAAC,MAAM,GAAG,CAAC,EAAE;gBACnC,6BAA6B;gBAC7B,MAAM,IAAI,KAAK,CAAC,IAAI,SAAS,wJAAwJ,CAAC,CAAC;aACxL;iBAAM;gBACL,gCAAgC;gBAChC,MAAM,IAAI,KAAK,CAAC,6GAA6G,CAAC,CAAC;aAChI;SACF;QAED,MAAM,YAAY,GAAwB;YACxC,GAAG,0CAA2B,CAAC,gBAAgB,CAAC;SACjD,CAAC;QAEF,yEAAyE;QACzE,IAAI,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,EAAE;YACrC,YAAY,CAAC,IAAI,CAAC,GAAG,MAAM,yCAA0B,CAAC,MAAM,IAAI,CAAC,mBAAmB,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;SAC/H;QAED,MAAM,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,EAAE,WAAW,EAAE,EAAE;YACvD,iBAAO,CAAC,qCAAqC,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;YAC7E,IAAI;gBACF,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,oBAAoB,CAAC,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;gBACrG,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI;oBACzB,CAAC,CAAC,+CAA+C;oBACjD,CAAC,CAAC,kCAAkC,CAAC;gBACvC,iBAAO,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;aAChD;YAAC,OAAO,CAAC,EAAE;gBACV,eAAK,CAAC,6CAA6C,EAAE,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;gBACtF,MAAM,CAAC,CAAC;aACT;QACH,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,KAAK,CAAC,mBAAmB,CAAC,QAAkB;QAClD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;QACvC,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,eAAe,EAAE,iCAAgB,CAAC,SAAS,EAAE,CAAC,CAAC;QAE1G,gBAAgB;QAEhB,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,KAAK,CAAC,qBAAqB,CAAC,QAAuB,EAAE,WAAqB,EAAE,kBAA4B;QAC9G,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;QACzD,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE;YACnD,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,uCAAsB,CAAC,IAAI,CAAC,CAAC,CAAC,uCAAsB,CAAC,QAAQ;YACnF,eAAe,EAAE,iCAAgB,CAAC,UAAU;SAC7C,CAAC,CAAC;QAEH,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACvD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAE5B,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,KAAK,CAAC,mBAAmB,CAAC,UAAoB,EAAE,WAAqB,EAAE,YAAsB;QACnG,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;QAEvC,MAAM,eAAe,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE;YAC5E,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,uCAAsB,CAAC,IAAI,CAAC,CAAC,CAAC,uCAAsB,CAAC,QAAQ;YACnF,eAAe,EAAE,iCAAgB,CAAC,YAAY;SAC/C,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC;QACrD,MAAM,kBAAkB,GAAG,YAAY;YACrC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,wBAAC,GAAG,CAAC,eAAe,mCAAI,KAAK,GAAA,CAAC;YACvD,CAAC,CAAC,IAAI,gCAAe,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAEtC,IAAI,CAAC,sBAAsB,CAAC,eAAe,CAAC,MAAM,CAAC,kBAAkB,CAAC,EAAE,UAAU,CAAC,CAAC;QACpF,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC;QAEhE,OAAO,eAAe,CAAC;IACzB,CAAC;IAEO,KAAK,CAAC,sBAAsB,CAAC,QAAuB,EAAE,WAAqB;QACjF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;QACvC,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE;YACnD,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,uCAAsB,CAAC,IAAI,CAAC,CAAC,CAAC,uCAAsB,CAAC,UAAU;YACrF,eAAe,EAAE,iCAAgB,CAAC,UAAU;SAC7C,CAAC,CAAC;QAEH,gBAAgB;QAEhB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,MAAuB;QAC5C,MAAM,CAAC,uBAAuB,CAAC;YAC7B,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;YACrC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;YACzB,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO;SAC5B,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACK,sBAAsB,CAAC,MAAuB,EAAE,UAAoB;QAC1E,IAAI,UAAU,CAAC,MAAM,IAAI,CAAC,IAAI,MAAM,CAAC,UAAU,IAAI,CAAC,EAAE;YACpD,MAAM,IAAI,KAAK,CAAC,+BAA+B,UAAU,EAAE,CAAC,CAAC;SAC9D;IACH,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,uBAAuB,CAAC,SAAiB;QACrD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;QAEvC,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE;YACpE,MAAM,EAAE,uCAAsB,CAAC,IAAI;YACnC,eAAe,EAAE,iCAAgB,CAAC,IAAI;SACvC,CAAC,CAAC;QAEH,mEAAmE;QACnE,IAAI,MAAM,CAAC,UAAU,GAAG,CAAC,EAAE;YACzB,MAAM,IAAI,KAAK,CAAC,yEAAyE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;SAC7G;QAED,OAAO,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IAClD,CAAC;IAEO,QAAQ,CAAC,kBAA4B;QAC3C,OAAO,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC;IACnE,CAAC;IAEO,qBAAqB,CAAC,QAAuC,EAAE,OAA2D;QAChI,MAAM,aAAa,GAAa,QAAQ,KAAK,SAAS;YACpD,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YACnD,CAAC,CAAC,EAAE,CAAC;QACP,OAAO,aAAa,CAAC,MAAM,GAAG,CAAC;YAC7B,CAAC,CAAC,aAAa;YACf,CAAC,CAAC,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IAC9D,CAAC;IAEO,KAAK,CAAC,qBAAqB,CAAC,OAAqB;QACvD,uDAAuD;QACvD,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;QACvE,MAAM,aAAa,GAAkB;YACnC,GAAG,OAAO;YACV,eAAe,EAAE,sBAAe,CAAC,KAAK;YACtC,yDAAyD;YACzD,gEAAgE;YAChE,gCAAgC;YAChC,KAAK,EAAE,KAAK;YACZ,kBAAkB,EAAE,KAAK;YACzB,OAAO,EAAE,OAAO;YAChB,cAAc,EAAE,qBAAqB,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE;SAC9D,CAAC;QAEF,IAAI;YACF,MAAM,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;SAClC;QAAC,OAAO,CAAC,EAAE;YACV,6CAA6C;SAC9C;IACH,CAAC;CACF;AAniBD,gCAmiBC;AAqOD;;GAEG;AACH,SAAS,YAAY,CAAC,KAAwC;IAC5D,OAAO,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;AAC5E,CAAC;AAOD;;;;GAIG;AACH,SAAS,UAAU,CAAC,GAAW;IAC7B,OAAO,eAAe,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC;AACrD,CAAC;AAED;;;GAGG;AACH,SAAS,eAAe,CAAC,GAAW;IAClC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC;AACrC,CAAC;AAED;;GAEG;AACH,SAAS,qBAAqB,CAAC,GAAW;IACxC,OAAO,GAAG,GAAG,IAAI,CAAC;AACpB,CAAC","sourcesContent":["import * as path from 'path';\nimport { format } from 'util';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as chokidar from 'chokidar';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport * as promptly from 'promptly';\nimport { environmentsFromDescriptors, globEnvironmentsFromStacks, looksLikeGlob } from '../lib/api/cxapp/environments';\nimport { SdkProvider } from './api/aws-auth';\nimport { Bootstrapper, BootstrapEnvironmentOptions } from './api/bootstrap';\nimport { CloudFormationDeployments } from './api/cloudformation-deployments';\nimport { CloudAssembly, DefaultSelection, ExtendedStackSelection, StackCollection, StackSelector } from './api/cxapp/cloud-assembly';\nimport { CloudExecutable } from './api/cxapp/cloud-executable';\nimport { StackActivityProgress } from './api/util/cloudformation/stack-activity-monitor';\nimport { printSecurityDiff, printStackDiff, RequireApproval } from './diff';\nimport { data, debug, error, highlight, print, success, warning } from './logging';\nimport { deserializeStructure } from './serialize';\nimport { Configuration, PROJECT_CONFIG } from './settings';\nimport { numberFromBool, partition } from './util';\n\nexport interface CdkToolkitProps {\n\n  /**\n   * The Cloud Executable\n   */\n  cloudExecutable: CloudExecutable;\n\n  /**\n   * The provisioning engine used to apply changes to the cloud\n   */\n  cloudFormation: CloudFormationDeployments;\n\n  /**\n   * Whether to be verbose\n   *\n   * @default false\n   */\n  verbose?: boolean;\n\n  /**\n   * Don't stop on error metadata\n   *\n   * @default false\n   */\n  ignoreErrors?: boolean;\n\n  /**\n   * Treat warnings in metadata as errors\n   *\n   * @default false\n   */\n  strict?: boolean;\n\n  /**\n   * Application configuration (settings and context)\n   */\n  configuration: Configuration;\n\n  /**\n   * AWS object (used by synthesizer and contextprovider)\n   */\n  sdkProvider: SdkProvider;\n}\n\n/**\n * Toolkit logic\n *\n * The toolkit runs the `cloudExecutable` to obtain a cloud assembly and\n * deploys applies them to `cloudFormation`.\n */\nexport class CdkToolkit {\n  constructor(private readonly props: CdkToolkitProps) {\n  }\n\n  public async metadata(stackName: string) {\n    const stacks = await this.selectSingleStackByName(stackName);\n    return stacks.firstStack.manifest.metadata ?? {};\n  }\n\n  public async diff(options: DiffOptions): Promise<number> {\n    const stacks = await this.selectStacksForDiff(options.stackNames, options.exclusively);\n\n    const strict = !!options.strict;\n    const contextLines = options.contextLines || 3;\n    const stream = options.stream || process.stderr;\n\n    let diffs = 0;\n    if (options.templatePath !== undefined) {\n      // Compare single stack against fixed template\n      if (stacks.stackCount !== 1) {\n        throw new Error('Can only select one stack when comparing to fixed template. Use --exclusively to avoid selecting multiple stacks.');\n      }\n\n      if (!await fs.pathExists(options.templatePath)) {\n        throw new Error(`There is no file at ${options.templatePath}`);\n      }\n      const template = deserializeStructure(await fs.readFile(options.templatePath, { encoding: 'UTF-8' }));\n      diffs = options.securityOnly\n        ? numberFromBool(printSecurityDiff(template, stacks.firstStack, RequireApproval.Broadening))\n        : printStackDiff(template, stacks.firstStack, strict, contextLines, stream);\n    } else {\n      // Compare N stacks against deployed templates\n      for (const stack of stacks.stackArtifacts) {\n        stream.write(format('Stack %s\\n', chalk.bold(stack.displayName)));\n        const currentTemplate = await this.props.cloudFormation.readCurrentTemplate(stack);\n        diffs += options.securityOnly\n          ? numberFromBool(printSecurityDiff(currentTemplate, stack, RequireApproval.Broadening))\n          : printStackDiff(currentTemplate, stack, strict, contextLines, stream);\n      }\n    }\n\n    return diffs && options.fail ? 1 : 0;\n  }\n\n  public async deploy(options: DeployOptions) {\n    if (options.watch) {\n      return this.watch(options);\n    }\n\n    const startSynthTime = new Date().getTime();\n    const stacks = await this.selectStacksForDeploy(options.selector, options.exclusively, options.cacheCloudAssembly);\n    const elapsedSynthTime = new Date().getTime() - startSynthTime;\n    print('\\n✨  Synthesis time: %ss\\n', formatTime(elapsedSynthTime));\n\n    const requireApproval = options.requireApproval ?? RequireApproval.Broadening;\n\n    const parameterMap: { [name: string]: { [name: string]: string | undefined } } = { '*': {} };\n    for (const key in options.parameters) {\n      if (options.parameters.hasOwnProperty(key)) {\n        const [stack, parameter] = key.split(':', 2);\n        if (!parameter) {\n          parameterMap['*'][stack] = options.parameters[key];\n        } else {\n          if (!parameterMap[stack]) {\n            parameterMap[stack] = {};\n          }\n          parameterMap[stack][parameter] = options.parameters[key];\n        }\n      }\n    }\n\n    if (options.hotswap) {\n      warning('⚠️ The --hotswap flag deliberately introduces CloudFormation drift to speed up deployments');\n      warning('⚠️ It should only be used for development - never use it for your production Stacks!');\n    }\n\n    const stackOutputs: { [key: string]: any } = { };\n    const outputsFile = options.outputsFile;\n\n    for (const stack of stacks.stackArtifacts) {\n      if (stacks.stackCount !== 1) { highlight(stack.displayName); }\n      if (!stack.environment) {\n        // eslint-disable-next-line max-len\n        throw new Error(`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      if (Object.keys(stack.template.Resources || {}).length === 0) { // The generated stack has no resources\n        if (!await this.props.cloudFormation.stackExists({ stack })) {\n          warning('%s: stack has no resources, skipping deployment.', chalk.bold(stack.displayName));\n        } else {\n          warning('%s: stack has no resources, deleting existing stack.', chalk.bold(stack.displayName));\n          await this.destroy({\n            selector: { patterns: [stack.stackName] },\n            exclusively: true,\n            force: true,\n            roleArn: options.roleArn,\n            fromDeploy: true,\n          });\n        }\n        continue;\n      }\n\n      if (requireApproval !== RequireApproval.Never) {\n        const currentTemplate = await this.props.cloudFormation.readCurrentTemplate(stack);\n        if (printSecurityDiff(currentTemplate, stack, requireApproval)) {\n\n          // only talk to user if STDIN is a terminal (otherwise, fail)\n          if (!process.stdin.isTTY) {\n            throw new Error(\n              '\"--require-approval\" is enabled and stack includes security-sensitive updates, ' +\n              'but terminal (TTY) is not attached so we are unable to get a confirmation from the user');\n          }\n\n          const confirmed = await promptly.confirm('Do you wish to deploy these changes (y/n)?');\n          if (!confirmed) { throw new Error('Aborted by user'); }\n        }\n      }\n\n      print('%s: deploying...', chalk.bold(stack.displayName));\n      const startDeployTime = new Date().getTime();\n\n      let tags = options.tags;\n      if (!tags || tags.length === 0) {\n        tags = tagsForStack(stack);\n      }\n\n      let elapsedDeployTime = 0;\n      try {\n        const result = await this.props.cloudFormation.deployStack({\n          stack,\n          deployName: stack.stackName,\n          roleArn: options.roleArn,\n          toolkitStackName: options.toolkitStackName,\n          reuseAssets: options.reuseAssets,\n          notificationArns: options.notificationArns,\n          tags,\n          execute: options.execute,\n          changeSetName: options.changeSetName,\n          force: options.force,\n          parameters: Object.assign({}, parameterMap['*'], parameterMap[stack.stackName]),\n          usePreviousParameters: options.usePreviousParameters,\n          progress: options.progress,\n          ci: options.ci,\n          rollback: options.rollback,\n          hotswap: options.hotswap,\n          extraUserAgent: options.extraUserAgent,\n        });\n\n        const message = result.noOp\n          ? ' ✅  %s (no changes)'\n          : ' ✅  %s';\n\n        success('\\n' + message, stack.displayName);\n        elapsedDeployTime = new Date().getTime() - startDeployTime;\n        print('\\n✨  Deployment time: %ss\\n', formatTime(elapsedDeployTime));\n\n        if (Object.keys(result.outputs).length > 0) {\n          print('Outputs:');\n\n          stackOutputs[stack.stackName] = result.outputs;\n        }\n\n        for (const name of Object.keys(result.outputs).sort()) {\n          const value = result.outputs[name];\n          print('%s.%s = %s', chalk.cyan(stack.id), chalk.cyan(name), chalk.underline(chalk.cyan(value)));\n        }\n\n        print('Stack ARN:');\n\n        data(result.stackArn);\n      } catch (e) {\n        error('\\n ❌  %s failed: %s', chalk.bold(stack.displayName), e);\n        throw e;\n      } finally {\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      print('\\n✨  Total time: %ss\\n', formatTime(elapsedSynthTime + elapsedDeployTime));\n    }\n  }\n\n  public async watch(options: WatchOptions) {\n    const rootDir = path.dirname(path.resolve(PROJECT_CONFIG));\n    debug(\"root directory used for 'watch' is: %s\", rootDir);\n\n    const watchSettings: { include?: string | string[], exclude: string | string [] } | undefined =\n        this.props.configuration.settings.get(['watch']);\n    if (!watchSettings) {\n      throw new Error(\"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    // For the \"include\" subkey under the \"watch\" key, the behavior is:\n    // 1. No \"watch\" setting? We error out.\n    // 2. \"watch\" setting without an \"include\" key? We default to observing \"./**\".\n    // 3. \"watch\" setting with an empty \"include\" key? We default to observing \"./**\".\n    // 4. Non-empty \"include\" key? Just use the \"include\" key.\n    const watchIncludes = this.patternsArrayForWatch(watchSettings.include, { rootDir, returnRootDirIfEmpty: true });\n    debug(\"'include' patterns for 'watch': %s\", watchIncludes);\n\n    // For the \"exclude\" subkey under the \"watch\" key,\n    // the behavior is to add some default excludes in addition to the ones specified by the user:\n    // 1. The CDK output directory.\n    // 2. Any file whose name starts with a dot.\n    // 3. Any directory's content whose name starts with a dot.\n    // 4. Any node_modules and its content (even if it's not a JS/TS project, you might be using a local aws-cli package)\n    const outputDir = this.props.configuration.settings.get(['output']);\n    const watchExcludes = this.patternsArrayForWatch(watchSettings.exclude, { rootDir, returnRootDirIfEmpty: false }).concat(\n      `${outputDir}/**`,\n      '**/.*',\n      '**/.*/**',\n      '**/node_modules/**',\n    );\n    debug(\"'exclude' patterns for 'watch': %s\", watchExcludes);\n\n    // Since 'cdk deploy' is a relatively slow operation for a 'watch' process,\n    // introduce a concurrency latch that tracks the state.\n    // This way, if file change events arrive when a 'cdk deploy' is still executing,\n    // we will batch them, and trigger another 'cdk deploy' after the current one finishes,\n    // making sure 'cdk deploy's  always execute one at a time.\n    // Here's a diagram showing the state transitions:\n    // --------------                --------    file changed     --------------    file changed     --------------  file changed\n    // |            |  ready event   |      | ------------------> |            | ------------------> |            | --------------|\n    // | pre-ready  | -------------> | open |                     | deploying  |                     |   queued   |               |\n    // |            |                |      | <------------------ |            | <------------------ |            | <-------------|\n    // --------------                --------  'cdk deploy' done  --------------  'cdk deploy' done  --------------\n    let latch: 'pre-ready' | 'open' | 'deploying' | 'queued' = 'pre-ready';\n\n    const deployAndWatch = async () => {\n      latch = 'deploying';\n\n      await this.invokeDeployFromWatch(options);\n\n      // If latch is still 'deploying' after the 'await', that's fine,\n      // but if it's 'queued', that means we need to deploy again\n      while ((latch as 'deploying' | 'queued') === 'queued') {\n        // TypeScript doesn't realize latch can change between 'awaits',\n        // and thinks the above 'while' condition is always 'false' without the cast\n        latch = 'deploying';\n        print(\"Detected file changes during deployment. Invoking 'cdk deploy' again\");\n        await this.invokeDeployFromWatch(options);\n      }\n      latch = 'open';\n    };\n\n    chokidar.watch(watchIncludes, {\n      ignored: watchExcludes,\n      cwd: rootDir,\n      // ignoreInitial: true,\n    }).on('ready', async () => {\n      latch = 'open';\n      debug(\"'watch' received the 'ready' event. From now on, all file changes will trigger a deployment\");\n      print(\"Triggering initial 'cdk deploy'\");\n      await deployAndWatch();\n    }).on('all', async (event: 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir', filePath?: string) => {\n      if (latch === 'pre-ready') {\n        print(`'watch' is observing ${event === 'addDir' ? 'directory' : 'the file'} '%s' for changes`, filePath);\n      } else if (latch === 'open') {\n        print(\"Detected change to '%s' (type: %s). Triggering 'cdk deploy'\", filePath, event);\n        await deployAndWatch();\n      } else { // this means latch is either 'deploying' or 'queued'\n        latch = 'queued';\n        print(\"Detected change to '%s' (type: %s) while 'cdk deploy' is still running. \" +\n            'Will queue for another deployment after this one finishes', filePath, event);\n      }\n    });\n  }\n\n  public async destroy(options: DestroyOptions) {\n    let stacks = await this.selectStacksForDestroy(options.selector, options.exclusively);\n\n    // The stacks will have been ordered for deployment, so reverse them for deletion.\n    stacks = stacks.reversed();\n\n    if (!options.force) {\n      // eslint-disable-next-line max-len\n      const confirmed = await promptly.confirm(`Are you sure you want to delete: ${chalk.blue(stacks.stackArtifacts.map(s => s.hierarchicalId).join(', '))} (y/n)?`);\n      if (!confirmed) {\n        return;\n      }\n    }\n\n    const action = options.fromDeploy ? 'deploy' : 'destroy';\n    for (const stack of stacks.stackArtifacts) {\n      success('%s: destroying...', chalk.blue(stack.displayName));\n      try {\n        await this.props.cloudFormation.destroyStack({\n          stack,\n          deployName: stack.stackName,\n          roleArn: options.roleArn,\n        });\n        success(`\\n ✅  %s: ${action}ed`, chalk.blue(stack.displayName));\n      } catch (e) {\n        error(`\\n ❌  %s: ${action} failed`, chalk.blue(stack.displayName), e);\n        throw e;\n      }\n    }\n  }\n\n  public async list(selectors: string[], options: { long?: boolean } = { }) {\n    const stacks = await this.selectStacksForList(selectors);\n\n    // if we are in \"long\" mode, emit the array as-is (JSON/YAML)\n    if (options.long) {\n      const long = [];\n      for (const stack of stacks.stackArtifacts) {\n        long.push({\n          id: stack.hierarchicalId,\n          name: stack.stackName,\n          environment: stack.environment,\n        });\n      }\n      return long; // will be YAML formatted output\n    }\n\n    // just print stack IDs\n    for (const stack of stacks.stackArtifacts) {\n      data(stack.hierarchicalId);\n    }\n\n    return 0; // exit-code\n  }\n\n  /**\n   * Synthesize the given set of stacks (called when the user runs 'cdk synth')\n   *\n   * INPUT: Stack names can be supplied using a glob filter. If no stacks are\n   * given, all stacks from the application are implictly selected.\n   *\n   * OUTPUT: If more than one stack ends up being selected, an output directory\n   * should be supplied, where the templates will be written.\n   */\n  public async synth(stackNames: string[], exclusively: boolean, quiet: boolean, autoValidate?: boolean): Promise<any> {\n    const stacks = await this.selectStacksForDiff(stackNames, exclusively, autoValidate);\n\n    // if we have a single stack, print it to STDOUT\n    if (stacks.stackCount === 1) {\n      if (!quiet) {\n        return stacks.firstStack.template;\n      }\n      return undefined;\n    }\n\n    // This is a slight hack; in integ mode we allow multiple stacks to be synthesized to stdout sequentially.\n    // This is to make it so that we can support multi-stack integ test expectations, without so drastically\n    // having to change the synthesis format that we have to rerun all integ tests.\n    //\n    // Because this feature is not useful to consumers (the output is missing\n    // the stack names), it's not exposed as a CLI flag. Instead, it's hidden\n    // behind an environment variable.\n    const isIntegMode = process.env.CDK_INTEG_MODE === '1';\n    if (isIntegMode) {\n      return stacks.stackArtifacts.map(s => s.template);\n    }\n\n    // not outputting template to stdout, let's explain things to the user a little bit...\n    success(`Successfully synthesized to ${chalk.blue(path.resolve(stacks.assembly.directory))}`);\n    print(`Supply a stack id (${stacks.stackArtifacts.map(s => chalk.green(s.id)).join(', ')}) to display its template.`);\n\n    return undefined;\n  }\n\n  /**\n   * Bootstrap the CDK Toolkit stack in the accounts used by the specified stack(s).\n   *\n   * @param environmentSpecs environment names that need to have toolkit support\n   *             provisioned, as a glob filter. If none is provided,\n   *             all stacks are implicitly selected.\n   * @param toolkitStackName the name to be used for the CDK Toolkit stack.\n   */\n  public async bootstrap(userEnvironmentSpecs: string[], bootstrapper: Bootstrapper, options: BootstrapEnvironmentOptions): Promise<void> {\n    // If there is an '--app' argument and an environment looks like a glob, we\n    // select the environments from the app. Otherwise use what the user said.\n\n    // By default glob for everything\n    const environmentSpecs = userEnvironmentSpecs.length > 0 ? [...userEnvironmentSpecs] : ['**'];\n\n    // Partition into globs and non-globs (this will mutate environmentSpecs).\n    const globSpecs = partition(environmentSpecs, looksLikeGlob);\n    if (globSpecs.length > 0 && !this.props.cloudExecutable.hasApp) {\n      if (userEnvironmentSpecs.length > 0) {\n        // User did request this glob\n        throw new Error(`'${globSpecs}' is not an environment name. Specify an environment name like 'aws://123456789012/us-east-1', or run in a directory with 'cdk.json' to use wildcards.`);\n      } else {\n        // User did not request anything\n        throw new Error('Specify an environment name like \\'aws://123456789012/us-east-1\\', or run in a directory with \\'cdk.json\\'.');\n      }\n    }\n\n    const environments: cxapi.Environment[] = [\n      ...environmentsFromDescriptors(environmentSpecs),\n    ];\n\n    // If there is an '--app' argument, select the environments from the app.\n    if (this.props.cloudExecutable.hasApp) {\n      environments.push(...await globEnvironmentsFromStacks(await this.selectStacksForList([]), globSpecs, this.props.sdkProvider));\n    }\n\n    await Promise.all(environments.map(async (environment) => {\n      success(' ⏳  Bootstrapping environment %s...', chalk.blue(environment.name));\n      try {\n        const result = await bootstrapper.bootstrapEnvironment(environment, this.props.sdkProvider, options);\n        const message = result.noOp\n          ? ' ✅  Environment %s bootstrapped (no changes).'\n          : ' ✅  Environment %s bootstrapped.';\n        success(message, chalk.blue(environment.name));\n      } catch (e) {\n        error(' ❌  Environment %s failed bootstrapping: %s', chalk.blue(environment.name), e);\n        throw e;\n      }\n    }));\n  }\n\n  private async selectStacksForList(patterns: string[]) {\n    const assembly = await this.assembly();\n    const stacks = await assembly.selectStacks({ patterns }, { defaultBehavior: DefaultSelection.AllStacks });\n\n    // No validation\n\n    return stacks;\n  }\n\n  private async selectStacksForDeploy(selector: StackSelector, exclusively?: boolean, cacheCloudAssembly?: boolean): Promise<StackCollection> {\n    const assembly = await this.assembly(cacheCloudAssembly);\n    const stacks = await assembly.selectStacks(selector, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Upstream,\n      defaultBehavior: DefaultSelection.OnlySingle,\n    });\n\n    this.validateStacksSelected(stacks, selector.patterns);\n    this.validateStacks(stacks);\n\n    return stacks;\n  }\n\n  private async selectStacksForDiff(stackNames: string[], exclusively?: boolean, autoValidate?: boolean): Promise<StackCollection> {\n    const assembly = await this.assembly();\n\n    const selectedForDiff = await assembly.selectStacks({ patterns: stackNames }, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Upstream,\n      defaultBehavior: DefaultSelection.MainAssembly,\n    });\n\n    const allStacks = await this.selectStacksForList([]);\n    const autoValidateStacks = autoValidate\n      ? allStacks.filter(art => art.validateOnSynth ?? false)\n      : new StackCollection(assembly, []);\n\n    this.validateStacksSelected(selectedForDiff.concat(autoValidateStacks), stackNames);\n    this.validateStacks(selectedForDiff.concat(autoValidateStacks));\n\n    return selectedForDiff;\n  }\n\n  private async selectStacksForDestroy(selector: StackSelector, exclusively?: boolean) {\n    const assembly = await this.assembly();\n    const stacks = await assembly.selectStacks(selector, {\n      extend: exclusively ? ExtendedStackSelection.None : ExtendedStackSelection.Downstream,\n      defaultBehavior: DefaultSelection.OnlySingle,\n    });\n\n    // No validation\n\n    return stacks;\n  }\n\n  /**\n   * Validate the stacks for errors and warnings according to the CLI's current settings\n   */\n  private validateStacks(stacks: StackCollection) {\n    stacks.processMetadataMessages({\n      ignoreErrors: this.props.ignoreErrors,\n      strict: this.props.strict,\n      verbose: this.props.verbose,\n    });\n  }\n\n  /**\n   * Validate that if a user specified a stack name there exists at least 1 stack selected\n   */\n  private validateStacksSelected(stacks: StackCollection, stackNames: string[]) {\n    if (stackNames.length != 0 && stacks.stackCount == 0) {\n      throw new Error(`No stacks match the name(s) ${stackNames}`);\n    }\n  }\n\n  /**\n   * Select a single stack by its name\n   */\n  private async selectSingleStackByName(stackName: string) {\n    const assembly = await this.assembly();\n\n    const stacks = await assembly.selectStacks({ patterns: [stackName] }, {\n      extend: ExtendedStackSelection.None,\n      defaultBehavior: DefaultSelection.None,\n    });\n\n    // Could have been a glob so check that we evaluated to exactly one\n    if (stacks.stackCount > 1) {\n      throw new Error(`This command requires exactly one stack and we matched more than one: ${stacks.stackIds}`);\n    }\n\n    return assembly.stackById(stacks.firstStack.id);\n  }\n\n  private assembly(cacheCloudAssembly?: boolean): Promise<CloudAssembly> {\n    return this.props.cloudExecutable.synthesize(cacheCloudAssembly);\n  }\n\n  private patternsArrayForWatch(patterns: string | string[] | undefined, options: { rootDir: string, returnRootDirIfEmpty: boolean }): string[] {\n    const patternsArray: string[] = patterns !== undefined\n      ? (Array.isArray(patterns) ? patterns : [patterns])\n      : [];\n    return patternsArray.length > 0\n      ? patternsArray\n      : (options.returnRootDirIfEmpty ? [options.rootDir] : []);\n  }\n\n  private async invokeDeployFromWatch(options: WatchOptions): Promise<void> {\n    // 'watch' has different defaults than regular 'deploy'\n    const hotswap = options.hotswap === undefined ? true : options.hotswap;\n    const deployOptions: DeployOptions = {\n      ...options,\n      requireApproval: RequireApproval.Never,\n      // if 'watch' is called by invoking 'cdk deploy --watch',\n      // we need to make sure to not call 'deploy' with 'watch' again,\n      // as that would lead to a cycle\n      watch: false,\n      cacheCloudAssembly: false,\n      hotswap: hotswap,\n      extraUserAgent: `cdk-watch/hotswap-${hotswap ? 'on' : 'off'}`,\n    };\n\n    try {\n      await this.deploy(deployOptions);\n    } catch (e) {\n      // just continue - deploy will show the error\n    }\n  }\n}\n\nexport interface DiffOptions {\n  /**\n   * Stack names to diff\n   */\n  stackNames: string[];\n\n  /**\n   * Only select the given stack\n   *\n   * @default false\n   */\n  exclusively?: boolean;\n\n  /**\n   * Used a template from disk instead of from the server\n   *\n   * @default Use from the server\n   */\n  templatePath?: string;\n\n  /**\n   * Strict diff mode\n   *\n   * @default false\n   */\n  strict?: boolean;\n\n  /**\n   * How many lines of context to show in the diff\n   *\n   * @default 3\n   */\n  contextLines?: number;\n\n  /**\n   * Where to write the default\n   *\n   * @default stderr\n   */\n  stream?: NodeJS.WritableStream;\n\n  /**\n   * Whether to fail with exit code 1 in case of diff\n   *\n   * @default false\n   */\n  fail?: boolean;\n\n  /**\n   * Only run diff on broadened security changes\n   *\n   * @default false\n   */\n  securityOnly?: boolean;\n}\n\ninterface WatchOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  selector: StackSelector;\n\n  /**\n   * Only select the given stack\n   *\n   * @default false\n   */\n  exclusively?: boolean;\n\n  /**\n   * Name of the toolkit stack to use/deploy\n   *\n   * @default CDKToolkit\n   */\n  toolkitStackName?: string;\n\n  /**\n   * Role to pass to CloudFormation for deployment\n   */\n  roleArn?: string;\n\n  /**\n   * Reuse the assets with the given asset IDs\n   */\n  reuseAssets?: string[];\n\n  /**\n   * Optional name to use for the CloudFormation change set.\n   * If not provided, a name will be generated automatically.\n   */\n  changeSetName?: string;\n\n  /**\n   * Always deploy, even if templates are identical.\n   * @default false\n   */\n  force?: boolean;\n\n  /**\n   * Display mode for stack deployment progress.\n   *\n   * @default - StackActivityProgress.Bar - stack events will be displayed for\n   *   the resource currently being deployed.\n   */\n  progress?: StackActivityProgress;\n\n  /**\n   * Rollback failed deployments\n   *\n   * @default true\n   */\n  readonly rollback?: boolean;\n\n  /**\n   * Whether to perform a 'hotswap' deployment.\n   * A 'hotswap' deployment will attempt to short-circuit CloudFormation\n   * and update the affected resources like Lambda functions directly.\n   *\n   * @default - false for regular deployments, true for 'watch' deployments\n   */\n  readonly hotswap?: boolean;\n\n  /**\n   * The extra string to append to the User-Agent header when performing AWS SDK calls.\n   *\n   * @default - nothing extra is appended to the User-Agent header\n   */\n  readonly extraUserAgent?: string;\n}\n\nexport interface DeployOptions extends WatchOptions {\n  /**\n   * ARNs of SNS topics that CloudFormation will notify with stack related events\n   */\n  notificationArns?: string[];\n\n  /**\n   * What kind of security changes require approval\n   *\n   * @default RequireApproval.Broadening\n   */\n  requireApproval?: RequireApproval;\n\n  /**\n   * Tags to pass to CloudFormation for deployment\n   */\n  tags?: Tag[];\n\n  /**\n   * Whether to execute the ChangeSet\n   * Not providing `execute` parameter will result in execution of ChangeSet\n   * @default true\n   */\n  execute?: boolean;\n\n  /**\n   * Additional parameters for CloudFormation at deploy time\n   * @default {}\n   */\n  parameters?: { [name: string]: string | undefined };\n\n  /**\n   * Use previous values for unspecified parameters\n   *\n   * If not set, all parameters must be specified for every deployment.\n   *\n   * @default true\n   */\n  usePreviousParameters?: boolean;\n\n  /**\n   * Path to file where stack outputs will be written after a successful deploy as JSON\n   * @default - Outputs are not written to any file\n   */\n  outputsFile?: string;\n\n  /**\n   * Whether we are on a CI system\n   *\n   * @default false\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Whether this 'deploy' command should actually delegate to the 'watch' command.\n   *\n   * @default false\n   */\n  readonly watch?: boolean;\n\n  /**\n   * Whether we should cache the Cloud Assembly after the first time it has been synthesized.\n   * The default is 'true', we only don't want to do it in case the deployment is triggered by\n   * 'cdk watch'.\n   *\n   * @default true\n   */\n  readonly cacheCloudAssembly?: boolean;\n}\n\nexport interface DestroyOptions {\n  /**\n   * Criteria for selecting stacks to deploy\n   */\n  selector: StackSelector;\n\n  /**\n   * Whether to exclude stacks that depend on the stacks to be deleted\n   */\n  exclusively: boolean;\n\n  /**\n   * Whether to skip prompting for confirmation\n   */\n  force: boolean;\n\n  /**\n   * The arn of the IAM role to use\n   */\n  roleArn?: string;\n\n  /**\n   * Whether the destroy request came from a deploy.\n   */\n  fromDeploy?: boolean\n}\n\n/**\n * @returns an array with the tags available in the stack metadata.\n */\nfunction tagsForStack(stack: cxapi.CloudFormationStackArtifact): Tag[] {\n  return Object.entries(stack.tags).map(([Key, Value]) => ({ Key, Value }));\n}\n\nexport interface Tag {\n  readonly Key: string;\n  readonly Value: string;\n}\n\n/**\n * Formats time in milliseconds (which we get from 'Date.getTime()')\n * to a human-readable time; returns time in seconds rounded to 2\n * decimal places.\n */\nfunction formatTime(num: number): number {\n  return roundPercentage(millisecondsToSeconds(num));\n}\n\n/**\n * Rounds a decimal number to two decimal points.\n * The function is useful for fractions that need to be outputted as percentages.\n */\nfunction roundPercentage(num: number): number {\n  return Math.round(100 * num) / 100;\n}\n\n/**\n * Given a time in miliseconds, return an equivalent amount in seconds.\n */\nfunction millisecondsToSeconds(num: number): number {\n  return num / 1000;\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.realHandler = exports.handler = exports.builder = exports.describe = exports.command = void 0;
4
- const colors = require("colors/safe");
4
+ const chalk = require("chalk");
5
5
  const version = require("../../lib/version");
6
6
  const logging_1 = require("../logging");
7
7
  const settings_1 = require("../settings");
@@ -60,15 +60,15 @@ function listContext(context) {
60
60
  return;
61
61
  }
62
62
  // Print config by default
63
- const data = [[colors.green('#'), colors.green('Key'), colors.green('Value')]];
63
+ const data = [[chalk.green('#'), chalk.green('Key'), chalk.green('Value')]];
64
64
  for (const [i, key] of keys) {
65
65
  const jsonWithoutNewlines = JSON.stringify(context.all[key], undefined, 2).replace(/\s+/g, ' ');
66
66
  data.push([i, key, jsonWithoutNewlines]);
67
67
  }
68
- logging_1.print(`Context found in ${colors.blue(settings_1.PROJECT_CONFIG)}:\n`);
68
+ logging_1.print(`Context found in ${chalk.blue(settings_1.PROJECT_CONFIG)}:\n`);
69
69
  logging_1.print(util_1.renderTable(data, process.stdout.columns));
70
70
  // eslint-disable-next-line max-len
71
- logging_1.print(`Run ${colors.blue('cdk context --reset KEY_OR_NUMBER')} to remove a context key. It will be refreshed on the next CDK synthesis run.`);
71
+ logging_1.print(`Run ${chalk.blue('cdk context --reset KEY_OR_NUMBER')} to remove a context key. It will be refreshed on the next CDK synthesis run.`);
72
72
  }
73
73
  function invalidateContext(context, key) {
74
74
  const i = parseInt(key, 10);
@@ -79,10 +79,10 @@ function invalidateContext(context, key) {
79
79
  // Unset!
80
80
  if (context.has(key)) {
81
81
  context.unset(key);
82
- logging_1.print(`Context value ${colors.blue(key)} reset. It will be refreshed on next synthesis`);
82
+ logging_1.print(`Context value ${chalk.blue(key)} reset. It will be refreshed on next synthesis`);
83
83
  }
84
84
  else {
85
- logging_1.print(`No context value with key ${colors.blue(key)}`);
85
+ logging_1.print(`No context value with key ${chalk.blue(key)}`);
86
86
  }
87
87
  }
88
88
  function keyByNumber(context, n) {
@@ -110,4 +110,4 @@ function enumerate1(xs) {
110
110
  }
111
111
  return ret;
112
112
  }
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["context.ts"],"names":[],"mappings":"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","sourcesContent":["import * as colors from 'colors/safe';\nimport * as yargs from 'yargs';\nimport * as version from '../../lib/version';\nimport { CommandOptions } from '../command-api';\nimport { print } from '../logging';\nimport { Context, PROJECT_CONFIG } from '../settings';\nimport { renderTable } from '../util';\n\nexport const command = 'context';\nexport const describe = 'Manage cached context values';\nexport const builder = {\n  reset: {\n    alias: 'e',\n    desc: 'The context key (or its index) to reset',\n    type: 'string',\n    requiresArg: true,\n  },\n  clear: {\n    desc: 'Clear all context',\n    type: 'boolean',\n  },\n};\n\nexport function handler(args: yargs.Arguments) {\n  args.commandHandler = realHandler;\n}\n\nexport async function realHandler(options: CommandOptions): Promise<number> {\n  const { configuration, args } = options;\n\n  if (args.clear) {\n    configuration.context.clear();\n    await configuration.saveContext();\n    print('All context values cleared.');\n  } else if (args.reset) {\n    invalidateContext(configuration.context, args.reset as string);\n    await configuration.saveContext();\n  } else {\n    // List -- support '--json' flag\n    if (args.json) {\n      const contextValues = configuration.context.all;\n      process.stdout.write(JSON.stringify(contextValues, undefined, 2));\n    } else {\n      listContext(configuration.context);\n    }\n  }\n  await version.displayVersionMessage();\n\n  return 0;\n}\n\nfunction listContext(context: Context) {\n  const keys = contextKeys(context);\n\n  if (keys.length === 0) {\n    print('This CDK application does not have any saved context values yet.');\n    print('');\n    print('Context will automatically be saved when you synthesize CDK apps');\n    print('that use environment context information like AZ information, VPCs,');\n    print('SSM parameters, and so on.');\n\n    return;\n  }\n\n  // Print config by default\n  const data: any[] = [[colors.green('#'), colors.green('Key'), colors.green('Value')]];\n  for (const [i, key] of keys) {\n    const jsonWithoutNewlines = JSON.stringify(context.all[key], undefined, 2).replace(/\\s+/g, ' ');\n    data.push([i, key, jsonWithoutNewlines]);\n  }\n\n  print(`Context found in ${colors.blue(PROJECT_CONFIG)}:\\n`);\n\n  print(renderTable(data, process.stdout.columns));\n\n  // eslint-disable-next-line max-len\n  print(`Run ${colors.blue('cdk context --reset KEY_OR_NUMBER')} to remove a context key. It will be refreshed on the next CDK synthesis run.`);\n}\n\nfunction invalidateContext(context: Context, key: string) {\n  const i = parseInt(key, 10);\n  if (`${i}` === key) {\n    // was a number and we fully parsed it.\n    key = keyByNumber(context, i);\n  }\n\n  // Unset!\n  if (context.has(key)) {\n    context.unset(key);\n    print(`Context value ${colors.blue(key)} reset. It will be refreshed on next synthesis`);\n  } else {\n    print(`No context value with key ${colors.blue(key)}`);\n  }\n}\n\nfunction keyByNumber(context: Context, n: number) {\n  for (const [i, key] of contextKeys(context)) {\n    if (n === i) {\n      return key;\n    }\n  }\n  throw new Error(`No context key with number: ${n}`);\n}\n\n/**\n * Return enumerated keys in a definitive order\n */\nfunction contextKeys(context: Context): [number, string][] {\n  const keys = context.keys;\n  keys.sort();\n  return enumerate1(keys);\n}\n\nfunction enumerate1<T>(xs: T[]): Array<[number, T]> {\n  const ret = new Array<[number, T]>();\n  let i = 1;\n  for (const x of xs) {\n    ret.push([i, x]);\n    i += 1;\n  }\n  return ret;\n}\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["context.ts"],"names":[],"mappings":"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","sourcesContent":["import * as chalk from 'chalk';\nimport * as yargs from 'yargs';\nimport * as version from '../../lib/version';\nimport { CommandOptions } from '../command-api';\nimport { print } from '../logging';\nimport { Context, PROJECT_CONFIG } from '../settings';\nimport { renderTable } from '../util';\n\nexport const command = 'context';\nexport const describe = 'Manage cached context values';\nexport const builder = {\n  reset: {\n    alias: 'e',\n    desc: 'The context key (or its index) to reset',\n    type: 'string',\n    requiresArg: true,\n  },\n  clear: {\n    desc: 'Clear all context',\n    type: 'boolean',\n  },\n};\n\nexport function handler(args: yargs.Arguments) {\n  args.commandHandler = realHandler;\n}\n\nexport async function realHandler(options: CommandOptions): Promise<number> {\n  const { configuration, args } = options;\n\n  if (args.clear) {\n    configuration.context.clear();\n    await configuration.saveContext();\n    print('All context values cleared.');\n  } else if (args.reset) {\n    invalidateContext(configuration.context, args.reset as string);\n    await configuration.saveContext();\n  } else {\n    // List -- support '--json' flag\n    if (args.json) {\n      const contextValues = configuration.context.all;\n      process.stdout.write(JSON.stringify(contextValues, undefined, 2));\n    } else {\n      listContext(configuration.context);\n    }\n  }\n  await version.displayVersionMessage();\n\n  return 0;\n}\n\nfunction listContext(context: Context) {\n  const keys = contextKeys(context);\n\n  if (keys.length === 0) {\n    print('This CDK application does not have any saved context values yet.');\n    print('');\n    print('Context will automatically be saved when you synthesize CDK apps');\n    print('that use environment context information like AZ information, VPCs,');\n    print('SSM parameters, and so on.');\n\n    return;\n  }\n\n  // Print config by default\n  const data: any[] = [[chalk.green('#'), chalk.green('Key'), chalk.green('Value')]];\n  for (const [i, key] of keys) {\n    const jsonWithoutNewlines = JSON.stringify(context.all[key], undefined, 2).replace(/\\s+/g, ' ');\n    data.push([i, key, jsonWithoutNewlines]);\n  }\n\n  print(`Context found in ${chalk.blue(PROJECT_CONFIG)}:\\n`);\n\n  print(renderTable(data, process.stdout.columns));\n\n  // eslint-disable-next-line max-len\n  print(`Run ${chalk.blue('cdk context --reset KEY_OR_NUMBER')} to remove a context key. It will be refreshed on the next CDK synthesis run.`);\n}\n\nfunction invalidateContext(context: Context, key: string) {\n  const i = parseInt(key, 10);\n  if (`${i}` === key) {\n    // was a number and we fully parsed it.\n    key = keyByNumber(context, i);\n  }\n\n  // Unset!\n  if (context.has(key)) {\n    context.unset(key);\n    print(`Context value ${chalk.blue(key)} reset. It will be refreshed on next synthesis`);\n  } else {\n    print(`No context value with key ${chalk.blue(key)}`);\n  }\n}\n\nfunction keyByNumber(context: Context, n: number) {\n  for (const [i, key] of contextKeys(context)) {\n    if (n === i) {\n      return key;\n    }\n  }\n  throw new Error(`No context key with number: ${n}`);\n}\n\n/**\n * Return enumerated keys in a definitive order\n */\nfunction contextKeys(context: Context): [number, string][] {\n  const keys = context.keys;\n  keys.sort();\n  return enumerate1(keys);\n}\n\nfunction enumerate1<T>(xs: T[]): Array<[number, T]> {\n  const ret = new Array<[number, T]>();\n  let i = 1;\n  for (const x of xs) {\n    ret.push([i, x]);\n    i += 1;\n  }\n  return ret;\n}\n"]}