aws-cdk 2.1020.2 → 2.1021.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 (71) hide show
  1. package/README.md +40 -35
  2. package/THIRD_PARTY_LICENSES +65 -65
  3. package/build-info.json +2 -2
  4. package/db.json.gz +0 -0
  5. package/lib/api/refactor.d.ts +1 -0
  6. package/lib/api/refactor.js +8 -0
  7. package/lib/cli/cdk-toolkit.d.ts +18 -21
  8. package/lib/cli/cdk-toolkit.js +121 -140
  9. package/lib/cli/cli-config.js +12 -12
  10. package/lib/cli/cli-type-registry.json +15 -11
  11. package/lib/cli/cli.js +38 -17
  12. package/lib/cli/convert-to-user-input.js +12 -6
  13. package/lib/cli/display-version.d.ts +11 -0
  14. package/lib/cli/display-version.js +101 -0
  15. package/lib/cli/io-host/cli-io-host.d.ts +1 -6
  16. package/lib/cli/io-host/cli-io-host.js +1 -16
  17. package/lib/cli/parse-command-line-arguments.js +16 -10
  18. package/lib/cli/platform-warnings.d.ts +2 -1
  19. package/lib/cli/platform-warnings.js +3 -4
  20. package/lib/cli/telemetry/endpoint-sink.d.ts +1 -2
  21. package/lib/cli/telemetry/endpoint-sink.js +4 -3
  22. package/lib/cli/telemetry/file-sink.js +8 -12
  23. package/lib/cli/user-configuration.d.ts +14 -4
  24. package/lib/cli/user-configuration.js +42 -30
  25. package/lib/cli/user-input.d.ts +18 -12
  26. package/lib/cli/user-input.js +1 -1
  27. package/lib/cli/util/yargs-helpers.js +3 -3
  28. package/lib/cli/version.d.ts +2 -12
  29. package/lib/cli/version.js +5 -102
  30. package/lib/commands/context.d.ts +10 -5
  31. package/lib/commands/context.js +35 -35
  32. package/lib/commands/docs.d.ts +6 -1
  33. package/lib/commands/docs.js +20 -19
  34. package/lib/commands/doctor.d.ts +4 -1
  35. package/lib/commands/doctor.js +17 -17
  36. package/lib/commands/flags.d.ts +3 -0
  37. package/lib/commands/flags.js +43 -0
  38. package/lib/commands/init/init-hooks.d.ts +2 -1
  39. package/lib/commands/init/init-hooks.js +6 -6
  40. package/lib/commands/init/init.d.ts +4 -2
  41. package/lib/commands/init/init.js +56 -54
  42. package/lib/commands/init/os.d.ts +2 -1
  43. package/lib/commands/init/os.js +3 -4
  44. package/lib/commands/list-stacks.js +8 -2
  45. package/lib/commands/migrate.d.ts +6 -17
  46. package/lib/commands/migrate.js +28 -29
  47. package/lib/cxapp/cloud-assembly.js +1 -1
  48. package/lib/index.d.ts +1 -1
  49. package/lib/index.js +44594 -30673
  50. package/lib/index_bg.wasm +0 -0
  51. package/lib/init-templates/.init-version.json +1 -1
  52. package/lib/init-templates/.recommended-feature-flags.json +1 -0
  53. package/lib/{legacy-aws-auth.d.ts → legacy/aws-auth.d.ts} +1 -1
  54. package/lib/legacy/aws-auth.js +47 -0
  55. package/lib/legacy/configuration.d.ts +82 -0
  56. package/lib/legacy/configuration.js +321 -0
  57. package/lib/legacy/index.d.ts +19 -0
  58. package/lib/{legacy-exports-source.js → legacy/index.js} +23 -23
  59. package/lib/{legacy-logging-source.d.ts → legacy/logging.d.ts} +50 -0
  60. package/lib/legacy/logging.js +154 -0
  61. package/lib/legacy/types.js +3 -0
  62. package/lib/legacy-exports.d.ts +4 -3
  63. package/lib/legacy-exports.js +4 -1
  64. package/package.json +12 -12
  65. package/lib/legacy-aws-auth.js +0 -47
  66. package/lib/legacy-exports-source.d.ts +0 -18
  67. package/lib/legacy-logging-source.js +0 -107
  68. package/lib/legacy-types.js +0 -3
  69. package/lib/logging.d.ts +0 -99
  70. package/lib/logging.js +0 -146
  71. /package/lib/{legacy-types.d.ts → legacy/types.d.ts} +0 -0
@@ -9,15 +9,13 @@ exports.generateTemplate = generateTemplate;
9
9
  exports.chunks = chunks;
10
10
  exports.setEnvironment = setEnvironment;
11
11
  exports.parseSourceOptions = parseSourceOptions;
12
- exports.scanProgressBar = scanProgressBar;
13
12
  exports.printBar = printBar;
14
13
  exports.printDots = printDots;
15
14
  exports.rewriteLine = rewriteLine;
16
- exports.displayTimeDiff = displayTimeDiff;
17
15
  exports.writeMigrateJsonFile = writeMigrateJsonFile;
18
16
  exports.getMigrateScanType = getMigrateScanType;
19
17
  exports.isThereAWarning = isThereAWarning;
20
- exports.buildGenertedTemplateOutput = buildGenertedTemplateOutput;
18
+ exports.buildGeneratedTemplateOutput = buildGeneratedTemplateOutput;
21
19
  exports.buildCfnClient = buildCfnClient;
22
20
  exports.appendWarningsToReadme = appendWarningsToReadme;
23
21
  /* eslint-disable @typescript-eslint/no-require-imports */
@@ -29,7 +27,6 @@ const toolkit_lib_1 = require("@aws-cdk/toolkit-lib");
29
27
  const cdk_from_cfn = require("cdk-from-cfn");
30
28
  const chalk = require("chalk");
31
29
  const init_1 = require("./init");
32
- const logging_1 = require("../../lib/logging");
33
30
  const cloudformation_1 = require("../api/cloudformation");
34
31
  const plugin_1 = require("../api/plugin");
35
32
  const util_1 = require("../util");
@@ -45,7 +42,7 @@ const MIGRATE_SUPPORTED_LANGUAGES = cdk_from_cfn.supported_languages();
45
42
  * @param language - The language to generate the CDK app in
46
43
  * @param outputPath - The path at which to generate the CDK app
47
44
  */
