aws-cdk 2.1026.0 → 2.1028.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.
@@ -16,6 +16,7 @@ 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
18
  const util_1 = require("../../util");
19
+ const language_1 = require("../language");
19
20
  /* eslint-disable @typescript-eslint/no-var-requires */ // Packages don't have @types module
20
21
  // eslint-disable-next-line @typescript-eslint/no-require-imports
21
22
  const camelCase = require('camelcase');
@@ -29,32 +30,188 @@ async function cliInit(options) {
29
30
  const canUseNetwork = options.canUseNetwork ?? true;
30
31
  const generateOnly = options.generateOnly ?? false;
31
32
  const workDir = options.workDir ?? process.cwd();
32
- if (!options.type && !options.language) {
33
+ // Show available templates if no type and no language provided (main branch logic)
34
+ if (!options.fromPath && !options.type && !options.language) {
33
35
  await printAvailableTemplates(ioHelper);
34
36
  return;
35
37
  }
36
- const type = options.type || 'default'; // "default" is the default type (and maps to "app")
37
- const template = (await availableInitTemplates()).find((t) => t.hasName(type));
38
+ // Step 1: Load template
39
+ let template;
40
+ if (options.fromPath) {
41
+ template = await loadLocalTemplate(options.fromPath, options.templatePath);
42
+ }
43
+ else {
44
+ template = await loadBuiltinTemplate(ioHelper, options.type, options.language);
45
+ }
46
+ // Step 2: Resolve language
47
+ const language = await resolveLanguage(ioHelper, template, options.language, options.type);
48
+ // Step 3: Initialize project following standard process
49
+ await initializeProject(ioHelper, template, language, canUseNetwork, generateOnly, workDir, options.stackName, options.migrate, options.libVersion);
50
+ }
51
+ /**
52
+ * Load a local custom template from file system path
53
+ * @param fromPath - Path to the local template directory or multi-template repository
54
+ * @param templatePath - Optional path to a specific template within a multi-template repository
55
+ * @returns Promise resolving to the loaded InitTemplate
56
+ */
57
+ async function loadLocalTemplate(fromPath, templatePath) {
58
+ try {
59
+ let actualTemplatePath = fromPath;
60
+ // If templatePath is provided, it's a multi-template repository
61
+ if (templatePath) {
62
+ actualTemplatePath = path.join(fromPath, templatePath);
63
+ if (!await fs.pathExists(actualTemplatePath)) {
64
+ throw new toolkit_lib_1.ToolkitError(`Template path does not exist: ${actualTemplatePath}`);
65
+ }
66
+ }
67
+ const template = await InitTemplate.fromPath(actualTemplatePath);
68
+ if (template.languages.length === 0) {
69
+ // Check if this might be a multi-template repository
70
+ if (!templatePath) {
71
+ const availableTemplates = await findPotentialTemplates(fromPath);
72
+ if (availableTemplates.length > 0) {
73
+ throw new toolkit_lib_1.ToolkitError('Use --template-path to specify which template to use.');
74
+ }
75
+ }
76
+ throw new toolkit_lib_1.ToolkitError('Custom template must contain at least one language directory');
77
+ }
78
+ return template;
79
+ }
80
+ catch (error) {
81
+ const displayPath = templatePath ? `${fromPath}/${templatePath}` : fromPath;
82
+ throw new toolkit_lib_1.ToolkitError(`Failed to load template from path: ${displayPath}. ${error.message}`);
83
+ }
84
+ }
85
+ /**
86
+ * Load a built-in template by name
87
+ */
88
+ async function loadBuiltinTemplate(ioHelper, type, language) {
89
+ const templateType = type || 'default'; // "default" is the default type (and maps to "app")
90
+ const template = (await availableInitTemplates()).find((t) => t.hasName(templateType));
38
91
  if (!template) {
39
- await printAvailableTemplates(ioHelper, options.language);
40
- throw new toolkit_lib_1.ToolkitError(`Unknown init template: ${type}`);
92
+ await printAvailableTemplates(ioHelper, language);
93
+ throw new toolkit_lib_1.ToolkitError(`Unknown init template: ${templateType}`);
41
94
  }
42
- const language = await (async () => {
43
- if (options.language) {
44
- return options.language;
95
+ return template;
96
+ }
97
+ /**
98
+ * Resolve the programming language for the template
99
+ * @param ioHelper - IO helper for user interaction
100
+ * @param template - The template to resolve language for
101
+ * @param requestedLanguage - User-requested language (optional)
102
+ * @param type - The template type name for messages
103
+ * @default undefined
104
+ * @returns Promise resolving to the selected language
105
+ */
106
+ async function resolveLanguage(ioHelper, template, requestedLanguage, type) {
107
+ return (async () => {
108
+ if (requestedLanguage) {
109
+ return requestedLanguage;
45
110
  }
46
111
  if (template.languages.length === 1) {
47
112
  const templateLanguage = template.languages[0];
48
- await ioHelper.defaults.warn(`No --language was provided, but '${type}' supports only '${templateLanguage}', so defaulting to --language=${templateLanguage}`);
113
+ // Only show auto-detection message for built-in templates
114
+ if (template.templateType !== TemplateType.CUSTOM) {
115
+ await ioHelper.defaults.warn(`No --language was provided, but '${type || template.name}' supports only '${templateLanguage}', so defaulting to --language=${templateLanguage}`);
116
+ }
49
117
  return templateLanguage;
50
118
  }
51
- await ioHelper.defaults.info(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);
119
+ await ioHelper.defaults.info(`Available languages for ${chalk.green(type || template.name)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);
52
120
  throw new toolkit_lib_1.ToolkitError('No language was selected');
53
121
  })();
54
- await initializeProject(ioHelper, template, language, canUseNetwork, generateOnly, workDir, options.stackName, options.migrate, options.libVersion);
122
+ }
123
+ /**
124
+ * Find potential template directories in a multi-template repository
125
+ * @param repositoryPath - Path to the repository root
126
+ * @returns Promise resolving to array of potential template directory names
127
+ */
128
+ async function findPotentialTemplates(repositoryPath) {
129
+ try {
130
+ const entries = await fs.readdir(repositoryPath, { withFileTypes: true });
131
+ const potentialTemplates = [];
132
+ for (const entry of entries) {
133
+ if (entry.isDirectory() && !entry.name.startsWith('.')) {
134
+ const templatePath = path.join(repositoryPath, entry.name);
135
+ const languages = await getLanguageDirectories(templatePath);
136
+ if (languages.length > 0) {
137
+ potentialTemplates.push(entry.name);
138
+ }
139
+ }
140
+ }
141
+ return potentialTemplates;
142
+ }
143
+ catch (error) {
144
+ return [];
145
+ }
146
+ }
147
+ /**
148
+ * Get valid CDK language directories from a template path
149
+ * @param templatePath - Path to the template directory
150
+ * @returns Promise resolving to array of supported language names
151
+ */
152
+ async function getLanguageDirectories(templatePath) {
153
+ const cdkSupportedLanguages = ['typescript', 'javascript', 'python', 'java', 'csharp', 'fsharp', 'go'];
154
+ const languageExtensions = {
155
+ typescript: ['.ts', '.js'],
156
+ javascript: ['.js'],
157
+ python: ['.py'],
158
+ java: ['.java'],
159
+ csharp: ['.cs'],
160
+ fsharp: ['.fs'],
161
+ go: ['.go'],
162
+ };
163
+ try {
164
+ const entries = await fs.readdir(templatePath, { withFileTypes: true });
165
+ const languageValidationPromises = entries
166
+ .filter(directoryEntry => directoryEntry.isDirectory() && cdkSupportedLanguages.includes(directoryEntry.name))
167
+ .map(async (directoryEntry) => {
168
+ const languageDirectoryPath = path.join(templatePath, directoryEntry.name);
169
+ try {
170
+ const hasValidLanguageFiles = await hasLanguageFiles(languageDirectoryPath, languageExtensions[directoryEntry.name]);
171
+ return hasValidLanguageFiles ? directoryEntry.name : null;
172
+ }
173
+ catch (error) {
174
+ throw new toolkit_lib_1.ToolkitError(`Cannot read language directory '${directoryEntry.name}': ${error.message}`);
175
+ }
176
+ });
177
+ /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Limited to supported CDK languages (7 max)
178
+ const validationResults = await Promise.all(languageValidationPromises);
179
+ return validationResults.filter((languageName) => languageName !== null);
180
+ }
181
+ catch (error) {
182
+ throw new toolkit_lib_1.ToolkitError(`Cannot read template directory '${templatePath}': ${error.message}`);
183
+ }
184
+ }
185
+ /**
186
+ * Iteratively check if a directory contains files with the specified extensions
187
+ * @param directoryPath - Path to search for language files
188
+ * @param extensions - Array of file extensions to look for
189
+ * @returns Promise resolving to true if language files are found
190
+ */
191
+ async function hasLanguageFiles(directoryPath, extensions) {
192
+ const dirsToCheck = [directoryPath];
193
+ while (dirsToCheck.length > 0) {
194
+ const currentDir = dirsToCheck.pop();
195
+ try {
196
+ const entries = await fs.readdir(currentDir, { withFileTypes: true });
197
+ for (const entry of entries) {
198
+ if (entry.isFile() && extensions.some(ext => entry.name.endsWith(ext))) {
199
+ return true;
200
+ }
201
+ else if (entry.isDirectory()) {
202
+ dirsToCheck.push(path.join(currentDir, entry.name));
203
+ }
204
+ }
205
+ }
206
+ catch (error) {
207
+ throw error;
208
+ }
209
+ }
210
+ return false;
55
211
  }
56
212
  /**
57
213
  * Returns the name of the Python executable for this OS
214
+ * @returns The Python executable name for the current platform
58
215
  */
59
216
  function pythonExecutable() {
60
217
  let python = 'python3';
@@ -64,21 +221,39 @@ function pythonExecutable() {
64
221
  return python;
65
222
  }
66
223
  const INFO_DOT_JSON = 'info.json';
224
+ var TemplateType;
225
+ (function (TemplateType) {
226
+ TemplateType["BUILT_IN"] = "builtin";
227
+ TemplateType["CUSTOM"] = "custom";
228
+ })(TemplateType || (TemplateType = {}));
67
229
  class InitTemplate {
68
230
  static async fromName(templatesDir, name) {
69
231
  const basePath = path.join(templatesDir, name);
70
232
  const languages = await listDirectory(basePath);
71
233
  const initInfo = await fs.readJson(path.join(basePath, INFO_DOT_JSON));
72
- return new InitTemplate(basePath, name, languages, initInfo);
234
+ return new InitTemplate(basePath, name, languages, initInfo, TemplateType.BUILT_IN);
73
235
  }
74
- constructor(basePath, name, languages, initInfo) {
236
+ static async fromPath(templatePath) {
237
+ const basePath = path.resolve(templatePath);
238
+ if (!await fs.pathExists(basePath)) {
239
+ throw new toolkit_lib_1.ToolkitError(`Template path does not exist: ${basePath}`);
240
+ }
241
+ const languages = await getLanguageDirectories(basePath);
242
+ const name = path.basename(basePath);
243
+ return new InitTemplate(basePath, name, languages, null, TemplateType.CUSTOM);
244
+ }
245
+ constructor(basePath, name, languages, initInfo, templateType) {
75
246
  this.basePath = basePath;
76
247
  this.name = name;
77
248
  this.languages = languages;
78
249
  this.aliases = new Set();
79
- this.description = initInfo.description;
80
- for (const alias of initInfo.aliases || []) {
81
- this.aliases.add(alias);
250
+ this.templateType = templateType;
251
+ // Only built-in templates have descriptions and aliases from info.json
252
+ if (templateType === TemplateType.BUILT_IN && initInfo) {
253
+ this.description = initInfo.description;
254
+ for (const alias of initInfo.aliases || []) {
255
+ this.aliases.add(alias);
256
+ }
82
257
  }
83
258
  }
84
259
  /**
@@ -91,8 +266,12 @@ class InitTemplate {
91
266
  /**
92
267
  * Creates a new instance of this ``InitTemplate`` for a given language to a specified folder.
93
268
  *
94
- * @param language - the language to instantiate this template with
269
+ * @param language - the language to instantiate this template with
95
270
  * @param targetDirectory - the directory where the template is to be instantiated into
271
+ * @param stackName - the name of the stack to create
272
+ * @default undefined
273
+ * @param libVersion - the version of the CDK library to use
274
+ * @default undefined
96
275
  */
97
276
  async install(ioHelper, language, targetDirectory, stackName, libVersion) {
98
277
  if (this.languages.indexOf(language) === -1) {
@@ -109,18 +288,27 @@ class InitTemplate {
109
288
  projectInfo.versions['aws-cdk-lib'] = libVersion;
110
289
  }
111
290
  const sourceDirectory = path.join(this.basePath, language);
112
- await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo);
113
- await this.applyFutureFlags(targetDirectory);
114
- await (0, init_hooks_1.invokeBuiltinHooks)(ioHelper, { targetDirectory, language, templateName: this.name }, {
115
- substitutePlaceholdersIn: async (...fileNames) => {
116
- for (const fileName of fileNames) {
117
- const fullPath = path.join(targetDirectory, fileName);
118
- const template = await fs.readFile(fullPath, { encoding: 'utf-8' });
119
- await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo));
120
- }
121
- },
122
- placeholder: (ph) => expandPlaceholders(`%${ph}%`, language, projectInfo),
123
- });
291
+ if (this.templateType === TemplateType.CUSTOM) {
292
+ // For custom templates, copy files without processing placeholders
293
+ await this.installFilesWithoutProcessing(sourceDirectory, targetDirectory);
294
+ }
295
+ else {
296
+ // For built-in templates, process placeholders as usual
297
+ await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo);
298
+ await this.applyFutureFlags(targetDirectory);
299
+ await (0, init_hooks_1.invokeBuiltinHooks)(ioHelper, { targetDirectory, language, templateName: this.name }, {
300
+ substitutePlaceholdersIn: async (...fileNames) => {
301
+ const fileProcessingPromises = fileNames.map(async (fileName) => {
302
+ const fullPath = path.join(targetDirectory, fileName);
303
+ const template = await fs.readFile(fullPath, { encoding: 'utf-8' });
304
+ await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo));
305
+ });
306
+ /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Processing a small, known set of template files
307
+ await Promise.all(fileProcessingPromises);
308
+ },
309
+ placeholder: (ph) => expandPlaceholders(`%${ph}%`, language, projectInfo),
310
+ });
311
+ }
124
312
  }
125
313
  async installFiles(sourceDirectory, targetDirectory, language, project) {
126
314
  for (const file of await fs.readdir(sourceDirectory)) {
@@ -148,6 +336,17 @@ class InitTemplate {
148
336
  const template = await fs.readFile(templatePath, { encoding: 'utf-8' });
149
337
  await fs.writeFile(toFile, expandPlaceholders(template, language, project));
150
338
  }
339
+ /**
340
+ * Copy template files without processing placeholders (for custom templates)
341
+ */
342
+ async installFilesWithoutProcessing(sourceDirectory, targetDirectory) {
343
+ await fs.copy(sourceDirectory, targetDirectory, {
344
+ filter: (src) => {
345
+ const filename = path.basename(src);
346
+ return !filename.match(/^.*\.hook\.(d.)?[^.]+$/);
347
+ },
348
+ });
349
+ }
151
350
  /**
152
351
  * Adds context variables to `cdk.json` in the generated project directory to
153
352
  * enable future behavior for new projects.
@@ -208,32 +407,33 @@ function expandPlaceholders(template, language, project) {
208
407
  .replace(/%name\.StackName%/g, project.name.replace(/[^A-Za-z0-9-]/g, '-'));
209
408
  }
210
409
  async function availableInitTemplates() {
211
- return new Promise(async (resolve) => {
212
- try {
213
- const templatesDir = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates');
214
- const templateNames = await listDirectory(templatesDir);
215
- const templates = new Array();
216
- for (const templateName of templateNames) {
217
- templates.push(await InitTemplate.fromName(templatesDir, templateName));
218
- }
219
- resolve(templates);
220
- }
221
- catch {
222
- resolve([]);
410
+ try {
411
+ const templatesDir = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates');
412
+ const templateNames = await listDirectory(templatesDir);
413
+ const templatePromises = templateNames.map(templateName => InitTemplate.fromName(templatesDir, templateName));
414
+ /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Built-in templates are limited in number
415
+ return await Promise.all(templatePromises);
416
+ }
417
+ catch (error) {
418
+ // Return empty array if templates directory doesn't exist or can't be read
419
+ // This allows the CLI to gracefully handle missing built-in templates
420
+ if (error.code === 'ENOENT' || error.code === 'EACCES') {
421
+ return [];
223
422
  }
224
- });
423
+ throw error;
424
+ }
225
425
  }
226
426
  async function availableInitLanguages() {
227
- return new Promise(async (resolve) => {
228
- const templates = await availableInitTemplates();
229
- const result = new Set();
230
- for (const template of templates) {
231
- for (const language of template.languages) {
232
- result.add(language);
233
- }
427
+ const templates = await availableInitTemplates();
428
+ const result = new Set();
429
+ for (const template of templates) {
430
+ for (const language of template.languages) {
431
+ const alias = (0, language_1.getLanguageAlias)(language);
432
+ result.add(language);
433
+ alias && result.add(alias);
234
434
  }
235
- resolve([...result]);
236
- });
435
+ }
436
+ return [...result];
237
437
  }
238
438
  /**
239
439
  * @param dirPath - is the directory to be listed.
@@ -247,6 +447,12 @@ async function listDirectory(dirPath) {
247
447
  .filter((p) => !(p === INFO_DOT_JSON))
248
448
  .sort());
249
449
  }
450
+ /**
451
+ * Print available templates to the user
452
+ * @param ioHelper - IO helper for user interaction
453
+ * @param language - Programming language filter
454
+ * @default undefined
455
+ */
250
456
  async function printAvailableTemplates(ioHelper, language) {
251
457
  await ioHelper.defaults.info('Available templates:');
252
458
  for (const template of await availableInitTemplates()) {
@@ -263,7 +469,9 @@ async function printAvailableTemplates(ioHelper, language) {
263
469
  }
264
470
  }
265
471
  async function initializeProject(ioHelper, template, language, canUseNetwork, generateOnly, workDir, stackName, migrate, cdkVersion) {
472
+ // Step 1: Ensure target directory is empty
266
473
  await assertIsEmptyDirectory(workDir);
474
+ // Step 2: Copy template files
267
475
  await ioHelper.defaults.info(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`);
268
476
  await template.install(ioHelper, language, workDir, stackName, cdkVersion);
269
477
  if (migrate) {
@@ -274,15 +482,27 @@ async function initializeProject(ioHelper, template, language, canUseNetwork, ge
274
482
  await ioHelper.defaults.info(chalk.green(readme));
275
483
  }
276
484
  if (!generateOnly) {
485
+ // Step 3: Initialize Git repository and create initial commit
277
486
  await initializeGitRepository(ioHelper, workDir);
487
+ // Step 4: Post-install steps
278
488
  await postInstall(ioHelper, language, canUseNetwork, workDir);
279
489
  }
280
490
  await ioHelper.defaults.info('✅ All done!');
281
491
  }
282
492
  async function assertIsEmptyDirectory(workDir) {
283
- const files = await fs.readdir(workDir);
284
- if (files.filter((f) => !f.startsWith('.')).length !== 0) {
285
- throw new toolkit_lib_1.ToolkitError('`cdk init` cannot be run in a non-empty directory!');
493
+ try {
494
+ const files = await fs.readdir(workDir);
495
+ if (files.filter((f) => !f.startsWith('.')).length !== 0) {
496
+ throw new toolkit_lib_1.ToolkitError('`cdk init` cannot be run in a non-empty directory!');
497
+ }
498
+ }
499
+ catch (e) {
500
+ if (e.code === 'ENOENT') {
501
+ throw new toolkit_lib_1.ToolkitError(`Directory does not exist: ${workDir}. Please create the directory first.`);
502
+ }
503
+ else {
504
+ throw e;
505
+ }
286
506
  }
287
507
  }
288
508
  async function initializeGitRepository(ioHelper, workDir) {
@@ -311,6 +531,10 @@ async function postInstall(ioHelper, language, canUseNetwork, workDir) {
311
531
  return postInstallPython(ioHelper, workDir);
312
532
  case 'go':
313
533
  return postInstallGo(ioHelper, canUseNetwork, workDir);
534
+ case 'csharp':
535
+ return postInstallCSharp(ioHelper, canUseNetwork, workDir);
536
+ case 'fsharp':
537
+ return postInstallFSharp(ioHelper, canUseNetwork, workDir);
314
538
  }
315
539
  }
316
540
  async function postInstallJavascript(ioHelper, canUseNetwork, cwd) {
@@ -331,30 +555,66 @@ async function postInstallTypescript(ioHelper, canUseNetwork, cwd) {
331
555
  }
332
556
  }
333
557
  async function postInstallJava(ioHelper, canUseNetwork, cwd) {
334
- const mvnPackageWarning = "Please run 'mvn package'!";
335
- if (!canUseNetwork) {
336
- await ioHelper.defaults.warn(mvnPackageWarning);
337
- return;
558
+ // Check if this is a Gradle or Maven project
559
+ const hasGradleBuild = await fs.pathExists(path.join(cwd, 'build.gradle'));
560
+ const hasMavenPom = await fs.pathExists(path.join(cwd, 'pom.xml'));
561
+ if (hasGradleBuild) {
562
+ // Gradle project
563
+ const gradleWarning = "Please run './gradlew build'!";
564
+ if (!canUseNetwork) {
565
+ await ioHelper.defaults.warn(gradleWarning);
566
+ return;
567
+ }
568
+ await ioHelper.defaults.info("Executing './gradlew build'");
569
+ try {
570
+ await execute(ioHelper, './gradlew', ['build'], { cwd });
571
+ }
572
+ catch {
573
+ await ioHelper.defaults.warn('Unable to build Gradle project');
574
+ await ioHelper.defaults.warn(gradleWarning);
575
+ }
338
576
  }
339
- await ioHelper.defaults.info("Executing 'mvn package'");
340
- try {
341
- await execute(ioHelper, 'mvn', ['package'], { cwd });
577
+ else if (hasMavenPom) {
578
+ // Maven project
579
+ const mvnPackageWarning = "Please run 'mvn package'!";
580
+ if (!canUseNetwork) {
581
+ await ioHelper.defaults.warn(mvnPackageWarning);
582
+ return;
583
+ }
584
+ await ioHelper.defaults.info("Executing 'mvn package'");
585
+ try {
586
+ await execute(ioHelper, 'mvn', ['package'], { cwd });
587
+ }
588
+ catch {
589
+ await ioHelper.defaults.warn('Unable to package compiled code as JAR');
590
+ await ioHelper.defaults.warn(mvnPackageWarning);
591
+ }
342
592
  }
343
- catch {
344
- await ioHelper.defaults.warn('Unable to package compiled code as JAR');
345
- await ioHelper.defaults.warn(mvnPackageWarning);
593
+ else {
594
+ // No recognized build file
595
+ await ioHelper.defaults.warn('No build.gradle or pom.xml found. Please set up your build system manually.');
346
596
  }
347
597
  }
348
598
  async function postInstallPython(ioHelper, cwd) {
349
599
  const python = pythonExecutable();
350
- await ioHelper.defaults.warn(`Please run '${python} -m venv .venv'!`);
351
- await ioHelper.defaults.info(`Executing ${chalk.green('Creating virtualenv...')}`);
352
- try {
353
- await execute(ioHelper, python, ['-m venv', '.venv'], { cwd });
600
+ // Check if requirements.txt exists
601
+ const hasRequirements = await fs.pathExists(path.join(cwd, 'requirements.txt'));
602
+ if (hasRequirements) {
603
+ await ioHelper.defaults.info(`Executing ${chalk.green('Creating virtualenv...')}`);
604
+ try {
605
+ await execute(ioHelper, python, ['-m', 'venv', '.venv'], { cwd });
606
+ await ioHelper.defaults.info(`Executing ${chalk.green('Installing dependencies...')}`);
607
+ // Install dependencies in the virtual environment
608
+ const pipPath = process.platform === 'win32' ? '.venv\\Scripts\\pip' : '.venv/bin/pip';
609
+ await execute(ioHelper, pipPath, ['install', '-r', 'requirements.txt'], { cwd });
610
+ }
611
+ catch {
612
+ await ioHelper.defaults.warn('Unable to create virtualenv or install dependencies automatically');
613
+ await ioHelper.defaults.warn(`Please run '${python} -m venv .venv && .venv/bin/pip install -r requirements.txt'!`);
614
+ }
354
615
  }
355
- catch {
356
- await ioHelper.defaults.warn('Unable to create virtualenv automatically');
357
- await ioHelper.defaults.warn(`Please run '${python} -m venv .venv'!`);
616
+ else {
617
+ await ioHelper.defaults.warn('No requirements.txt found. Please set up your Python environment manually.');
358
618
  }
359
619
  }
360
620
  async function postInstallGo(ioHelper, canUseNetwork, cwd) {
@@ -370,6 +630,27 @@ async function postInstallGo(ioHelper, canUseNetwork, cwd) {
370
630
  await ioHelper.defaults.warn('\'go mod tidy\' failed: ' + (0, util_1.formatErrorMessage)(e));
371
631
  }
372
632
  }
633
+ async function postInstallCSharp(ioHelper, canUseNetwork, cwd) {
634
+ const dotnetWarning = "Please run 'dotnet restore && dotnet build'!";
635
+ if (!canUseNetwork) {
636
+ await ioHelper.defaults.warn(dotnetWarning);
637
+ return;
638
+ }
639
+ await ioHelper.defaults.info(`Executing ${chalk.green('dotnet restore')}...`);
640
+ try {
641
+ await execute(ioHelper, 'dotnet', ['restore'], { cwd });
642
+ await ioHelper.defaults.info(`Executing ${chalk.green('dotnet build')}...`);
643
+ await execute(ioHelper, 'dotnet', ['build'], { cwd });
644
+ }
645
+ catch (e) {
646
+ await ioHelper.defaults.warn('Unable to restore/build .NET project: ' + (0, util_1.formatErrorMessage)(e));
647
+ await ioHelper.defaults.warn(dotnetWarning);
648
+ }
649
+ }
650
+ async function postInstallFSharp(ioHelper, canUseNetwork, cwd) {
651
+ // F# uses the same build system as C#
652
+ return postInstallCSharp(ioHelper, canUseNetwork, cwd);
653
+ }
373
654
  /**
374
655
  * @param dir - a directory to be checked
375
656
  * @returns true if ``dir`` is within a git repository.
@@ -437,11 +718,9 @@ async function loadInitVersions() {
437
718
  'aws-cdk': (0, version_1.versionNumber)(),
438
719
  };
439
720
  for (const [key, value] of Object.entries(ret)) {
440
- /* c8 ignore start */
441
721
  if (!value) {
442
722
  throw new toolkit_lib_1.ToolkitError(`Missing init version from ${initVersionFile}: ${key}`);
443
723
  }
444
- /* c8 ignore stop */
445
724
  }
446
725
  return ret;
447
726
  }
@@ -454,4 +733,4 @@ async function currentlyRecommendedAwsCdkLibFlags() {
454
733
  const recommendedFlagsFile = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates', '.recommended-feature-flags.json');
455
734
  return JSON.parse(await fs.readFile(recommendedFlagsFile, { encoding: 'utf-8' }));
456
735
  }
457
- //# 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\n  const language = await (async () => {\n    if (options.language) {\n      return options.language;\n    }\n    if (template.languages.length === 1) {\n      const templateLanguage = template.languages[0];\n      await ioHelper.defaults.warn(\n        `No --language was provided, but '${type}' supports only '${templateLanguage}', so defaulting to --language=${templateLanguage}`,\n      );\n      return templateLanguage;\n    }\n    await ioHelper.defaults.info(\n      `Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`,\n    );\n    throw new ToolkitError('No language was selected');\n  })();\n\n  await initializeProject(\n    ioHelper,\n    template,\n    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    case 'go':\n      return postInstallGo(ioHelper, canUseNetwork, 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\nasync function postInstallGo(ioHelper: IoHelper, canUseNetwork: boolean, cwd: string) {\n  if (!canUseNetwork) {\n    await ioHelper.defaults.warn('Please run \\'go mod tidy\\'!');\n    return;\n  }\n\n  await ioHelper.defaults.info(`Executing ${chalk.green('go mod tidy')}...`);\n  try {\n    await execute(ioHelper, 'go', ['mod', 'tidy'], { cwd });\n  } catch (e: any) {\n    await ioHelper.defaults.warn('\\'go mod tidy\\' failed: ' + formatErrorMessage(e));\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"]}
736
+ //# 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';\nimport { getLanguageAlias } from '../language';\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  /**\n   * Template name to initialize\n   * @default undefined\n   */\n  readonly type?: string;\n\n  /**\n   * Programming language for the project\n   * @default - Optional/auto-detected if template supports only one language, otherwise required\n   */\n  readonly language?: string;\n\n  /**\n   * @default true\n   */\n  readonly canUseNetwork?: boolean;\n\n  /**\n   * @default false\n   */\n  readonly generateOnly?: boolean;\n\n  /**\n   * @default process.cwd()\n   */\n  readonly workDir?: string;\n\n  /**\n   * @default undefined\n   */\n  readonly stackName?: string;\n\n  /**\n   * @default undefined\n   */\n  readonly migrate?: boolean;\n\n  /**\n   * Override the built-in CDK version\n   * @default undefined\n   */\n  readonly libVersion?: string;\n\n  /**\n   * Path to a local custom template directory\n   * @default undefined\n   */\n  readonly fromPath?: string;\n\n  /**\n   * Path to a specific template within a multi-template repository.\n   * This parameter requires --from-path to be specified.\n   * @default undefined\n   */\n  readonly templatePath?: 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\n  // Show available templates if no type and no language provided (main branch logic)\n  if (!options.fromPath && !options.type && !options.language) {\n    await printAvailableTemplates(ioHelper);\n    return;\n  }\n\n  // Step 1: Load template\n  let template: InitTemplate;\n  if (options.fromPath) {\n    template = await loadLocalTemplate(options.fromPath, options.templatePath);\n  } else {\n    template = await loadBuiltinTemplate(ioHelper, options.type, options.language);\n  }\n\n  // Step 2: Resolve language\n  const language = await resolveLanguage(ioHelper, template, options.language, options.type);\n\n  // Step 3: Initialize project following standard process\n  await initializeProject(\n    ioHelper,\n    template,\n    language,\n    canUseNetwork,\n    generateOnly,\n    workDir,\n    options.stackName,\n    options.migrate,\n    options.libVersion,\n  );\n}\n\n/**\n * Load a local custom template from file system path\n * @param fromPath - Path to the local template directory or multi-template repository\n * @param templatePath - Optional path to a specific template within a multi-template repository\n * @returns Promise resolving to the loaded InitTemplate\n */\nasync function loadLocalTemplate(fromPath: string, templatePath?: string): Promise<InitTemplate> {\n  try {\n    let actualTemplatePath = fromPath;\n\n    // If templatePath is provided, it's a multi-template repository\n    if (templatePath) {\n      actualTemplatePath = path.join(fromPath, templatePath);\n\n      if (!await fs.pathExists(actualTemplatePath)) {\n        throw new ToolkitError(`Template path does not exist: ${actualTemplatePath}`);\n      }\n    }\n\n    const template = await InitTemplate.fromPath(actualTemplatePath);\n\n    if (template.languages.length === 0) {\n      // Check if this might be a multi-template repository\n      if (!templatePath) {\n        const availableTemplates = await findPotentialTemplates(fromPath);\n        if (availableTemplates.length > 0) {\n          throw new ToolkitError(\n            'Use --template-path to specify which template to use.',\n          );\n        }\n      }\n      throw new ToolkitError('Custom template must contain at least one language directory');\n    }\n\n    return template;\n  } catch (error: any) {\n    const displayPath = templatePath ? `${fromPath}/${templatePath}` : fromPath;\n    throw new ToolkitError(`Failed to load template from path: ${displayPath}. ${error.message}`);\n  }\n}\n\n/**\n * Load a built-in template by name\n */\nasync function loadBuiltinTemplate(ioHelper: IoHelper, type?: string, language?: string): Promise<InitTemplate> {\n  const templateType = type || 'default'; // \"default\" is the default type (and maps to \"app\")\n\n  const template = (await availableInitTemplates()).find((t) => t.hasName(templateType));\n  if (!template) {\n    await printAvailableTemplates(ioHelper, language);\n    throw new ToolkitError(`Unknown init template: ${templateType}`);\n  }\n\n  return template;\n}\n\n/**\n * Resolve the programming language for the template\n * @param ioHelper - IO helper for user interaction\n * @param template - The template to resolve language for\n * @param requestedLanguage - User-requested language (optional)\n * @param type - The template type name for messages\n * @default undefined\n * @returns Promise resolving to the selected language\n */\nasync function resolveLanguage(ioHelper: IoHelper, template: InitTemplate, requestedLanguage?: string, type?: string): Promise<string> {\n  return (async () => {\n    if (requestedLanguage) {\n      return requestedLanguage;\n    }\n    if (template.languages.length === 1) {\n      const templateLanguage = template.languages[0];\n      // Only show auto-detection message for built-in templates\n      if (template.templateType !== TemplateType.CUSTOM) {\n        await ioHelper.defaults.warn(\n          `No --language was provided, but '${type || template.name}' supports only '${templateLanguage}', so defaulting to --language=${templateLanguage}`,\n        );\n      }\n      return templateLanguage;\n    }\n    await ioHelper.defaults.info(\n      `Available languages for ${chalk.green(type || template.name)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`,\n    );\n    throw new ToolkitError('No language was selected');\n  })();\n}\n\n/**\n * Find potential template directories in a multi-template repository\n * @param repositoryPath - Path to the repository root\n * @returns Promise resolving to array of potential template directory names\n */\nasync function findPotentialTemplates(repositoryPath: string): Promise<string[]> {\n  try {\n    const entries = await fs.readdir(repositoryPath, { withFileTypes: true });\n    const potentialTemplates: string[] = [];\n\n    for (const entry of entries) {\n      if (entry.isDirectory() && !entry.name.startsWith('.')) {\n        const templatePath = path.join(repositoryPath, entry.name);\n        const languages = await getLanguageDirectories(templatePath);\n        if (languages.length > 0) {\n          potentialTemplates.push(entry.name);\n        }\n      }\n    }\n\n    return potentialTemplates;\n  } catch (error: any) {\n    return [];\n  }\n}\n\n/**\n * Get valid CDK language directories from a template path\n * @param templatePath - Path to the template directory\n * @returns Promise resolving to array of supported language names\n */\nasync function getLanguageDirectories(templatePath: string): Promise<string[]> {\n  const cdkSupportedLanguages = ['typescript', 'javascript', 'python', 'java', 'csharp', 'fsharp', 'go'];\n  const languageExtensions: Record<string, string[]> = {\n    typescript: ['.ts', '.js'],\n    javascript: ['.js'],\n    python: ['.py'],\n    java: ['.java'],\n    csharp: ['.cs'],\n    fsharp: ['.fs'],\n    go: ['.go'],\n  };\n\n  try {\n    const entries = await fs.readdir(templatePath, { withFileTypes: true });\n\n    const languageValidationPromises = entries\n      .filter(directoryEntry => directoryEntry.isDirectory() && cdkSupportedLanguages.includes(directoryEntry.name))\n      .map(async (directoryEntry) => {\n        const languageDirectoryPath = path.join(templatePath, directoryEntry.name);\n        try {\n          const hasValidLanguageFiles = await hasLanguageFiles(languageDirectoryPath, languageExtensions[directoryEntry.name]);\n          return hasValidLanguageFiles ? directoryEntry.name : null;\n        } catch (error: any) {\n          throw new ToolkitError(`Cannot read language directory '${directoryEntry.name}': ${error.message}`);\n        }\n      });\n\n    /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Limited to supported CDK languages (7 max)\n    const validationResults = await Promise.all(languageValidationPromises);\n    return validationResults.filter((languageName): languageName is string => languageName !== null);\n  } catch (error: any) {\n    throw new ToolkitError(`Cannot read template directory '${templatePath}': ${error.message}`);\n  }\n}\n\n/**\n * Iteratively check if a directory contains files with the specified extensions\n * @param directoryPath - Path to search for language files\n * @param extensions - Array of file extensions to look for\n * @returns Promise resolving to true if language files are found\n */\nasync function hasLanguageFiles(directoryPath: string, extensions: string[]): Promise<boolean> {\n  const dirsToCheck = [directoryPath];\n\n  while (dirsToCheck.length > 0) {\n    const currentDir = dirsToCheck.pop()!;\n\n    try {\n      const entries = await fs.readdir(currentDir, { withFileTypes: true });\n\n      for (const entry of entries) {\n        if (entry.isFile() && extensions.some(ext => entry.name.endsWith(ext))) {\n          return true;\n        } else if (entry.isDirectory()) {\n          dirsToCheck.push(path.join(currentDir, entry.name));\n        }\n      }\n    } catch (error: any) {\n      throw error;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Returns the name of the Python executable for this OS\n * @returns The Python executable name for the current platform\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\ninterface TemplateInitInfo {\n  readonly description: string;\n  readonly aliases?: string[];\n}\n\nenum TemplateType {\n  BUILT_IN = 'builtin',\n  CUSTOM = 'custom',\n}\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, TemplateType.BUILT_IN);\n  }\n\n  public static async fromPath(templatePath: string) {\n    const basePath = path.resolve(templatePath);\n\n    if (!await fs.pathExists(basePath)) {\n      throw new ToolkitError(`Template path does not exist: ${basePath}`);\n    }\n\n    const languages = await getLanguageDirectories(basePath);\n    const name = path.basename(basePath);\n\n    return new InitTemplate(basePath, name, languages, null, TemplateType.CUSTOM);\n  }\n\n  public readonly description?: string;\n  public readonly aliases = new Set<string>();\n  public readonly templateType: TemplateType;\n\n  constructor(\n    private readonly basePath: string,\n    public readonly name: string,\n    public readonly languages: string[],\n    initInfo: TemplateInitInfo | null,\n    templateType: TemplateType,\n  ) {\n    this.templateType = templateType;\n    // Only built-in templates have descriptions and aliases from info.json\n    if (templateType === TemplateType.BUILT_IN && initInfo) {\n      this.description = initInfo.description;\n      for (const alias of initInfo.aliases || []) {\n        this.aliases.add(alias);\n      }\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   * @param stackName - the name of the stack to create\n   * @default undefined\n   * @param libVersion - the version of the CDK library to use\n   * @default undefined\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    if (this.templateType === TemplateType.CUSTOM) {\n      // For custom templates, copy files without processing placeholders\n      await this.installFilesWithoutProcessing(sourceDirectory, targetDirectory);\n    } else {\n      // For built-in templates, process placeholders as usual\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            const fileProcessingPromises = fileNames.map(async (fileName) => {\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            /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Processing a small, known set of template files\n            await Promise.all(fileProcessingPromises);\n          },\n          placeholder: (ph: string) => expandPlaceholders(`%${ph}%`, language, projectInfo),\n        },\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   * Copy template files without processing placeholders (for custom templates)\n   */\n  private async installFilesWithoutProcessing(sourceDirectory: string, targetDirectory: string) {\n    await fs.copy(sourceDirectory, targetDirectory, {\n      filter: (src: string) => {\n        const filename = path.basename(src);\n        return !filename.match(/^.*\\.hook\\.(d.)?[^.]+$/);\n      },\n    });\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  try {\n    const templatesDir = path.join(cliRootDir(), 'lib', 'init-templates');\n    const templateNames = await listDirectory(templatesDir);\n    const templatePromises = templateNames.map(templateName =>\n      InitTemplate.fromName(templatesDir, templateName),\n    );\n    /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Built-in templates are limited in number\n    return await Promise.all(templatePromises);\n  } catch (error: any) {\n    // Return empty array if templates directory doesn't exist or can't be read\n    // This allows the CLI to gracefully handle missing built-in templates\n    if (error.code === 'ENOENT' || error.code === 'EACCES') {\n      return [];\n    }\n    throw error;\n  }\n}\n\nexport async function availableInitLanguages(): Promise<string[]> {\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      const alias = getLanguageAlias(language);\n      result.add(language);\n      alias && result.add(alias);\n    }\n  }\n  return [...result];\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\n/**\n * Print available templates to the user\n * @param ioHelper - IO helper for user interaction\n * @param language - Programming language filter\n * @default undefined\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  // Step 1: Ensure target directory is empty\n  await assertIsEmptyDirectory(workDir);\n\n  // Step 2: Copy template files\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\n  if (migrate) {\n    await template.addMigrateContext(workDir);\n  }\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    // Step 3: Initialize Git repository and create initial commit\n    await initializeGitRepository(ioHelper, workDir);\n\n    // Step 4: Post-install steps\n    await postInstall(ioHelper, language, canUseNetwork, workDir);\n  }\n\n  await ioHelper.defaults.info('✅ All done!');\n}\n\nasync function assertIsEmptyDirectory(workDir: string) {\n  try {\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  } catch (e: any) {\n    if (e.code === 'ENOENT') {\n      throw new ToolkitError(`Directory does not exist: ${workDir}. Please create the directory first.`);\n    } else {\n      throw e;\n    }\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    case 'go':\n      return postInstallGo(ioHelper, canUseNetwork, workDir);\n    case 'csharp':\n      return postInstallCSharp(ioHelper, canUseNetwork, workDir);\n    case 'fsharp':\n      return postInstallFSharp(ioHelper, canUseNetwork, 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  // Check if this is a Gradle or Maven project\n  const hasGradleBuild = await fs.pathExists(path.join(cwd, 'build.gradle'));\n  const hasMavenPom = await fs.pathExists(path.join(cwd, 'pom.xml'));\n\n  if (hasGradleBuild) {\n    // Gradle project\n    const gradleWarning = \"Please run './gradlew build'!\";\n    if (!canUseNetwork) {\n      await ioHelper.defaults.warn(gradleWarning);\n      return;\n    }\n\n    await ioHelper.defaults.info(\"Executing './gradlew build'\");\n    try {\n      await execute(ioHelper, './gradlew', ['build'], { cwd });\n    } catch {\n      await ioHelper.defaults.warn('Unable to build Gradle project');\n      await ioHelper.defaults.warn(gradleWarning);\n    }\n  } else if (hasMavenPom) {\n    // Maven project\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  } else {\n    // No recognized build file\n    await ioHelper.defaults.warn('No build.gradle or pom.xml found. Please set up your build system manually.');\n  }\n}\n\nasync function postInstallPython(ioHelper: IoHelper, cwd: string) {\n  const python = pythonExecutable();\n\n  // Check if requirements.txt exists\n  const hasRequirements = await fs.pathExists(path.join(cwd, 'requirements.txt'));\n\n  if (hasRequirements) {\n    await ioHelper.defaults.info(`Executing ${chalk.green('Creating virtualenv...')}`);\n    try {\n      await execute(ioHelper, python, ['-m', 'venv', '.venv'], { cwd });\n      await ioHelper.defaults.info(`Executing ${chalk.green('Installing dependencies...')}`);\n      // Install dependencies in the virtual environment\n      const pipPath = process.platform === 'win32' ? '.venv\\\\Scripts\\\\pip' : '.venv/bin/pip';\n      await execute(ioHelper, pipPath, ['install', '-r', 'requirements.txt'], { cwd });\n    } catch {\n      await ioHelper.defaults.warn('Unable to create virtualenv or install dependencies automatically');\n      await ioHelper.defaults.warn(`Please run '${python} -m venv .venv && .venv/bin/pip install -r requirements.txt'!`);\n    }\n  } else {\n    await ioHelper.defaults.warn('No requirements.txt found. Please set up your Python environment manually.');\n  }\n}\n\nasync function postInstallGo(ioHelper: IoHelper, canUseNetwork: boolean, cwd: string) {\n  if (!canUseNetwork) {\n    await ioHelper.defaults.warn('Please run \\'go mod tidy\\'!');\n    return;\n  }\n\n  await ioHelper.defaults.info(`Executing ${chalk.green('go mod tidy')}...`);\n  try {\n    await execute(ioHelper, 'go', ['mod', 'tidy'], { cwd });\n  } catch (e: any) {\n    await ioHelper.defaults.warn('\\'go mod tidy\\' failed: ' + formatErrorMessage(e));\n  }\n}\n\nasync function postInstallCSharp(ioHelper: IoHelper, canUseNetwork: boolean, cwd: string) {\n  const dotnetWarning = \"Please run 'dotnet restore && dotnet build'!\";\n  if (!canUseNetwork) {\n    await ioHelper.defaults.warn(dotnetWarning);\n    return;\n  }\n\n  await ioHelper.defaults.info(`Executing ${chalk.green('dotnet restore')}...`);\n  try {\n    await execute(ioHelper, 'dotnet', ['restore'], { cwd });\n    await ioHelper.defaults.info(`Executing ${chalk.green('dotnet build')}...`);\n    await execute(ioHelper, 'dotnet', ['build'], { cwd });\n  } catch (e: any) {\n    await ioHelper.defaults.warn('Unable to restore/build .NET project: ' + formatErrorMessage(e));\n    await ioHelper.defaults.warn(dotnetWarning);\n  }\n}\n\nasync function postInstallFSharp(ioHelper: IoHelper, canUseNetwork: boolean, cwd: string) {\n  // F# uses the same build system as C#\n  return postInstallCSharp(ioHelper, canUseNetwork, cwd);\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    if (!value) {\n      throw new ToolkitError(`Missing init version from ${initVersionFile}: ${key}`);\n    }\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"]}