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
@@ -15,7 +15,6 @@ const fs = require("fs-extra");
15
15
  const init_hooks_1 = require("./init-hooks");
16
16
  const root_dir_1 = require("../../cli/root-dir");
17
17
  const version_1 = require("../../cli/version");
18
- const logging_1 = require("../../logging");
19
18
  const util_1 = require("../../util");
20
19
  /* eslint-disable @typescript-eslint/no-var-requires */ // Packages don't have @types module
21
20
  // eslint-disable-next-line @typescript-eslint/no-require-imports
@@ -26,28 +25,29 @@ const decamelize = require('decamelize');
26
25
  * Initialize a CDK package in the current directory
27
26
  */
28
27
  async function cliInit(options) {
28
+ const ioHelper = options.ioHelper;
29
29
  const canUseNetwork = options.canUseNetwork ?? true;
30
30
  const generateOnly = options.generateOnly ?? false;
31
31
  const workDir = options.workDir ?? process.cwd();
32
32
  if (!options.type && !options.language) {
33
- await printAvailableTemplates();
33
+ await printAvailableTemplates(ioHelper);
34
34
  return;
35
35
  }
36
36
  const type = options.type || 'default'; // "default" is the default type (and maps to "app")
37
37
  const template = (await availableInitTemplates()).find((t) => t.hasName(type));
38
38
  if (!template) {
39
- await printAvailableTemplates(options.language);
39
+ await printAvailableTemplates(ioHelper, options.language);
40
40
  throw new toolkit_lib_1.ToolkitError(`Unknown init template: ${type}`);
41
41
  }
42
42
  if (!options.language && template.languages.length === 1) {
43
43
  const language = template.languages[0];
44
- (0, logging_1.warning)(`No --language was provided, but '${type}' supports only '${language}', so defaulting to --language=${language}`);
44
+ await ioHelper.defaults.warn(`No --language was provided, but '${type}' supports only '${language}', so defaulting to --language=${language}`);
45
45
  }
46
46
  if (!options.language) {
47
- (0, logging_1.info)(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);
47
+ await ioHelper.defaults.info(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);
48
48
  throw new toolkit_lib_1.ToolkitError('No language was selected');
49
49
  }
50
- await initializeProject(template, options.language, canUseNetwork, generateOnly, workDir, options.stackName, options.migrate, options.libVersion);
50
+ await initializeProject(ioHelper, template, options.language, canUseNetwork, generateOnly, workDir, options.stackName, options.migrate, options.libVersion);
51
51
  }
52
52
  /**
53
53
  * Returns the name of the Python executable for this OS
@@ -90,9 +90,9 @@ class InitTemplate {
90
90
  * @param language - the language to instantiate this template with
91
91
  * @param targetDirectory - the directory where the template is to be instantiated into
92
92
  */