48
- async function generateCdkApp(stackName, stack, language, outputPath, compress) {
45
+ async function generateCdkApp(ioHelper, stackName, stack, language, outputPath, compress) {
49
46
  const resolvedOutputPath = path.join(outputPath ?? process.cwd(), stackName);
50
47
  const formattedStackName = decamelize(stackName);
51
48
  try {
@@ -53,6 +50,7 @@ async function generateCdkApp(stackName, stack, language, outputPath, compress)
53
50
  fs.mkdirSync(resolvedOutputPath, { recursive: true });
54
51
  const generateOnly = compress;
55
52
  await (0, init_1.cliInit)({
53
+ ioHelper,
56
54
  type: 'app',
57
55
  language,
58
56
  canUseNetwork: true,
@@ -153,36 +151,37 @@ async function readFromStack(stackName, sdkProvider, environment) {
153
151
  * @returns a generated cloudformation template
154
152
  */
155
153
  async function generateTemplate(options) {
156
- const cfn = new CfnTemplateGeneratorProvider(await buildCfnClient(options.sdkProvider, options.environment));
154
+ const cfn = new CfnTemplateGeneratorProvider(await buildCfnClient(options.sdkProvider, options.environment), options.ioHelper);
155
+ const ioHelper = options.ioHelper;
157
156
  const scanId = await findLastSuccessfulScan(cfn, options);
158
157
  // if a customer accidentally ctrl-c's out of the command and runs it again, this will continue the progress bar where it left off
159
158
  const curScan = await cfn.describeResourceScan(scanId);
160
159
  if (curScan.Status == ScanStatus.IN_PROGRESS) {
161
- (0, logging_1.info)('Resource scan in progress. Please wait, this can take 10 minutes or longer.');
162
- await scanProgressBar(scanId, cfn);
160
+ await ioHelper.defaults.info('Resource scan in progress. Please wait, this can take 10 minutes or longer.');
161
+ await scanProgressBar(ioHelper, scanId, cfn);
163
162
  }
164
- displayTimeDiff(new Date(), new Date(curScan.StartTime));
163
+ await displayTimeDiff(ioHelper, new Date(), new Date(curScan.StartTime));
165
164
  let resources = await cfn.listResourceScanResources(scanId, options.filters);
166
- (0, logging_1.info)('finding related resources.');
165
+ await ioHelper.defaults.info('finding related resources.');
167
166
  let relatedResources = await cfn.getResourceScanRelatedResources(scanId, resources);
168
- (0, logging_1.info)(`Found ${relatedResources.length} resources.`);
169
- (0, logging_1.info)('Generating CFN template from scanned resources.');
167
+ await ioHelper.defaults.info(`Found ${relatedResources.length} resources.`);
168
+ await ioHelper.defaults.info('Generating CFN template from scanned resources.');
170
169
  const templateArn = (await cfn.createGeneratedTemplate(options.stackName, relatedResources)).GeneratedTemplateId;
171
170
  let generatedTemplate = await cfn.describeGeneratedTemplate(templateArn);
172
- (0, logging_1.info)('Please wait, template creation in progress. This may take a couple minutes.');
171
+ await ioHelper.defaults.info('Please wait, template creation in progress. This may take a couple minutes.');
173
172
  while (generatedTemplate.Status !== ScanStatus.COMPLETE && generatedTemplate.Status !== ScanStatus.FAILED) {
174
173
  await printDots(`[${generatedTemplate.Status}] Template Creation in Progress`, 400);
175
174
  generatedTemplate = await cfn.describeGeneratedTemplate(templateArn);
176
175
  }
177
- (0, logging_1.info)('');
178
- (0, logging_1.info)('Template successfully generated!');
179
- return buildGenertedTemplateOutput(generatedTemplate, (await cfn.getGeneratedTemplate(templateArn)).TemplateBody, templateArn);
176
+ await ioHelper.defaults.info('\nTemplate successfully generated!');
177
+ return buildGeneratedTemplateOutput(generatedTemplate, (await cfn.getGeneratedTemplate(templateArn)).TemplateBody, templateArn);
180
178
  }
181
179
  async function findLastSuccessfulScan(cfn, options) {
180
+ const ioHelper = options.ioHelper;
182
181
  let resourceScanSummaries = [];
183
182
  const clientRequestToken = `cdk-migrate-${options.environment.account}-${options.environment.region}`;
184
183
  if (options.fromScan === FromScan.NEW) {
185
- (0, logging_1.info)(`Starting new scan for account ${options.environment.account} in region ${options.environment.region}`);
184
+ await ioHelper.defaults.info(`Starting new scan for account ${options.environment.account} in region ${options.environment.region}`);
186
185
  try {
187
186
  await cfn.startResourceScan(clientRequestToken);
188
187
  resourceScanSummaries = (await cfn.listResourceScans()).ResourceScanSummaries;
@@ -191,7 +190,7 @@ async function findLastSuccessfulScan(cfn, options) {
191
190
  // continuing here because if the scan fails on a new-scan it is very likely because there is either already a scan in progress
192
191
  // or the customer hit a rate limit. In either case we want to continue with the most recent scan.
193
192
  // If this happens to fail for a credential error then that will be caught immediately after anyway.
194
- (0, logging_1.info)(`Scan failed to start due to error '${e.message}', defaulting to latest scan.`);
193
+ await ioHelper.defaults.info(`Scan failed to start due to error '${e.message}', defaulting to latest scan.`);
195
194
  }
196
195
  }
197
196
  else {
@@ -365,7 +364,7 @@ function resourceIdentifiers(resourceList) {
365
364
  * @param scanId - A string representing the scan id
366
365
  * @param cloudFormation - The CloudFormation sdk client to use
367
366
  */
368
- async function scanProgressBar(scanId, cfn) {
367
+ async function scanProgressBar(ioHelper, scanId, cfn) {
369
368
  let curProgress = 0.5;
370
369
  // we know it's in progress initially since we wouldn't have gotten here if it wasn't
371
370
  let curScan = {
@@ -378,8 +377,7 @@ async function scanProgressBar(scanId, cfn) {
378
377
  printBar(30, curProgress);
379
378
  await new Promise((resolve) => setTimeout(resolve, 2000));
380
379
  }
381
- (0, logging_1.info)('');
382
- (0, logging_1.info)('✅ Scan Complete!');
380
+ await ioHelper.defaults.info('\n✅ Scan Complete!');
383
381
  }
384
382
  /**
385
383
  * Prints a progress bar to the console. To be used in a while loop to show progress of a long running task.
@@ -439,12 +437,12 @@ function rewriteLine(message) {
439
437
  * @param time1 - The first date to compare
440
438
  * @param time2 - The second date to compare
441
439
  */
442
- function displayTimeDiff(time1, time2) {
440
+ async function displayTimeDiff(ioHelper, time1, time2) {
443
441
  const diff = Math.abs(time1.getTime() - time2.getTime());
444
442
  const days = Math.floor(diff / (1000 * 60 * 60 * 24));
445
443
  const hours = Math.floor((diff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
446
444
  const minutes = Math.floor((diff % (1000 * 60 * 60)) / (1000 * 60));
447
- (0, logging_1.info)(`Using the latest successful scan which is ${days} days, ${hours} hours, and ${minutes} minutes old.`);
445
+ await ioHelper.defaults.info(`Using the latest successful scan which is ${days} days, ${hours} hours, and ${minutes} minutes old.`);
448
446
  }
449
447
  /**
450
448
  * Writes a migrate.json file to the output directory.
@@ -504,7 +502,7 @@ function isThereAWarning(generatedTemplateOutput) {
504
502
  * @param templateBody - The body of the generated template
505
503
  * @returns A GenerateTemplateOutput object
506
504
  */
507
- function buildGenertedTemplateOutput(generatedTemplateSummary, templateBody, source) {
505
+ function buildGeneratedTemplateOutput(generatedTemplateSummary, templateBody, source) {
508
506
  const resources = generatedTemplateSummary.Resources;
509
507
  const migrateJson = {
510
508
  templateBody: templateBody,
@@ -584,8 +582,9 @@ function deduplicateResources(resources) {
584
582
  * Class for making CloudFormation template generator calls
585
583
  */
586
584
  class CfnTemplateGeneratorProvider {
587
- constructor(cfn) {
585
+ constructor(cfn, ioHelper) {
588
586
  this.cfn = cfn;
587
+ this.ioHelper = ioHelper;
589
588
  }
590
589
  async checkForResourceScan(resourceScanSummaries, options, clientRequestToken) {
591
590
  if (!resourceScanSummaries || resourceScanSummaries.length === 0) {
@@ -593,7 +592,7 @@ class CfnTemplateGeneratorProvider {
593
592
  throw new toolkit_lib_1.ToolkitError('No scans found. Please either start a new scan with the `--from-scan` new or do not specify a `--from-scan` option.');
594
593
  }
595
594
  else {
596
- (0, logging_1.info)('No scans found. Initiating a new resource scan.');
595
+ await this.ioHelper.defaults.info('No scans found. Initiating a new resource scan.');
597
596
  await this.startResourceScan(clientRequestToken);
598
597
  }
599
598
  }
@@ -667,7 +666,7 @@ class CfnTemplateGeneratorProvider {
667
666
  let resourceList = [];
668
667
  let resourceScanInputs;
669
668
  if (filters.length > 0) {
670
- (0, logging_1.info)('Applying filters to resource scan.');
669
+ await this.ioHelper.defaults.info('Applying filters to resource scan.');
671
670
  for (const filter of filters) {
672
671
  const filterList = parseFilters(filter);
673
672
  resourceScanInputs = {
@@ -690,7 +689,7 @@ class CfnTemplateGeneratorProvider {
690
689
  }
691
690
  }
692
691
  else {
693
- (0, logging_1.info)('No filters provided. Retrieving all resources from scan.');
692
+ await this.ioHelper.defaults.info('No filters provided. Retrieving all resources from scan.');
694
693
  resourceScanInputs = {
695
694
  ResourceScanId: scanId,
696
695
  };
@@ -799,4 +798,4 @@ var FromScan;
799
798
  */
800
799
  FromScan[FromScan["DEFAULT"] = 2] = "DEFAULT";
801
800
  })(FromScan || (exports.FromScan = FromScan = {}));
802
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migrate.js","sourceRoot":"","sources":["migrate.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-require-imports */\n/* eslint-disable @typescript-eslint/no-var-requires */\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport type { Environment } from '@aws-cdk/cx-api';\nimport { UNKNOWN_ACCOUNT, UNKNOWN_REGION } from '@aws-cdk/cx-api';\nimport { ToolkitError } from '@aws-cdk/toolkit-lib';\nimport type {\n  DescribeGeneratedTemplateCommandOutput,\n  DescribeResourceScanCommandOutput,\n  GetGeneratedTemplateCommandOutput,\n  ListResourceScanResourcesCommandInput,\n  ResourceDefinition,\n  ResourceDetail,\n  ResourceIdentifierSummary,\n  ResourceScanSummary,\n  ScannedResource,\n  ScannedResourceIdentifier,\n} from '@aws-sdk/client-cloudformation';\nimport * as cdk_from_cfn from 'cdk-from-cfn';\nimport * as chalk from 'chalk';\nimport { cliInit } from './init';\nimport { info } from '../../lib/logging';\nimport type { ICloudFormationClient, SdkProvider } from '../api/aws-auth';\nimport { CloudFormationStack } from '../api/cloudformation';\nimport { Mode } from '../api/plugin';\nimport { zipDirectory } from '../util';\nconst camelCase = require('camelcase');\nconst decamelize = require('decamelize');\n/** The list of languages supported by the built-in noctilucent binary. */\nconst MIGRATE_SUPPORTED_LANGUAGES: readonly string[] = cdk_from_cfn.supported_languages();\n\n/**\n * Generates a CDK app from a yaml or json template.\n *\n * @param stackName - The name to assign to the stack in the generated app\n * @param stack - The yaml or json template for the stack\n * @param language - The language to generate the CDK app in\n * @param outputPath - The path at which to generate the CDK app\n */\nexport async function generateCdkApp(\n  stackName: string,\n  stack: string,\n  language: string,\n  outputPath?: string,\n  compress?: boolean,\n): Promise<void> {\n  const resolvedOutputPath = path.join(outputPath ?? process.cwd(), stackName);\n  const formattedStackName = decamelize(stackName);\n\n  try {\n    fs.rmSync(resolvedOutputPath, { recursive: true, force: true });\n    fs.mkdirSync(resolvedOutputPath, { recursive: true });\n    const generateOnly = compress;\n    await cliInit({\n      type: 'app',\n      language,\n      canUseNetwork: true,\n      generateOnly,\n      workDir: resolvedOutputPath,\n      stackName,\n      migrate: true,\n    });\n\n    let stackFileName: string;\n    switch (language) {\n      case 'typescript':\n        stackFileName = `${resolvedOutputPath}/lib/${formattedStackName}-stack.ts`;\n        break;\n      case 'java':\n        stackFileName = `${resolvedOutputPath}/src/main/java/com/myorg/${camelCase(formattedStackName, { pascalCase: true })}Stack.java`;\n        break;\n      case 'python':\n        stackFileName = `${resolvedOutputPath}/${formattedStackName.replace(/-/g, '_')}/${formattedStackName.replace(/-/g, '_')}_stack.py`;\n        break;\n      case 'csharp':\n        stackFileName = `${resolvedOutputPath}/src/${camelCase(formattedStackName, { pascalCase: true })}/${camelCase(formattedStackName, { pascalCase: true })}Stack.cs`;\n        break;\n      case 'go':\n        stackFileName = `${resolvedOutputPath}/${formattedStackName}.go`;\n        break;\n      default:\n        throw new ToolkitError(\n          `${language} is not supported by CDK Migrate. Please choose from: ${MIGRATE_SUPPORTED_LANGUAGES.join(', ')}`,\n        );\n    }\n    fs.writeFileSync(stackFileName, stack);\n    if (compress) {\n      await zipDirectory(resolvedOutputPath, `${resolvedOutputPath}.zip`);\n      fs.rmSync(resolvedOutputPath, { recursive: true, force: true });\n    }\n  } catch (error) {\n    fs.rmSync(resolvedOutputPath, { recursive: true, force: true });\n    throw error;\n  }\n}\n\n/**\n * Generates a CDK stack file.\n * @param template - The template to translate into a CDK stack\n * @param stackName - The name to assign to the stack\n * @param language - The language to generate the stack in\n * @returns A string representation of a CDK stack file\n */\nexport function generateStack(template: string, stackName: string, language: string) {\n  const formattedStackName = `${camelCase(decamelize(stackName), { pascalCase: true })}Stack`;\n  try {\n    return cdk_from_cfn.transmute(template, language, formattedStackName);\n  } catch (e) {\n    throw new ToolkitError(`${formattedStackName} could not be generated because ${(e as Error).message}`);\n  }\n}\n\n/**\n * Reads and returns a stack template from a local path.\n *\n * @param inputPath - The location of the template\n * @returns A string representation of the template if present, otherwise undefined\n */\nexport function readFromPath(inputPath: string): string {\n  let readFile: string;\n  try {\n    readFile = fs.readFileSync(inputPath, 'utf8');\n  } catch (e) {\n    throw new ToolkitError(`'${inputPath}' is not a valid path.`);\n  }\n  if (readFile == '') {\n    throw new ToolkitError(`Cloudformation template filepath: '${inputPath}' is an empty file.`);\n  }\n  return readFile;\n}\n\n/**\n * Reads and returns a stack template from a deployed CloudFormation stack.\n *\n * @param stackName - The name of the stack\n * @param sdkProvider - The sdk provider for making CloudFormation calls\n * @param environment - The account and region where the stack is deployed\n * @returns A string representation of the template if present, otherwise undefined\n */\nexport async function readFromStack(\n  stackName: string,\n  sdkProvider: SdkProvider,\n  environment: Environment,\n): Promise<string | undefined> {\n  const cloudFormation = (await sdkProvider.forEnvironment(environment, Mode.ForReading)).sdk.cloudFormation();\n\n  const stack = await CloudFormationStack.lookup(cloudFormation, stackName, true);\n  if (stack.stackStatus.isDeploySuccess || stack.stackStatus.isRollbackSuccess) {\n    return JSON.stringify(await stack.template());\n  } else {\n    throw new ToolkitError(\n      `Stack '${stackName}' in account ${environment.account} and region ${environment.region} has a status of '${stack.stackStatus.name}' due to '${stack.stackStatus.reason}'. The stack cannot be migrated until it is in a healthy state.`,\n    );\n  }\n}\n\n/**\n * Takes in a stack name and account and region and returns a generated cloudformation template using the cloudformation\n * template generator.\n *\n * @param GenerateTemplateOptions - An object containing the stack name, filters, sdkProvider, environment, and newScan flag\n * @returns a generated cloudformation template\n */\nexport async function generateTemplate(options: GenerateTemplateOptions): Promise<GenerateTemplateOutput> {\n  const cfn = new CfnTemplateGeneratorProvider(await buildCfnClient(options.sdkProvider, options.environment));\n\n  const scanId = await findLastSuccessfulScan(cfn, options);\n\n  // if a customer accidentally ctrl-c's out of the command and runs it again, this will continue the progress bar where it left off\n  const curScan = await cfn.describeResourceScan(scanId);\n  if (curScan.Status == ScanStatus.IN_PROGRESS) {\n    info('Resource scan in progress. Please wait, this can take 10 minutes or longer.');\n    await scanProgressBar(scanId, cfn);\n  }\n\n  displayTimeDiff(new Date(), new Date(curScan.StartTime!));\n\n  let resources: ScannedResource[] = await cfn.listResourceScanResources(scanId!, options.filters);\n\n  info('finding related resources.');\n  let relatedResources = await cfn.getResourceScanRelatedResources(scanId!, resources);\n\n  info(`Found ${relatedResources.length} resources.`);\n\n  info('Generating CFN template from scanned resources.');\n  const templateArn = (await cfn.createGeneratedTemplate(options.stackName, relatedResources)).GeneratedTemplateId!;\n\n  let generatedTemplate = await cfn.describeGeneratedTemplate(templateArn);\n\n  info('Please wait, template creation in progress. This may take a couple minutes.');\n  while (generatedTemplate.Status !== ScanStatus.COMPLETE && generatedTemplate.Status !== ScanStatus.FAILED) {\n    await printDots(`[${generatedTemplate.Status}] Template Creation in Progress`, 400);\n    generatedTemplate = await cfn.describeGeneratedTemplate(templateArn);\n  }\n  info('');\n  info('Template successfully generated!');\n  return buildGenertedTemplateOutput(\n    generatedTemplate,\n    (await cfn.getGeneratedTemplate(templateArn)).TemplateBody!,\n    templateArn,\n  );\n}\n\nasync function findLastSuccessfulScan(\n  cfn: CfnTemplateGeneratorProvider,\n  options: GenerateTemplateOptions,\n): Promise<string> {\n  let resourceScanSummaries: ResourceScanSummary[] | undefined = [];\n  const clientRequestToken = `cdk-migrate-${options.environment.account}-${options.environment.region}`;\n  if (options.fromScan === FromScan.NEW) {\n    info(`Starting new scan for account ${options.environment.account} in region ${options.environment.region}`);\n    try {\n      await cfn.startResourceScan(clientRequestToken);\n      resourceScanSummaries = (await cfn.listResourceScans()).ResourceScanSummaries;\n    } catch (e) {\n      // continuing here because if the scan fails on a new-scan it is very likely because there is either already a scan in progress\n      // or the customer hit a rate limit. In either case we want to continue with the most recent scan.\n      // If this happens to fail for a credential error then that will be caught immediately after anyway.\n      info(`Scan failed to start due to error '${(e as Error).message}', defaulting to latest scan.`);\n    }\n  } else {\n    resourceScanSummaries = (await cfn.listResourceScans()).ResourceScanSummaries;\n    await cfn.checkForResourceScan(resourceScanSummaries, options, clientRequestToken);\n  }\n  // get the latest scan, which we know will exist\n  resourceScanSummaries = (await cfn.listResourceScans()).ResourceScanSummaries;\n  let scanId: string | undefined = resourceScanSummaries![0].ResourceScanId;\n\n  // find the most recent scan that isn't in a failed state in case we didn't start a new one\n  for (const summary of resourceScanSummaries!) {\n    if (summary.Status !== ScanStatus.FAILED) {\n      scanId = summary.ResourceScanId!;\n      break;\n    }\n  }\n\n  return scanId!;\n}\n\n/**\n * Takes a string of filters in the format of key1=value1,key2=value2 and returns a map of the filters.\n *\n * @param filters - a string of filters in the format of key1=value1,key2=value2\n * @returns a map of the filters\n */\nfunction parseFilters(filters: string): {\n  [key in FilterType]: string | undefined;\n} {\n  if (!filters) {\n    return {\n      'resource-identifier': undefined,\n      'resource-type-prefix': undefined,\n      'tag-key': undefined,\n      'tag-value': undefined,\n    };\n  }\n\n  const filterShorthands: { [key: string]: FilterType } = {\n    'identifier': FilterType.RESOURCE_IDENTIFIER,\n    'id': FilterType.RESOURCE_IDENTIFIER,\n    'type': FilterType.RESOURCE_TYPE_PREFIX,\n    'type-prefix': FilterType.RESOURCE_TYPE_PREFIX,\n  };\n\n  const filterList = filters.split(',');\n\n  let filterMap: { [key in FilterType]: string | undefined } = {\n    [FilterType.RESOURCE_IDENTIFIER]: undefined,\n    [FilterType.RESOURCE_TYPE_PREFIX]: undefined,\n    [FilterType.TAG_KEY]: undefined,\n    [FilterType.TAG_VALUE]: undefined,\n  };\n\n  for (const fil of filterList) {\n    const filter = fil.split('=');\n    let filterKey = filter[0];\n    const filterValue = filter[1];\n    // if the key is a shorthand, replace it with the full name\n    if (filterKey in filterShorthands) {\n      filterKey = filterShorthands[filterKey];\n    }\n    if (Object.values(FilterType).includes(filterKey as any)) {\n      filterMap[filterKey as keyof typeof filterMap] = filterValue;\n    } else {\n      throw new ToolkitError(`Invalid filter: ${filterKey}`);\n    }\n  }\n  return filterMap;\n}\n\n/**\n * Takes a list of any type and breaks it up into chunks of a specified size.\n *\n * @param list - The list to break up\n * @param chunkSize - The size of each chunk\n * @returns A list of lists of the specified size\n */\nexport function chunks(list: any[], chunkSize: number): any[][] {\n  const chunkedList: any[][] = [];\n  for (let i = 0; i < list.length; i += chunkSize) {\n    chunkedList.push(list.slice(i, i + chunkSize));\n  }\n  return chunkedList;\n}\n\n/**\n * Sets the account and region for making CloudFormation calls.\n * @param account - The account to use\n * @param region - The region to use\n * @returns The environment object\n */\nexport function setEnvironment(account?: string, region?: string): Environment {\n  return {\n    account: account ?? UNKNOWN_ACCOUNT,\n    region: region ?? UNKNOWN_REGION,\n    name: 'cdk-migrate-env',\n  };\n}\n\n/**\n * Enum for the source options for the template\n */\nexport enum TemplateSourceOptions {\n  PATH = 'path',\n  STACK = 'stack',\n  SCAN = 'scan',\n}\n\n/**\n * An object representing the source of a template.\n */\ntype TemplateSource =\n  | { source: TemplateSourceOptions.SCAN }\n  | { source: TemplateSourceOptions.PATH; templatePath: string }\n  | { source: TemplateSourceOptions.STACK; stackName: string };\n\n/**\n * Enum for the status of a resource scan\n */\nexport enum ScanStatus {\n  IN_PROGRESS = 'IN_PROGRESS',\n  COMPLETE = 'COMPLETE',\n  FAILED = 'FAILED',\n}\n\nexport enum FilterType {\n  RESOURCE_IDENTIFIER = 'resource-identifier',\n  RESOURCE_TYPE_PREFIX = 'resource-type-prefix',\n  TAG_KEY = 'tag-key',\n  TAG_VALUE = 'tag-value',\n}\n\n/**\n * Validates that exactly one source option has been provided.\n * @param fromPath - The content of the flag `--from-path`\n * @param fromStack - the content of the flag `--from-stack`\n */\nexport function parseSourceOptions(fromPath?: string, fromStack?: boolean, stackName?: string): TemplateSource {\n  if (fromPath && fromStack) {\n    throw new ToolkitError('Only one of `--from-path` or `--from-stack` may be provided.');\n  }\n  if (!stackName) {\n    throw new ToolkitError('`--stack-name` is a required field.');\n  }\n  if (!fromPath && !fromStack) {\n    return { source: TemplateSourceOptions.SCAN };\n  }\n  if (fromPath) {\n    return { source: TemplateSourceOptions.PATH, templatePath: fromPath };\n  }\n  return { source: TemplateSourceOptions.STACK, stackName: stackName! };\n}\n\n/**\n * Takes a set of resources and removes any with the managedbystack flag set to true.\n *\n * @param resourceList - the list of resources provided by the list scanned resources calls\n * @returns a list of resources not managed by cfn stacks\n */\nfunction excludeManaged(resourceList: ScannedResource[]): ScannedResourceIdentifier[] {\n  return resourceList\n    .filter((r) => !r.ManagedByStack)\n    .map((r) => ({\n      ResourceType: r.ResourceType!,\n      ResourceIdentifier: r.ResourceIdentifier!,\n    }));\n}\n\n/**\n * Transforms a list of resources into a list of resource identifiers by removing the ManagedByStack flag.\n * Setting the value of the field to undefined effectively removes it from the object.\n *\n * @param resourceList - the list of resources provided by the list scanned resources calls\n * @returns a list of ScannedResourceIdentifier[]\n */\nfunction resourceIdentifiers(resourceList: ScannedResource[]): ScannedResourceIdentifier[] {\n  const identifiers: ScannedResourceIdentifier[] = [];\n  resourceList.forEach((r) => {\n    const identifier: ScannedResourceIdentifier = {\n      ResourceType: r.ResourceType!,\n      ResourceIdentifier: r.ResourceIdentifier!,\n    };\n    identifiers.push(identifier);\n  });\n  return identifiers;\n}\n\n/**\n * Takes a scan id and maintains a progress bar to display the progress of a scan to the user.\n *\n * @param scanId - A string representing the scan id\n * @param cloudFormation - The CloudFormation sdk client to use\n */\nexport async function scanProgressBar(scanId: string, cfn: CfnTemplateGeneratorProvider) {\n  let curProgress = 0.5;\n  // we know it's in progress initially since we wouldn't have gotten here if it wasn't\n  let curScan: DescribeResourceScanCommandOutput = {\n    Status: ScanStatus.IN_PROGRESS,\n    $metadata: {},\n  };\n  while (curScan.Status == ScanStatus.IN_PROGRESS) {\n    curScan = await cfn.describeResourceScan(scanId);\n    curProgress = curScan.PercentageCompleted ?? curProgress;\n    printBar(30, curProgress);\n    await new Promise((resolve) => setTimeout(resolve, 2000));\n  }\n  info('');\n  info('✅ Scan Complete!');\n}\n\n/**\n * Prints a progress bar to the console. To be used in a while loop to show progress of a long running task.\n * The progress bar deletes the current line on the console and rewrites it with the progress amount.\n *\n * @param width - The width of the progress bar\n * @param progress - The current progress to display as a percentage of 100\n */\nexport function printBar(width: number, progress: number) {\n  if (!process.env.MIGRATE_INTEG_TEST) {\n    const FULL_BLOCK = '█';\n    const PARTIAL_BLOCK = ['', '▏', '▎', '▍', '▌', '▋', '▊', '▉'];\n    const fraction = Math.min(progress / 100, 1);\n    const innerWidth = Math.max(1, width - 2);\n    const chars = innerWidth * fraction;\n    const remainder = chars - Math.floor(chars);\n\n    const fullChars = FULL_BLOCK.repeat(Math.floor(chars));\n    const partialChar = PARTIAL_BLOCK[Math.floor(remainder * PARTIAL_BLOCK.length)];\n    const filler = '·'.repeat(innerWidth - Math.floor(chars) - (partialChar ? 1 : 0));\n\n    const color = chalk.green;\n\n    rewriteLine('[' + color(fullChars + partialChar) + filler + `] (${progress}%)`);\n  }\n}\n\n/**\n * Prints a message to the console with a series periods appended to it. To be used in a while loop to show progress of a long running task.\n * The message deletes the current line and rewrites it several times to display 1-3 periods to show the user that the task is still running.\n *\n * @param message - The message to display\n * @param timeoutx4 - The amount of time to wait before printing the next period\n */\nexport async function printDots(message: string, timeoutx4: number) {\n  if (!process.env.MIGRATE_INTEG_TEST) {\n    rewriteLine(message + ' .');\n    await new Promise((resolve) => setTimeout(resolve, timeoutx4));\n\n    rewriteLine(message + ' ..');\n    await new Promise((resolve) => setTimeout(resolve, timeoutx4));\n\n    rewriteLine(message + ' ...');\n    await new Promise((resolve) => setTimeout(resolve, timeoutx4));\n\n    rewriteLine(message);\n    await new Promise((resolve) => setTimeout(resolve, timeoutx4));\n  }\n}\n\n/**\n * Rewrites the current line on the console and writes a new message to it.\n * This is a helper funciton for printDots and printBar.\n *\n * @param message - The message to display\n */\nexport function rewriteLine(message: string) {\n  process.stdout.clearLine(0);\n  process.stdout.cursorTo(0);\n  process.stdout.write(message);\n}\n\n/**\n * Prints the time difference between two dates in days, hours, and minutes.\n *\n * @param time1 - The first date to compare\n * @param time2 - The second date to compare\n */\nexport function displayTimeDiff(time1: Date, time2: Date): void {\n  const diff = Math.abs(time1.getTime() - time2.getTime());\n\n  const days = Math.floor(diff / (1000 * 60 * 60 * 24));\n  const hours = Math.floor((diff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));\n  const minutes = Math.floor((diff % (1000 * 60 * 60)) / (1000 * 60));\n\n  info(`Using the latest successful scan which is ${days} days, ${hours} hours, and ${minutes} minutes old.`);\n}\n\n/**\n * Writes a migrate.json file to the output directory.\n *\n * @param outputPath - The path to write the migrate.json file to\n * @param stackName - The name of the stack\n * @param generatedOutput - The output of the template generator\n */\nexport function writeMigrateJsonFile(\n  outputPath: string | undefined,\n  stackName: string,\n  migrateJson: MigrateJsonFormat,\n) {\n  const outputToJson = {\n    '//': 'This file is generated by cdk migrate. It will be automatically deleted after the first successful deployment of this app to the environment of the original resources.',\n    'Source': migrateJson.source,\n    'Resources': migrateJson.resources,\n  };\n  fs.writeFileSync(\n    `${path.join(outputPath ?? process.cwd(), stackName)}/migrate.json`,\n    JSON.stringify(outputToJson, null, 2),\n  );\n}\n\n/**\n * Takes a string representing the from-scan flag and returns a FromScan enum value.\n *\n * @param scanType - A string representing the from-scan flag\n * @returns A FromScan enum value\n */\nexport function getMigrateScanType(scanType: string) {\n  switch (scanType) {\n    case 'new':\n      return FromScan.NEW;\n    case 'most-recent':\n      return FromScan.MOST_RECENT;\n    case '':\n      return FromScan.DEFAULT;\n    case undefined:\n      return FromScan.DEFAULT;\n    default:\n      throw new ToolkitError(`Unknown scan type: ${scanType}`);\n  }\n}\n\n/**\n * Takes a generatedTemplateOutput objct and returns a boolean representing whether there are any warnings on any rescources.\n *\n * @param generatedTemplateOutput - A GenerateTemplateOutput object\n * @returns A boolean representing whether there are any warnings on any rescources\n */\nexport function isThereAWarning(generatedTemplateOutput: GenerateTemplateOutput) {\n  if (generatedTemplateOutput.resources) {\n    for (const resource of generatedTemplateOutput.resources) {\n      if (resource.Warnings && resource.Warnings.length > 0) {\n        return true;\n      }\n    }\n  }\n  return false;\n}\n\n/**\n * Builds the GenerateTemplateOutput object from the DescribeGeneratedTemplateOutput and the template body.\n *\n * @param generatedTemplateSummary - The output of the describe generated template call\n * @param templateBody - The body of the generated template\n * @returns A GenerateTemplateOutput object\n */\nexport function buildGenertedTemplateOutput(\n  generatedTemplateSummary: DescribeGeneratedTemplateCommandOutput,\n  templateBody: string,\n  source: string,\n): GenerateTemplateOutput {\n  const resources: ResourceDetail[] | undefined = generatedTemplateSummary.Resources;\n  const migrateJson: MigrateJsonFormat = {\n    templateBody: templateBody,\n    source: source,\n    resources: generatedTemplateSummary.Resources!.map((r) => ({\n      ResourceType: r.ResourceType!,\n      LogicalResourceId: r.LogicalResourceId!,\n      ResourceIdentifier: r.ResourceIdentifier!,\n    })),\n  };\n  const templateId = generatedTemplateSummary.GeneratedTemplateId!;\n  return {\n    migrateJson: migrateJson,\n    resources: resources,\n    templateId: templateId,\n  };\n}\n\n/**\n * Builds a CloudFormation sdk client for making requests with the CFN template generator.\n *\n * @param sdkProvider - The sdk provider for making CloudFormation calls\n * @param environment - The account and region where the stack is deployed\n * @returns A CloudFormation sdk client\n */\nexport async function buildCfnClient(sdkProvider: SdkProvider, environment: Environment) {\n  const sdk = (await sdkProvider.forEnvironment(environment, Mode.ForReading)).sdk;\n  sdk.appendCustomUserAgent('cdk-migrate');\n  return sdk.cloudFormation();\n}\n\n/**\n * Appends a list of warnings to a readme file.\n *\n * @param filepath - The path to the readme file\n * @param resources - A list of resources to append warnings for\n */\nexport function appendWarningsToReadme(filepath: string, resources: ResourceDetail[]) {\n  const readme = fs.readFileSync(filepath, 'utf8');\n  const lines = readme.split('\\n');\n  const index = lines.findIndex((line) => line.trim() === 'Enjoy!');\n  let linesToAdd = ['\\n## Warnings'];\n  linesToAdd.push('### Write-only properties');\n  linesToAdd.push(\n    \"Write-only properties are resource property values that can be written to but can't be read by AWS CloudFormation or CDK Migrate. For more information, see [IaC generator and write-only properties](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/generate-IaC-write-only-properties.html).\",\n  );\n  linesToAdd.push('\\n');\n  linesToAdd.push(\n    'Write-only properties discovered during migration are organized here by resource ID and categorized by write-only property type. Resolve write-only properties by providing property values in your CDK app. For guidance, see [Resolve write-only properties](https://docs.aws.amazon.com/cdk/v2/guide/migrate.html#migrate-resources-writeonly).',\n  );\n  for (const resource of resources) {\n    if (resource.Warnings && resource.Warnings.length > 0) {\n      linesToAdd.push(`### ${resource.LogicalResourceId}`);\n      for (const warning of resource.Warnings) {\n        linesToAdd.push(`- **${warning.Type}**: `);\n        for (const property of warning.Properties!) {\n          linesToAdd.push(`  - ${property.PropertyPath}: ${property.Description}`);\n        }\n      }\n    }\n  }\n  lines.splice(index, 0, ...linesToAdd);\n  fs.writeFileSync(filepath, lines.join('\\n'));\n}\n\n/**\n * takes a list of resources and returns a list of unique resources based on the resource type and logical resource id.\n *\n * @param resources - A list of resources to deduplicate\n * @returns A list of unique resources\n */\nfunction deduplicateResources(resources: ResourceDetail[]) {\n  let uniqueResources: { [key: string]: ResourceDetail } = {};\n\n  for (const resource of resources) {\n    const key = Object.keys(resource.ResourceIdentifier!)[0];\n\n    // Creating our unique identifier using the resource type, the key, and the value of the resource identifier\n    // The resource identifier is a combination of a key value pair defined by a resource's schema, and the resource type of the resource.\n    const uniqueIdentifer = `${resource.ResourceType}:${key}:${resource.ResourceIdentifier![key]}`;\n    uniqueResources[uniqueIdentifer] = resource;\n  }\n\n  return Object.values(uniqueResources);\n}\n\n/**\n * Class for making CloudFormation template generator calls\n */\nexport class CfnTemplateGeneratorProvider {\n  private cfn: ICloudFormationClient;\n  constructor(cfn: ICloudFormationClient) {\n    this.cfn = cfn;\n  }\n\n  async checkForResourceScan(\n    resourceScanSummaries: ResourceScanSummary[] | undefined,\n    options: GenerateTemplateOptions,\n    clientRequestToken: string,\n  ) {\n    if (!resourceScanSummaries || resourceScanSummaries.length === 0) {\n      if (options.fromScan === FromScan.MOST_RECENT) {\n        throw new ToolkitError(\n          'No scans found. Please either start a new scan with the `--from-scan` new or do not specify a `--from-scan` option.',\n        );\n      } else {\n        info('No scans found. Initiating a new resource scan.');\n        await this.startResourceScan(clientRequestToken);\n      }\n    }\n  }\n\n  /**\n   * Retrieves a tokenized list of resources and their associated scan. If a token is present the function\n   * will loop through all pages and combine them into a single list of ScannedRelatedResources\n   *\n   * @param scanId - scan id for the to list resources for\n   * @param resources - A list of resources to find related resources for\n   */\n  async getResourceScanRelatedResources(\n    scanId: string,\n    resources: ScannedResource[],\n  ): Promise<ScannedResourceIdentifier[]> {\n    let relatedResourceList = resources;\n\n    // break the list of resources into chunks of 100 to avoid hitting the 100 resource limit\n    for (const chunk of chunks(resources, 100)) {\n      // get the first page of related resources\n      const res = await this.cfn.listResourceScanRelatedResources({\n        ResourceScanId: scanId,\n        Resources: chunk,\n      });\n\n      // add the first page to the list\n      relatedResourceList.push(...(res.RelatedResources ?? []));\n      let nextToken = res.NextToken;\n\n      // if there are more pages, cycle through them and add them to the list before moving on to the next chunk\n      while (nextToken) {\n        const nextRelatedResources = await this.cfn.listResourceScanRelatedResources({\n          ResourceScanId: scanId,\n          Resources: resourceIdentifiers(resources),\n          NextToken: nextToken,\n        });\n        nextToken = nextRelatedResources.NextToken;\n        relatedResourceList.push(...(nextRelatedResources.RelatedResources ?? []));\n      }\n    }\n\n    relatedResourceList = deduplicateResources(relatedResourceList);\n\n    // prune the managedbystack flag off of them again.\n    return process.env.MIGRATE_INTEG_TEST\n      ? resourceIdentifiers(relatedResourceList)\n      : resourceIdentifiers(excludeManaged(relatedResourceList));\n  }\n\n  /**\n   * Kicks off a scan of a customers account, returning the scan id. A scan can take\n   * 10 minutes or longer to complete. However this will return a scan id as soon as\n   * the scan has begun.\n   *\n   * @returns A string representing the scan id\n   */\n  async startResourceScan(requestToken: string) {\n    return (\n      await this.cfn.startResourceScan({\n        ClientRequestToken: requestToken,\n      })\n    ).ResourceScanId;\n  }\n\n  /**\n   * Gets the most recent scans a customer has completed\n   *\n   * @returns a list of resource scan summaries\n   */\n  async listResourceScans() {\n    return this.cfn.listResourceScans();\n  }\n\n  /**\n   * Retrieves a tokenized list of resources from a resource scan. If a token is present, this function\n   * will loop through all pages and combine them into a single list of ScannedResource[].\n   * Additionally will apply any filters provided by the customer.\n   *\n   * @param scanId - scan id for the to list resources for\n   * @param filters - a string of filters in the format of key1=value1,key2=value2\n   * @returns a combined list of all resources from the scan\n   */\n  async listResourceScanResources(scanId: string, filters: string[] = []): Promise<ScannedResourceIdentifier[]> {\n    let resourceList: ScannedResource[] = [];\n    let resourceScanInputs: ListResourceScanResourcesCommandInput;\n\n    if (filters.length > 0) {\n      info('Applying filters to resource scan.');\n      for (const filter of filters) {\n        const filterList = parseFilters(filter);\n        resourceScanInputs = {\n          ResourceScanId: scanId,\n          ResourceIdentifier: filterList[FilterType.RESOURCE_IDENTIFIER],\n          ResourceTypePrefix: filterList[FilterType.RESOURCE_TYPE_PREFIX],\n          TagKey: filterList[FilterType.TAG_KEY],\n          TagValue: filterList[FilterType.TAG_VALUE],\n        };\n        const resources = await this.cfn.listResourceScanResources(resourceScanInputs);\n        resourceList = resourceList.concat(resources.Resources ?? []);\n        let nextToken = resources.NextToken;\n\n        // cycle through the pages adding all resources to the list until we run out of pages\n        while (nextToken) {\n          resourceScanInputs.NextToken = nextToken;\n          const nextResources = await this.cfn.listResourceScanResources(resourceScanInputs);\n          nextToken = nextResources.NextToken;\n          resourceList = resourceList!.concat(nextResources.Resources ?? []);\n        }\n      }\n    } else {\n      info('No filters provided. Retrieving all resources from scan.');\n      resourceScanInputs = {\n        ResourceScanId: scanId,\n      };\n      const resources = await this.cfn.listResourceScanResources(resourceScanInputs);\n      resourceList = resourceList!.concat(resources.Resources ?? []);\n      let nextToken = resources.NextToken;\n\n      // cycle through the pages adding all resources to the list until we run out of pages\n      while (nextToken) {\n        resourceScanInputs.NextToken = nextToken;\n        const nextResources = await this.cfn.listResourceScanResources(resourceScanInputs);\n        nextToken = nextResources.NextToken;\n        resourceList = resourceList!.concat(nextResources.Resources ?? []);\n      }\n    }\n    if (resourceList.length === 0) {\n      throw new ToolkitError(`No resources found with filters ${filters.join(' ')}. Please try again with different filters.`);\n    }\n    resourceList = deduplicateResources(resourceList);\n\n    return process.env.MIGRATE_INTEG_TEST\n      ? resourceIdentifiers(resourceList)\n      : resourceIdentifiers(excludeManaged(resourceList));\n  }\n\n  /**\n   * Retrieves information about a resource scan.\n   *\n   * @param scanId - scan id for the to list resources for\n   * @returns information about the scan\n   */\n  async describeResourceScan(scanId: string): Promise<DescribeResourceScanCommandOutput> {\n    return this.cfn.describeResourceScan({\n      ResourceScanId: scanId,\n    });\n  }\n\n  /**\n   * Describes the current status of the template being generated.\n   *\n   * @param templateId - A string representing the template id\n   * @returns DescribeGeneratedTemplateOutput an object containing the template status and results\n   */\n  async describeGeneratedTemplate(templateId: string): Promise<DescribeGeneratedTemplateCommandOutput> {\n    const generatedTemplate = await this.cfn.describeGeneratedTemplate({\n      GeneratedTemplateName: templateId,\n    });\n\n    if (generatedTemplate.Status == ScanStatus.FAILED) {\n      throw new ToolkitError(generatedTemplate.StatusReason!);\n    }\n\n    return generatedTemplate;\n  }\n\n  /**\n   * Retrieves a completed generated cloudformation template from the template generator.\n   *\n   * @param templateId - A string representing the template id\n   * @param cloudFormation - The CloudFormation sdk client to use\n   * @returns DescribeGeneratedTemplateOutput an object containing the template status and body\n   */\n  async getGeneratedTemplate(templateId: string): Promise<GetGeneratedTemplateCommandOutput> {\n    return this.cfn.getGeneratedTemplate({\n      GeneratedTemplateName: templateId,\n    });\n  }\n\n  /**\n   * Kicks off a template generation for a set of resources.\n   *\n   * @param stackName - The name of the stack\n   * @param resources - A list of resources to generate the template from\n   * @returns CreateGeneratedTemplateOutput an object containing the template arn to query on later\n   */\n  async createGeneratedTemplate(stackName: string, resources: ResourceDefinition[]) {\n    const createTemplateOutput = await this.cfn.createGeneratedTemplate({\n      Resources: resources,\n      GeneratedTemplateName: stackName,\n    });\n\n    if (createTemplateOutput.GeneratedTemplateId === undefined) {\n      throw new ToolkitError('CreateGeneratedTemplate failed to return an Arn.');\n    }\n    return createTemplateOutput;\n  }\n\n  /**\n   * Deletes a generated template from the template generator.\n   *\n   * @param templateArn - The arn of the template to delete\n   * @returns A promise that resolves when the template has been deleted\n   */\n  async deleteGeneratedTemplate(templateArn: string): Promise<void> {\n    await this.cfn.deleteGeneratedTemplate({\n      GeneratedTemplateName: templateArn,\n    });\n  }\n}\n\n/**\n * The possible ways to choose a scan to generate a CDK application from\n */\nexport enum FromScan {\n  /**\n   * Initiate a new resource scan to build the CDK application from.\n   */\n  NEW,\n\n  /**\n   * Use the last successful scan to build the CDK application from. Will fail if no scan is found.\n   */\n  MOST_RECENT,\n\n  /**\n   * Starts a scan if none exists, otherwise uses the most recent successful scan to build the CDK application from.\n   */\n  DEFAULT,\n}\n\n/**\n * Interface for the options object passed to the generateTemplate function\n *\n * @param stackName - The name of the stack\n * @param filters - A list of filters to apply to the scan\n * @param fromScan - An enum value specifying whether a new scan should be started or the most recent successful scan should be used\n * @param sdkProvider - The sdk provider for making CloudFormation calls\n * @param environment - The account and region where the stack is deployed\n */\nexport interface GenerateTemplateOptions {\n  stackName: string;\n  filters?: string[];\n  fromScan?: FromScan;\n  sdkProvider: SdkProvider;\n  environment: Environment;\n}\n\n/**\n * Interface for the output of the generateTemplate function\n *\n * @param migrateJson - The generated Migrate.json file\n * @param resources - The generated template\n */\nexport interface GenerateTemplateOutput {\n  migrateJson: MigrateJsonFormat;\n  resources?: ResourceDetail[];\n  templateId?: string;\n}\n\n/**\n * Interface defining the format of the generated Migrate.json file\n *\n * @param TemplateBody - The generated template\n * @param Source - The source of the template\n * @param Resources - A list of resources that were used to generate the template\n */\nexport interface MigrateJsonFormat {\n  templateBody: string;\n  source: string;\n  resources?: GeneratedResourceImportIdentifier[];\n}\n\n/**\n * Interface representing the format of a resource identifier required for resource import\n *\n * @param ResourceType - The type of resource\n * @param LogicalResourceId - The logical id of the resource\n * @param ResourceIdentifier - The resource identifier of the resource\n */\nexport interface GeneratedResourceImportIdentifier {\n  // cdk deploy expects the migrate.json resource identifiers to be PascalCase, not camelCase.\n  ResourceType: string;\n  LogicalResourceId: string;\n  ResourceIdentifier: ResourceIdentifierSummary;\n}\n"]}
801
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migrate.js","sourceRoot":"","sources":["migrate.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-require-imports */\n/* eslint-disable @typescript-eslint/no-var-requires */\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport type { Environment } from '@aws-cdk/cx-api';\nimport { UNKNOWN_ACCOUNT, UNKNOWN_REGION } from '@aws-cdk/cx-api';\nimport { ToolkitError } from '@aws-cdk/toolkit-lib';\nimport type {\n  DescribeGeneratedTemplateCommandOutput,\n  DescribeResourceScanCommandOutput,\n  GetGeneratedTemplateCommandOutput,\n  ListResourceScanResourcesCommandInput,\n  ResourceDefinition,\n  ResourceDetail,\n  ResourceIdentifierSummary,\n  ResourceScanSummary,\n  ScannedResource,\n  ScannedResourceIdentifier,\n} from '@aws-sdk/client-cloudformation';\nimport * as cdk_from_cfn from 'cdk-from-cfn';\nimport * as chalk from 'chalk';\nimport { cliInit } from './init';\nimport type { ICloudFormationClient, SdkProvider } from '../api/aws-auth';\nimport { CloudFormationStack } from '../api/cloudformation';\nimport { Mode } from '../api/plugin';\nimport type { IoHelper } from '../api-private';\nimport { zipDirectory } from '../util';\nconst camelCase = require('camelcase');\nconst decamelize = require('decamelize');\n/** The list of languages supported by the built-in noctilucent binary. */\nconst MIGRATE_SUPPORTED_LANGUAGES: readonly string[] = cdk_from_cfn.supported_languages();\n\n/**\n * Generates a CDK app from a yaml or json template.\n *\n * @param stackName - The name to assign to the stack in the generated app\n * @param stack - The yaml or json template for the stack\n * @param language - The language to generate the CDK app in\n * @param outputPath - The path at which to generate the CDK app\n */\nexport async function generateCdkApp(\n  ioHelper: IoHelper,\n  stackName: string,\n  stack: string,\n  language: string,\n  outputPath?: string,\n  compress?: boolean,\n): Promise<void> {\n  const resolvedOutputPath = path.join(outputPath ?? process.cwd(), stackName);\n  const formattedStackName = decamelize(stackName);\n\n  try {\n    fs.rmSync(resolvedOutputPath, { recursive: true, force: true });\n    fs.mkdirSync(resolvedOutputPath, { recursive: true });\n    const generateOnly = compress;\n    await cliInit({\n      ioHelper,\n      type: 'app',\n      language,\n      canUseNetwork: true,\n      generateOnly,\n      workDir: resolvedOutputPath,\n      stackName,\n      migrate: true,\n    });\n\n    let stackFileName: string;\n    switch (language) {\n      case 'typescript':\n        stackFileName = `${resolvedOutputPath}/lib/${formattedStackName}-stack.ts`;\n        break;\n      case 'java':\n        stackFileName = `${resolvedOutputPath}/src/main/java/com/myorg/${camelCase(formattedStackName, { pascalCase: true })}Stack.java`;\n        break;\n      case 'python':\n        stackFileName = `${resolvedOutputPath}/${formattedStackName.replace(/-/g, '_')}/${formattedStackName.replace(/-/g, '_')}_stack.py`;\n        break;\n      case 'csharp':\n        stackFileName = `${resolvedOutputPath}/src/${camelCase(formattedStackName, { pascalCase: true })}/${camelCase(formattedStackName, { pascalCase: true })}Stack.cs`;\n        break;\n      case 'go':\n        stackFileName = `${resolvedOutputPath}/${formattedStackName}.go`;\n        break;\n      default:\n        throw new ToolkitError(\n          `${language} is not supported by CDK Migrate. Please choose from: ${MIGRATE_SUPPORTED_LANGUAGES.join(', ')}`,\n        );\n    }\n    fs.writeFileSync(stackFileName, stack);\n    if (compress) {\n      await zipDirectory(resolvedOutputPath, `${resolvedOutputPath}.zip`);\n      fs.rmSync(resolvedOutputPath, { recursive: true, force: true });\n    }\n  } catch (error) {\n    fs.rmSync(resolvedOutputPath, { recursive: true, force: true });\n    throw error;\n  }\n}\n\n/**\n * Generates a CDK stack file.\n * @param template - The template to translate into a CDK stack\n * @param stackName - The name to assign to the stack\n * @param language - The language to generate the stack in\n * @returns A string representation of a CDK stack file\n */\nexport function generateStack(template: string, stackName: string, language: string) {\n  const formattedStackName = `${camelCase(decamelize(stackName), { pascalCase: true })}Stack`;\n  try {\n    return cdk_from_cfn.transmute(template, language, formattedStackName);\n  } catch (e) {\n    throw new ToolkitError(`${formattedStackName} could not be generated because ${(e as Error).message}`);\n  }\n}\n\n/**\n * Reads and returns a stack template from a local path.\n *\n * @param inputPath - The location of the template\n * @returns A string representation of the template if present, otherwise undefined\n */\nexport function readFromPath(inputPath: string): string {\n  let readFile: string;\n  try {\n    readFile = fs.readFileSync(inputPath, 'utf8');\n  } catch (e) {\n    throw new ToolkitError(`'${inputPath}' is not a valid path.`);\n  }\n  if (readFile == '') {\n    throw new ToolkitError(`Cloudformation template filepath: '${inputPath}' is an empty file.`);\n  }\n  return readFile;\n}\n\n/**\n * Reads and returns a stack template from a deployed CloudFormation stack.\n *\n * @param stackName - The name of the stack\n * @param sdkProvider - The sdk provider for making CloudFormation calls\n * @param environment - The account and region where the stack is deployed\n * @returns A string representation of the template if present, otherwise undefined\n */\nexport async function readFromStack(\n  stackName: string,\n  sdkProvider: SdkProvider,\n  environment: Environment,\n): Promise<string | undefined> {\n  const cloudFormation = (await sdkProvider.forEnvironment(environment, Mode.ForReading)).sdk.cloudFormation();\n\n  const stack = await CloudFormationStack.lookup(cloudFormation, stackName, true);\n  if (stack.stackStatus.isDeploySuccess || stack.stackStatus.isRollbackSuccess) {\n    return JSON.stringify(await stack.template());\n  } else {\n    throw new ToolkitError(\n      `Stack '${stackName}' in account ${environment.account} and region ${environment.region} has a status of '${stack.stackStatus.name}' due to '${stack.stackStatus.reason}'. The stack cannot be migrated until it is in a healthy state.`,\n    );\n  }\n}\n\n/**\n * Takes in a stack name and account and region and returns a generated cloudformation template using the cloudformation\n * template generator.\n *\n * @param GenerateTemplateOptions - An object containing the stack name, filters, sdkProvider, environment, and newScan flag\n * @returns a generated cloudformation template\n */\nexport async function generateTemplate(options: GenerateTemplateOptions): Promise<GenerateTemplateOutput> {\n  const cfn = new CfnTemplateGeneratorProvider(await buildCfnClient(options.sdkProvider, options.environment), options.ioHelper);\n  const ioHelper = options.ioHelper;\n\n  const scanId = await findLastSuccessfulScan(cfn, options);\n\n  // if a customer accidentally ctrl-c's out of the command and runs it again, this will continue the progress bar where it left off\n  const curScan = await cfn.describeResourceScan(scanId);\n  if (curScan.Status == ScanStatus.IN_PROGRESS) {\n    await ioHelper.defaults.info('Resource scan in progress. Please wait, this can take 10 minutes or longer.');\n    await scanProgressBar(ioHelper, scanId, cfn);\n  }\n\n  await displayTimeDiff(ioHelper, new Date(), new Date(curScan.StartTime!));\n\n  let resources: ScannedResource[] = await cfn.listResourceScanResources(scanId!, options.filters);\n\n  await ioHelper.defaults.info('finding related resources.');\n  let relatedResources = await cfn.getResourceScanRelatedResources(scanId!, resources);\n\n  await ioHelper.defaults.info(`Found ${relatedResources.length} resources.`);\n\n  await ioHelper.defaults.info('Generating CFN template from scanned resources.');\n  const templateArn = (await cfn.createGeneratedTemplate(options.stackName, relatedResources)).GeneratedTemplateId!;\n\n  let generatedTemplate = await cfn.describeGeneratedTemplate(templateArn);\n\n  await ioHelper.defaults.info('Please wait, template creation in progress. This may take a couple minutes.');\n  while (generatedTemplate.Status !== ScanStatus.COMPLETE && generatedTemplate.Status !== ScanStatus.FAILED) {\n    await printDots(`[${generatedTemplate.Status}] Template Creation in Progress`, 400);\n    generatedTemplate = await cfn.describeGeneratedTemplate(templateArn);\n  }\n  await ioHelper.defaults.info('\\nTemplate successfully generated!');\n  return buildGeneratedTemplateOutput(\n    generatedTemplate,\n    (await cfn.getGeneratedTemplate(templateArn)).TemplateBody!,\n    templateArn,\n  );\n}\n\nasync function findLastSuccessfulScan(\n  cfn: CfnTemplateGeneratorProvider,\n  options: GenerateTemplateOptions,\n): Promise<string> {\n  const ioHelper = options.ioHelper;\n  let resourceScanSummaries: ResourceScanSummary[] | undefined = [];\n  const clientRequestToken = `cdk-migrate-${options.environment.account}-${options.environment.region}`;\n  if (options.fromScan === FromScan.NEW) {\n    await ioHelper.defaults.info(`Starting new scan for account ${options.environment.account} in region ${options.environment.region}`);\n    try {\n      await cfn.startResourceScan(clientRequestToken);\n      resourceScanSummaries = (await cfn.listResourceScans()).ResourceScanSummaries;\n    } catch (e) {\n      // continuing here because if the scan fails on a new-scan it is very likely because there is either already a scan in progress\n      // or the customer hit a rate limit. In either case we want to continue with the most recent scan.\n      // If this happens to fail for a credential error then that will be caught immediately after anyway.\n      await ioHelper.defaults.info(`Scan failed to start due to error '${(e as Error).message}', defaulting to latest scan.`);\n    }\n  } else {\n    resourceScanSummaries = (await cfn.listResourceScans()).ResourceScanSummaries;\n    await cfn.checkForResourceScan(resourceScanSummaries, options, clientRequestToken);\n  }\n  // get the latest scan, which we know will exist\n  resourceScanSummaries = (await cfn.listResourceScans()).ResourceScanSummaries;\n  let scanId: string | undefined = resourceScanSummaries![0].ResourceScanId;\n\n  // find the most recent scan that isn't in a failed state in case we didn't start a new one\n  for (const summary of resourceScanSummaries!) {\n    if (summary.Status !== ScanStatus.FAILED) {\n      scanId = summary.ResourceScanId!;\n      break;\n    }\n  }\n\n  return scanId!;\n}\n\n/**\n * Takes a string of filters in the format of key1=value1,key2=value2 and returns a map of the filters.\n *\n * @param filters - a string of filters in the format of key1=value1,key2=value2\n * @returns a map of the filters\n */\nfunction parseFilters(filters: string): {\n  [key in FilterType]: string | undefined;\n} {\n  if (!filters) {\n    return {\n      'resource-identifier': undefined,\n      'resource-type-prefix': undefined,\n      'tag-key': undefined,\n      'tag-value': undefined,\n    };\n  }\n\n  const filterShorthands: { [key: string]: FilterType } = {\n    'identifier': FilterType.RESOURCE_IDENTIFIER,\n    'id': FilterType.RESOURCE_IDENTIFIER,\n    'type': FilterType.RESOURCE_TYPE_PREFIX,\n    'type-prefix': FilterType.RESOURCE_TYPE_PREFIX,\n  };\n\n  const filterList = filters.split(',');\n\n  let filterMap: { [key in FilterType]: string | undefined } = {\n    [FilterType.RESOURCE_IDENTIFIER]: undefined,\n    [FilterType.RESOURCE_TYPE_PREFIX]: undefined,\n    [FilterType.TAG_KEY]: undefined,\n    [FilterType.TAG_VALUE]: undefined,\n  };\n\n  for (const fil of filterList) {\n    const filter = fil.split('=');\n    let filterKey = filter[0];\n    const filterValue = filter[1];\n    // if the key is a shorthand, replace it with the full name\n    if (filterKey in filterShorthands) {\n      filterKey = filterShorthands[filterKey];\n    }\n    if (Object.values(FilterType).includes(filterKey as any)) {\n      filterMap[filterKey as keyof typeof filterMap] = filterValue;\n    } else {\n      throw new ToolkitError(`Invalid filter: ${filterKey}`);\n    }\n  }\n  return filterMap;\n}\n\n/**\n * Takes a list of any type and breaks it up into chunks of a specified size.\n *\n * @param list - The list to break up\n * @param chunkSize - The size of each chunk\n * @returns A list of lists of the specified size\n */\nexport function chunks(list: any[], chunkSize: number): any[][] {\n  const chunkedList: any[][] = [];\n  for (let i = 0; i < list.length; i += chunkSize) {\n    chunkedList.push(list.slice(i, i + chunkSize));\n  }\n  return chunkedList;\n}\n\n/**\n * Sets the account and region for making CloudFormation calls.\n * @param account - The account to use\n * @param region - The region to use\n * @returns The environment object\n */\nexport function setEnvironment(account?: string, region?: string): Environment {\n  return {\n    account: account ?? UNKNOWN_ACCOUNT,\n    region: region ?? UNKNOWN_REGION,\n    name: 'cdk-migrate-env',\n  };\n}\n\n/**\n * Enum for the source options for the template\n */\nexport enum TemplateSourceOptions {\n  PATH = 'path',\n  STACK = 'stack',\n  SCAN = 'scan',\n}\n\n/**\n * An object representing the source of a template.\n */\ntype TemplateSource =\n  | { source: TemplateSourceOptions.SCAN }\n  | { source: TemplateSourceOptions.PATH; templatePath: string }\n  | { source: TemplateSourceOptions.STACK; stackName: string };\n\n/**\n * Enum for the status of a resource scan\n */\nexport enum ScanStatus {\n  IN_PROGRESS = 'IN_PROGRESS',\n  COMPLETE = 'COMPLETE',\n  FAILED = 'FAILED',\n}\n\nexport enum FilterType {\n  RESOURCE_IDENTIFIER = 'resource-identifier',\n  RESOURCE_TYPE_PREFIX = 'resource-type-prefix',\n  TAG_KEY = 'tag-key',\n  TAG_VALUE = 'tag-value',\n}\n\n/**\n * Validates that exactly one source option has been provided.\n * @param fromPath - The content of the flag `--from-path`\n * @param fromStack - the content of the flag `--from-stack`\n */\nexport function parseSourceOptions(fromPath?: string, fromStack?: boolean, stackName?: string): TemplateSource {\n  if (fromPath && fromStack) {\n    throw new ToolkitError('Only one of `--from-path` or `--from-stack` may be provided.');\n  }\n  if (!stackName) {\n    throw new ToolkitError('`--stack-name` is a required field.');\n  }\n  if (!fromPath && !fromStack) {\n    return { source: TemplateSourceOptions.SCAN };\n  }\n  if (fromPath) {\n    return { source: TemplateSourceOptions.PATH, templatePath: fromPath };\n  }\n  return { source: TemplateSourceOptions.STACK, stackName: stackName! };\n}\n\n/**\n * Takes a set of resources and removes any with the managedbystack flag set to true.\n *\n * @param resourceList - the list of resources provided by the list scanned resources calls\n * @returns a list of resources not managed by cfn stacks\n */\nfunction excludeManaged(resourceList: ScannedResource[]): ScannedResourceIdentifier[] {\n  return resourceList\n    .filter((r) => !r.ManagedByStack)\n    .map((r) => ({\n      ResourceType: r.ResourceType!,\n      ResourceIdentifier: r.ResourceIdentifier!,\n    }));\n}\n\n/**\n * Transforms a list of resources into a list of resource identifiers by removing the ManagedByStack flag.\n * Setting the value of the field to undefined effectively removes it from the object.\n *\n * @param resourceList - the list of resources provided by the list scanned resources calls\n * @returns a list of ScannedResourceIdentifier[]\n */\nfunction resourceIdentifiers(resourceList: ScannedResource[]): ScannedResourceIdentifier[] {\n  const identifiers: ScannedResourceIdentifier[] = [];\n  resourceList.forEach((r) => {\n    const identifier: ScannedResourceIdentifier = {\n      ResourceType: r.ResourceType!,\n      ResourceIdentifier: r.ResourceIdentifier!,\n    };\n    identifiers.push(identifier);\n  });\n  return identifiers;\n}\n\n/**\n * Takes a scan id and maintains a progress bar to display the progress of a scan to the user.\n *\n * @param scanId - A string representing the scan id\n * @param cloudFormation - The CloudFormation sdk client to use\n */\nasync function scanProgressBar(ioHelper: IoHelper, scanId: string, cfn: CfnTemplateGeneratorProvider) {\n  let curProgress = 0.5;\n  // we know it's in progress initially since we wouldn't have gotten here if it wasn't\n  let curScan: DescribeResourceScanCommandOutput = {\n    Status: ScanStatus.IN_PROGRESS,\n    $metadata: {},\n  };\n  while (curScan.Status == ScanStatus.IN_PROGRESS) {\n    curScan = await cfn.describeResourceScan(scanId);\n    curProgress = curScan.PercentageCompleted ?? curProgress;\n    printBar(30, curProgress);\n    await new Promise((resolve) => setTimeout(resolve, 2000));\n  }\n  await ioHelper.defaults.info('\\n✅ Scan Complete!');\n}\n\n/**\n * Prints a progress bar to the console. To be used in a while loop to show progress of a long running task.\n * The progress bar deletes the current line on the console and rewrites it with the progress amount.\n *\n * @param width - The width of the progress bar\n * @param progress - The current progress to display as a percentage of 100\n */\nexport function printBar(width: number, progress: number) {\n  if (!process.env.MIGRATE_INTEG_TEST) {\n    const FULL_BLOCK = '█';\n    const PARTIAL_BLOCK = ['', '▏', '▎', '▍', '▌', '▋', '▊', '▉'];\n    const fraction = Math.min(progress / 100, 1);\n    const innerWidth = Math.max(1, width - 2);\n    const chars = innerWidth * fraction;\n    const remainder = chars - Math.floor(chars);\n\n    const fullChars = FULL_BLOCK.repeat(Math.floor(chars));\n    const partialChar = PARTIAL_BLOCK[Math.floor(remainder * PARTIAL_BLOCK.length)];\n    const filler = '·'.repeat(innerWidth - Math.floor(chars) - (partialChar ? 1 : 0));\n\n    const color = chalk.green;\n\n    rewriteLine('[' + color(fullChars + partialChar) + filler + `] (${progress}%)`);\n  }\n}\n\n/**\n * Prints a message to the console with a series periods appended to it. To be used in a while loop to show progress of a long running task.\n * The message deletes the current line and rewrites it several times to display 1-3 periods to show the user that the task is still running.\n *\n * @param message - The message to display\n * @param timeoutx4 - The amount of time to wait before printing the next period\n */\nexport async function printDots(message: string, timeoutx4: number) {\n  if (!process.env.MIGRATE_INTEG_TEST) {\n    rewriteLine(message + ' .');\n    await new Promise((resolve) => setTimeout(resolve, timeoutx4));\n\n    rewriteLine(message + ' ..');\n    await new Promise((resolve) => setTimeout(resolve, timeoutx4));\n\n    rewriteLine(message + ' ...');\n    await new Promise((resolve) => setTimeout(resolve, timeoutx4));\n\n    rewriteLine(message);\n    await new Promise((resolve) => setTimeout(resolve, timeoutx4));\n  }\n}\n\n/**\n * Rewrites the current line on the console and writes a new message to it.\n * This is a helper funciton for printDots and printBar.\n *\n * @param message - The message to display\n */\nexport function rewriteLine(message: string) {\n  process.stdout.clearLine(0);\n  process.stdout.cursorTo(0);\n  process.stdout.write(message);\n}\n\n/**\n * Prints the time difference between two dates in days, hours, and minutes.\n *\n * @param time1 - The first date to compare\n * @param time2 - The second date to compare\n */\nasync function displayTimeDiff(ioHelper: IoHelper, time1: Date, time2: Date): Promise<void> {\n  const diff = Math.abs(time1.getTime() - time2.getTime());\n\n  const days = Math.floor(diff / (1000 * 60 * 60 * 24));\n  const hours = Math.floor((diff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));\n  const minutes = Math.floor((diff % (1000 * 60 * 60)) / (1000 * 60));\n\n  await ioHelper.defaults.info(`Using the latest successful scan which is ${days} days, ${hours} hours, and ${minutes} minutes old.`);\n}\n\n/**\n * Writes a migrate.json file to the output directory.\n *\n * @param outputPath - The path to write the migrate.json file to\n * @param stackName - The name of the stack\n * @param generatedOutput - The output of the template generator\n */\nexport function writeMigrateJsonFile(\n  outputPath: string | undefined,\n  stackName: string,\n  migrateJson: MigrateJsonFormat,\n) {\n  const outputToJson = {\n    '//': 'This file is generated by cdk migrate. It will be automatically deleted after the first successful deployment of this app to the environment of the original resources.',\n    'Source': migrateJson.source,\n    'Resources': migrateJson.resources,\n  };\n  fs.writeFileSync(\n    `${path.join(outputPath ?? process.cwd(), stackName)}/migrate.json`,\n    JSON.stringify(outputToJson, null, 2),\n  );\n}\n\n/**\n * Takes a string representing the from-scan flag and returns a FromScan enum value.\n *\n * @param scanType - A string representing the from-scan flag\n * @returns A FromScan enum value\n */\nexport function getMigrateScanType(scanType: string) {\n  switch (scanType) {\n    case 'new':\n      return FromScan.NEW;\n    case 'most-recent':\n      return FromScan.MOST_RECENT;\n    case '':\n      return FromScan.DEFAULT;\n    case undefined:\n      return FromScan.DEFAULT;\n    default:\n      throw new ToolkitError(`Unknown scan type: ${scanType}`);\n  }\n}\n\n/**\n * Takes a generatedTemplateOutput objct and returns a boolean representing whether there are any warnings on any rescources.\n *\n * @param generatedTemplateOutput - A GenerateTemplateOutput object\n * @returns A boolean representing whether there are any warnings on any rescources\n */\nexport function isThereAWarning(generatedTemplateOutput: GenerateTemplateOutput) {\n  if (generatedTemplateOutput.resources) {\n    for (const resource of generatedTemplateOutput.resources) {\n      if (resource.Warnings && resource.Warnings.length > 0) {\n        return true;\n      }\n    }\n  }\n  return false;\n}\n\n/**\n * Builds the GenerateTemplateOutput object from the DescribeGeneratedTemplateOutput and the template body.\n *\n * @param generatedTemplateSummary - The output of the describe generated template call\n * @param templateBody - The body of the generated template\n * @returns A GenerateTemplateOutput object\n */\nexport function buildGeneratedTemplateOutput(\n  generatedTemplateSummary: DescribeGeneratedTemplateCommandOutput,\n  templateBody: string,\n  source: string,\n): GenerateTemplateOutput {\n  const resources: ResourceDetail[] | undefined = generatedTemplateSummary.Resources;\n  const migrateJson: MigrateJsonFormat = {\n    templateBody: templateBody,\n    source: source,\n    resources: generatedTemplateSummary.Resources!.map((r) => ({\n      ResourceType: r.ResourceType!,\n      LogicalResourceId: r.LogicalResourceId!,\n      ResourceIdentifier: r.ResourceIdentifier!,\n    })),\n  };\n  const templateId = generatedTemplateSummary.GeneratedTemplateId!;\n  return {\n    migrateJson: migrateJson,\n    resources: resources,\n    templateId: templateId,\n  };\n}\n\n/**\n * Builds a CloudFormation sdk client for making requests with the CFN template generator.\n *\n * @param sdkProvider - The sdk provider for making CloudFormation calls\n * @param environment - The account and region where the stack is deployed\n * @returns A CloudFormation sdk client\n */\nexport async function buildCfnClient(sdkProvider: SdkProvider, environment: Environment) {\n  const sdk = (await sdkProvider.forEnvironment(environment, Mode.ForReading)).sdk;\n  sdk.appendCustomUserAgent('cdk-migrate');\n  return sdk.cloudFormation();\n}\n\n/**\n * Appends a list of warnings to a readme file.\n *\n * @param filepath - The path to the readme file\n * @param resources - A list of resources to append warnings for\n */\nexport function appendWarningsToReadme(filepath: string, resources: ResourceDetail[]) {\n  const readme = fs.readFileSync(filepath, 'utf8');\n  const lines = readme.split('\\n');\n  const index = lines.findIndex((line) => line.trim() === 'Enjoy!');\n  let linesToAdd = ['\\n## Warnings'];\n  linesToAdd.push('### Write-only properties');\n  linesToAdd.push(\n    \"Write-only properties are resource property values that can be written to but can't be read by AWS CloudFormation or CDK Migrate. For more information, see [IaC generator and write-only properties](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/generate-IaC-write-only-properties.html).\",\n  );\n  linesToAdd.push('\\n');\n  linesToAdd.push(\n    'Write-only properties discovered during migration are organized here by resource ID and categorized by write-only property type. Resolve write-only properties by providing property values in your CDK app. For guidance, see [Resolve write-only properties](https://docs.aws.amazon.com/cdk/v2/guide/migrate.html#migrate-resources-writeonly).',\n  );\n  for (const resource of resources) {\n    if (resource.Warnings && resource.Warnings.length > 0) {\n      linesToAdd.push(`### ${resource.LogicalResourceId}`);\n      for (const warning of resource.Warnings) {\n        linesToAdd.push(`- **${warning.Type}**: `);\n        for (const property of warning.Properties!) {\n          linesToAdd.push(`  - ${property.PropertyPath}: ${property.Description}`);\n        }\n      }\n    }\n  }\n  lines.splice(index, 0, ...linesToAdd);\n  fs.writeFileSync(filepath, lines.join('\\n'));\n}\n\n/**\n * takes a list of resources and returns a list of unique resources based on the resource type and logical resource id.\n *\n * @param resources - A list of resources to deduplicate\n * @returns A list of unique resources\n */\nfunction deduplicateResources(resources: ResourceDetail[]) {\n  let uniqueResources: { [key: string]: ResourceDetail } = {};\n\n  for (const resource of resources) {\n    const key = Object.keys(resource.ResourceIdentifier!)[0];\n\n    // Creating our unique identifier using the resource type, the key, and the value of the resource identifier\n    // The resource identifier is a combination of a key value pair defined by a resource's schema, and the resource type of the resource.\n    const uniqueIdentifer = `${resource.ResourceType}:${key}:${resource.ResourceIdentifier![key]}`;\n    uniqueResources[uniqueIdentifer] = resource;\n  }\n\n  return Object.values(uniqueResources);\n}\n\n/**\n * Class for making CloudFormation template generator calls\n */\nexport class CfnTemplateGeneratorProvider {\n  private cfn: ICloudFormationClient;\n  private ioHelper: IoHelper;\n  constructor(cfn: ICloudFormationClient, ioHelper: IoHelper) {\n    this.cfn = cfn;\n    this.ioHelper = ioHelper;\n  }\n\n  async checkForResourceScan(\n    resourceScanSummaries: ResourceScanSummary[] | undefined,\n    options: GenerateTemplateOptions,\n    clientRequestToken: string,\n  ) {\n    if (!resourceScanSummaries || resourceScanSummaries.length === 0) {\n      if (options.fromScan === FromScan.MOST_RECENT) {\n        throw new ToolkitError(\n          'No scans found. Please either start a new scan with the `--from-scan` new or do not specify a `--from-scan` option.',\n        );\n      } else {\n        await this.ioHelper.defaults.info('No scans found. Initiating a new resource scan.');\n        await this.startResourceScan(clientRequestToken);\n      }\n    }\n  }\n\n  /**\n   * Retrieves a tokenized list of resources and their associated scan. If a token is present the function\n   * will loop through all pages and combine them into a single list of ScannedRelatedResources\n   *\n   * @param scanId - scan id for the to list resources for\n   * @param resources - A list of resources to find related resources for\n   */\n  async getResourceScanRelatedResources(\n    scanId: string,\n    resources: ScannedResource[],\n  ): Promise<ScannedResourceIdentifier[]> {\n    let relatedResourceList = resources;\n\n    // break the list of resources into chunks of 100 to avoid hitting the 100 resource limit\n    for (const chunk of chunks(resources, 100)) {\n      // get the first page of related resources\n      const res = await this.cfn.listResourceScanRelatedResources({\n        ResourceScanId: scanId,\n        Resources: chunk,\n      });\n\n      // add the first page to the list\n      relatedResourceList.push(...(res.RelatedResources ?? []));\n      let nextToken = res.NextToken;\n\n      // if there are more pages, cycle through them and add them to the list before moving on to the next chunk\n      while (nextToken) {\n        const nextRelatedResources = await this.cfn.listResourceScanRelatedResources({\n          ResourceScanId: scanId,\n          Resources: resourceIdentifiers(resources),\n          NextToken: nextToken,\n        });\n        nextToken = nextRelatedResources.NextToken;\n        relatedResourceList.push(...(nextRelatedResources.RelatedResources ?? []));\n      }\n    }\n\n    relatedResourceList = deduplicateResources(relatedResourceList);\n\n    // prune the managedbystack flag off of them again.\n    return process.env.MIGRATE_INTEG_TEST\n      ? resourceIdentifiers(relatedResourceList)\n      : resourceIdentifiers(excludeManaged(relatedResourceList));\n  }\n\n  /**\n   * Kicks off a scan of a customers account, returning the scan id. A scan can take\n   * 10 minutes or longer to complete. However this will return a scan id as soon as\n   * the scan has begun.\n   *\n   * @returns A string representing the scan id\n   */\n  async startResourceScan(requestToken: string) {\n    return (\n      await this.cfn.startResourceScan({\n        ClientRequestToken: requestToken,\n      })\n    ).ResourceScanId;\n  }\n\n  /**\n   * Gets the most recent scans a customer has completed\n   *\n   * @returns a list of resource scan summaries\n   */\n  async listResourceScans() {\n    return this.cfn.listResourceScans();\n  }\n\n  /**\n   * Retrieves a tokenized list of resources from a resource scan. If a token is present, this function\n   * will loop through all pages and combine them into a single list of ScannedResource[].\n   * Additionally will apply any filters provided by the customer.\n   *\n   * @param scanId - scan id for the to list resources for\n   * @param filters - a string of filters in the format of key1=value1,key2=value2\n   * @returns a combined list of all resources from the scan\n   */\n  async listResourceScanResources(scanId: string, filters: string[] = []): Promise<ScannedResourceIdentifier[]> {\n    let resourceList: ScannedResource[] = [];\n    let resourceScanInputs: ListResourceScanResourcesCommandInput;\n\n    if (filters.length > 0) {\n      await this.ioHelper.defaults.info('Applying filters to resource scan.');\n      for (const filter of filters) {\n        const filterList = parseFilters(filter);\n        resourceScanInputs = {\n          ResourceScanId: scanId,\n          ResourceIdentifier: filterList[FilterType.RESOURCE_IDENTIFIER],\n          ResourceTypePrefix: filterList[FilterType.RESOURCE_TYPE_PREFIX],\n          TagKey: filterList[FilterType.TAG_KEY],\n          TagValue: filterList[FilterType.TAG_VALUE],\n        };\n        const resources = await this.cfn.listResourceScanResources(resourceScanInputs);\n        resourceList = resourceList.concat(resources.Resources ?? []);\n        let nextToken = resources.NextToken;\n\n        // cycle through the pages adding all resources to the list until we run out of pages\n        while (nextToken) {\n          resourceScanInputs.NextToken = nextToken;\n          const nextResources = await this.cfn.listResourceScanResources(resourceScanInputs);\n          nextToken = nextResources.NextToken;\n          resourceList = resourceList!.concat(nextResources.Resources ?? []);\n        }\n      }\n    } else {\n      await this.ioHelper.defaults.info('No filters provided. Retrieving all resources from scan.');\n      resourceScanInputs = {\n        ResourceScanId: scanId,\n      };\n      const resources = await this.cfn.listResourceScanResources(resourceScanInputs);\n      resourceList = resourceList!.concat(resources.Resources ?? []);\n      let nextToken = resources.NextToken;\n\n      // cycle through the pages adding all resources to the list until we run out of pages\n      while (nextToken) {\n        resourceScanInputs.NextToken = nextToken;\n        const nextResources = await this.cfn.listResourceScanResources(resourceScanInputs);\n        nextToken = nextResources.NextToken;\n        resourceList = resourceList!.concat(nextResources.Resources ?? []);\n      }\n    }\n    if (resourceList.length === 0) {\n      throw new ToolkitError(`No resources found with filters ${filters.join(' ')}. Please try again with different filters.`);\n    }\n    resourceList = deduplicateResources(resourceList);\n\n    return process.env.MIGRATE_INTEG_TEST\n      ? resourceIdentifiers(resourceList)\n      : resourceIdentifiers(excludeManaged(resourceList));\n  }\n\n  /**\n   * Retrieves information about a resource scan.\n   *\n   * @param scanId - scan id for the to list resources for\n   * @returns information about the scan\n   */\n  async describeResourceScan(scanId: string): Promise<DescribeResourceScanCommandOutput> {\n    return this.cfn.describeResourceScan({\n      ResourceScanId: scanId,\n    });\n  }\n\n  /**\n   * Describes the current status of the template being generated.\n   *\n   * @param templateId - A string representing the template id\n   * @returns DescribeGeneratedTemplateOutput an object containing the template status and results\n   */\n  async describeGeneratedTemplate(templateId: string): Promise<DescribeGeneratedTemplateCommandOutput> {\n    const generatedTemplate = await this.cfn.describeGeneratedTemplate({\n      GeneratedTemplateName: templateId,\n    });\n\n    if (generatedTemplate.Status == ScanStatus.FAILED) {\n      throw new ToolkitError(generatedTemplate.StatusReason!);\n    }\n\n    return generatedTemplate;\n  }\n\n  /**\n   * Retrieves a completed generated cloudformation template from the template generator.\n   *\n   * @param templateId - A string representing the template id\n   * @param cloudFormation - The CloudFormation sdk client to use\n   * @returns DescribeGeneratedTemplateOutput an object containing the template status and body\n   */\n  async getGeneratedTemplate(templateId: string): Promise<GetGeneratedTemplateCommandOutput> {\n    return this.cfn.getGeneratedTemplate({\n      GeneratedTemplateName: templateId,\n    });\n  }\n\n  /**\n   * Kicks off a template generation for a set of resources.\n   *\n   * @param stackName - The name of the stack\n   * @param resources - A list of resources to generate the template from\n   * @returns CreateGeneratedTemplateOutput an object containing the template arn to query on later\n   */\n  async createGeneratedTemplate(stackName: string, resources: ResourceDefinition[]) {\n    const createTemplateOutput = await this.cfn.createGeneratedTemplate({\n      Resources: resources,\n      GeneratedTemplateName: stackName,\n    });\n\n    if (createTemplateOutput.GeneratedTemplateId === undefined) {\n      throw new ToolkitError('CreateGeneratedTemplate failed to return an Arn.');\n    }\n    return createTemplateOutput;\n  }\n\n  /**\n   * Deletes a generated template from the template generator.\n   *\n   * @param templateArn - The arn of the template to delete\n   * @returns A promise that resolves when the template has been deleted\n   */\n  async deleteGeneratedTemplate(templateArn: string): Promise<void> {\n    await this.cfn.deleteGeneratedTemplate({\n      GeneratedTemplateName: templateArn,\n    });\n  }\n}\n\n/**\n * The possible ways to choose a scan to generate a CDK application from\n */\nexport enum FromScan {\n  /**\n   * Initiate a new resource scan to build the CDK application from.\n   */\n  NEW,\n\n  /**\n   * Use the last successful scan to build the CDK application from. Will fail if no scan is found.\n   */\n  MOST_RECENT,\n\n  /**\n   * Starts a scan if none exists, otherwise uses the most recent successful scan to build the CDK application from.\n   */\n  DEFAULT,\n}\n\n/**\n * Interface for the options object passed to the generateTemplate function\n *\n * @param stackName - The name of the stack\n * @param filters - A list of filters to apply to the scan\n * @param fromScan - An enum value specifying whether a new scan should be started or the most recent successful scan should be used\n * @param sdkProvider - The sdk provider for making CloudFormation calls\n * @param environment - The account and region where the stack is deployed\n */\nexport interface GenerateTemplateOptions {\n  stackName: string;\n  filters?: string[];\n  fromScan?: FromScan;\n  sdkProvider: SdkProvider;\n  environment: Environment;\n  ioHelper: IoHelper;\n}\n\n/**\n * Interface for the output of the generateTemplate function\n *\n * @param migrateJson - The generated Migrate.json file\n * @param resources - The generated template\n */\nexport interface GenerateTemplateOutput {\n  migrateJson: MigrateJsonFormat;\n  resources?: ResourceDetail[];\n  templateId?: string;\n}\n\n/**\n * Interface defining the format of the generated Migrate.json file\n *\n * @param TemplateBody - The generated template\n * @param Source - The source of the template\n * @param Resources - A list of resources that were used to generate the template\n */\nexport interface MigrateJsonFormat {\n  templateBody: string;\n  source: string;\n  resources?: GeneratedResourceImportIdentifier[];\n}\n\n/**\n * Interface representing the format of a resource identifier required for resource import\n *\n * @param ResourceType - The type of resource\n * @param LogicalResourceId - The logical id of the resource\n * @param ResourceIdentifier - The resource identifier of the resource\n */\nexport interface GeneratedResourceImportIdentifier {\n  // cdk deploy expects the migrate.json resource identifiers to be PascalCase, not camelCase.\n  ResourceType: string;\n  LogicalResourceId: string;\n  ResourceIdentifier: ResourceIdentifierSummary;\n}\n"]}
@@ -106,4 +106,4 @@ class CloudAssembly extends cloud_assembly_1.BaseStackAssembly {
106
106
  }
107
107
  }
108
108
  exports.CloudAssembly = CloudAssembly;
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-assembly.js","sourceRoot":"","sources":["cloud-assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import type * as cxapi from '@aws-cdk/cx-api';\nimport { ToolkitError } from '@aws-cdk/toolkit-lib';\nimport { minimatch } from 'minimatch';\nimport * as semver from 'semver';\nimport { BaseStackAssembly, StackCollection } from '../api/cloud-assembly';\nimport { flatten } from '../util';\n\nexport enum DefaultSelection {\n  /**\n   * Returns an empty selection in case there are no selectors.\n   */\n  None = 'none',\n\n  /**\n   * If the app includes a single stack, returns it. Otherwise throws an exception.\n   * This behavior is used by \"deploy\".\n   */\n  OnlySingle = 'single',\n\n  /**\n   * Returns all stacks in the main (top level) assembly only.\n   */\n  MainAssembly = 'main',\n\n  /**\n   * If no selectors are provided, returns all stacks in the app,\n   * including stacks inside nested assemblies.\n   */\n  AllStacks = 'all',\n}\n\nexport interface SelectStacksOptions {\n  /**\n   * Extend the selection to upstread/downstream stacks\n   * @default ExtendedStackSelection.None only select the specified stacks.\n   */\n  extend?: ExtendedStackSelection;\n\n  /**\n   * The behavior if no selectors are provided.\n   */\n  defaultBehavior: DefaultSelection;\n\n  /**\n   * Whether to deploy if the app contains no stacks.\n   *\n   * @default false\n   */\n  ignoreNoStacks?: boolean;\n}\n\n/**\n * When selecting stacks, what other stacks to include because of dependencies\n */\nexport enum ExtendedStackSelection {\n  /**\n   * Don't select any extra stacks\n   */\n  None,\n\n  /**\n   * Include stacks that this stack depends on\n   */\n  Upstream,\n\n  /**\n   * Include stacks that depend on this stack\n   */\n  Downstream,\n}\n\n/**\n * A specification of which stacks should be selected\n */\nexport interface StackSelector {\n  /**\n   * Whether all stacks at the top level assembly should\n   * be selected and nothing else\n   */\n  allTopLevel?: boolean;\n\n  /**\n   * A list of patterns to match the stack hierarchical ids\n   */\n  patterns: string[];\n}\n\n/**\n * A single Cloud Assembly and the operations we do on it to deploy the artifacts inside\n */\nexport class CloudAssembly extends BaseStackAssembly {\n  public async selectStacks(selector: StackSelector, options: SelectStacksOptions): Promise<StackCollection> {\n    const asm = this.assembly;\n    const topLevelStacks = asm.stacks;\n    const stacks = semver.major(asm.version) < 10 ? asm.stacks : asm.stacksRecursively;\n    const allTopLevel = selector.allTopLevel ?? false;\n    const patterns = CloudAssembly.sanitizePatterns(selector.patterns);\n\n    if (stacks.length === 0) {\n      if (options.ignoreNoStacks) {\n        return new StackCollection(this, []);\n      }\n      throw new ToolkitError('This app contains no stacks');\n    }\n\n    if (allTopLevel) {\n      return this.selectTopLevelStacks(stacks, topLevelStacks, options.extend);\n    } else if (patterns.length > 0) {\n      return this.selectMatchingStacks(stacks, patterns, options.extend);\n    } else {\n      return this.selectDefaultStacks(stacks, topLevelStacks, options.defaultBehavior);\n    }\n  }\n\n  private async selectTopLevelStacks(\n    stacks: cxapi.CloudFormationStackArtifact[],\n    topLevelStacks: cxapi.CloudFormationStackArtifact[],\n    extend: ExtendedStackSelection = ExtendedStackSelection.None,\n  ): Promise<StackCollection> {\n    if (topLevelStacks.length > 0) {\n      return this.extendStacks(topLevelStacks, stacks, extend);\n    } else {\n      throw new ToolkitError('No stack found in the main cloud assembly. Use \"list\" to print manifest');\n    }\n  }\n\n  protected async selectMatchingStacks(\n    stacks: cxapi.CloudFormationStackArtifact[],\n    patterns: string[],\n    extend: ExtendedStackSelection = ExtendedStackSelection.None,\n  ): Promise<StackCollection> {\n    const matchingPattern = (pattern: string) => (stack: cxapi.CloudFormationStackArtifact) => minimatch(stack.hierarchicalId, pattern);\n    const matchedStacks = flatten(patterns.map(pattern => stacks.filter(matchingPattern(pattern))));\n\n    return this.extendStacks(matchedStacks, stacks, extend);\n  }\n\n  private selectDefaultStacks(\n    stacks: cxapi.CloudFormationStackArtifact[],\n    topLevelStacks: cxapi.CloudFormationStackArtifact[],\n    defaultSelection: DefaultSelection,\n  ) {\n    switch (defaultSelection) {\n      case DefaultSelection.MainAssembly:\n        return new StackCollection(this, topLevelStacks);\n      case DefaultSelection.AllStacks:\n        return new StackCollection(this, stacks);\n      case DefaultSelection.None:\n        return new StackCollection(this, []);\n      case DefaultSelection.OnlySingle:\n        if (topLevelStacks.length === 1) {\n          return new StackCollection(this, topLevelStacks);\n        } else {\n          throw new ToolkitError('Since this app includes more than a single stack, specify which stacks to use (wildcards are supported) or specify `--all`\\n' +\n          `Stacks: ${stacks.map(x => x.hierarchicalId).join(' · ')}`);\n        }\n      default:\n        throw new ToolkitError(`invalid default behavior: ${defaultSelection}`);\n    }\n  }\n}\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloud-assembly.js","sourceRoot":"","sources":["cloud-assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import type * as cxapi from '@aws-cdk/cx-api';\nimport { ToolkitError } from '@aws-cdk/toolkit-lib';\nimport { minimatch } from 'minimatch';\nimport * as semver from 'semver';\nimport { BaseStackAssembly, StackCollection } from '../api/cloud-assembly';\nimport { flatten } from '../util';\n\nexport enum DefaultSelection {\n  /**\n   * Returns an empty selection in case there are no selectors.\n   */\n  None = 'none',\n\n  /**\n   * If the app includes a single stack, returns it. Otherwise throws an exception.\n   * This behavior is used by \"deploy\".\n   */\n  OnlySingle = 'single',\n\n  /**\n   * Returns all stacks in the main (top level) assembly only.\n   */\n  MainAssembly = 'main',\n\n  /**\n   * If no selectors are provided, returns all stacks in the app,\n   * including stacks inside nested assemblies.\n   */\n  AllStacks = 'all',\n}\n\nexport interface SelectStacksOptions {\n  /**\n   * Extend the selection to upstread/downstream stacks\n   * @default ExtendedStackSelection.None only select the specified stacks.\n   */\n  extend?: ExtendedStackSelection;\n\n  /**\n   * The behavior if no selectors are provided.\n   */\n  defaultBehavior: DefaultSelection;\n\n  /**\n   * Whether to deploy if the app contains no stacks.\n   *\n   * @default false\n   */\n  ignoreNoStacks?: boolean;\n}\n\n/**\n * When selecting stacks, what other stacks to include because of dependencies\n */\nexport enum ExtendedStackSelection {\n  /**\n   * Don't select any extra stacks\n   */\n  None,\n\n  /**\n   * Include stacks that this stack depends on\n   */\n  Upstream,\n\n  /**\n   * Include stacks that depend on this stack\n   */\n  Downstream,\n}\n\n/**\n * A specification of which stacks should be selected\n */\nexport interface StackSelector {\n  /**\n   * Whether all stacks at the top level assembly should\n   * be selected and nothing else\n   */\n  allTopLevel?: boolean;\n\n  /**\n   * A list of patterns to match the stack hierarchical ids\n   */\n  patterns: string[];\n}\n\n/**\n * A single Cloud Assembly and the operations we do on it to deploy the artifacts inside\n */\nexport class CloudAssembly extends BaseStackAssembly {\n  public async selectStacks(selector: StackSelector, options: SelectStacksOptions): Promise<StackCollection> {\n    const asm = this.assembly;\n    const topLevelStacks = asm.stacks;\n    const stacks = semver.major(asm.version) < 10 ? asm.stacks : asm.stacksRecursively;\n    const allTopLevel = selector.allTopLevel ?? false;\n    const patterns = CloudAssembly.sanitizePatterns(selector.patterns);\n\n    if (stacks.length === 0) {\n      if (options.ignoreNoStacks) {\n        return new StackCollection(this, []);\n      }\n      throw new ToolkitError('This app contains no stacks');\n    }\n\n    if (allTopLevel) {\n      return this.selectTopLevelStacks(stacks, topLevelStacks, options.extend);\n    } else if (patterns.length > 0) {\n      return this.selectMatchingStacks(stacks, patterns, options.extend);\n    } else {\n      return this.selectDefaultStacks(stacks, topLevelStacks, options.defaultBehavior);\n    }\n  }\n\n  private async selectTopLevelStacks(\n    stacks: cxapi.CloudFormationStackArtifact[],\n    topLevelStacks: cxapi.CloudFormationStackArtifact[],\n    extend: ExtendedStackSelection = ExtendedStackSelection.None,\n  ): Promise<StackCollection> {\n    if (topLevelStacks.length > 0) {\n      return this.extendStacks(topLevelStacks, stacks, extend);\n    } else {\n      throw new ToolkitError('No stack found in the main cloud assembly. Use \"list\" to print manifest');\n    }\n  }\n\n  protected async selectMatchingStacks(\n    stacks: cxapi.CloudFormationStackArtifact[],\n    patterns: string[],\n    extend: ExtendedStackSelection = ExtendedStackSelection.None,\n  ): Promise<StackCollection> {\n    const matchingPattern = (pattern: string) => (stack: cxapi.CloudFormationStackArtifact) => minimatch(stack.hierarchicalId, pattern);\n    const matchedStacks = flatten(patterns.map(pattern => stacks.filter(matchingPattern(pattern))));\n    return this.extendStacks(matchedStacks, stacks, extend);\n  }\n\n  private selectDefaultStacks(\n    stacks: cxapi.CloudFormationStackArtifact[],\n    topLevelStacks: cxapi.CloudFormationStackArtifact[],\n    defaultSelection: DefaultSelection,\n  ) {\n    switch (defaultSelection) {\n      case DefaultSelection.MainAssembly:\n        return new StackCollection(this, topLevelStacks);\n      case DefaultSelection.AllStacks:\n        return new StackCollection(this, stacks);\n      case DefaultSelection.None:\n        return new StackCollection(this, []);\n      case DefaultSelection.OnlySingle:\n        if (topLevelStacks.length === 1) {\n          return new StackCollection(this, topLevelStacks);\n        } else {\n          throw new ToolkitError('Since this app includes more than a single stack, specify which stacks to use (wildcards are supported) or specify `--all`\\n' +\n          `Stacks: ${stacks.map(x => x.hierarchicalId).join(' · ')}`);\n        }\n      default:\n        throw new ToolkitError(`invalid default behavior: ${defaultSelection}`);\n    }\n  }\n}\n"]}
package/lib/index.d.ts CHANGED
@@ -1,3 +1,3 @@
1
1
  export * from './api';
2
2
  export { cli, exec } from './cli/cli';
3
- export * as legacy from './legacy-exports-source';
3
+ export * as legacy from './legacy';