UNPKG

aws-cdk

Version:

AWS CDK CLI, the command line tool for CDK apps

436 lines 62.1 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 chalk = require("chalk"); const fs = require("fs-extra"); const init_hooks_1 = require("./init-hooks"); const api_1 = require("../../../../@aws-cdk/tmp-toolkit-helpers/src/api"); const root_dir_1 = require("../../cli/root-dir"); const version_1 = require("../../cli/version"); const logging_1 = require("../../logging"); const util_1 = require("../../util"); /* 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'); /** * Initialize a CDK package in the current directory */ async function cliInit(options) { const canUseNetwork = options.canUseNetwork ?? true; const generateOnly = options.generateOnly ?? false; const workDir = options.workDir ?? process.cwd(); if (!options.type && !options.language) { await printAvailableTemplates(); return; } const type = options.type || 'default'; // "default" is the default type (and maps to "app") const template = (await availableInitTemplates()).find((t) => t.hasName(type)); if (!template) { await printAvailableTemplates(options.language); throw new api_1.ToolkitError(`Unknown init template: ${type}`); } if (!options.language && template.languages.length === 1) { const language = template.languages[0]; (0, logging_1.warning)(`No --language was provided, but '${type}' supports only '${language}', so defaulting to --language=${language}`); } if (!options.language) { (0, logging_1.info)(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`); throw new api_1.ToolkitError('No language was selected'); } await initializeProject(template, options.language, canUseNetwork, generateOnly, workDir, options.stackName, options.migrate, options.libVersion); } /** * Returns the name of the Python executable for this OS */ function pythonExecutable() { let python = 'python3'; if (process.platform === 'win32') { python = 'python'; } return python; } const INFO_DOT_JSON = 'info.json'; 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); } constructor(basePath, name, languages, initInfo) { this.basePath = basePath; this.name = name; this.languages = languages; this.aliases = new Set(); 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 */ async install(language, targetDirectory, stackName, libVersion) { if (this.languages.indexOf(language) === -1) { (0, logging_1.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 api_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; } const sourceDirectory = path.join(this.basePath, language); await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo); await this.applyFutureFlags(targetDirectory); await (0, init_hooks_1.invokeBuiltinHooks)({ targetDirectory, language, templateName: this.name }, { substitutePlaceholdersIn: async (...fileNames) => { for (const fileName of fileNames) { const fullPath = path.join(targetDirectory, fileName); const template = await fs.readFile(fullPath, { encoding: 'utf-8' }); await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo)); } }, placeholder: (ph) => expandPlaceholders(`%${ph}%`, language, projectInfo), }); } async installFiles(sourceDirectory, targetDirectory, language, project) { for (const file of await fs.readdir(sourceDirectory)) { const fromFile = path.join(sourceDirectory, file); const toFile = path.join(targetDirectory, expandPlaceholders(file, language, project)); if ((await fs.stat(fromFile)).isDirectory()) { await fs.mkdir(toFile); await this.installFiles(fromFile, toFile, language, project); continue; } else if (file.match(/^.*\.template\.[^.]+$/)) { await this.installProcessed(fromFile, toFile.replace(/\.template(\.[^.]+)$/, '$1'), language, project); continue; } else if (file.match(/^.*\.hook\.(d.)?[^.]+$/)) { // Ignore continue; } else { await fs.copy(fromFile, toFile); } } } async installProcessed(templatePath, toFile, language, project) { const template = await fs.readFile(templatePath, { encoding: 'utf-8' }); await fs.writeFile(toFile, expandPlaceholders(template, language, project)); } /** * 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) { 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, '-')); } async function availableInitTemplates() { return new Promise(async (resolve) => { try { const templatesDir = path.join((0, root_dir_1.cliRootDir)(), 'lib', 'init-templates'); const templateNames = await listDirectory(templatesDir); const templates = new Array(); for (const templateName of templateNames) { templates.push(await InitTemplate.fromName(templatesDir, templateName)); } resolve(templates); } catch { resolve([]); } }); } async function availableInitLanguages() { return new Promise(async (resolve) => { const templates = await availableInitTemplates(); const result = new Set(); for (const template of templates) { for (const language of template.languages) { result.add(language); } } resolve([...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()); } async function printAvailableTemplates(language) { (0, logging_1.info)('Available templates:'); for (const template of await availableInitTemplates()) { if (language && template.languages.indexOf(language) === -1) { continue; } (0, logging_1.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]); (0, logging_1.info)(` └─ ${chalk.blue(`cdk init ${chalk.bold(template.name)} --language=${languageArg}`)}`); } } async function initializeProject(template, language, canUseNetwork, generateOnly, workDir, stackName, migrate, cdkVersion) { await assertIsEmptyDirectory(workDir); (0, logging_1.info)(`Applying project template ${chalk.green(template.name)} for ${chalk.blue(language)}`); await template.install(language, workDir, stackName, cdkVersion); if (migrate) { await template.addMigrateContext(workDir); } if (await fs.pathExists(`${workDir}/README.md`)) { const readme = await fs.readFile(`${workDir}/README.md`, { encoding: 'utf-8' }); (0, logging_1.info)(chalk.green(readme)); } if (!generateOnly) { await initializeGitRepository(workDir); await postInstall(language, canUseNetwork, workDir); } (0, logging_1.info)('✅ All done!'); } async function assertIsEmptyDirectory(workDir) { const files = await fs.readdir(workDir); if (files.filter((f) => !f.startsWith('.')).length !== 0) { throw new api_1.ToolkitError('`cdk init` cannot be run in a non-empty directory!'); } } async function initializeGitRepository(workDir) { if (await isInGitRepository(workDir)) { return; } (0, logging_1.info)('Initializing a new git repository...'); try { await execute('git', ['init'], { cwd: workDir }); await execute('git', ['add', '.'], { cwd: workDir }); await execute('git', ['commit', '--message="Initial commit"', '--no-gpg-sign'], { cwd: workDir }); } catch { (0, logging_1.warning)('Unable to initialize git repository for your project.'); } } async function postInstall(language, canUseNetwork, workDir) { switch (language) { case 'javascript': return postInstallJavascript(canUseNetwork, workDir); case 'typescript': return postInstallTypescript(canUseNetwork, workDir); case 'java': return postInstallJava(canUseNetwork, workDir); case 'python': return postInstallPython(workDir); } } async function postInstallJavascript(canUseNetwork, cwd) { return postInstallTypescript(canUseNetwork, cwd); } async function postInstallTypescript(canUseNetwork, cwd) { const command = 'npm'; if (!canUseNetwork) { (0, logging_1.warning)(`Please run '${command} install'!`); return; } (0, logging_1.info)(`Executing ${chalk.green(`${command} install`)}...`); try { await execute(command, ['install'], { cwd }); } catch (e) { (0, logging_1.warning)(`${command} install failed: ` + (0, util_1.formatErrorMessage)(e)); } } async function postInstallJava(canUseNetwork, cwd) { const mvnPackageWarning = "Please run 'mvn package'!"; if (!canUseNetwork) { (0, logging_1.warning)(mvnPackageWarning); return; } (0, logging_1.info)("Executing 'mvn package'"); try { await execute('mvn', ['package'], { cwd }); } catch { (0, logging_1.warning)('Unable to package compiled code as JAR'); (0, logging_1.warning)(mvnPackageWarning); } } async function postInstallPython(cwd) { const python = pythonExecutable(); (0, logging_1.warning)(`Please run '${python} -m venv .venv'!`); (0, logging_1.info)(`Executing ${chalk.green('Creating virtualenv...')}`); try { await execute(python, ['-m venv', '.venv'], { cwd }); } catch { (0, logging_1.warning)('Unable to create virtualenv automatically'); (0, logging_1.warning)(`Please run '${python} -m venv .venv'!`); } } /** * @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 exceprion is thrown and includes * the contents of STDOUT. * * @returns STDOUT (if successful). */ async function execute(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 { (0, logging_1.error)(stdout); return fail(new api_1.ToolkitError(`${cmd} exited with status ${status}`)); } }); }); } /** * 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)) { /* c8 ignore start */ if (!value) { throw new api_1.ToolkitError(`Missing init version from ${initVersionFile}: ${key}`); } /* c8 ignore stop */ } 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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","sourcesContent":["import * as childProcess from 'child_process';\nimport * as path from 'path';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport { invokeBuiltinHooks } from './init-hooks';\nimport { ToolkitError } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api';\nimport { cliRootDir } from '../../cli/root-dir';\nimport { versionNumber } from '../../cli/version';\nimport { error, info, warning } from '../../logging';\nimport { cdkHomeDir, formatErrorMessage, rangeFromSemver } from '../../util';\n\n/* eslint-disable @typescript-eslint/no-var-requires */ // Packages don't have @types module\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst camelCase = require('camelcase');\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst decamelize = require('decamelize');\n\nexport interface CliInitOptions {\n  readonly type?: string;\n  readonly language?: string;\n  readonly canUseNetwork?: boolean;\n  readonly generateOnly?: boolean;\n  readonly workDir?: string;\n  readonly stackName?: string;\n  readonly migrate?: boolean;\n\n  /**\n   * Override the built-in CDK version\n   */\n  readonly libVersion?: string;\n}\n\n/**\n * Initialize a CDK package in the current directory\n */\nexport async function cliInit(options: CliInitOptions) {\n  const canUseNetwork = options.canUseNetwork ?? true;\n  const generateOnly = options.generateOnly ?? false;\n  const workDir = options.workDir ?? process.cwd();\n  if (!options.type && !options.language) {\n    await printAvailableTemplates();\n    return;\n  }\n\n  const type = options.type || 'default'; // \"default\" is the default type (and maps to \"app\")\n\n  const template = (await availableInitTemplates()).find((t) => t.hasName(type!));\n  if (!template) {\n    await printAvailableTemplates(options.language);\n    throw new ToolkitError(`Unknown init template: ${type}`);\n  }\n  if (!options.language && template.languages.length === 1) {\n    const language = template.languages[0];\n    warning(\n      `No --language was provided, but '${type}' supports only '${language}', so defaulting to --language=${language}`,\n    );\n  }\n  if (!options.language) {\n    info(`Available languages for ${chalk.green(type)}: ${template.languages.map((l) => chalk.blue(l)).join(', ')}`);\n    throw new ToolkitError('No language was selected');\n  }\n\n  await initializeProject(\n    template,\n    options.language,\n    canUseNetwork,\n    generateOnly,\n    workDir,\n    options.stackName,\n    options.migrate,\n    options.libVersion,\n  );\n}\n\n/**\n * Returns the name of the Python executable for this OS\n */\nfunction pythonExecutable() {\n  let python = 'python3';\n  if (process.platform === 'win32') {\n    python = 'python';\n  }\n  return python;\n}\nconst INFO_DOT_JSON = 'info.json';\n\nexport class InitTemplate {\n  public static async fromName(templatesDir: string, name: string) {\n    const basePath = path.join(templatesDir, name);\n    const languages = await listDirectory(basePath);\n    const initInfo = await fs.readJson(path.join(basePath, INFO_DOT_JSON));\n    return new InitTemplate(basePath, name, languages, initInfo);\n  }\n\n  public readonly description: string;\n  public readonly aliases = new Set<string>();\n\n  constructor(\n    private readonly basePath: string,\n    public readonly name: string,\n    public readonly languages: string[],\n    initInfo: any,\n  ) {\n    this.description = initInfo.description;\n    for (const alias of initInfo.aliases || []) {\n      this.aliases.add(alias);\n    }\n  }\n\n  /**\n   * @param name the name that is being checked\n   * @returns ``true`` if ``name`` is the name of this template or an alias of it.\n   */\n  public hasName(name: string): boolean {\n    return name === this.name || this.aliases.has(name);\n  }\n\n  /**\n   * Creates a new instance of this ``InitTemplate`` for a given language to a specified folder.\n   *\n   * @param language    the language to instantiate this template with\n   * @param targetDirectory the directory where the template is to be instantiated into\n   */\n  public async install(language: string, targetDirectory: string, stackName?: string, libVersion?: string) {\n    if (this.languages.indexOf(language) === -1) {\n      error(\n        `The ${chalk.blue(language)} language is not supported for ${chalk.green(this.name)} ` +\n          `(it supports: ${this.languages.map((l) => chalk.blue(l)).join(', ')})`,\n      );\n      throw new ToolkitError(`Unsupported language: ${language}`);\n    }\n\n    const projectInfo: ProjectInfo = {\n      name: decamelize(path.basename(path.resolve(targetDirectory))),\n      stackName,\n      versions: await loadInitVersions(),\n    };\n\n    if (libVersion) {\n      projectInfo.versions['aws-cdk-lib'] = libVersion;\n    }\n\n    const sourceDirectory = path.join(this.basePath, language);\n\n    await this.installFiles(sourceDirectory, targetDirectory, language, projectInfo);\n    await this.applyFutureFlags(targetDirectory);\n    await invokeBuiltinHooks(\n      { targetDirectory, language, templateName: this.name },\n      {\n        substitutePlaceholdersIn: async (...fileNames: string[]) => {\n          for (const fileName of fileNames) {\n            const fullPath = path.join(targetDirectory, fileName);\n            const template = await fs.readFile(fullPath, { encoding: 'utf-8' });\n            await fs.writeFile(fullPath, expandPlaceholders(template, language, projectInfo));\n          }\n        },\n        placeholder: (ph: string) => expandPlaceholders(`%${ph}%`, language, projectInfo),\n      },\n    );\n  }\n\n  private async installFiles(sourceDirectory: string, targetDirectory: string, language: string, project: ProjectInfo) {\n    for (const file of await fs.readdir(sourceDirectory)) {\n      const fromFile = path.join(sourceDirectory, file);\n      const toFile = path.join(targetDirectory, expandPlaceholders(file, language, project));\n      if ((await fs.stat(fromFile)).isDirectory()) {\n        await fs.mkdir(toFile);\n        await this.installFiles(fromFile, toFile, language, project);\n        continue;\n      } else if (file.match(/^.*\\.template\\.[^.]+$/)) {\n        await this.installProcessed(fromFile, toFile.replace(/\\.template(\\.[^.]+)$/, '$1'), language, project);\n        continue;\n      } else if (file.match(/^.*\\.hook\\.(d.)?[^.]+$/)) {\n        // Ignore\n        continue;\n      } else {\n        await fs.copy(fromFile, toFile);\n      }\n    }\n  }\n\n  private async installProcessed(templatePath: string, toFile: string, language: string, project: ProjectInfo) {\n    const template = await fs.readFile(templatePath, { encoding: 'utf-8' });\n    await fs.writeFile(toFile, expandPlaceholders(template, language, project));\n  }\n\n  /**\n   * Adds context variables to `cdk.json` in the generated project directory to\n   * enable future behavior for new projects.\n   */\n  private async applyFutureFlags(projectDir: string) {\n    const cdkJson = path.join(projectDir, 'cdk.json');\n    if (!(await fs.pathExists(cdkJson))) {\n      return;\n    }\n\n    const config = await fs.readJson(cdkJson);\n    config.context = {\n      ...config.context,\n      ...await currentlyRecommendedAwsCdkLibFlags(),\n    };\n\n    await fs.writeJson(cdkJson, config, { spaces: 2 });\n  }\n\n  public async addMigrateContext(projectDir: string) {\n    const cdkJson = path.join(projectDir, 'cdk.json');\n    if (!(await fs.pathExists(cdkJson))) {\n      return;\n    }\n\n    const config = await fs.readJson(cdkJson);\n    config.context = {\n      ...config.context,\n      'cdk-migrate': true,\n    };\n\n    await fs.writeJson(cdkJson, config, { spaces: 2 });\n  }\n}\n\nexport function expandPlaceholders(template: string, language: string, project: ProjectInfo) {\n  const cdkVersion = project.versions['aws-cdk-lib'];\n  const cdkCliVersion = project.versions['aws-cdk'];\n  let constructsVersion = project.versions.constructs;\n\n  switch (language) {\n    case 'java':\n    case 'csharp':\n    case 'fsharp':\n      constructsVersion = rangeFromSemver(constructsVersion, 'bracket');\n      break;\n    case 'python':\n      constructsVersion = rangeFromSemver(constructsVersion, 'pep');\n      break;\n  }\n  return template\n    .replace(/%name%/g, project.name)\n    .replace(/%stackname%/, project.stackName ?? '%name.PascalCased%Stack')\n    .replace(\n      /%PascalNameSpace%/,\n      project.stackName ? camelCase(project.stackName + 'Stack', { pascalCase: true }) : '%name.PascalCased%',\n    )\n    .replace(\n    