cdk8s-cli
Version:
This is the command line tool for Cloud Development Kit (CDK) for Kubernetes (cdk8s).
163 lines • 22.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;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ImportBase = exports.Language = void 0;
const path = __importStar(require("path"));
const codemaker_1 = require("codemaker");
const fs = __importStar(require("fs-extra"));
const srcmak = __importStar(require("jsii-srcmak"));
const util_1 = require("../util");
var Language;
(function (Language) {
Language["TYPESCRIPT"] = "typescript";
Language["PYTHON"] = "python";
Language["CSHARP"] = "csharp";
Language["JAVA"] = "java";
Language["GO"] = "go";
})(Language = exports.Language || (exports.Language = {}));
class ImportBase {
async import(options) {
const code = new codemaker_1.CodeMaker();
const outdir = path.resolve(options.outdir);
await fs.mkdirp(outdir);
const isTypescript = options.targetLanguage === Language.TYPESCRIPT;
const { moduleNamePrefix } = options;
if (this.moduleNames.length === 0) {
console.error('warning: no definitions to import');
}
const mapFunc = (origName) => {
let name = origName;
switch (options.targetLanguage) {
case Language.PYTHON:
case Language.JAVA:
name = name.split('.').reverse().join('.');
break;
}
return {
origName: origName,
name: name,
};
};
// sort to ensure python writes parent packages first, so children are not deleted
const modules = this.moduleNames.map(mapFunc).sort((a, b) => a.name.localeCompare(b.name));
for (const module of modules) {
// output the name of the imported resource
console.log(module.origName);
const fileName = moduleNamePrefix ? `${moduleNamePrefix}-${module.name}.ts` : `${module.name}.ts`;
code.openFile(fileName);
code.indentation = 2;
await this.generateTypeScript(code, module.origName, {
classNamePrefix: options.classNamePrefix,
});
code.closeFile(fileName);
if (isTypescript) {
await code.save(outdir);
}
if (!isTypescript || options.outputJsii) {
await (0, util_1.mkdtemp)(async (staging) => {
// this is not typescript, so we generate in a staging directory and
// use jsii-srcmak to compile and extract the language-specific source
// into our project.
await code.save(staging);
// these are the module dependencies we compile against
const deps = ['@types/node', 'constructs', 'cdk8s'];
const opts = {
entrypoint: fileName,
moduleKey: moduleNamePrefix ? `${moduleNamePrefix}_${module.name}` : module.name,
deps: deps.map(dep => path.dirname(require.resolve(`${dep}/package.json`))),
};
// used for testing.
if (options.outputJsii) {
opts.jsii = { path: options.outputJsii };
}
// python!
if (options.targetLanguage === Language.PYTHON) {
const moduleName = `${moduleNamePrefix ? `${moduleNamePrefix}.${module.name}` : module.name}`.replace(/-/g, '_');
opts.python = {
outdir: outdir,
moduleName,
};
}
// java!
if (options.targetLanguage === Language.JAVA) {
const javaName = module.name.replace(/\//g, '.').replace(/-/g, '_');
opts.java = {
outdir: '.',
package: `imports.${moduleNamePrefix ? moduleNamePrefix + '.' + javaName : javaName}`,
};
}
// go!
if (options.targetLanguage === Language.GO) {
const { userModuleName, userModulePath } = this.getGoModuleName(outdir);
const relativeDir = path.relative(userModulePath, outdir);
// go package names may only consist of letters or digits.
// underscores are allowed too, but they are less idiomatic
// this converts e.g. "cert-manager.path.to.url" to "certmanagerpathtourl"
const importModuleName = module.name.replace(/[^A-Za-z0-9]/g, '').toLocaleLowerCase();
opts.golang = {
outdir: outdir,
moduleName: `${userModuleName}/${relativeDir}`,
packageName: moduleNamePrefix ? moduleNamePrefix + '_' + importModuleName : importModuleName,
};
}
// csharp!
if (options.targetLanguage === Language.CSHARP) {
const csharpName = module.name.replace(/\//g, '.').replace(/-/g, '_').replace(/(?:^|_)([a-z])/g, (_, char) => char.toUpperCase());
opts.csharp = {
outdir: outdir,
namespace: `Imports.${moduleNamePrefix ? moduleNamePrefix + '.' + csharpName : csharpName}`,
};
}
await srcmak.srcmak(staging, opts);
});
}
}
}
/**
* Traverses up directories until it finds a directory with a go.mod file,
* and parses the module name from the file.
*/
getGoModuleName(origOutdir) {
let outdir = path.resolve(origOutdir);
while (outdir !== path.dirname(outdir)) {
const file = path.join(outdir, 'go.mod');
if (fs.existsSync(file)) {
const contents = fs.readFileSync(file, 'utf8');
const matches = /module (.*)/.exec(contents);
if (!matches) {
throw new Error('Invalid go.mod file - could not find module path.');
}
return {
userModuleName: matches[1],
userModulePath: outdir,
};
}
outdir = path.dirname(outdir);
}
throw new Error(`Cannot find go.mod file within ${origOutdir} or any of its parent directories.`);
}
}
exports.ImportBase = ImportBase;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../src/import/base.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { CodeMaker } from 'codemaker';\nimport * as fs from 'fs-extra';\nimport * as srcmak from 'jsii-srcmak';\nimport { mkdtemp } from '../util';\n\nexport enum Language {\n  TYPESCRIPT = 'typescript',\n  PYTHON = 'python',\n  CSHARP = 'csharp',\n  JAVA = 'java',\n  GO = 'go',\n}\n\nexport interface ImportOptions {\n  readonly moduleNamePrefix?: string;\n  readonly targetLanguage: Language;\n  readonly outdir: string;\n  readonly save?: boolean;\n\n  /**\n   * Path to copy the output .jsii file.\n   * @default - jsii file is not emitted\n   */\n  readonly outputJsii?: string;\n\n  /**\n   * A prefix for all construct classes.\n   *\n   * @default - default is determined by the specific import type. For example\n   * k8s imports will add a \"Kube\" prefix by default.\n   */\n  readonly classNamePrefix?: string;\n}\n\nexport interface GenerateOptions {\n  readonly classNamePrefix?: string;\n}\n\nexport abstract class ImportBase {\n  public abstract get moduleNames(): string[];\n\n  protected abstract generateTypeScript(code: CodeMaker, moduleName: string, options: GenerateOptions): Promise<void>;\n\n  public async import(options: ImportOptions) {\n    const code = new CodeMaker();\n\n    const outdir = path.resolve(options.outdir);\n    await fs.mkdirp(outdir);\n    const isTypescript = options.targetLanguage === Language.TYPESCRIPT;\n    const { moduleNamePrefix } = options;\n\n    if (this.moduleNames.length === 0) {\n      console.error('warning: no definitions to import');\n    }\n\n    const mapFunc = ( origName: string ) => {\n      let name = origName;\n      switch (options.targetLanguage) {\n        case Language.PYTHON:\n        case Language.JAVA:\n          name = name.split('.').reverse().join('.');\n          break;\n      }\n      return {\n        origName: origName,\n        name: name,\n      };\n    };\n\n    // sort to ensure python writes parent packages first, so children are not deleted\n    const modules = this.moduleNames.map(mapFunc).sort((a: any, b: any) => a.name.localeCompare(b.name));\n\n    for (const module of modules) {\n      // output the name of the imported resource\n      console.log(module.origName);\n\n      const fileName = moduleNamePrefix ? `${moduleNamePrefix}-${module.name}.ts` : `${module.name}.ts`;\n      code.openFile(fileName);\n      code.indentation = 2;\n      await this.generateTypeScript(code, module.origName, {\n        classNamePrefix: options.classNamePrefix,\n      });\n\n      code.closeFile(fileName);\n\n      if (isTypescript) {\n        await code.save(outdir);\n      }\n\n      if (!isTypescript || options.outputJsii) {\n        await mkdtemp(async staging => {\n\n          // this is not typescript, so we generate in a staging directory and\n          // use jsii-srcmak to compile and extract the language-specific source\n          // into our project.\n          await code.save(staging);\n\n          // these are the module dependencies we compile against\n          const deps = ['@types/node', 'constructs', 'cdk8s'];\n\n          const opts: srcmak.Options = {\n            entrypoint: fileName,\n            moduleKey: moduleNamePrefix ? `${moduleNamePrefix}_${module.name}` : module.name,\n            deps: deps.map(dep => path.dirname(require.resolve(`${dep}/package.json`))),\n          };\n\n          // used for testing.\n          if (options.outputJsii) {\n            opts.jsii = { path: options.outputJsii };\n          }\n\n          // python!\n          if (options.targetLanguage === Language.PYTHON) {\n            const moduleName = `${moduleNamePrefix ? `${moduleNamePrefix}.${module.name}` : module.name}`.replace(/-/g, '_');\n            opts.python = {\n              outdir: outdir,\n              moduleName,\n            };\n          }\n\n          // java!\n          if (options.targetLanguage === Language.JAVA) {\n            const javaName = module.name.replace(/\\//g, '.').replace(/-/g, '_');\n            opts.java = {\n              outdir: '.',\n              package: `imports.${moduleNamePrefix ? moduleNamePrefix + '.' + javaName : javaName}`,\n            };\n          }\n\n          // go!\n          if (options.targetLanguage === Language.GO) {\n            const { userModuleName, userModulePath } = this.getGoModuleName(outdir);\n            const relativeDir = path.relative(userModulePath, outdir);\n\n            // go package names may only consist of letters or digits.\n            // underscores are allowed too, but they are less idiomatic\n            // this converts e.g. \"cert-manager.path.to.url\" to \"certmanagerpathtourl\"\n            const importModuleName = module.name.replace(/[^A-Za-z0-9]/g, '').toLocaleLowerCase();\n\n            opts.golang = {\n              outdir: outdir,\n              moduleName: `${userModuleName}/${relativeDir}`,\n              packageName: moduleNamePrefix ? moduleNamePrefix + '_' + importModuleName : importModuleName,\n            };\n          }\n\n          // csharp!\n          if (options.targetLanguage === Language.CSHARP) {\n            const csharpName = module.name.replace(/\\//g, '.').replace(/-/g, '_').replace(/(?:^|_)([a-z])/g, (_, char) => char.toUpperCase());\n            opts.csharp = {\n              outdir: outdir,\n              namespace: `Imports.${moduleNamePrefix ? moduleNamePrefix + '.' + csharpName : csharpName}`,\n            };\n          }\n\n          await srcmak.srcmak(staging, opts);\n        });\n      }\n    }\n  }\n\n  /**\n   * Traverses up directories until it finds a directory with a go.mod file,\n   * and parses the module name from the file.\n   */\n  private getGoModuleName(origOutdir: string) {\n    let outdir = path.resolve(origOutdir);\n\n    while (outdir !== path.dirname(outdir)) {\n      const file = path.join(outdir, 'go.mod');\n\n      if (fs.existsSync(file)) {\n        const contents = fs.readFileSync(file, 'utf8');\n        const matches = /module (.*)/.exec(contents);\n\n        if (!matches) {\n          throw new Error('Invalid go.mod file - could not find module path.');\n        }\n\n        return {\n          userModuleName: matches[1],\n          userModulePath: outdir,\n        };\n      }\n\n      outdir = path.dirname(outdir);\n    }\n\n    throw new Error(`Cannot find go.mod file within ${origOutdir} or any of its parent directories.`);\n  }\n}\n"]}
;