93
- async install(language, targetDirectory, stackName, libVersion) {
93
+ async install(ioHelper, language, targetDirectory, stackName, libVersion) {
94
94
  if (this.languages.indexOf(language) === -1) {
95
- (0, logging_1.error)(`The ${chalk.blue(language)} language is not supported for ${chalk.green(this.name)} ` +
95
+ await ioHelper.defaults.error(`The ${chalk.blue(language)} language is not supported for ${chalk.green(this.name)} ` +
96
96
  `(it supports: ${this.languages.map((l) => chalk.blue(l)).join(', ')})`);
97
97
  throw new toolkit_lib_1.ToolkitError(`Unsupported language: ${language}`);
98
98
  }
@@ -107,7 +107,7 @@ class InitTemplate {
107
107
  const sourceDirectory = path.join(this.basePath, language);
108
108
  await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo);
109
109
  await this.applyFutureFlags(targetDirectory);
110
- await (0, init_hooks_1.invokeBuiltinHooks)({ targetDirectory, language, templateName: this.name }, {
110
+ await (0, init_hooks_1.invokeBuiltinHooks)(ioHelper, { targetDirectory, language, templateName: this.name }, {
111
111
  substitutePlaceholdersIn: async (...fileNames) => {
112
112
  for (const fileName of fileNames) {
113
113
  const fullPath = path.join(targetDirectory, fileName);
@@ -243,37 +243,37 @@ async function listDirectory(dirPath) {
243
243
  .filter((p) => !(p === INFO_DOT_JSON))
244
244
  .sort());
245
245
  }
246
- async function printAvailableTemplates(language) {
247
- (0, logging_1.info)('Available templates:');
246
+ async function printAvailableTemplates(ioHelper, language) {
247
+ await ioHelper.defaults.info('Available templates:');
248
248
  for (const template of await availableInitTemplates()) {
249
249
  if (language && template.languages.indexOf(language) === -1) {
250
250
  continue;
251
251
  }
252
- (0, logging_1.info)(`* ${chalk.green(template.name)}: ${template.description}`);
252
+ await ioHelper.defaults.info(`* ${chalk.green(template.name)}: ${template.description}`);
253
253
  const languageArg = language
254
254
  ? chalk.bold(language)
255
255
  : template.languages.length > 1
256
256
  ? `[${template.languages.map((t) => chalk.bold(t)).join('|')}]`
257
257
  : chalk.bold(template.languages[0]);
258
- (0, logging_1.info)(` └─ ${chalk.blue(`cdk init ${chalk.bold(template.name)} --language=${languageArg}`)}`);
258
+ await ioHelper.defaults.info(` └─ ${chalk.blue(`cdk init ${chalk.bold(template.name)} --language=${languageArg}`)}`);
259
259
  }
260
260
  }
261
- async function initializeProject(template, language, canUseNetwork, generateOnly, workDir, stackName, migrate, cdkVersion) {
261
+ async function initializeProject(ioHelper, template, language, canUseNetwork, generateOnly, workDir, stackName, migrate, cdkVersion) {
262
262
  await assertIsEmptyDirectory(workDir);
263
- (0, logging_1.info)(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`);
264
- await template.install(language, workDir, stackName, cdkVersion);
263
+ await ioHelper.defaults.info(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`);
264
+ await template.install(ioHelper, language, workDir, stackName, cdkVersion);
265
265
  if (migrate) {
266
266
  await template.addMigrateContext(workDir);
267
267
  }
268
268
  if (await fs.pathExists(`${workDir}/README.md`)) {
269
269
  const readme = await fs.readFile(`${workDir}/README.md`, { encoding: 'utf-8' });
270
- (0, logging_1.info)(chalk.green(readme));
270
+ await ioHelper.defaults.info(chalk.green(readme));
271
271
  }
272
272
  if (!generateOnly) {
273
- await initializeGitRepository(workDir);
274
- await postInstall(language, canUseNetwork, workDir);
273
+ await initializeGitRepository(ioHelper, workDir);
274
+ await postInstall(ioHelper, language, canUseNetwork, workDir);
275
275
  }
276
- (0, logging_1.info)('✅ All done!');
276
+ await ioHelper.defaults.info('✅ All done!');
277
277
  }
278
278
  async function assertIsEmptyDirectory(workDir) {
279
279
  const files = await fs.readdir(workDir);
@@ -281,74 +281,74 @@ async function assertIsEmptyDirectory(workDir) {
281
281
  throw new toolkit_lib_1.ToolkitError('`cdk init` cannot be run in a non-empty directory!');
282
282
  }
283
283
  }
284
- async function initializeGitRepository(workDir) {
284
+ async function initializeGitRepository(ioHelper, workDir) {
285
285
  if (await isInGitRepository(workDir)) {
286
286
  return;
287
287
  }
288
- (0, logging_1.info)('Initializing a new git repository...');
288
+ await ioHelper.defaults.info('Initializing a new git repository...');
289
289
  try {
290
- await execute('git', ['init'], { cwd: workDir });
291
- await execute('git', ['add', '.'], { cwd: workDir });
292
- await execute('git', ['commit', '--message="Initial commit"', '--no-gpg-sign'], { cwd: workDir });
290
+ await execute(ioHelper, 'git', ['init'], { cwd: workDir });
291
+ await execute(ioHelper, 'git', ['add', '.'], { cwd: workDir });
292
+ await execute(ioHelper, 'git', ['commit', '--message="Initial commit"', '--no-gpg-sign'], { cwd: workDir });
293
293
  }
294
294
  catch {
295
- (0, logging_1.warning)('Unable to initialize git repository for your project.');
295
+ await ioHelper.defaults.warn('Unable to initialize git repository for your project.');
296
296
  }
297
297
  }
298
- async function postInstall(language, canUseNetwork, workDir) {
298
+ async function postInstall(ioHelper, language, canUseNetwork, workDir) {
299
299
  switch (language) {
300
300
  case 'javascript':
301
- return postInstallJavascript(canUseNetwork, workDir);
301
+ return postInstallJavascript(ioHelper, canUseNetwork, workDir);
302
302
  case 'typescript':
303
- return postInstallTypescript(canUseNetwork, workDir);
303
+ return postInstallTypescript(ioHelper, canUseNetwork, workDir);
304
304
  case 'java':
305
- return postInstallJava(canUseNetwork, workDir);
305
+ return postInstallJava(ioHelper, canUseNetwork, workDir);
306
306
  case 'python':
307
- return postInstallPython(workDir);
307
+ return postInstallPython(ioHelper, workDir);
308
308
  }
309
309
  }
310
- async function postInstallJavascript(canUseNetwork, cwd) {
311
- return postInstallTypescript(canUseNetwork, cwd);
310
+ async function postInstallJavascript(ioHelper, canUseNetwork, cwd) {
311
+ return postInstallTypescript(ioHelper, canUseNetwork, cwd);
312
312
  }
313
- async function postInstallTypescript(canUseNetwork, cwd) {
313
+ async function postInstallTypescript(ioHelper, canUseNetwork, cwd) {
314
314
  const command = 'npm';
315
315
  if (!canUseNetwork) {
316
- (0, logging_1.warning)(`Please run '${command} install'!`);
316
+ await ioHelper.defaults.warn(`Please run '${command} install'!`);
317
317
  return;
318
318
  }
319
- (0, logging_1.info)(`Executing ${chalk.green(`${command} install`)}...`);
319
+ await ioHelper.defaults.info(`Executing ${chalk.green(`${command} install`)}...`);
320
320
  try {
321
- await execute(command, ['install'], { cwd });
321
+ await execute(ioHelper, command, ['install'], { cwd });
322
322
  }
323
323
  catch (e) {
324
- (0, logging_1.warning)(`${command} install failed: ` + (0, util_1.formatErrorMessage)(e));
324
+ await ioHelper.defaults.warn(`${command} install failed: ` + (0, util_1.formatErrorMessage)(e));
325
325
  }
326
326
  }
327
- async function postInstallJava(canUseNetwork, cwd) {
327
+ async function postInstallJava(ioHelper, canUseNetwork, cwd) {
328
328
  const mvnPackageWarning = "Please run 'mvn package'!";
329
329
  if (!canUseNetwork) {
330
- (0, logging_1.warning)(mvnPackageWarning);
330
+ await ioHelper.defaults.warn(mvnPackageWarning);
331
331
  return;
332
332
  }
333
- (0, logging_1.info)("Executing 'mvn package'");
333
+ await ioHelper.defaults.info("Executing 'mvn package'");
334
334
  try {
335
- await execute('mvn', ['package'], { cwd });
335
+ await execute(ioHelper, 'mvn', ['package'], { cwd });
336
336
  }
337
337
  catch {
338
- (0, logging_1.warning)('Unable to package compiled code as JAR');
339
- (0, logging_1.warning)(mvnPackageWarning);
338
+ await ioHelper.defaults.warn('Unable to package compiled code as JAR');
339
+ await ioHelper.defaults.warn(mvnPackageWarning);
340
340
  }
341
341
  }
342
- async function postInstallPython(cwd) {
342
+ async function postInstallPython(ioHelper, cwd) {
343
343
  const python = pythonExecutable();
344
- (0, logging_1.warning)(`Please run '${python} -m venv .venv'!`);
345
- (0, logging_1.info)(`Executing ${chalk.green('Creating virtualenv...')}`);
344
+ await ioHelper.defaults.warn(`Please run '${python} -m venv .venv'!`);
345
+ await ioHelper.defaults.info(`Executing ${chalk.green('Creating virtualenv...')}`);
346
346
  try {
347
- await execute(python, ['-m venv', '.venv'], { cwd });
347
+ await execute(ioHelper, python, ['-m venv', '.venv'], { cwd });
348
348
  }
349
349
  catch {
350
- (0, logging_1.warning)('Unable to create virtualenv automatically');
351
- (0, logging_1.warning)(`Please run '${python} -m venv .venv'!`);
350
+ await ioHelper.defaults.warn('Unable to create virtualenv automatically');
351
+ await ioHelper.defaults.warn(`Please run '${python} -m venv .venv'!`);
352
352
  }
353
353
  }
354
354
  /**
@@ -376,12 +376,12 @@ function isRoot(dir) {
376
376
  /**
377
377
  * Executes `command`. STDERR is emitted in real-time.
378
378
  *
379
- * If command exits with non-zero exit code, an exceprion is thrown and includes
379
+ * If command exits with non-zero exit code, an exception is thrown and includes
380
380
  * the contents of STDOUT.
381
381
  *
382
382
  * @returns STDOUT (if successful).
383
383
  */
384
- async function execute(cmd, args, { cwd }) {
384
+ async function execute(ioHelper, cmd, args, { cwd }) {
385
385
  const child = childProcess.spawn(cmd, args, {
386
386
  cwd,
387
387
  shell: true,
@@ -396,10 +396,12 @@ async function execute(cmd, args, { cwd }) {
396
396
  return ok(stdout);
397
397
  }
398
398
  else {
399
- (0, logging_1.error)(stdout);
400
399
  return fail(new toolkit_lib_1.ToolkitError(`${cmd} exited with status ${status}`));
401
400
  }
402
401
  });
402
+ }).catch(async (err) => {
403
+ await ioHelper.defaults.error(stdout);
404
+ throw err;
403
405
  });
404
406
  }
405
407
  /**
@@ -433,4 +435,4 @@ async function currentlyRecommendedAwsCdkLibFlags() {
433
435
  const recommendedFlagsFile = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates', '.recommended-feature-flags.json');
434
436
  return JSON.parse(await fs.readFile(recommendedFlagsFile, { encoding: 'utf-8' }));
435
437
  }
436
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"init.js","sourceRoot":"","sources":["init.ts"],"names":[],"mappings":"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","sourcesContent":["import * as childProcess from 'child_process';\nimport * as path from 'path';\nimport { ToolkitError } from '@aws-cdk/toolkit-lib';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport { invokeBuiltinHooks } from './init-hooks';\nimport { cliRootDir } from '../../cli/root-dir';\nimport { versionNumber } from '../../cli/version';\nimport { error, info, warning } from '../../logging';\nimport { cdkHomeDir, formatErrorMessage, rangeFromSemver } from '../../util';\n\n/* eslint-disable @typescript-eslint/no-var-requires */ // Packages don't have @types module\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst camelCase = require('camelcase');\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst decamelize = require('decamelize');\n\nexport interface CliInitOptions {\n  readonly type?: string;\n  readonly language?: string;\n  readonly canUseNetwork?: boolean;\n  readonly generateOnly?: boolean;\n  readonly workDir?: string;\n  readonly stackName?: string;\n  readonly migrate?: boolean;\n\n  /**\n   * Override the built-in CDK version\n   */\n  readonly libVersion?: string;\n}\n\n/**\n * Initialize a CDK package in the current directory\n */\nexport async function cliInit(options: CliInitOptions) {\n  const canUseNetwork = options.canUseNetwork ?? true;\n  const generateOnly = options.generateOnly ?? false;\n  const workDir = options.workDir ?? process.cwd();\n  if (!options.type && !options.language) {\n    await printAvailableTemplates();\n    return;\n  }\n\n  const type = options.type || 'default'; // \"default\" is the default type (and maps to \"app\")\n\n  const template = (await availableInitTemplates()).find((t) => t.hasName(type!));\n  if (!template) {\n    await printAvailableTemplates(options.language);\n    throw new ToolkitError(`Unknown init template: ${type}`);\n  }\n  if (!options.language && template.languages.length === 1) {\n    const language = template.languages[0];\n    warning(\n      `No --language was provided, but '${type}' supports only '${language}', so defaulting to --language=${language}`,\n    );\n  }\n  if (!options.language) {\n    info(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);\n    throw new ToolkitError('No language was selected');\n  }\n\n  await initializeProject(\n    template,\n    options.language,\n    canUseNetwork,\n    generateOnly,\n    workDir,\n    options.stackName,\n    options.migrate,\n    options.libVersion,\n  );\n}\n\n/**\n * Returns the name of the Python executable for this OS\n */\nfunction pythonExecutable() {\n  let python = 'python3';\n  if (process.platform === 'win32') {\n    python = 'python';\n  }\n  return python;\n}\nconst INFO_DOT_JSON = 'info.json';\n\nexport class InitTemplate {\n  public static async fromName(templatesDir: string, name: string) {\n    const basePath = path.join(templatesDir, name);\n    const languages = await listDirectory(basePath);\n    const initInfo = await fs.readJson(path.join(basePath, INFO_DOT_JSON));\n    return new InitTemplate(basePath, name, languages, initInfo);\n  }\n\n  public readonly description: string;\n  public readonly aliases = new Set<string>();\n\n  constructor(\n    private readonly basePath: string,\n    public readonly name: string,\n    public readonly languages: string[],\n    initInfo: any,\n  ) {\n    this.description = initInfo.description;\n    for (const alias of initInfo.aliases || []) {\n      this.aliases.add(alias);\n    }\n  }\n\n  /**\n   * @param name - the name that is being checked\n   * @returns ``true`` if ``name`` is the name of this template or an alias of it.\n   */\n  public hasName(name: string): boolean {\n    return name === this.name || this.aliases.has(name);\n  }\n\n  /**\n   * Creates a new instance of this ``InitTemplate`` for a given language to a specified folder.\n   *\n   * @param language    - the language to instantiate this template with\n   * @param targetDirectory - the directory where the template is to be instantiated into\n   */\n  public async install(language: string, targetDirectory: string, stackName?: string, libVersion?: string) {\n    if (this.languages.indexOf(language) === -1) {\n      error(\n        `The ${chalk.blue(language)} language is not supported for ${chalk.green(this.name)} ` +\n          `(it supports: ${this.languages.map((l) => chalk.blue(l)).join(', ')})`,\n      );\n      throw new ToolkitError(`Unsupported language: ${language}`);\n    }\n\n    const projectInfo: ProjectInfo = {\n      name: decamelize(path.basename(path.resolve(targetDirectory))),\n      stackName,\n      versions: await loadInitVersions(),\n    };\n\n    if (libVersion) {\n      projectInfo.versions['aws-cdk-lib'] = libVersion;\n    }\n\n    const sourceDirectory = path.join(this.basePath, language);\n\n    await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo);\n    await this.applyFutureFlags(targetDirectory);\n    await invokeBuiltinHooks(\n      { targetDirectory, language, templateName: this.name },\n      {\n        substitutePlaceholdersIn: async (...fileNames: string[]) => {\n          for (const fileName of fileNames) {\n            const fullPath = path.join(targetDirectory, fileName);\n            const template = await fs.readFile(fullPath, { encoding: 'utf-8' });\n            await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo));\n          }\n        },\n        placeholder: (ph: string) => expandPlaceholders(`%${ph}%`, language, projectInfo),\n      },\n    );\n  }\n\n  private async installFiles(sourceDirectory: string, targetDirectory: string, language: string, project: ProjectInfo) {\n    for (const file of await fs.readdir(sourceDirectory)) {\n      const fromFile = path.join(sourceDirectory, file);\n      const toFile = path.join(targetDirectory, expandPlaceholders(file, language, project));\n      if ((await fs.stat(fromFile)).isDirectory()) {\n        await fs.mkdir(toFile);\n        await this.installFiles(fromFile, toFile, language, project);\n        continue;\n      } else if (file.match(/^.*\\.template\\.[^.]+$/)) {\n        await this.installProcessed(fromFile, toFile.replace(/\\.template(\\.[^.]+)$/, '$1'), language, project);\n        continue;\n      } else if (file.match(/^.*\\.hook\\.(d.)?[^.]+$/)) {\n        // Ignore\n        continue;\n      } else {\n        await fs.copy(fromFile, toFile);\n      }\n    }\n  }\n\n  private async installProcessed(templatePath: string, toFile: string, language: string, project: ProjectInfo) {\n    const template = await fs.readFile(templatePath, { encoding: 'utf-8' });\n    await fs.writeFile(toFile, expandPlaceholders(template, language, project));\n  }\n\n  /**\n   * Adds context variables to `cdk.json` in the generated project directory to\n   * enable future behavior for new projects.\n   */\n  private async applyFutureFlags(projectDir: string) {\n    const cdkJson = path.join(projectDir, 'cdk.json');\n    if (!(await fs.pathExists(cdkJson))) {\n      return;\n    }\n\n    const config = await fs.readJson(cdkJson);\n    config.context = {\n      ...config.context,\n      ...await currentlyRecommendedAwsCdkLibFlags(),\n    };\n\n    await fs.writeJson(cdkJson, config, { spaces: 2 });\n  }\n\n  public async addMigrateContext(projectDir: string) {\n    const cdkJson = path.join(projectDir, 'cdk.json');\n    if (!(await fs.pathExists(cdkJson))) {\n      return;\n    }\n\n    const config = await fs.readJson(cdkJson);\n    config.context = {\n      ...config.context,\n      'cdk-migrate': true,\n    };\n\n    await fs.writeJson(cdkJson, config, { spaces: 2 });\n  }\n}\n\nexport function expandPlaceholders(template: string, language: string, project: ProjectInfo) {\n  const cdkVersion = project.versions['aws-cdk-lib'];\n  const cdkCliVersion = project.versions['aws-cdk'];\n  let constructsVersion = project.versions.constructs;\n\n  switch (language) {\n    case 'java':\n    case 'csharp':\n    case 'fsharp':\n      constructsVersion = rangeFromSemver(constructsVersion, 'bracket');\n      break;\n    case 'python':\n      constructsVersion = rangeFromSemver(constructsVersion, 'pep');\n      break;\n  }\n  return template\n    .replace(/%name%/g, project.name)\n    .replace(/%stackname%/, project.stackName ?? '%name.PascalCased%Stack')\n    .replace(\n      /%PascalNameSpace%/,\n      project.stackName ? camelCase(project.stackName + 'Stack', { pascalCase: true }) : '%name.PascalCased%',\n    )\n    .replace(\n      /%PascalStackProps%/,\n      project.stackName ? camelCase(project.stackName, { pascalCase: true }) + 'StackProps' : 'StackProps',\n    )\n    .replace(/%name\\.camelCased%/g, camelCase(project.name))\n    .replace(/%name\\.PascalCased%/g, camelCase(project.name, { pascalCase: true }))\n    .replace(/%cdk-version%/g, cdkVersion)\n    .replace(/%cdk-cli-version%/g, cdkCliVersion)\n    .replace(/%constructs-version%/g, constructsVersion)\n    .replace(/%cdk-home%/g, cdkHomeDir())\n    .replace(/%name\\.PythonModule%/g, project.name.replace(/-/g, '_'))\n    .replace(/%python-executable%/g, pythonExecutable())\n    .replace(/%name\\.StackName%/g, project.name.replace(/[^A-Za-z0-9-]/g, '-'));\n}\n\ninterface ProjectInfo {\n  /** The value used for %name% */\n  readonly name: string;\n  readonly stackName?: string;\n\n  readonly versions: Versions;\n}\n\nexport async function availableInitTemplates(): Promise<InitTemplate[]> {\n  return new Promise(async (resolve) => {\n    try {\n      const templatesDir = path.join(cliRootDir(), 'lib', 'init-templates');\n      const templateNames = await listDirectory(templatesDir);\n      const templates = new Array<InitTemplate>();\n      for (const templateName of templateNames) {\n        templates.push(await InitTemplate.fromName(templatesDir, templateName));\n      }\n      resolve(templates);\n    } catch {\n      resolve([]);\n    }\n  });\n}\n\nexport async function availableInitLanguages(): Promise<string[]> {\n  return new Promise(async (resolve) => {\n    const templates = await availableInitTemplates();\n    const result = new Set<string>();\n    for (const template of templates) {\n      for (const language of template.languages) {\n        result.add(language);\n      }\n    }\n    resolve([...result]);\n  });\n}\n\n/**\n * @param dirPath - is the directory to be listed.\n * @returns the list of file or directory names contained in ``dirPath``, excluding any dot-file, and sorted.\n */\nasync function listDirectory(dirPath: string) {\n  return (\n    (await fs.readdir(dirPath))\n      .filter((p) => !p.startsWith('.'))\n      .filter((p) => !(p === 'LICENSE'))\n      // if, for some reason, the temp folder for the hook doesn't get deleted we don't want to display it in this list\n      .filter((p) => !(p === INFO_DOT_JSON))\n      .sort()\n  );\n}\n\nexport async function printAvailableTemplates(language?: string) {\n  info('Available templates:');\n  for (const template of await availableInitTemplates()) {\n    if (language && template.languages.indexOf(language) === -1) {\n      continue;\n    }\n    info(`* ${chalk.green(template.name)}: ${template.description}`);\n    const languageArg = language\n      ? chalk.bold(language)\n      : template.languages.length > 1\n        ? `[${template.languages.map((t) => chalk.bold(t)).join('|')}]`\n        : chalk.bold(template.languages[0]);\n    info(`   └─ ${chalk.blue(`cdk init ${chalk.bold(template.name)} --language=${languageArg}`)}`);\n  }\n}\n\nasync function initializeProject(\n  template: InitTemplate,\n  language: string,\n  canUseNetwork: boolean,\n  generateOnly: boolean,\n  workDir: string,\n  stackName?: string,\n  migrate?: boolean,\n  cdkVersion?: string,\n) {\n  await assertIsEmptyDirectory(workDir);\n  info(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`);\n  await template.install(language, workDir, stackName, cdkVersion);\n  if (migrate) {\n    await template.addMigrateContext(workDir);\n  }\n  if (await fs.pathExists(`${workDir}/README.md`)) {\n    const readme = await fs.readFile(`${workDir}/README.md`, { encoding: 'utf-8' });\n    info(chalk.green(readme));\n  }\n\n  if (!generateOnly) {\n    await initializeGitRepository(workDir);\n    await postInstall(language, canUseNetwork, workDir);\n  }\n\n  info('✅ All done!');\n}\n\nasync function assertIsEmptyDirectory(workDir: string) {\n  const files = await fs.readdir(workDir);\n  if (files.filter((f) => !f.startsWith('.')).length !== 0) {\n    throw new ToolkitError('`cdk init` cannot be run in a non-empty directory!');\n  }\n}\n\nasync function initializeGitRepository(workDir: string) {\n  if (await isInGitRepository(workDir)) {\n    return;\n  }\n  info('Initializing a new git repository...');\n  try {\n    await execute('git', ['init'], { cwd: workDir });\n    await execute('git', ['add', '.'], { cwd: workDir });\n    await execute('git', ['commit', '--message=\"Initial commit\"', '--no-gpg-sign'], { cwd: workDir });\n  } catch {\n    warning('Unable to initialize git repository for your project.');\n  }\n}\n\nasync function postInstall(language: string, canUseNetwork: boolean, workDir: string) {\n  switch (language) {\n    case 'javascript':\n      return postInstallJavascript(canUseNetwork, workDir);\n    case 'typescript':\n      return postInstallTypescript(canUseNetwork, workDir);\n    case 'java':\n      return postInstallJava(canUseNetwork, workDir);\n    case 'python':\n      return postInstallPython(workDir);\n  }\n}\n\nasync function postInstallJavascript(canUseNetwork: boolean, cwd: string) {\n  return postInstallTypescript(canUseNetwork, cwd);\n}\n\nasync function postInstallTypescript(canUseNetwork: boolean, cwd: string) {\n  const command = 'npm';\n\n  if (!canUseNetwork) {\n    warning(`Please run '${command} install'!`);\n    return;\n  }\n\n  info(`Executing ${chalk.green(`${command} install`)}...`);\n  try {\n    await execute(command, ['install'], { cwd });\n  } catch (e: any) {\n    warning(`${command} install failed: ` + formatErrorMessage(e));\n  }\n}\n\nasync function postInstallJava(canUseNetwork: boolean, cwd: string) {\n  const mvnPackageWarning = \"Please run 'mvn package'!\";\n  if (!canUseNetwork) {\n    warning(mvnPackageWarning);\n    return;\n  }\n\n  info(\"Executing 'mvn package'\");\n  try {\n    await execute('mvn', ['package'], { cwd });\n  } catch {\n    warning('Unable to package compiled code as JAR');\n    warning(mvnPackageWarning);\n  }\n}\n\nasync function postInstallPython(cwd: string) {\n  const python = pythonExecutable();\n  warning(`Please run '${python} -m venv .venv'!`);\n  info(`Executing ${chalk.green('Creating virtualenv...')}`);\n  try {\n    await execute(python, ['-m venv', '.venv'], { cwd });\n  } catch {\n    warning('Unable to create virtualenv automatically');\n    warning(`Please run '${python} -m venv .venv'!`);\n  }\n}\n\n/**\n * @param dir - a directory to be checked\n * @returns true if ``dir`` is within a git repository.\n */\nasync function isInGitRepository(dir: string) {\n  while (true) {\n    if (await fs.pathExists(path.join(dir, '.git'))) {\n      return true;\n    }\n    if (isRoot(dir)) {\n      return false;\n    }\n    dir = path.dirname(dir);\n  }\n}\n\n/**\n * @param dir - a directory to be checked.\n * @returns true if ``dir`` is the root of a filesystem.\n */\nfunction isRoot(dir: string) {\n  return path.dirname(dir) === dir;\n}\n\n/**\n * Executes `command`. STDERR is emitted in real-time.\n *\n * If command exits with non-zero exit code, an exceprion is thrown and includes\n * the contents of STDOUT.\n *\n * @returns STDOUT (if successful).\n */\nasync function execute(cmd: string, args: string[], { cwd }: { cwd: string }) {\n  const child = childProcess.spawn(cmd, args, {\n    cwd,\n    shell: true,\n    stdio: ['ignore', 'pipe', 'inherit'],\n  });\n  let stdout = '';\n  child.stdout.on('data', (chunk) => (stdout += chunk.toString()));\n  return new Promise<string>((ok, fail) => {\n    child.once('error', (err) => fail(err));\n    child.once('exit', (status) => {\n      if (status === 0) {\n        return ok(stdout);\n      } else {\n        error(stdout);\n        return fail(new ToolkitError(`${cmd} exited with status ${status}`));\n      }\n    });\n  });\n}\n\ninterface Versions {\n  ['aws-cdk']: string;\n  ['aws-cdk-lib']: string;\n  constructs: string;\n}\n\n/**\n * Return the 'aws-cdk-lib' version we will init\n *\n * This has been built into the CLI at build time.\n */\nasync function loadInitVersions(): Promise<Versions> {\n  const initVersionFile = path.join(cliRootDir(), 'lib', 'init-templates', '.init-version.json');\n  const contents = JSON.parse(await fs.readFile(initVersionFile, { encoding: 'utf-8' }));\n\n  const ret = {\n    'aws-cdk-lib': contents['aws-cdk-lib'],\n    'constructs': contents.constructs,\n    'aws-cdk': versionNumber(),\n  };\n  for (const [key, value] of Object.entries(ret)) {\n    /* c8 ignore start */\n    if (!value) {\n      throw new ToolkitError(`Missing init version from ${initVersionFile}: ${key}`);\n    }\n    /* c8 ignore stop */\n  }\n\n  return ret;\n}\n\n/**\n * Return the currently recommended flags for `aws-cdk-lib`.\n *\n * These have been built into the CLI at build time.\n */\nexport async function currentlyRecommendedAwsCdkLibFlags() {\n  const recommendedFlagsFile = path.join(cliRootDir(), 'lib', 'init-templates', '.recommended-feature-flags.json');\n  return JSON.parse(await fs.readFile(recommendedFlagsFile, { encoding: 'utf-8' }));\n}\n"]}
438
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"init.js","sourceRoot":"","sources":["init.ts"],"names":[],"mappings":"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","sourcesContent":["import * as childProcess from 'child_process';\nimport * as path from 'path';\nimport { ToolkitError } from '@aws-cdk/toolkit-lib';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport { invokeBuiltinHooks } from './init-hooks';\nimport type { IoHelper } from '../../api-private';\nimport { cliRootDir } from '../../cli/root-dir';\nimport { versionNumber } from '../../cli/version';\nimport { cdkHomeDir, formatErrorMessage, rangeFromSemver } from '../../util';\n\n/* eslint-disable @typescript-eslint/no-var-requires */ // Packages don't have @types module\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst camelCase = require('camelcase');\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst decamelize = require('decamelize');\n\nexport interface CliInitOptions {\n  readonly type?: string;\n  readonly language?: string;\n  readonly canUseNetwork?: boolean;\n  readonly generateOnly?: boolean;\n  readonly workDir?: string;\n  readonly stackName?: string;\n  readonly migrate?: boolean;\n\n  /**\n   * Override the built-in CDK version\n   */\n  readonly libVersion?: string;\n\n  readonly ioHelper: IoHelper;\n}\n\n/**\n * Initialize a CDK package in the current directory\n */\nexport async function cliInit(options: CliInitOptions) {\n  const ioHelper = options.ioHelper;\n  const canUseNetwork = options.canUseNetwork ?? true;\n  const generateOnly = options.generateOnly ?? false;\n  const workDir = options.workDir ?? process.cwd();\n  if (!options.type && !options.language) {\n    await printAvailableTemplates(ioHelper);\n    return;\n  }\n\n  const type = options.type || 'default'; // \"default\" is the default type (and maps to \"app\")\n\n  const template = (await availableInitTemplates()).find((t) => t.hasName(type!));\n  if (!template) {\n    await printAvailableTemplates(ioHelper, options.language);\n    throw new ToolkitError(`Unknown init template: ${type}`);\n  }\n  if (!options.language && template.languages.length === 1) {\n    const language = template.languages[0];\n    await ioHelper.defaults.warn(\n      `No --language was provided, but '${type}' supports only '${language}', so defaulting to --language=${language}`,\n    );\n  }\n  if (!options.language) {\n    await ioHelper.defaults.info(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);\n    throw new ToolkitError('No language was selected');\n  }\n\n  await initializeProject(\n    ioHelper,\n    template,\n    options.language,\n    canUseNetwork,\n    generateOnly,\n    workDir,\n    options.stackName,\n    options.migrate,\n    options.libVersion,\n  );\n}\n\n/**\n * Returns the name of the Python executable for this OS\n */\nfunction pythonExecutable() {\n  let python = 'python3';\n  if (process.platform === 'win32') {\n    python = 'python';\n  }\n  return python;\n}\nconst INFO_DOT_JSON = 'info.json';\n\nexport class InitTemplate {\n  public static async fromName(templatesDir: string, name: string) {\n    const basePath = path.join(templatesDir, name);\n    const languages = await listDirectory(basePath);\n    const initInfo = await fs.readJson(path.join(basePath, INFO_DOT_JSON));\n    return new InitTemplate(basePath, name, languages, initInfo);\n  }\n\n  public readonly description: string;\n  public readonly aliases = new Set<string>();\n\n  constructor(\n    private readonly basePath: string,\n    public readonly name: string,\n    public readonly languages: string[],\n    initInfo: any,\n  ) {\n    this.description = initInfo.description;\n    for (const alias of initInfo.aliases || []) {\n      this.aliases.add(alias);\n    }\n  }\n\n  /**\n   * @param name - the name that is being checked\n   * @returns ``true`` if ``name`` is the name of this template or an alias of it.\n   */\n  public hasName(name: string): boolean {\n    return name === this.name || this.aliases.has(name);\n  }\n\n  /**\n   * Creates a new instance of this ``InitTemplate`` for a given language to a specified folder.\n   *\n   * @param language    - the language to instantiate this template with\n   * @param targetDirectory - the directory where the template is to be instantiated into\n   */\n  public async install(ioHelper: IoHelper, language: string, targetDirectory: string, stackName?: string, libVersion?: string) {\n    if (this.languages.indexOf(language) === -1) {\n      await ioHelper.defaults.error(\n        `The ${chalk.blue(language)} language is not supported for ${chalk.green(this.name)} ` +\n          `(it supports: ${this.languages.map((l) => chalk.blue(l)).join(', ')})`,\n      );\n      throw new ToolkitError(`Unsupported language: ${language}`);\n    }\n\n    const projectInfo: ProjectInfo = {\n      name: decamelize(path.basename(path.resolve(targetDirectory))),\n      stackName,\n      versions: await loadInitVersions(),\n    };\n\n    if (libVersion) {\n      projectInfo.versions['aws-cdk-lib'] = libVersion;\n    }\n\n    const sourceDirectory = path.join(this.basePath, language);\n\n    await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo);\n    await this.applyFutureFlags(targetDirectory);\n    await invokeBuiltinHooks(\n      ioHelper,\n      { targetDirectory, language, templateName: this.name },\n      {\n        substitutePlaceholdersIn: async (...fileNames: string[]) => {\n          for (const fileName of fileNames) {\n            const fullPath = path.join(targetDirectory, fileName);\n            const template = await fs.readFile(fullPath, { encoding: 'utf-8' });\n            await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo));\n          }\n        },\n        placeholder: (ph: string) => expandPlaceholders(`%${ph}%`, language, projectInfo),\n      },\n    );\n  }\n\n  private async installFiles(sourceDirectory: string, targetDirectory: string, language: string, project: ProjectInfo) {\n    for (const file of await fs.readdir(sourceDirectory)) {\n      const fromFile = path.join(sourceDirectory, file);\n      const toFile = path.join(targetDirectory, expandPlaceholders(file, language, project));\n      if ((await fs.stat(fromFile)).isDirectory()) {\n        await fs.mkdir(toFile);\n        await this.installFiles(fromFile, toFile, language, project);\n        continue;\n      } else if (file.match(/^.*\\.template\\.[^.]+$/)) {\n        await this.installProcessed(fromFile, toFile.replace(/\\.template(\\.[^.]+)$/, '$1'), language, project);\n        continue;\n      } else if (file.match(/^.*\\.hook\\.(d.)?[^.]+$/)) {\n        // Ignore\n        continue;\n      } else {\n        await fs.copy(fromFile, toFile);\n      }\n    }\n  }\n\n  private async installProcessed(templatePath: string, toFile: string, language: string, project: ProjectInfo) {\n    const template = await fs.readFile(templatePath, { encoding: 'utf-8' });\n    await fs.writeFile(toFile, expandPlaceholders(template, language, project));\n  }\n\n  /**\n   * Adds context variables to `cdk.json` in the generated project directory to\n   * enable future behavior for new projects.\n   */\n  private async applyFutureFlags(projectDir: string) {\n    const cdkJson = path.join(projectDir, 'cdk.json');\n    if (!(await fs.pathExists(cdkJson))) {\n      return;\n    }\n\n    const config = await fs.readJson(cdkJson);\n    config.context = {\n      ...config.context,\n      ...await currentlyRecommendedAwsCdkLibFlags(),\n    };\n\n    await fs.writeJson(cdkJson, config, { spaces: 2 });\n  }\n\n  public async addMigrateContext(projectDir: string) {\n    const cdkJson = path.join(projectDir, 'cdk.json');\n    if (!(await fs.pathExists(cdkJson))) {\n      return;\n    }\n\n    const config = await fs.readJson(cdkJson);\n    config.context = {\n      ...config.context,\n      'cdk-migrate': true,\n    };\n\n    await fs.writeJson(cdkJson, config, { spaces: 2 });\n  }\n}\n\nexport function expandPlaceholders(template: string, language: string, project: ProjectInfo) {\n  const cdkVersion = project.versions['aws-cdk-lib'];\n  const cdkCliVersion = project.versions['aws-cdk'];\n  let constructsVersion = project.versions.constructs;\n\n  switch (language) {\n    case 'java':\n    case 'csharp':\n    case 'fsharp':\n      constructsVersion = rangeFromSemver(constructsVersion, 'bracket');\n      break;\n    case 'python':\n      constructsVersion = rangeFromSemver(constructsVersion, 'pep');\n      break;\n  }\n  return template\n    .replace(/%name%/g, project.name)\n    .replace(/%stackname%/, project.stackName ?? '%name.PascalCased%Stack')\n    .replace(\n      /%PascalNameSpace%/,\n      project.stackName ? camelCase(project.stackName + 'Stack', { pascalCase: true }) : '%name.PascalCased%',\n    )\n    .replace(\n      /%PascalStackProps%/,\n      project.stackName ? camelCase(project.stackName, { pascalCase: true }) + 'StackProps' : 'StackProps',\n    )\n    .replace(/%name\\.camelCased%/g, camelCase(project.name))\n    .replace(/%name\\.PascalCased%/g, camelCase(project.name, { pascalCase: true }))\n    .replace(/%cdk-version%/g, cdkVersion)\n    .replace(/%cdk-cli-version%/g, cdkCliVersion)\n    .replace(/%constructs-version%/g, constructsVersion)\n    .replace(/%cdk-home%/g, cdkHomeDir())\n    .replace(/%name\\.PythonModule%/g, project.name.replace(/-/g, '_'))\n    .replace(/%python-executable%/g, pythonExecutable())\n    .replace(/%name\\.StackName%/g, project.name.replace(/[^A-Za-z0-9-]/g, '-'));\n}\n\ninterface ProjectInfo {\n  /** The value used for %name% */\n  readonly name: string;\n  readonly stackName?: string;\n\n  readonly versions: Versions;\n}\n\nexport async function availableInitTemplates(): Promise<InitTemplate[]> {\n  return new Promise(async (resolve) => {\n    try {\n      const templatesDir = path.join(cliRootDir(), 'lib', 'init-templates');\n      const templateNames = await listDirectory(templatesDir);\n      const templates = new Array<InitTemplate>();\n      for (const templateName of templateNames) {\n        templates.push(await InitTemplate.fromName(templatesDir, templateName));\n      }\n      resolve(templates);\n    } catch {\n      resolve([]);\n    }\n  });\n}\n\nexport async function availableInitLanguages(): Promise<string[]> {\n  return new Promise(async (resolve) => {\n    const templates = await availableInitTemplates();\n    const result = new Set<string>();\n    for (const template of templates) {\n      for (const language of template.languages) {\n        result.add(language);\n      }\n    }\n    resolve([...result]);\n  });\n}\n\n/**\n * @param dirPath - is the directory to be listed.\n * @returns the list of file or directory names contained in ``dirPath``, excluding any dot-file, and sorted.\n */\nasync function listDirectory(dirPath: string) {\n  return (\n    (await fs.readdir(dirPath))\n      .filter((p) => !p.startsWith('.'))\n      .filter((p) => !(p === 'LICENSE'))\n      // if, for some reason, the temp folder for the hook doesn't get deleted we don't want to display it in this list\n      .filter((p) => !(p === INFO_DOT_JSON))\n      .sort()\n  );\n}\n\nexport async function printAvailableTemplates(ioHelper: IoHelper, language?: string) {\n  await ioHelper.defaults.info('Available templates:');\n  for (const template of await availableInitTemplates()) {\n    if (language && template.languages.indexOf(language) === -1) {\n      continue;\n    }\n    await ioHelper.defaults.info(`* ${chalk.green(template.name)}: ${template.description}`);\n    const languageArg = language\n      ? chalk.bold(language)\n      : template.languages.length > 1\n        ? `[${template.languages.map((t) => chalk.bold(t)).join('|')}]`\n        : chalk.bold(template.languages[0]);\n    await ioHelper.defaults.info(`   └─ ${chalk.blue(`cdk init ${chalk.bold(template.name)} --language=${languageArg}`)}`);\n  }\n}\n\nasync function initializeProject(\n  ioHelper: IoHelper,\n  template: InitTemplate,\n  language: string,\n  canUseNetwork: boolean,\n  generateOnly: boolean,\n  workDir: string,\n  stackName?: string,\n  migrate?: boolean,\n  cdkVersion?: string,\n) {\n  await assertIsEmptyDirectory(workDir);\n  await ioHelper.defaults.info(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`);\n  await template.install(ioHelper, language, workDir, stackName, cdkVersion);\n  if (migrate) {\n    await template.addMigrateContext(workDir);\n  }\n  if (await fs.pathExists(`${workDir}/README.md`)) {\n    const readme = await fs.readFile(`${workDir}/README.md`, { encoding: 'utf-8' });\n    await ioHelper.defaults.info(chalk.green(readme));\n  }\n\n  if (!generateOnly) {\n    await initializeGitRepository(ioHelper, workDir);\n    await postInstall(ioHelper, language, canUseNetwork, workDir);\n  }\n\n  await ioHelper.defaults.info('✅ All done!');\n}\n\nasync function assertIsEmptyDirectory(workDir: string) {\n  const files = await fs.readdir(workDir);\n  if (files.filter((f) => !f.startsWith('.')).length !== 0) {\n    throw new ToolkitError('`cdk init` cannot be run in a non-empty directory!');\n  }\n}\n\nasync function initializeGitRepository(ioHelper: IoHelper, workDir: string) {\n  if (await isInGitRepository(workDir)) {\n    return;\n  }\n  await ioHelper.defaults.info('Initializing a new git repository...');\n  try {\n    await execute(ioHelper, 'git', ['init'], { cwd: workDir });\n    await execute(ioHelper, 'git', ['add', '.'], { cwd: workDir });\n    await execute(ioHelper, 'git', ['commit', '--message=\"Initial commit\"', '--no-gpg-sign'], { cwd: workDir });\n  } catch {\n    await ioHelper.defaults.warn('Unable to initialize git repository for your project.');\n  }\n}\n\nasync function postInstall(ioHelper: IoHelper, language: string, canUseNetwork: boolean, workDir: string) {\n  switch (language) {\n    case 'javascript':\n      return postInstallJavascript(ioHelper, canUseNetwork, workDir);\n    case 'typescript':\n      return postInstallTypescript(ioHelper, canUseNetwork, workDir);\n    case 'java':\n      return postInstallJava(ioHelper, canUseNetwork, workDir);\n    case 'python':\n      return postInstallPython(ioHelper, workDir);\n  }\n}\n\nasync function postInstallJavascript(ioHelper: IoHelper, canUseNetwork: boolean, cwd: string) {\n  return postInstallTypescript(ioHelper, canUseNetwork, cwd);\n}\n\nasync function postInstallTypescript(ioHelper: IoHelper, canUseNetwork: boolean, cwd: string) {\n  const command = 'npm';\n\n  if (!canUseNetwork) {\n    await ioHelper.defaults.warn(`Please run '${command} install'!`);\n    return;\n  }\n\n  await ioHelper.defaults.info(`Executing ${chalk.green(`${command} install`)}...`);\n  try {\n    await execute(ioHelper, command, ['install'], { cwd });\n  } catch (e: any) {\n    await ioHelper.defaults.warn(`${command} install failed: ` + formatErrorMessage(e));\n  }\n}\n\nasync function postInstallJava(ioHelper: IoHelper, canUseNetwork: boolean, cwd: string) {\n  const mvnPackageWarning = \"Please run 'mvn package'!\";\n  if (!canUseNetwork) {\n    await ioHelper.defaults.warn(mvnPackageWarning);\n    return;\n  }\n\n  await ioHelper.defaults.info(\"Executing 'mvn package'\");\n  try {\n    await execute(ioHelper, 'mvn', ['package'], { cwd });\n  } catch {\n    await ioHelper.defaults.warn('Unable to package compiled code as JAR');\n    await ioHelper.defaults.warn(mvnPackageWarning);\n  }\n}\n\nasync function postInstallPython(ioHelper: IoHelper, cwd: string) {\n  const python = pythonExecutable();\n  await ioHelper.defaults.warn(`Please run '${python} -m venv .venv'!`);\n  await ioHelper.defaults.info(`Executing ${chalk.green('Creating virtualenv...')}`);\n  try {\n    await execute(ioHelper, python, ['-m venv', '.venv'], { cwd });\n  } catch {\n    await ioHelper.defaults.warn('Unable to create virtualenv automatically');\n    await ioHelper.defaults.warn(`Please run '${python} -m venv .venv'!`);\n  }\n}\n\n/**\n * @param dir - a directory to be checked\n * @returns true if ``dir`` is within a git repository.\n */\nasync function isInGitRepository(dir: string) {\n  while (true) {\n    if (await fs.pathExists(path.join(dir, '.git'))) {\n      return true;\n    }\n    if (isRoot(dir)) {\n      return false;\n    }\n    dir = path.dirname(dir);\n  }\n}\n\n/**\n * @param dir - a directory to be checked.\n * @returns true if ``dir`` is the root of a filesystem.\n */\nfunction isRoot(dir: string) {\n  return path.dirname(dir) === dir;\n}\n\n/**\n * Executes `command`. STDERR is emitted in real-time.\n *\n * If command exits with non-zero exit code, an exception is thrown and includes\n * the contents of STDOUT.\n *\n * @returns STDOUT (if successful).\n */\nasync function execute(ioHelper: IoHelper, cmd: string, args: string[], { cwd }: { cwd: string }) {\n  const child = childProcess.spawn(cmd, args, {\n    cwd,\n    shell: true,\n    stdio: ['ignore', 'pipe', 'inherit'],\n  });\n  let stdout = '';\n  child.stdout.on('data', (chunk) => (stdout += chunk.toString()));\n  return new Promise<string>((ok, fail) => {\n    child.once('error', (err) => fail(err));\n    child.once('exit', (status) => {\n      if (status === 0) {\n        return ok(stdout);\n      } else {\n        return fail(new ToolkitError(`${cmd} exited with status ${status}`));\n      }\n    });\n  }).catch(async (err) => {\n    await ioHelper.defaults.error(stdout);\n    throw err;\n  });\n}\n\ninterface Versions {\n  ['aws-cdk']: string;\n  ['aws-cdk-lib']: string;\n  constructs: string;\n}\n\n/**\n * Return the 'aws-cdk-lib' version we will init\n *\n * This has been built into the CLI at build time.\n */\nasync function loadInitVersions(): Promise<Versions> {\n  const initVersionFile = path.join(cliRootDir(), 'lib', 'init-templates', '.init-version.json');\n  const contents = JSON.parse(await fs.readFile(initVersionFile, { encoding: 'utf-8' }));\n\n  const ret = {\n    'aws-cdk-lib': contents['aws-cdk-lib'],\n    'constructs': contents.constructs,\n    'aws-cdk': versionNumber(),\n  };\n  for (const [key, value] of Object.entries(ret)) {\n    /* c8 ignore start */\n    if (!value) {\n      throw new ToolkitError(`Missing init version from ${initVersionFile}: ${key}`);\n    }\n    /* c8 ignore stop */\n  }\n\n  return ret;\n}\n\n/**\n * Return the currently recommended flags for `aws-cdk-lib`.\n *\n * These have been built into the CLI at build time.\n */\nexport async function currentlyRecommendedAwsCdkLibFlags() {\n  const recommendedFlagsFile = path.join(cliRootDir(), 'lib', 'init-templates', '.recommended-feature-flags.json');\n  return JSON.parse(await fs.readFile(recommendedFlagsFile, { encoding: 'utf-8' }));\n}\n"]}
@@ -1,7 +1,8 @@
1
+ import type { IoHelper } from '../../api-private';
1
2
  /**
2
3
  * OS helpers
3
4
  *
4
5
  * Shell function which both prints to stdout and collects the output into a
5
6
  * string.
6
7
  */
7
- export declare function shell(command: string[]): Promise<string>;
8
+ export declare function shell(ioHelper: IoHelper, command: string[]): Promise<string>;
@@ -4,16 +4,15 @@ exports.shell = shell;
4
4
  const child_process = require("child_process");
5
5
  const toolkit_lib_1 = require("@aws-cdk/toolkit-lib");
6
6
  const chalk = require("chalk");
7
- const logging_1 = require("../../logging");
8
7
  /**
9
8
  * OS helpers
10
9
  *
11
10
  * Shell function which both prints to stdout and collects the output into a
12
11
  * string.
13
12
  */
14
- async function shell(command) {
13
+ async function shell(ioHelper, command) {
15
14
  const commandLine = renderCommandLine(command);
16
- (0, logging_1.debug)(`Executing ${chalk.blue(commandLine)}`);
15
+ await ioHelper.defaults.debug(`Executing ${chalk.blue(commandLine)}`);
17
16
  const child = child_process.spawn(command[0], renderArguments(command.slice(1)), {
18
17
  // Need this for Windows where we want .cmd and .bat to be found as well.
19
18
  shell: true,
@@ -89,4 +88,4 @@ function windowsEscape(x) {
89
88
  const shellMeta = new Set(['"', '&', '^', '%']);
90
89
  return x.split('').map(c => shellMeta.has(x) ? '^' + c : c).join('');
91
90
  }
92
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJvcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQVdBLHNCQTRCQztBQXZDRCwrQ0FBK0M7QUFDL0Msc0RBQW9EO0FBQ3BELCtCQUErQjtBQUMvQiwyQ0FBc0M7QUFFdEM7Ozs7O0dBS0c7QUFDSSxLQUFLLFVBQVUsS0FBSyxDQUFDLE9BQWlCO0lBQzNDLE1BQU0sV0FBVyxHQUFHLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQy9DLElBQUEsZUFBSyxFQUFDLGFBQWEsS0FBSyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDOUMsTUFBTSxLQUFLLEdBQUcsYUFBYSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsZUFBZSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRTtRQUMvRSx5RUFBeUU7UUFDekUsS0FBSyxFQUFFLElBQUk7UUFDWCxLQUFLLEVBQUUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLFNBQVMsQ0FBQztLQUNyQyxDQUFDLENBQUM7SUFFSCxPQUFPLElBQUksT0FBTyxDQUFTLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFO1FBQzdDLE1BQU0sTUFBTSxHQUFHLElBQUksS0FBSyxFQUFPLENBQUM7UUFFaEMsbUNBQW1DO1FBQ25DLEtBQUssQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsRUFBRTtZQUM5QixPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM1QixNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3JCLENBQUMsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFNUIsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUU7WUFDeEIsSUFBSSxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUM7Z0JBQ2YsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDakQsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLE1BQU0sQ0FBQyxJQUFJLDBCQUFZLENBQUMsR0FBRyxXQUFXLDJCQUEyQixJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDNUUsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBUyxpQkFBaUIsQ0FBQyxHQUFhO0lBQ3RDLE9BQU8sZUFBZSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUN4QyxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLGVBQWUsQ0FBQyxHQUFhO0lBQ3BDLElBQUksT0FBTyxDQUFDLFFBQVEsS0FBSyxPQUFPLEVBQUUsQ0FBQztRQUNqQyxPQUFPLFFBQVEsQ0FBQyxHQUFHLEVBQUUsV0FBVyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3JGLENBQUM7U0FBTSxDQUFDO1FBQ04sT0FBTyxRQUFRLENBQUMsR0FBRyxFQUFFLFdBQVcsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDNUUsQ0FBQztBQUNILENBQUM7QUFFRDs7R0FFRztBQUNILFNBQVMsUUFBUSxDQUFDLEdBQWEsRUFBRSxhQUFxQyxFQUFFLFFBQStCO0lBQ3JHLE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUMxRCxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLFdBQVcsQ0FBQyxHQUFHLEtBQWU7SUFDckMsT0FBTyxDQUFDLEdBQVcsRUFBRSxFQUFFO1FBQ3JCLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNoRCxDQUFDLENBQUM7QUFDSixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQVMsV0FBVyxDQUFDLENBQVM7SUFDNUIsa0JBQWtCO0lBQ2xCLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztJQUMvQixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUM7QUFDbEIsQ0FBQztBQUVEOzs7Ozs7R0FNRztBQUNILFNBQVMsYUFBYSxDQUFDLENBQVM7SUFDOUIscUVBQXFFO0lBQ3JFLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQ2Isb0NBQW9DO0lBQ3BDLE1BQU0sU0FBUyxHQUFHLElBQUksR0FBRyxDQUFTLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUN4RCxPQUFPLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBQ3ZFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjaGlsZF9wcm9jZXNzIGZyb20gJ2NoaWxkX3Byb2Nlc3MnO1xuaW1wb3J0IHsgVG9vbGtpdEVycm9yIH0gZnJvbSAnQGF3cy1jZGsvdG9vbGtpdC1saWInO1xuaW1wb3J0ICogYXMgY2hhbGsgZnJvbSAnY2hhbGsnO1xuaW1wb3J0IHsgZGVidWcgfSBmcm9tICcuLi8uLi9sb2dnaW5nJztcblxuLyoqXG4gKiBPUyBoZWxwZXJzXG4gKlxuICogU2hlbGwgZnVuY3Rpb24gd2hpY2ggYm90aCBwcmludHMgdG8gc3Rkb3V0IGFuZCBjb2xsZWN0cyB0aGUgb3V0cHV0IGludG8gYVxuICogc3RyaW5nLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc2hlbGwoY29tbWFuZDogc3RyaW5nW10pOiBQcm9taXNlPHN0cmluZz4ge1xuICBjb25zdCBjb21tYW5kTGluZSA9IHJlbmRlckNvbW1hbmRMaW5lKGNvbW1hbmQpO1xuICBkZWJ1ZyhgRXhlY3V0aW5nICR7Y2hhbGsuYmx1ZShjb21tYW5kTGluZSl9YCk7XG4gIGNvbnN0IGNoaWxkID0gY2hpbGRfcHJvY2Vzcy5zcGF3bihjb21tYW5kWzBdLCByZW5kZXJBcmd1bWVudHMoY29tbWFuZC5zbGljZSgxKSksIHtcbiAgICAvLyBOZWVkIHRoaXMgZm9yIFdpbmRvd3Mgd2hlcmUgd2Ugd2FudCAuY21kIGFuZCAuYmF0IHRvIGJlIGZvdW5kIGFzIHdlbGwuXG4gICAgc2hlbGw6IHRydWUsXG4gICAgc3RkaW86IFsnaWdub3JlJywgJ3BpcGUnLCAnaW5oZXJpdCddLFxuICB9KTtcblxuICByZXR1cm4gbmV3IFByb21pc2U8c3RyaW5nPigocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgY29uc3Qgc3Rkb3V0ID0gbmV3IEFycmF5PGFueT4oKTtcblxuICAgIC8vIEJvdGggd3JpdGUgdG8gc3Rkb3V0IGFuZCBjb2xsZWN0XG4gICAgY2hpbGQuc3Rkb3V0Lm9uKCdkYXRhJywgY2h1bmsgPT4ge1xuICAgICAgcHJvY2Vzcy5zdGRvdXQud3JpdGUoY2h1bmspO1xuICAgICAgc3Rkb3V0LnB1c2goY2h1bmspO1xuICAgIH0pO1xuXG4gICAgY2hpbGQub25jZSgnZXJyb3InLCByZWplY3QpO1xuXG4gICAgY2hpbGQub25jZSgnZXhpdCcsIGNvZGUgPT4ge1xuICAgICAgaWYgKGNvZGUgPT09IDApIHtcbiAgICAgICAgcmVzb2x2ZShCdWZmZXIuZnJvbShzdGRvdXQpLnRvU3RyaW5nKCd1dGYtOCcpKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlamVjdChuZXcgVG9vbGtpdEVycm9yKGAke2NvbW1hbmRMaW5lfSBleGl0ZWQgd2l0aCBlcnJvciBjb2RlICR7Y29kZX1gKSk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xufVxuXG5mdW5jdGlvbiByZW5kZXJDb21tYW5kTGluZShjbWQ6IHN0cmluZ1tdKSB7XG4gIHJldHVybiByZW5kZXJBcmd1bWVudHMoY21kKS5qb2luKCcgJyk7XG59XG5cbi8qKlxuICogUmVuZGVyIHRoZSBhcmd1bWVudHMgdG8gaW5jbHVkZSBlc2NhcGUgY2hhcmFjdGVycyBmb3IgZWFjaCBwbGF0Zm9ybS5cbiAqL1xuZnVuY3Rpb24gcmVuZGVyQXJndW1lbnRzKGNtZDogc3RyaW5nW10pIHtcbiAgaWYgKHByb2Nlc3MucGxhdGZvcm0gIT09ICd3aW4zMicpIHtcbiAgICByZXR1cm4gZG9SZW5kZXIoY21kLCBoYXNBbnlDaGFycygnICcsICdcXFxcJywgJyEnLCAnXCInLCBcIidcIiwgJyYnLCAnJCcpLCBwb3NpeEVzY2FwZSk7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIGRvUmVuZGVyKGNtZCwgaGFzQW55Q2hhcnMoJyAnLCAnXCInLCAnJicsICdeJywgJyUnKSwgd2luZG93c0VzY2FwZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBSZW5kZXIgYSBVTklYIGNvbW1hbmQgbGluZVxuICovXG5mdW5jdGlvbiBkb1JlbmRlcihjbWQ6IHN0cmluZ1tdLCBuZWVkc0VzY2FwaW5nOiAoeDogc3RyaW5nKSA9PiBib29sZWFuLCBkb0VzY2FwZTogKHg6IHN0cmluZykgPT4gc3RyaW5nKTogc3RyaW5nW10ge1xuICByZXR1cm4gY21kLm1hcCh4ID0+IG5lZWRzRXNjYXBpbmcoeCkgPyBkb0VzY2FwZSh4KSA6IHgpO1xufVxuXG4vKipcbiAqIFJldHVybiBhIHByZWRpY2F0ZSB0aGF0IGNoZWNrcyBpZiBhIHN0cmluZyBoYXMgYW55IG9mIHRoZSBpbmRpY2F0ZWQgY2hhcnMgaW4gaXRcbiAqL1xuZnVuY3Rpb24gaGFzQW55Q2hhcnMoLi4uY2hhcnM6IHN0cmluZ1tdKTogKHg6IHN0cmluZykgPT4gYm9vbGVhbiB7XG4gIHJldHVybiAoc3RyOiBzdHJpbmcpID0+IHtcbiAgICByZXR1cm4gY2hhcnMuc29tZShjID0+IHN0ci5pbmRleE9mKGMpICE9PSAtMSk7XG4gIH07XG59XG5cbi8qKlxuICogRXNjYXBlIGEgc2hlbGwgYXJndW1lbnQgZm9yIFBPU0lYIHNoZWxsc1xuICpcbiAqIFdyYXBwaW5nIGluIHNpbmdsZSBxdW90ZXMgYW5kIGVzY2FwaW5nIHNpbmdsZSBxdW90ZXMgaW5zaWRlIHdpbGwgZG8gaXQgZm9yIHVzLlxuICovXG5mdW5jdGlvbiBwb3NpeEVzY2FwZSh4OiBzdHJpbmcpIHtcbiAgLy8gVHVybiAnIC0+ICdcIidcIidcbiAgeCA9IHgucmVwbGFjZSgvJy9nLCBcIidcXFwiJ1xcXCInXCIpO1xuICByZXR1cm4gYCcke3h9J2A7XG59XG5cbi8qKlxuICogRXNjYXBlIGEgc2hlbGwgYXJndW1lbnQgZm9yIGNtZC5leGVcbiAqXG4gKiBUaGlzIGlzIGhvdyB0byBkbyBpdCByaWdodCwgYnV0IEknbSBub3QgZm9sbG93aW5nIGV2ZXJ5dGhpbmc6XG4gKlxuICogaHR0cHM6Ly9ibG9ncy5tc2RuLm1pY3Jvc29mdC5jb20vdHdpc3R5bGl0dGxlcGFzc2FnZXNhbGxhbGlrZS8yMDExLzA0LzIzL2V2ZXJ5b25lLXF1b3Rlcy1jb21tYW5kLWxpbmUtYXJndW1lbnRzLXRoZS13cm9uZy13YXkvXG4gKi9cbmZ1bmN0aW9uIHdpbmRvd3NFc2NhcGUoeDogc3RyaW5nKTogc3RyaW5nIHtcbiAgLy8gRmlyc3Qgc3Vycm91bmQgYnkgZG91YmxlIHF1b3RlcywgaWdub3JlIHRoZSBwYXJ0IGFib3V0IGJhY2tzbGFzaGVzXG4gIHggPSBgXCIke3h9XCJgO1xuICAvLyBOb3cgZXNjYXBlIGFsbCBzcGVjaWFsIGNoYXJhY3RlcnNcbiAgY29uc3Qgc2hlbGxNZXRhID0gbmV3IFNldDxzdHJpbmc+KFsnXCInLCAnJicsICdeJywgJyUnXSk7XG4gIHJldHVybiB4LnNwbGl0KCcnKS5tYXAoYyA9PiBzaGVsbE1ldGEuaGFzKHgpID8gJ14nICsgYyA6IGMpLmpvaW4oJycpO1xufVxuIl19
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJvcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQVdBLHNCQTRCQztBQXZDRCwrQ0FBK0M7QUFDL0Msc0RBQW9EO0FBQ3BELCtCQUErQjtBQUcvQjs7Ozs7R0FLRztBQUNJLEtBQUssVUFBVSxLQUFLLENBQUMsUUFBa0IsRUFBRSxPQUFpQjtJQUMvRCxNQUFNLFdBQVcsR0FBRyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMvQyxNQUFNLFFBQVEsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLGFBQWEsS0FBSyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDdEUsTUFBTSxLQUFLLEdBQUcsYUFBYSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsZUFBZSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRTtRQUMvRSx5RUFBeUU7UUFDekUsS0FBSyxFQUFFLElBQUk7UUFDWCxLQUFLLEVBQUUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLFNBQVMsQ0FBQztLQUNyQyxDQUFDLENBQUM7SUFFSCxPQUFPLElBQUksT0FBTyxDQUFTLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFO1FBQzdDLE1BQU0sTUFBTSxHQUFHLElBQUksS0FBSyxFQUFPLENBQUM7UUFFaEMsbUNBQW1DO1FBQ25DLEtBQUssQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsRUFBRTtZQUM5QixPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM1QixNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3JCLENBQUMsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFNUIsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEVBQUU7WUFDeEIsSUFBSSxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUM7Z0JBQ2YsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDakQsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLE1BQU0sQ0FBQyxJQUFJLDBCQUFZLENBQUMsR0FBRyxXQUFXLDJCQUEyQixJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDNUUsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBUyxpQkFBaUIsQ0FBQyxHQUFhO0lBQ3RDLE9BQU8sZUFBZSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUN4QyxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLGVBQWUsQ0FBQyxHQUFhO0lBQ3BDLElBQUksT0FBTyxDQUFDLFFBQVEsS0FBSyxPQUFPLEVBQUUsQ0FBQztRQUNqQyxPQUFPLFFBQVEsQ0FBQyxHQUFHLEVBQUUsV0FBVyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3JGLENBQUM7U0FBTSxDQUFDO1FBQ04sT0FBTyxRQUFRLENBQUMsR0FBRyxFQUFFLFdBQVcsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDNUUsQ0FBQztBQUNILENBQUM7QUFFRDs7R0FFRztBQUNILFNBQVMsUUFBUSxDQUFDLEdBQWEsRUFBRSxhQUFxQyxFQUFFLFFBQStCO0lBQ3JHLE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUMxRCxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFTLFdBQVcsQ0FBQyxHQUFHLEtBQWU7SUFDckMsT0FBTyxDQUFDLEdBQVcsRUFBRSxFQUFFO1FBQ3JCLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNoRCxDQUFDLENBQUM7QUFDSixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQVMsV0FBVyxDQUFDLENBQVM7SUFDNUIsa0JBQWtCO0lBQ2xCLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztJQUMvQixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUM7QUFDbEIsQ0FBQztBQUVEOzs7Ozs7R0FNRztBQUNILFNBQVMsYUFBYSxDQUFDLENBQVM7SUFDOUIscUVBQXFFO0lBQ3JFLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQ2Isb0NBQW9DO0lBQ3BDLE1BQU0sU0FBUyxHQUFHLElBQUksR0FBRyxDQUFTLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUN4RCxPQUFPLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBQ3ZFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBjaGlsZF9wcm9jZXNzIGZyb20gJ2NoaWxkX3Byb2Nlc3MnO1xuaW1wb3J0IHsgVG9vbGtpdEVycm9yIH0gZnJvbSAnQGF3cy1jZGsvdG9vbGtpdC1saWInO1xuaW1wb3J0ICogYXMgY2hhbGsgZnJvbSAnY2hhbGsnO1xuaW1wb3J0IHR5cGUgeyBJb0hlbHBlciB9IGZyb20gJy4uLy4uL2FwaS1wcml2YXRlJztcblxuLyoqXG4gKiBPUyBoZWxwZXJzXG4gKlxuICogU2hlbGwgZnVuY3Rpb24gd2hpY2ggYm90aCBwcmludHMgdG8gc3Rkb3V0IGFuZCBjb2xsZWN0cyB0aGUgb3V0cHV0IGludG8gYVxuICogc3RyaW5nLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc2hlbGwoaW9IZWxwZXI6IElvSGVscGVyLCBjb21tYW5kOiBzdHJpbmdbXSk6IFByb21pc2U8c3RyaW5nPiB7XG4gIGNvbnN0IGNvbW1hbmRMaW5lID0gcmVuZGVyQ29tbWFuZExpbmUoY29tbWFuZCk7XG4gIGF3YWl0IGlvSGVscGVyLmRlZmF1bHRzLmRlYnVnKGBFeGVjdXRpbmcgJHtjaGFsay5ibHVlKGNvbW1hbmRMaW5lKX1gKTtcbiAgY29uc3QgY2hpbGQgPSBjaGlsZF9wcm9jZXNzLnNwYXduKGNvbW1hbmRbMF0sIHJlbmRlckFyZ3VtZW50cyhjb21tYW5kLnNsaWNlKDEpKSwge1xuICAgIC8vIE5lZWQgdGhpcyBmb3IgV2luZG93cyB3aGVyZSB3ZSB3YW50IC5jbWQgYW5kIC5iYXQgdG8gYmUgZm91bmQgYXMgd2VsbC5cbiAgICBzaGVsbDogdHJ1ZSxcbiAgICBzdGRpbzogWydpZ25vcmUnLCAncGlwZScsICdpbmhlcml0J10sXG4gIH0pO1xuXG4gIHJldHVybiBuZXcgUHJvbWlzZTxzdHJpbmc+KChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICBjb25zdCBzdGRvdXQgPSBuZXcgQXJyYXk8YW55PigpO1xuXG4gICAgLy8gQm90aCB3cml0ZSB0byBzdGRvdXQgYW5kIGNvbGxlY3RcbiAgICBjaGlsZC5zdGRvdXQub24oJ2RhdGEnLCBjaHVuayA9PiB7XG4gICAgICBwcm9jZXNzLnN0ZG91dC53cml0ZShjaHVuayk7XG4gICAgICBzdGRvdXQucHVzaChjaHVuayk7XG4gICAgfSk7XG5cbiAgICBjaGlsZC5vbmNlKCdlcnJvcicsIHJlamVjdCk7XG5cbiAgICBjaGlsZC5vbmNlKCdleGl0JywgY29kZSA9PiB7XG4gICAgICBpZiAoY29kZSA9PT0gMCkge1xuICAgICAgICByZXNvbHZlKEJ1ZmZlci5mcm9tKHN0ZG91dCkudG9TdHJpbmcoJ3V0Zi04JykpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmVqZWN0KG5ldyBUb29sa2l0RXJyb3IoYCR7Y29tbWFuZExpbmV9IGV4aXRlZCB3aXRoIGVycm9yIGNvZGUgJHtjb2RlfWApKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIHJlbmRlckNvbW1hbmRMaW5lKGNtZDogc3RyaW5nW10pIHtcbiAgcmV0dXJuIHJlbmRlckFyZ3VtZW50cyhjbWQpLmpvaW4oJyAnKTtcbn1cblxuLyoqXG4gKiBSZW5kZXIgdGhlIGFyZ3VtZW50cyB0byBpbmNsdWRlIGVzY2FwZSBjaGFyYWN0ZXJzIGZvciBlYWNoIHBsYXRmb3JtLlxuICovXG5mdW5jdGlvbiByZW5kZXJBcmd1bWVudHMoY21kOiBzdHJpbmdbXSkge1xuICBpZiAocHJvY2Vzcy5wbGF0Zm9ybSAhPT0gJ3dpbjMyJykge1xuICAgIHJldHVybiBkb1JlbmRlcihjbWQsIGhhc0FueUNoYXJzKCcgJywgJ1xcXFwnLCAnIScsICdcIicsIFwiJ1wiLCAnJicsICckJyksIHBvc2l4RXNjYXBlKTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gZG9SZW5kZXIoY21kLCBoYXNBbnlDaGFycygnICcsICdcIicsICcmJywgJ14nLCAnJScpLCB3aW5kb3dzRXNjYXBlKTtcbiAgfVxufVxuXG4vKipcbiAqIFJlbmRlciBhIFVOSVggY29tbWFuZCBsaW5lXG4gKi9cbmZ1bmN0aW9uIGRvUmVuZGVyKGNtZDogc3RyaW5nW10sIG5lZWRzRXNjYXBpbmc6ICh4OiBzdHJpbmcpID0+IGJvb2xlYW4sIGRvRXNjYXBlOiAoeDogc3RyaW5nKSA9PiBzdHJpbmcpOiBzdHJpbmdbXSB7XG4gIHJldHVybiBjbWQubWFwKHggPT4gbmVlZHNFc2NhcGluZyh4KSA/IGRvRXNjYXBlKHgpIDogeCk7XG59XG5cbi8qKlxuICogUmV0dXJuIGEgcHJlZGljYXRlIHRoYXQgY2hlY2tzIGlmIGEgc3RyaW5nIGhhcyBhbnkgb2YgdGhlIGluZGljYXRlZCBjaGFycyBpbiBpdFxuICovXG5mdW5jdGlvbiBoYXNBbnlDaGFycyguLi5jaGFyczogc3RyaW5nW10pOiAoeDogc3RyaW5nKSA9PiBib29sZWFuIHtcbiAgcmV0dXJuIChzdHI6IHN0cmluZykgPT4ge1xuICAgIHJldHVybiBjaGFycy5zb21lKGMgPT4gc3RyLmluZGV4T2YoYykgIT09IC0xKTtcbiAgfTtcbn1cblxuLyoqXG4gKiBFc2NhcGUgYSBzaGVsbCBhcmd1bWVudCBmb3IgUE9TSVggc2hlbGxzXG4gKlxuICogV3JhcHBpbmcgaW4gc2luZ2xlIHF1b3RlcyBhbmQgZXNjYXBpbmcgc2luZ2xlIHF1b3RlcyBpbnNpZGUgd2lsbCBkbyBpdCBmb3IgdXMuXG4gKi9cbmZ1bmN0aW9uIHBvc2l4RXNjYXBlKHg6IHN0cmluZykge1xuICAvLyBUdXJuICcgLT4gJ1wiJ1wiJ1xuICB4ID0geC5yZXBsYWNlKC8nL2csIFwiJ1xcXCInXFxcIidcIik7XG4gIHJldHVybiBgJyR7eH0nYDtcbn1cblxuLyoqXG4gKiBFc2NhcGUgYSBzaGVsbCBhcmd1bWVudCBmb3IgY21kLmV4ZVxuICpcbiAqIFRoaXMgaXMgaG93IHRvIGRvIGl0IHJpZ2h0LCBidXQgSSdtIG5vdCBmb2xsb3dpbmcgZXZlcnl0aGluZzpcbiAqXG4gKiBodHRwczovL2Jsb2dzLm1zZG4ubWljcm9zb2Z0LmNvbS90d2lzdHlsaXR0bGVwYXNzYWdlc2FsbGFsaWtlLzIwMTEvMDQvMjMvZXZlcnlvbmUtcXVvdGVzLWNvbW1hbmQtbGluZS1hcmd1bWVudHMtdGhlLXdyb25nLXdheS9cbiAqL1xuZnVuY3Rpb24gd2luZG93c0VzY2FwZSh4OiBzdHJpbmcpOiBzdHJpbmcge1xuICAvLyBGaXJzdCBzdXJyb3VuZCBieSBkb3VibGUgcXVvdGVzLCBpZ25vcmUgdGhlIHBhcnQgYWJvdXQgYmFja3NsYXNoZXNcbiAgeCA9IGBcIiR7eH1cImA7XG4gIC8vIE5vdyBlc2NhcGUgYWxsIHNwZWNpYWwgY2hhcmFjdGVyc1xuICBjb25zdCBzaGVsbE1ldGEgPSBuZXcgU2V0PHN0cmluZz4oWydcIicsICcmJywgJ14nLCAnJSddKTtcbiAgcmV0dXJuIHguc3BsaXQoJycpLm1hcChjID0+IHNoZWxsTWV0YS5oYXMoeCkgPyAnXicgKyBjIDogYykuam9pbignJyk7XG59XG4iXX0=
@@ -17,6 +17,12 @@ async function listStacks(toolkit, options) {
17
17
  extend: cxapp_1.ExtendedStackSelection.Upstream,
18
18
  defaultBehavior: cxapp_1.DefaultSelection.AllStacks,
19
19
  });
20
- return stacks.withDependencies();
20
+ // we only want to print a subset of information in `cdk list --json`
21
+ return stacks.withDependencies().map(stack => ({
22
+ id: stack.id,
23
+ name: stack.name,
24
+ environment: stack.environment,
25
+ dependencies: stack.dependencies,
26
+ }));
21
27
  }
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1zdGFja3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJsaXN0LXN0YWNrcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQXVCQSxnQ0FXQztBQWhDRCxvQ0FBb0U7QUFjcEU7Ozs7OztHQU1HO0FBQ0ksS0FBSyxVQUFVLFVBQVUsQ0FBQyxPQUFtQixFQUFFLE9BQTBCO0lBQzlFLE1BQU0sUUFBUSxHQUFHLE1BQU0sT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBRTFDLE1BQU0sTUFBTSxHQUFHLE1BQU0sUUFBUSxDQUFDLFlBQVksQ0FBQztRQUN6QyxRQUFRLEVBQUUsT0FBTyxDQUFDLFNBQVM7S0FDNUIsRUFBRTtRQUNELE1BQU0sRUFBRSw4QkFBc0IsQ0FBQyxRQUFRO1FBQ3ZDLGVBQWUsRUFBRSx3QkFBZ0IsQ0FBQyxTQUFTO0tBQzVDLENBQUMsQ0FBQztJQUVILE9BQU8sTUFBTSxDQUFDLGdCQUFnQixFQUFFLENBQUM7QUFDbkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU3RhY2tEZXRhaWxzIH0gZnJvbSAnQGF3cy1jZGsvdG9vbGtpdC1saWInO1xuaW1wb3J0IHR5cGUgeyBDZGtUb29sa2l0IH0gZnJvbSAnLi4vY2xpL2Nkay10b29sa2l0JztcbmltcG9ydCB7IERlZmF1bHRTZWxlY3Rpb24sIEV4dGVuZGVkU3RhY2tTZWxlY3Rpb24gfSBmcm9tICcuLi9jeGFwcCc7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgTGlzdCBTdGFja3NcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMaXN0U3RhY2tzT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBTdGFja3MgdG8gbGlzdFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIEFsbCBzdGFja3MgYXJlIGxpc3RlZFxuICAgKi9cbiAgcmVhZG9ubHkgc2VsZWN0b3JzOiBzdHJpbmdbXTtcbn1cblxuLyoqXG4gKiBMaXN0IFN0YWNrc1xuICpcbiAqIEBwYXJhbSB0b29sa2l0IC0gY2RrIHRvb2xraXRcbiAqIEBwYXJhbSBvcHRpb25zIC0gbGlzdCBzdGFja3Mgb3B0aW9uc1xuICogQHJldHVybnMgU3RhY2tEZXRhaWxzW11cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGxpc3RTdGFja3ModG9vbGtpdDogQ2RrVG9vbGtpdCwgb3B0aW9uczogTGlzdFN0YWNrc09wdGlvbnMpOiBQcm9taXNlPFN0YWNrRGV0YWlsc1tdPiB7XG4gIGNvbnN0IGFzc2VtYmx5ID0gYXdhaXQgdG9vbGtpdC5hc3NlbWJseSgpO1xuXG4gIGNvbnN0IHN0YWNrcyA9IGF3YWl0IGFzc2VtYmx5LnNlbGVjdFN0YWNrcyh7XG4gICAgcGF0dGVybnM6IG9wdGlvbnMuc2VsZWN0b3JzLFxuICB9LCB7XG4gICAgZXh0ZW5kOiBFeHRlbmRlZFN0YWNrU2VsZWN0aW9uLlVwc3RyZWFtLFxuICAgIGRlZmF1bHRCZWhhdmlvcjogRGVmYXVsdFNlbGVjdGlvbi5BbGxTdGFja3MsXG4gIH0pO1xuXG4gIHJldHVybiBzdGFja3Mud2l0aERlcGVuZGVuY2llcygpO1xufVxuIl19
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1zdGFja3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJsaXN0LXN0YWNrcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQXVCQSxnQ0FpQkM7QUF0Q0Qsb0NBQW9FO0FBY3BFOzs7Ozs7R0FNRztBQUNJLEtBQUssVUFBVSxVQUFVLENBQUMsT0FBbUIsRUFBRSxPQUEwQjtJQUM5RSxNQUFNLFFBQVEsR0FBRyxNQUFNLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUUxQyxNQUFNLE1BQU0sR0FBRyxNQUFNLFFBQVEsQ0FBQyxZQUFZLENBQUM7UUFDekMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxTQUFTO0tBQzVCLEVBQUU7UUFDRCxNQUFNLEVBQUUsOEJBQXNCLENBQUMsUUFBUTtRQUN2QyxlQUFlLEVBQUUsd0JBQWdCLENBQUMsU0FBUztLQUM1QyxDQUFDLENBQUM7SUFFSCxxRUFBcUU7SUFDckUsT0FBTyxNQUFNLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzdDLEVBQUUsRUFBRSxLQUFLLENBQUMsRUFBRTtRQUNaLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSTtRQUNoQixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7UUFDOUIsWUFBWSxFQUFFLEtBQUssQ0FBQyxZQUFZO0tBQ2pDLENBQUMsQ0FBQyxDQUFDO0FBQ04sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU3RhY2tEZXRhaWxzIH0gZnJvbSAnQGF3cy1jZGsvdG9vbGtpdC1saWInO1xuaW1wb3J0IHR5cGUgeyBDZGtUb29sa2l0IH0gZnJvbSAnLi4vY2xpL2Nkay10b29sa2l0JztcbmltcG9ydCB7IERlZmF1bHRTZWxlY3Rpb24sIEV4dGVuZGVkU3RhY2tTZWxlY3Rpb24gfSBmcm9tICcuLi9jeGFwcCc7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgTGlzdCBTdGFja3NcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBMaXN0U3RhY2tzT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBTdGFja3MgdG8gbGlzdFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIEFsbCBzdGFja3MgYXJlIGxpc3RlZFxuICAgKi9cbiAgcmVhZG9ubHkgc2VsZWN0b3JzOiBzdHJpbmdbXTtcbn1cblxuLyoqXG4gKiBMaXN0IFN0YWNrc1xuICpcbiAqIEBwYXJhbSB0b29sa2l0IC0gY2RrIHRvb2xraXRcbiAqIEBwYXJhbSBvcHRpb25zIC0gbGlzdCBzdGFja3Mgb3B0aW9uc1xuICogQHJldHVybnMgU3RhY2tEZXRhaWxzW11cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGxpc3RTdGFja3ModG9vbGtpdDogQ2RrVG9vbGtpdCwgb3B0aW9uczogTGlzdFN0YWNrc09wdGlvbnMpOiBQcm9taXNlPFN0YWNrRGV0YWlsc1tdPiB7XG4gIGNvbnN0IGFzc2VtYmx5ID0gYXdhaXQgdG9vbGtpdC5hc3NlbWJseSgpO1xuXG4gIGNvbnN0IHN0YWNrcyA9IGF3YWl0IGFzc2VtYmx5LnNlbGVjdFN0YWNrcyh7XG4gICAgcGF0dGVybnM6IG9wdGlvbnMuc2VsZWN0b3JzLFxuICB9LCB7XG4gICAgZXh0ZW5kOiBFeHRlbmRlZFN0YWNrU2VsZWN0aW9uLlVwc3RyZWFtLFxuICAgIGRlZmF1bHRCZWhhdmlvcjogRGVmYXVsdFNlbGVjdGlvbi5BbGxTdGFja3MsXG4gIH0pO1xuXG4gIC8vIHdlIG9ubHkgd2FudCB0byBwcmludCBhIHN1YnNldCBvZiBpbmZvcm1hdGlvbiBpbiBgY2RrIGxpc3QgLS1qc29uYFxuICByZXR1cm4gc3RhY2tzLndpdGhEZXBlbmRlbmNpZXMoKS5tYXAoc3RhY2sgPT4gKHtcbiAgICBpZDogc3RhY2suaWQsXG4gICAgbmFtZTogc3RhY2submFtZSxcbiAgICBlbnZpcm9ubWVudDogc3RhY2suZW52aXJvbm1lbnQsXG4gICAgZGVwZW5kZW5jaWVzOiBzdGFjay5kZXBlbmRlbmNpZXMsXG4gIH0pKTtcbn1cbiJdfQ==
@@ -1,6 +1,7 @@
1
1
  import type { Environment } from '@aws-cdk/cx-api';
2
2
  import type { DescribeGeneratedTemplateCommandOutput, DescribeResourceScanCommandOutput, GetGeneratedTemplateCommandOutput, ResourceDefinition, ResourceDetail, ResourceIdentifierSummary, ResourceScanSummary, ScannedResource, ScannedResourceIdentifier } from '@aws-sdk/client-cloudformation';
3
3
  import type { ICloudFormationClient, SdkProvider } from '../api/aws-auth';
4
+ import type { IoHelper } from '../api-private';
4
5
  /**
5
6
  * Generates a CDK app from a yaml or json template.
6
7
  *
@@ -9,7 +10,7 @@ import type { ICloudFormationClient, SdkProvider } from '../api/aws-auth';
9
10
  * @param language - The language to generate the CDK app in
10
11
  * @param outputPath - The path at which to generate the CDK app
11
12
  */
12
- export declare function generateCdkApp(stackName: string, stack: string, language: string, outputPath?: string, compress?: boolean): Promise<void>;
13
+ export declare function generateCdkApp(ioHelper: IoHelper, stackName: string, stack: string, language: string, outputPath?: string, compress?: boolean): Promise<void>;
13
14
  /**
14
15
  * Generates a CDK stack file.
15
16
  * @param template - The template to translate into a CDK stack
@@ -97,13 +98,6 @@ export declare enum FilterType {
97
98
  * @param fromStack - the content of the flag `--from-stack`
98
99
  */
99
100
  export declare function parseSourceOptions(fromPath?: string, fromStack?: boolean, stackName?: string): TemplateSource;
100
- /**
101
- * Takes a scan id and maintains a progress bar to display the progress of a scan to the user.
102
- *
103
- * @param scanId - A string representing the scan id
104
- * @param cloudFormation - The CloudFormation sdk client to use
105
- */
106
- export declare function scanProgressBar(scanId: string, cfn: CfnTemplateGeneratorProvider): Promise<void>;
107
101
  /**
108
102
  * Prints a progress bar to the console. To be used in a while loop to show progress of a long running task.
109
103
  * The progress bar deletes the current line on the console and rewrites it with the progress amount.
@@ -127,13 +121,6 @@ export declare function printDots(message: string, timeoutx4: number): Promise<v
127
121
  * @param message - The message to display
128
122
  */
129
123
  export declare function rewriteLine(message: string): void;
130
- /**
131
- * Prints the time difference between two dates in days, hours, and minutes.
132
- *
133
- * @param time1 - The first date to compare
134
- * @param time2 - The second date to compare
135
- */
136
- export declare function displayTimeDiff(time1: Date, time2: Date): void;
137
124
  /**
138
125
  * Writes a migrate.json file to the output directory.
139
126
  *
@@ -163,7 +150,7 @@ export declare function isThereAWarning(generatedTemplateOutput: GenerateTemplat
163
150
  * @param templateBody - The body of the generated template
164
151
  * @returns A GenerateTemplateOutput object
165
152
  */
166
- export declare function buildGenertedTemplateOutput(generatedTemplateSummary: DescribeGeneratedTemplateCommandOutput, templateBody: string, source: string): GenerateTemplateOutput;
153
+ export declare function buildGeneratedTemplateOutput(generatedTemplateSummary: DescribeGeneratedTemplateCommandOutput, templateBody: string, source: string): GenerateTemplateOutput;
167
154
  /**
168
155
  * Builds a CloudFormation sdk client for making requests with the CFN template generator.
169
156
  *
@@ -184,7 +171,8 @@ export declare function appendWarningsToReadme(filepath: string, resources: Reso
184
171
  */
185
172
  export declare class CfnTemplateGeneratorProvider {
186
173
  private cfn;
187
- constructor(cfn: ICloudFormationClient);
174
+ private ioHelper;
175
+ constructor(cfn: ICloudFormationClient, ioHelper: IoHelper);
188
176
  checkForResourceScan(resourceScanSummaries: ResourceScanSummary[] | undefined, options: GenerateTemplateOptions, clientRequestToken: string): Promise<void>;
189
177
  /**
190
178
  * Retrieves a tokenized list of resources and their associated scan. If a token is present the function
@@ -288,6 +276,7 @@ export interface GenerateTemplateOptions {
288
276
  fromScan?: FromScan;
289
277
  sdkProvider: SdkProvider;
290
278
  environment: Environment;
279
+ ioHelper: IoHelper;
291
280
  }
292
281
  /**
293
282
  * Interface for the output of the generateTemplate function