UNPKG

aws-cdk

Version:

AWS CDK CLI, the command line tool for CDK apps

778 lines 120 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.InitTemplate = void 0; exports.cliInit = cliInit; exports.expandPlaceholders = expandPlaceholders; exports.availableInitTemplates = availableInitTemplates; exports.availableInitLanguages = availableInitLanguages; exports.printAvailableTemplates = printAvailableTemplates; exports.currentlyRecommendedAwsCdkLibFlags = currentlyRecommendedAwsCdkLibFlags; const childProcess = require("child_process"); const path = require("path"); const toolkit_lib_1 = require("@aws-cdk/toolkit-lib"); const chalk = require("chalk"); const fs = require("fs-extra"); const init_hooks_1 = require("./init-hooks"); const root_dir_1 = require("../../cli/root-dir"); const version_1 = require("../../cli/version"); const util_1 = require("../../util"); const language_1 = require("../language"); const package_manager_1 = require("./package-manager"); /* eslint-disable @typescript-eslint/no-var-requires */ // Packages don't have @types module // eslint-disable-next-line @typescript-eslint/no-require-imports const camelCase = require('camelcase'); // eslint-disable-next-line @typescript-eslint/no-require-imports const decamelize = require('decamelize'); const SUPPORTED_LANGUAGE_NAMES = language_1.SUPPORTED_LANGUAGES.map((l) => l.name); /** * Initialize a CDK package in the current directory */ async function cliInit(options) { await ensureValidCliInitOptions(options, options.ioHelper); const ioHelper = options.ioHelper; const canUseNetwork = options.canUseNetwork ?? true; const generateOnly = options.generateOnly ?? false; const workDir = options.workDir ?? process.cwd(); // Show available templates only if no fromPath, type, or language provided if (!options.fromPath && !options.type && !options.language) { await printAvailableTemplates(ioHelper); return; } // Step 1: Load template let template; if (options.fromPath) { template = await loadLocalTemplate(options.fromPath, options.templatePath); } else { template = await loadBuiltinTemplate(ioHelper, options.type, options.language); } // Step 2: Resolve language const language = await resolveLanguage(ioHelper, template, options.language, options.type); // Step 3: Initialize project following standard process await initializeProject(ioHelper, template, language, canUseNetwork, generateOnly, workDir, options.stackName, options.migrate, options.libVersion, options.packageManager); } /** * Validate CLI init options and handle invalid or incompatible option combinations */ async function ensureValidCliInitOptions(options, ioHelper) { if (options.packageManager && !['javascript', 'typescript'].includes(options.language ?? '')) { await ioHelper.defaults.warn(`--package-manager option is only applicable for JavaScript and TypeScript projects. Ignoring the provided value: ${options.packageManager}`); } } /** * Load a local custom template from file system path * @param fromPath - Path to the local template directory or multi-template repository * @param templatePath - Optional path to a specific template within a multi-template repository * @returns Promise resolving to the loaded InitTemplate */ async function loadLocalTemplate(fromPath, templatePath) { try { let actualTemplatePath = fromPath; // If templatePath is provided, it's a multi-template repository if (templatePath) { actualTemplatePath = path.join(fromPath, templatePath); if (!await fs.pathExists(actualTemplatePath)) { throw new toolkit_lib_1.ToolkitError(`Template path does not exist: ${actualTemplatePath}`); } } const template = await InitTemplate.fromPath(actualTemplatePath); if (template.languages.length === 0) { // Check if this might be a multi-template repository if (!templatePath) { const availableTemplates = await findPotentialTemplates(fromPath); if (availableTemplates.length > 0) { throw new toolkit_lib_1.ToolkitError('Use --template-path to specify which template to use.'); } } throw new toolkit_lib_1.ToolkitError('Custom template must contain at least one language directory'); } return template; } catch (error) { const displayPath = templatePath ? `${fromPath}/${templatePath}` : fromPath; throw new toolkit_lib_1.ToolkitError(`Failed to load template from path: ${displayPath}. ${error.message}`); } } /** * Load a built-in template by name */ async function loadBuiltinTemplate(ioHelper, type, language) { const templateType = type || 'default'; // "default" is the default type (and maps to "app") const template = (await availableInitTemplates()).find((t) => t.hasName(templateType)); if (!template) { await printAvailableTemplates(ioHelper, language); throw new toolkit_lib_1.ToolkitError(`Unknown init template: ${templateType}`); } return template; } /** * Resolve the programming language for the template * @param ioHelper - IO helper for user interaction * @param template - The template to resolve language for * @param requestedLanguage - User-requested language (optional) * @param type - The template type name for messages * @default undefined * @returns Promise resolving to the selected language */ async function resolveLanguage(ioHelper, template, requestedLanguage, type) { return (async () => { if (requestedLanguage) { return requestedLanguage; } if (template.languages.length === 1) { const templateLanguage = template.languages[0]; // Only show auto-detection message for built-in templates if (template.templateType !== TemplateType.CUSTOM) { await ioHelper.defaults.warn(`No --language was provided, but '${type || template.name}' supports only '${templateLanguage}', so defaulting to --language=${templateLanguage}`); } return templateLanguage; } await ioHelper.defaults.info(`Available languages for ${chalk.green(type || template.name)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`); throw new toolkit_lib_1.ToolkitError('No language was selected'); })(); } /** * Find potential template directories in a multi-template repository * @param repositoryPath - Path to the repository root * @returns Promise resolving to array of potential template directory names */ async function findPotentialTemplates(repositoryPath) { const entries = await fs.readdir(repositoryPath, { withFileTypes: true }); const templateValidationPromises = entries .filter(entry => entry.isDirectory() && !entry.name.startsWith('.')) .map(async (entry) => { try { const templatePath = path.join(repositoryPath, entry.name); const { languages } = await getLanguageDirectories(templatePath); return languages.length > 0 ? entry.name : null; } catch (error) { // If we can't read a specific template directory, skip it but don't fail the entire operation return null; } }); /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Limited to directory entries const validationResults = await Promise.all(templateValidationPromises); return validationResults.filter((templateName) => templateName !== null); } /** * Get valid CDK language directories from a template path * @param templatePath - Path to the template directory * @returns Promise resolving to array of supported language names */ /** * Get valid CDK language directories from a template path * @param templatePath - Path to the template directory * @returns Promise resolving to array of supported language names and directory entries * @throws ToolkitError if directory cannot be read or validated */ async function getLanguageDirectories(templatePath) { try { const entries = await fs.readdir(templatePath, { withFileTypes: true }); const languageValidationPromises = entries .filter(directoryEntry => directoryEntry.isDirectory() && SUPPORTED_LANGUAGE_NAMES.includes(directoryEntry.name)) .map(async (directoryEntry) => { const languageDirectoryPath = path.join(templatePath, directoryEntry.name); try { const hasValidLanguageFiles = await hasLanguageFiles(languageDirectoryPath, (0, language_1.getLanguageExtensions)(directoryEntry.name)); return hasValidLanguageFiles ? directoryEntry.name : null; } catch (error) { throw new toolkit_lib_1.ToolkitError(`Cannot read language directory '${directoryEntry.name}': ${error.message}`); } }); /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Limited to supported CDK languages (7 max) const validationResults = await Promise.all(languageValidationPromises); return { languages: validationResults.filter((languageName) => languageName !== null), entries, }; } catch (error) { throw new toolkit_lib_1.ToolkitError(`Cannot read template directory '${templatePath}': ${error.message}`); } } /** * Iteratively check if a directory contains files with the specified extensions * @param directoryPath - Path to search for language files * @param extensions - Array of file extensions to look for * @returns Promise resolving to true if language files are found */ async function hasLanguageFiles(directoryPath, extensions) { const dirsToCheck = [directoryPath]; while (dirsToCheck.length > 0) { const currentDir = dirsToCheck.pop(); try { const entries = await fs.readdir(currentDir, { withFileTypes: true }); for (const entry of entries) { if (entry.isFile() && extensions.some(ext => entry.name.endsWith(ext))) { return true; } else if (entry.isDirectory()) { dirsToCheck.push(path.join(currentDir, entry.name)); } } } catch (error) { throw error; } } return false; } /** * Returns the name of the Python executable for this OS * @returns The Python executable name for the current platform */ function pythonExecutable() { let python = 'python3'; if (process.platform === 'win32') { python = 'python'; } return python; } const INFO_DOT_JSON = 'info.json'; var TemplateType; (function (TemplateType) { TemplateType["BUILT_IN"] = "builtin"; TemplateType["CUSTOM"] = "custom"; })(TemplateType || (TemplateType = {})); class InitTemplate { static async fromName(templatesDir, name) { const basePath = path.join(templatesDir, name); const languages = await listDirectory(basePath); const initInfo = await fs.readJson(path.join(basePath, INFO_DOT_JSON)); return new InitTemplate(basePath, name, languages, initInfo, TemplateType.BUILT_IN); } static async fromPath(templatePath) { const basePath = path.resolve(templatePath); if (!await fs.pathExists(basePath)) { throw new toolkit_lib_1.ToolkitError(`Template path does not exist: ${basePath}`); } let templateSourcePath = basePath; let { languages, entries } = await getLanguageDirectories(basePath); if (languages.length === 0) { const languageDirs = entries.filter(entry => entry.isDirectory() && SUPPORTED_LANGUAGE_NAMES.includes(entry.name)); if (languageDirs.length === 1) { // Validate that the language directory contains appropriate files const langDir = languageDirs[0].name; templateSourcePath = path.join(basePath, langDir); const hasValidFiles = await hasLanguageFiles(templateSourcePath, (0, language_1.getLanguageExtensions)(langDir)); if (!hasValidFiles) { // If we found a language directory but it doesn't contain valid files, we should inform the user throw new toolkit_lib_1.ToolkitError(`Found '${langDir}' directory but it doesn't contain the expected language files. Ensure the template contains ${langDir} source files.`); } } } const name = path.basename(basePath); return new InitTemplate(templateSourcePath, name, languages, null, TemplateType.CUSTOM); } constructor(basePath, name, languages, initInfo, templateType) { this.basePath = basePath; this.name = name; this.languages = languages; this.aliases = new Set(); this.templateType = templateType; // Only built-in templates have descriptions and aliases from info.json if (templateType === TemplateType.BUILT_IN && initInfo) { this.description = initInfo.description; for (const alias of initInfo.aliases || []) { this.aliases.add(alias); } } } /** * @param name - the name that is being checked * @returns ``true`` if ``name`` is the name of this template or an alias of it. */ hasName(name) { return name === this.name || this.aliases.has(name); } /** * Creates a new instance of this ``InitTemplate`` for a given language to a specified folder. * * @param language - the language to instantiate this template with * @param targetDirectory - the directory where the template is to be instantiated into * @param stackName - the name of the stack to create * @default undefined * @param libVersion - the version of the CDK library to use * @default undefined */ async install(ioHelper, language, targetDirectory, stackName, libVersion, packageManager) { if (this.languages.indexOf(language) === -1) { await ioHelper.defaults.error(`The ${chalk.blue(language)} language is not supported for ${chalk.green(this.name)} ` + `(it supports: ${this.languages.map((l) => chalk.blue(l)).join(', ')})`); throw new toolkit_lib_1.ToolkitError(`Unsupported language: ${language}`); } const projectInfo = { name: decamelize(path.basename(path.resolve(targetDirectory))), stackName, versions: await loadInitVersions(), }; if (libVersion) { projectInfo.versions['aws-cdk-lib'] = libVersion; } let sourceDirectory = path.join(this.basePath, language); // For auto-detected single language templates, use basePath directly if (this.templateType === TemplateType.CUSTOM && this.languages.length === 1 && path.basename(this.basePath) === language) { sourceDirectory = this.basePath; } if (this.templateType === TemplateType.CUSTOM) { // For custom templates, copy files without processing placeholders await this.installFilesWithoutProcessing(sourceDirectory, targetDirectory); } else { // For built-in templates, process placeholders as usual await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo, packageManager); await this.applyFutureFlags(targetDirectory); await (0, init_hooks_1.invokeBuiltinHooks)(ioHelper, { targetDirectory, language, templateName: this.name }, { substitutePlaceholdersIn: async (...fileNames) => { const fileProcessingPromises = fileNames.map(async (fileName) => { const fullPath = path.join(targetDirectory, fileName); const template = await fs.readFile(fullPath, { encoding: 'utf-8' }); await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo, packageManager)); }); /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Processing a small, known set of template files await Promise.all(fileProcessingPromises); }, placeholder: (ph) => expandPlaceholders(`%${ph}%`, language, projectInfo, packageManager), }); } } async installFiles(sourceDirectory, targetDirectory, language, project, packageManager) { for (const file of await fs.readdir(sourceDirectory)) { const fromFile = path.join(sourceDirectory, file); const toFile = path.join(targetDirectory, expandPlaceholders(file, language, project, packageManager)); if ((await fs.stat(fromFile)).isDirectory()) { await fs.mkdir(toFile); await this.installFiles(fromFile, toFile, language, project, packageManager); continue; } else if (file.match(/^.*\.template\.[^.]+$/)) { await this.installProcessed(fromFile, toFile.replace(/\.template(\.[^.]+)$/, '$1'), language, project, packageManager); continue; } else if (file.match(/^.*\.hook\.(d.)?[^.]+$/)) { // Ignore continue; } else { await fs.copy(fromFile, toFile); } } } async installProcessed(templatePath, toFile, language, project, packageManager) { const template = await fs.readFile(templatePath, { encoding: 'utf-8' }); await fs.writeFile(toFile, expandPlaceholders(template, language, project, packageManager)); } /** * Copy template files without processing placeholders (for custom templates) */ async installFilesWithoutProcessing(sourceDirectory, targetDirectory) { await fs.copy(sourceDirectory, targetDirectory, { filter: (src) => { const filename = path.basename(src); return !filename.match(/^.*\.hook\.(d.)?[^.]+$/); }, }); } /** * Adds context variables to `cdk.json` in the generated project directory to * enable future behavior for new projects. */ async applyFutureFlags(projectDir) { const cdkJson = path.join(projectDir, 'cdk.json'); if (!(await fs.pathExists(cdkJson))) { return; } const config = await fs.readJson(cdkJson); config.context = { ...config.context, ...await currentlyRecommendedAwsCdkLibFlags(), }; await fs.writeJson(cdkJson, config, { spaces: 2 }); } async addMigrateContext(projectDir) { const cdkJson = path.join(projectDir, 'cdk.json'); if (!(await fs.pathExists(cdkJson))) { return; } const config = await fs.readJson(cdkJson); config.context = { ...config.context, 'cdk-migrate': true, }; await fs.writeJson(cdkJson, config, { spaces: 2 }); } } exports.InitTemplate = InitTemplate; function expandPlaceholders(template, language, project, packageManager) { const cdkVersion = project.versions['aws-cdk-lib']; const cdkCliVersion = project.versions['aws-cdk']; let constructsVersion = project.versions.constructs; switch (language) { case 'java': case 'csharp': case 'fsharp': constructsVersion = (0, util_1.rangeFromSemver)(constructsVersion, 'bracket'); break; case 'python': constructsVersion = (0, util_1.rangeFromSemver)(constructsVersion, 'pep'); break; } return template .replace(/%name%/g, project.name) .replace(/%stackname%/, project.stackName ?? '%name.PascalCased%Stack') .replace(/%PascalNameSpace%/, project.stackName ? camelCase(project.stackName + 'Stack', { pascalCase: true }) : '%name.PascalCased%') .replace(/%PascalStackProps%/, project.stackName ? camelCase(project.stackName, { pascalCase: true }) + 'StackProps' : 'StackProps') .replace(/%name\.camelCased%/g, camelCase(project.name)) .replace(/%name\.PascalCased%/g, camelCase(project.name, { pascalCase: true })) .replace(/%cdk-version%/g, cdkVersion) .replace(/%cdk-cli-version%/g, cdkCliVersion) .replace(/%constructs-version%/g, constructsVersion) .replace(/%cdk-home%/g, (0, util_1.cdkHomeDir)()) .replace(/%name\.PythonModule%/g, project.name.replace(/-/g, '_')) .replace(/%python-executable%/g, pythonExecutable()) .replace(/%name\.StackName%/g, project.name.replace(/[^A-Za-z0-9-]/g, '-')) .replace(/%pm-cmd%/g, (0, package_manager_1.getPmCmdPrefix)(packageManager ?? 'npm')); } async function availableInitTemplates() { try { const templatesDir = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates'); const templateNames = await listDirectory(templatesDir); const templatePromises = templateNames.map(templateName => InitTemplate.fromName(templatesDir, templateName)); /* eslint-disable-next-line @cdklabs/promiseall-no-unbounded-parallelism */ // Built-in templates are limited in number return await Promise.all(templatePromises); } catch (error) { // Return empty array if templates directory doesn't exist or can't be read // This allows the CLI to gracefully handle missing built-in templates if (error.code === 'ENOENT' || error.code === 'EACCES') { return []; } throw error; } } async function availableInitLanguages() { const templates = await availableInitTemplates(); const result = new Set(); for (const template of templates) { for (const language of template.languages) { const alias = (0, language_1.getLanguageAlias)(language); result.add(language); alias && result.add(alias); } } return [...result]; } /** * @param dirPath - is the directory to be listed. * @returns the list of file or directory names contained in ``dirPath``, excluding any dot-file, and sorted. */ async function listDirectory(dirPath) { return ((await fs.readdir(dirPath)) .filter((p) => !p.startsWith('.')) .filter((p) => !(p === 'LICENSE')) // if, for some reason, the temp folder for the hook doesn't get deleted we don't want to display it in this list .filter((p) => !(p === INFO_DOT_JSON)) .sort()); } /** * Print available templates to the user * @param ioHelper - IO helper for user interaction * @param language - Programming language filter * @default undefined */ async function printAvailableTemplates(ioHelper, language) { await ioHelper.defaults.info('Available templates:'); for (const template of await availableInitTemplates()) { if (language && template.languages.indexOf(language) === -1) { continue; } await ioHelper.defaults.info(`* ${chalk.green(template.name)}: ${template.description}`); const languageArg = language ? chalk.bold(language) : template.languages.length > 1 ? `[${template.languages.map((t) => chalk.bold(t)).join('|')}]` : chalk.bold(template.languages[0]); await ioHelper.defaults.info(` └─ ${chalk.blue(`cdk init ${chalk.bold(template.name)} --language=${languageArg}`)}`); } } async function initializeProject(ioHelper, template, language, canUseNetwork, generateOnly, workDir, stackName, migrate, cdkVersion, packageManager) { // Step 1: Ensure target directory is empty await assertIsEmptyDirectory(workDir); // Step 2: Copy template files await ioHelper.defaults.info(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`); await template.install(ioHelper, language, workDir, stackName, cdkVersion, packageManager); if (migrate) { await template.addMigrateContext(workDir); } if (await fs.pathExists(`${workDir}/README.md`)) { const readme = await fs.readFile(`${workDir}/README.md`, { encoding: 'utf-8' }); await ioHelper.defaults.info(chalk.green(readme)); } if (!generateOnly) { // Step 3: Initialize Git repository and create initial commit await initializeGitRepository(ioHelper, workDir); // Step 4: Post-install steps await postInstall(ioHelper, language, canUseNetwork, workDir, packageManager); } await ioHelper.defaults.info('✅ All done!'); } /** * Validate that a directory exists and is empty (ignoring hidden files) * @param workDir - Directory path to validate * @throws ToolkitError if directory doesn't exist or is not empty */ async function assertIsEmptyDirectory(workDir) { try { const stats = await fs.stat(workDir); if (!stats.isDirectory()) { throw new toolkit_lib_1.ToolkitError(`Path exists but is not a directory: ${workDir}`); } const files = await fs.readdir(workDir); const visibleFiles = files.filter(f => !f.startsWith('.')); if (visibleFiles.length > 0) { throw new toolkit_lib_1.ToolkitError('`cdk init` cannot be run in a non-empty directory!\n' + `Found ${visibleFiles.length} visible files in ${workDir}:\n` + visibleFiles.map(f => ` - ${f}`).join('\n')); } } catch (e) { if (e.code === 'ENOENT') { throw new toolkit_lib_1.ToolkitError(`Directory does not exist: ${workDir}\n` + 'Please create the directory first using: mkdir -p ' + workDir); } throw new toolkit_lib_1.ToolkitError(`Failed to validate directory ${workDir}: ${e.message}`); } } async function initializeGitRepository(ioHelper, workDir) { if (await isInGitRepository(workDir)) { return; } await ioHelper.defaults.info('Initializing a new git repository...'); try { await execute(ioHelper, 'git', ['init'], { cwd: workDir }); await execute(ioHelper, 'git', ['add', '.'], { cwd: workDir }); await execute(ioHelper, 'git', ['commit', '--message="Initial commit"', '--no-gpg-sign'], { cwd: workDir }); } catch { await ioHelper.defaults.warn('Unable to initialize git repository for your project.'); } } async function postInstall(ioHelper, language, canUseNetwork, workDir, packageManager) { switch (language) { case 'javascript': return postInstallJavascript(ioHelper, canUseNetwork, workDir, packageManager); case 'typescript': return postInstallTypescript(ioHelper, canUseNetwork, workDir, packageManager); case 'java': return postInstallJava(ioHelper, canUseNetwork, workDir); case 'python': return postInstallPython(ioHelper, workDir); case 'go': return postInstallGo(ioHelper, canUseNetwork, workDir); case 'csharp': return postInstallCSharp(ioHelper, canUseNetwork, workDir); case 'fsharp': return postInstallFSharp(ioHelper, canUseNetwork, workDir); } } async function postInstallJavascript(ioHelper, canUseNetwork, cwd, packageManager) { return postInstallTypescript(ioHelper, canUseNetwork, cwd, packageManager); } async function postInstallTypescript(ioHelper, canUseNetwork, cwd, packageManager) { const command = packageManager ?? 'npm'; if (!canUseNetwork) { await ioHelper.defaults.warn(`Please run '${command} install'!`); return; } await ioHelper.defaults.info(`Executing ${chalk.green(`${command} install`)}...`); try { await execute(ioHelper, command, ['install'], { cwd }); } catch (e) { await ioHelper.defaults.warn(`${command} install failed: ` + (0, util_1.formatErrorMessage)(e)); } } async function postInstallJava(ioHelper, canUseNetwork, cwd) { // Check if this is a Gradle or Maven project const hasGradleBuild = await fs.pathExists(path.join(cwd, 'build.gradle')); const hasMavenPom = await fs.pathExists(path.join(cwd, 'pom.xml')); if (hasGradleBuild) { // Gradle project const gradleWarning = "Please run './gradlew build'!"; if (!canUseNetwork) { await ioHelper.defaults.warn(gradleWarning); return; } await ioHelper.defaults.info("Executing './gradlew build'"); try { await execute(ioHelper, './gradlew', ['build'], { cwd }); } catch { await ioHelper.defaults.warn('Unable to build Gradle project'); await ioHelper.defaults.warn(gradleWarning); } } else if (hasMavenPom) { // Maven project const mvnPackageWarning = "Please run 'mvn package'!"; if (!canUseNetwork) { await ioHelper.defaults.warn(mvnPackageWarning); return; } await ioHelper.defaults.info("Executing 'mvn package'"); try { await execute(ioHelper, 'mvn', ['package'], { cwd }); } catch { await ioHelper.defaults.warn('Unable to package compiled code as JAR'); await ioHelper.defaults.warn(mvnPackageWarning); } } else { // No recognized build file await ioHelper.defaults.warn('No build.gradle or pom.xml found. Please set up your build system manually.'); } } async function postInstallPython(ioHelper, cwd) { const python = pythonExecutable(); // Check if requirements.txt exists const hasRequirements = await fs.pathExists(path.join(cwd, 'requirements.txt')); if (hasRequirements) { await ioHelper.defaults.info(`Executing ${chalk.green('Creating virtualenv...')}`); try { await execute(ioHelper, python, ['-m', 'venv', '.venv'], { cwd }); await ioHelper.defaults.info(`Executing ${chalk.green('Installing dependencies...')}`); // Install dependencies in the virtual environment const pipPath = process.platform === 'win32' ? '.venv\\Scripts\\pip' : '.venv/bin/pip'; await execute(ioHelper, pipPath, ['install', '-r', 'requirements.txt'], { cwd }); } catch { await ioHelper.defaults.warn('Unable to create virtualenv or install dependencies automatically'); await ioHelper.defaults.warn(`Please run '${python} -m venv .venv && .venv/bin/pip install -r requirements.txt'!`); } } else { await ioHelper.defaults.warn('No requirements.txt found. Please set up your Python environment manually.'); } } async function postInstallGo(ioHelper, canUseNetwork, cwd) { if (!canUseNetwork) { await ioHelper.defaults.warn('Please run \'go mod tidy\'!'); return; } await ioHelper.defaults.info(`Executing ${chalk.green('go mod tidy')}...`); try { await execute(ioHelper, 'go', ['mod', 'tidy'], { cwd }); } catch (e) { await ioHelper.defaults.warn('\'go mod tidy\' failed: ' + (0, util_1.formatErrorMessage)(e)); } } async function postInstallCSharp(ioHelper, canUseNetwork, cwd) { const dotnetWarning = "Please run 'dotnet restore && dotnet build'!"; if (!canUseNetwork) { await ioHelper.defaults.warn(dotnetWarning); return; } await ioHelper.defaults.info(`Executing ${chalk.green('dotnet restore')}...`); try { await execute(ioHelper, 'dotnet', ['restore'], { cwd }); await ioHelper.defaults.info(`Executing ${chalk.green('dotnet build')}...`); await execute(ioHelper, 'dotnet', ['build'], { cwd }); } catch (e) { await ioHelper.defaults.warn('Unable to restore/build .NET project: ' + (0, util_1.formatErrorMessage)(e)); await ioHelper.defaults.warn(dotnetWarning); } } async function postInstallFSharp(ioHelper, canUseNetwork, cwd) { // F# uses the same build system as C# return postInstallCSharp(ioHelper, canUseNetwork, cwd); } /** * @param dir - a directory to be checked * @returns true if ``dir`` is within a git repository. */ async function isInGitRepository(dir) { while (true) { if (await fs.pathExists(path.join(dir, '.git'))) { return true; } if (isRoot(dir)) { return false; } dir = path.dirname(dir); } } /** * @param dir - a directory to be checked. * @returns true if ``dir`` is the root of a filesystem. */ function isRoot(dir) { return path.dirname(dir) === dir; } /** * Executes `command`. STDERR is emitted in real-time. * * If command exits with non-zero exit code, an exception is thrown and includes * the contents of STDOUT. * * @returns STDOUT (if successful). */ async function execute(ioHelper, cmd, args, { cwd }) { const child = childProcess.spawn(cmd, args, { cwd, shell: true, stdio: ['ignore', 'pipe', 'inherit'], }); let stdout = ''; child.stdout.on('data', (chunk) => (stdout += chunk.toString())); return new Promise((ok, fail) => { child.once('error', (err) => fail(err)); child.once('exit', (status) => { if (status === 0) { return ok(stdout); } else { return fail(new toolkit_lib_1.ToolkitError(`${cmd} exited with status ${status}`)); } }); }).catch(async (err) => { await ioHelper.defaults.error(stdout); throw err; }); } /** * Return the 'aws-cdk-lib' version we will init * * This has been built into the CLI at build time. */ async function loadInitVersions() { const initVersionFile = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates', '.init-version.json'); const contents = JSON.parse(await fs.readFile(initVersionFile, { encoding: 'utf-8' })); const ret = { 'aws-cdk-lib': contents['aws-cdk-lib'], 'constructs': contents.constructs, 'aws-cdk': (0, version_1.versionNumber)(), }; for (const [key, value] of Object.entries(ret)) { if (!value) { throw new toolkit_lib_1.ToolkitError(`Missing init version from ${initVersionFile}: ${key}`); } } return ret; } /** * Return the currently recommended flags for `aws-cdk-lib`. * * These have been built into the CLI at build time. */ async function currentlyRecommendedAwsCdkLibFlags() { const recommendedFlagsFile = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates', '.recommended-feature-flags.json'); return JSON.parse(await fs.readFile(recommendedFlagsFile, { encoding: 'utf-8' })); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"init.js","sourceRoot":"","sources":["init.ts"],"names":[],"mappings":"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