cdkdx
Version:
Zero-config CLI for aws cdk development
169 lines • 24.8 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Project = void 0;
const path = __importStar(require("path"));
const fs = __importStar(require("fs-extra"));
const camelcase_1 = __importDefault(require("camelcase"));
const constructs_1 = require("constructs");
const semver_1 = require("../semver");
const template_file_1 = require("./template-file");
const directory_1 = require("./directory");
const json_file_1 = require("./json-file");
const git_ignore_1 = require("./git-ignore");
const DEFAULT_JSII_MIN_NODE = '12.22.0';
class Project extends constructs_1.Construct {
constructor(options) {
var _a, _b, _c;
// eslint-disable-next-line @typescript-eslint/no-explicit-any
super(undefined, 'cdkdx');
this.scripts = {};
this.peerDependencies = {};
this.devDependencies = {};
this.dependencies = {};
this.targetPath = options.targetPath;
this.template = options.template;
this.minNodeVersion = (_a = options.minNodeVersion) !== null && _a !== void 0 ? _a : DEFAULT_JSII_MIN_NODE;
this.srcDir = (_b = options.srcDir) !== null && _b !== void 0 ? _b : 'src';
this.outDir = (_c = options.outDir) !== null && _c !== void 0 ? _c : 'lib';
const description = 'TODO: Add your description here';
this.manifest = {
name: options.name,
version: '0.1.0',
description,
license: 'MIT',
author: {
name: options.author,
url: `https://github.com/${options.author}`,
},
repository: {
type: 'git',
url: `https://github.com/${options.author}/${options.name}.git`,
},
homepage: `https://github.com/${options.author}/${options.name}`,
keywords: ['cdk'],
engines: { node: `>= ${this.minNodeVersion}` },
main: undefined,
types: undefined,
files: undefined,
jsii: undefined,
scripts: this.scripts,
peerDependencies: this.peerDependencies,
dependencies: this.dependencies,
devDependencies: this.devDependencies,
eslintConfig: {
extends: ['cdk'],
},
};
new json_file_1.JsonFile(this, 'package.json', {
obj: this.manifest,
});
this.gitignore = new git_ignore_1.GitIgnore(this);
this.addDefaultGitIgnoreExcludes();
this.addScripts({
build: 'cdkdx build',
watch: 'cdkdx build -w',
test: 'cdkdx test',
lint: 'cdkdx lint',
['upgrade:cdk']: 'cdkdx upgrade-cdk',
docgen: 'cdkdx docgen',
});
this.templateContext = {
name: options.name,
description,
author: options.author,
year: new Date().getFullYear(),
camelCase: (str) => (0, camelcase_1.default)(str),
pascalCase: (str) => (0, camelcase_1.default)(str, { pascalCase: true }),
};
}
addFields(fields) {
for (const [name, value] of Object.entries(fields)) {
this.manifest[name] = value;
}
}
addScripts(scripts) {
for (const [name, command] of Object.entries(scripts)) {
this.scripts[name] = command;
}
}
addPeerDependencies(deps, options = {}) {
var _a;
const pinnedDevDependency = (_a = options.pinnedDevDependency) !== null && _a !== void 0 ? _a : true;
for (const [k, v] of Object.entries(deps)) {
this.peerDependencies[k] = v.spec;
if (pinnedDevDependency) {
this.addDevDependencies({ [k]: semver_1.Semver.pinned(v.version) });
}
}
}
addDependencies(deps) {
for (const [k, v] of Object.entries(deps)) {
this.dependencies[k] = v.spec;
}
}
addDevDependencies(deps) {
for (const [k, v] of Object.entries(deps !== null && deps !== void 0 ? deps : {})) {
this.devDependencies[k] = v.spec;
}
}
addFiles(files, fromPath) {
const templatePath = fromPath !== null && fromPath !== void 0 ? fromPath : this.template;
files.forEach((file) => {
const sourceFile = path.join(templatePath, file);
const stats = fs.statSync(sourceFile);
if (stats.isDirectory()) {
new directory_1.Directory(this, file);
}
else {
const template = fs.readFileSync(sourceFile, {
encoding: 'utf-8',
});
new template_file_1.TemplateFile(this, file, {
template,
context: this.templateContext,
});
}
});
}
getDependencyNames() {
const dependencyNames = new Set([
...Object.keys(this.dependencies),
...Object.keys(this.devDependencies),
]);
return [...dependencyNames];
}
synth() {
constructs_1.Node.of(this).synthesize({ outdir: this.targetPath });
}
addDefaultGitIgnoreExcludes() {
this.gitignore.exclude('# Logs', 'logs', '*.log', 'npm-debug.log*', 'yarn-debug.log*', 'yarn-error.log*', 'lerna-debug.log*', '', '# Diagnostic reports (https://nodejs.org/api/report.html)', 'report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json', '', '# Runtime data', 'pids', '*.pid', '*.seed', '*.pid.lock', '', '# Directory for instrumented libs generated by jscoverage/JSCover', 'lib-cov', '', '# Coverage directory used by tools like istanbul', 'coverage', '*.lcov', '', '# nyc test coverage', '.nyc_output', '', '# Grunt intermediate storage(https://gruntjs.com/creating-plugins#storing-task-files)', '.grunt', '', '# Bower dependency directory(https://bower.io/)', 'bower_components', '', '# node-waf configuration', '.lock-wscript', '', '# Compiled binary addons (https://nodejs.org/api/addons.html)', 'build/Release', '', '# Dependency directories', 'node_modules/', 'jspm_packages/', '', '# TypeScript v1 declaration files', 'typings/', '', '# Optional npm cache directory', '.npm', '', '# Optional eslint cache', '.eslintcache', '', '# Optional REPL history', '.node_repl_history', '', '# Output of `npm pack`', '*.tgz', '', '# Yarn Integrity file', '.yarn-integrity', '', '# dotenv environment variables file', '.env', '', '# next.js build output', '.next', '', '# cdkdx', '.DS_Store', 'lib', '*.tsbuildinfo', 'tsconfig.json', 'tsconfig.eslint.json');
}
}
exports.Project = Project;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project.js","sourceRoot":"","sources":["../../src/templates/project.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport camelCase from 'camelcase';\nimport { Construct, Node } from 'constructs';\n\nimport { Semver } from '../semver';\nimport { TemplateFile } from './template-file';\nimport { Directory } from './directory';\nimport { JsonFile } from './json-file';\nimport { GitIgnore } from './git-ignore';\n\nconst DEFAULT_JSII_MIN_NODE = '12.22.0';\n\nexport interface ProjectOptions {\n  readonly targetPath: string;\n  readonly name: string;\n  readonly template: string;\n  readonly author: string;\n  readonly dependencyVersions: Record<string, Semver>;\n\n  readonly srcDir?: string;\n  readonly outDir?: string;\n\n  readonly minNodeVersion?: string;\n}\n\nexport interface PeerDependencyOptions {\n  /**\n   * Automatically add a pinned dev dependency.\n   * @default true\n   */\n  readonly pinnedDevDependency?: boolean;\n}\n\nexport class Project extends Construct {\n  public readonly targetPath: string;\n  public readonly template: string;\n  public readonly minNodeVersion: string;\n  public readonly outDir: string;\n  public readonly srcDir: string;\n  public readonly gitignore: GitIgnore;\n\n  private readonly scripts: Record<string, string> = {};\n  private readonly peerDependencies: Record<string, string> = {};\n  private readonly devDependencies: Record<string, string> = {};\n  private readonly dependencies: Record<string, string> = {};\n  private readonly manifest: Record<string, unknown>;\n  private readonly templateContext: Record<string, unknown>;\n\n  constructor(options: ProjectOptions) {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    super(undefined as any, 'cdkdx');\n\n    this.targetPath = options.targetPath;\n\n    this.template = options.template;\n    this.minNodeVersion = options.minNodeVersion ?? DEFAULT_JSII_MIN_NODE;\n\n    this.srcDir = options.srcDir ?? 'src';\n    this.outDir = options.outDir ?? 'lib';\n\n    const description = 'TODO: Add your description here';\n\n    this.manifest = {\n      name: options.name,\n      version: '0.1.0',\n      description,\n      license: 'MIT',\n      author: {\n        name: options.author,\n        url: `https://github.com/${options.author}`,\n      },\n      repository: {\n        type: 'git',\n        url: `https://github.com/${options.author}/${options.name}.git`,\n      },\n      homepage: `https://github.com/${options.author}/${options.name}`,\n      keywords: ['cdk'],\n      engines: { node: `>= ${this.minNodeVersion}` },\n      main: undefined,\n      types: undefined,\n      files: undefined,\n      jsii: undefined,\n      scripts: this.scripts,\n      peerDependencies: this.peerDependencies,\n      dependencies: this.dependencies,\n      devDependencies: this.devDependencies,\n      eslintConfig: {\n        extends: ['cdk'],\n      },\n    };\n\n    new JsonFile(this, 'package.json', {\n      obj: this.manifest,\n    });\n\n    this.gitignore = new GitIgnore(this);\n    this.addDefaultGitIgnoreExcludes();\n\n    this.addScripts({\n      build: 'cdkdx build',\n      watch: 'cdkdx build -w',\n      test: 'cdkdx test',\n      lint: 'cdkdx lint',\n      ['upgrade:cdk']: 'cdkdx upgrade-cdk',\n      docgen: 'cdkdx docgen',\n    });\n\n    this.templateContext = {\n      name: options.name,\n      description,\n      author: options.author,\n      year: new Date().getFullYear(),\n      camelCase: (str: string) => camelCase(str),\n      pascalCase: (str: string) => camelCase(str, { pascalCase: true }),\n    };\n  }\n\n  public addFields(fields: { [name: string]: unknown }): void {\n    for (const [name, value] of Object.entries(fields)) {\n      this.manifest[name] = value;\n    }\n  }\n\n  public addScripts(scripts: { [name: string]: string }): void {\n    for (const [name, command] of Object.entries(scripts)) {\n      this.scripts[name] = command;\n    }\n  }\n\n  public addPeerDependencies(\n    deps: { [module: string]: Semver },\n    options: PeerDependencyOptions = {},\n  ): void {\n    const pinnedDevDependency = options.pinnedDevDependency ?? true;\n\n    for (const [k, v] of Object.entries(deps)) {\n      this.peerDependencies[k] = v.spec;\n\n      if (pinnedDevDependency) {\n        this.addDevDependencies({ [k]: Semver.pinned(v.version) });\n      }\n    }\n  }\n\n  public addDependencies(deps: { [module: string]: Semver }): void {\n    for (const [k, v] of Object.entries(deps)) {\n      this.dependencies[k] = v.spec;\n    }\n  }\n\n  public addDevDependencies(deps: { [module: string]: Semver }): void {\n    for (const [k, v] of Object.entries(deps ?? {})) {\n      this.devDependencies[k] = v.spec;\n    }\n  }\n\n  public addFiles(files: string[], fromPath?: string): void {\n    const templatePath = fromPath ?? this.template;\n\n    files.forEach((file) => {\n      const sourceFile = path.join(templatePath, file);\n      const stats = fs.statSync(sourceFile);\n\n      if (stats.isDirectory()) {\n        new Directory(this, file);\n      } else {\n        const template = fs.readFileSync(sourceFile, {\n          encoding: 'utf-8',\n        });\n\n        new TemplateFile(this, file, {\n          template,\n          context: this.templateContext,\n        });\n      }\n    });\n  }\n\n  public getDependencyNames(): string[] {\n    const dependencyNames = new Set<string>([\n      ...Object.keys(this.dependencies),\n      ...Object.keys(this.devDependencies),\n    ]);\n\n    return [...dependencyNames];\n  }\n\n  public synth(): void {\n    Node.of(this).synthesize({ outdir: this.targetPath });\n  }\n\n  private addDefaultGitIgnoreExcludes() {\n    this.gitignore.exclude(\n      '# Logs',\n      'logs',\n      '*.log',\n      'npm-debug.log*',\n      'yarn-debug.log*',\n      'yarn-error.log*',\n      'lerna-debug.log*',\n      '',\n      '# Diagnostic reports (https://nodejs.org/api/report.html)',\n      'report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json',\n      '',\n      '# Runtime data',\n      'pids',\n      '*.pid',\n      '*.seed',\n      '*.pid.lock',\n      '',\n      '# Directory for instrumented libs generated by jscoverage/JSCover',\n      'lib-cov',\n      '',\n      '# Coverage directory used by tools like istanbul',\n      'coverage',\n      '*.lcov',\n      '',\n      '# nyc test coverage',\n      '.nyc_output',\n      '',\n      '# Grunt intermediate storage(https://gruntjs.com/creating-plugins#storing-task-files)',\n      '.grunt',\n      '',\n      '# Bower dependency directory(https://bower.io/)',\n      'bower_components',\n      '',\n      '# node-waf configuration',\n      '.lock-wscript',\n      '',\n      '# Compiled binary addons (https://nodejs.org/api/addons.html)',\n      'build/Release',\n      '',\n      '# Dependency directories',\n      'node_modules/',\n      'jspm_packages/',\n      '',\n      '# TypeScript v1 declaration files',\n      'typings/',\n      '',\n      '# Optional npm cache directory',\n      '.npm',\n      '',\n      '# Optional eslint cache',\n      '.eslintcache',\n      '',\n      '# Optional REPL history',\n      '.node_repl_history',\n      '',\n      '# Output of `npm pack`',\n      '*.tgz',\n      '',\n      '# Yarn Integrity file',\n      '.yarn-integrity',\n      '',\n      '# dotenv environment variables file',\n      '.env',\n      '',\n      '# next.js build output',\n      '.next',\n      '',\n      '# cdkdx',\n      '.DS_Store',\n      'lib',\n      '*.tsbuildinfo',\n      'tsconfig.json',\n      'tsconfig.eslint.json',\n    );\n  }\n}\n"]}