cdk8s-cli 2.200.49 → 2.200.51

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.
package/lib/import/crd.js CHANGED
@@ -44,9 +44,8 @@ const SUPPORTED_API_VERSIONS = [
44
44
  ];
45
45
  class CustomResourceDefinition {
46
46
  constructor(manifest) {
47
- var _a, _b, _c;
48
47
  this.versions = [];
49
- const apiVersion = (_a = manifest === null || manifest === void 0 ? void 0 : manifest.apiVersion) !== null && _a !== void 0 ? _a : 'undefined';
48
+ const apiVersion = manifest?.apiVersion ?? 'undefined';
50
49
  assert(SUPPORTED_API_VERSIONS.includes(apiVersion), `"apiVersion" is "${apiVersion}" but it should be one of: ${SUPPORTED_API_VERSIONS.map(x => `"${x}"`).join(', ')}`);
51
50
  assert(manifest.kind === CRD_KIND, `"kind" must be "${CRD_KIND}"`);
52
51
  const spec = manifest.spec;
@@ -56,10 +55,10 @@ class CustomResourceDefinition {
56
55
  this.group = spec.group;
57
56
  this.kind = spec.names.kind;
58
57
  if (spec.version) {
59
- this.addVersions([{ name: spec.version, schema: (_b = spec.validation) === null || _b === void 0 ? void 0 : _b.openAPIV3Schema }]);
58
+ this.addVersions([{ name: spec.version, schema: spec.validation?.openAPIV3Schema }]);
60
59
  }
61
60
  else {
62
- this.addVersions(((_c = spec.versions) !== null && _c !== void 0 ? _c : []).map(v => { var _a, _b, _c; return ({ name: v.name, schema: (_b = (_a = v.schema) === null || _a === void 0 ? void 0 : _a.openAPIV3Schema) !== null && _b !== void 0 ? _b : (_c = spec.validation) === null || _c === void 0 ? void 0 : _c.openAPIV3Schema }); }));
61
+ this.addVersions((spec.versions ?? []).map(v => ({ name: v.name, schema: v.schema?.openAPIV3Schema ?? spec.validation?.openAPIV3Schema })));
63
62
  }
64
63
  if (this.versions.length === 0) {
65
64
  throw new Error('unable to determine CRD versions');
@@ -193,4 +192,4 @@ function safeParseCrds(manifest) {
193
192
  return crds;
194
193
  }
195
194
  exports.safeParseCrds = safeParseCrds;
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crd.js","sourceRoot":"","sources":["../../src/import/crd.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport Ajv from 'ajv';\nimport { CodeMaker, toPascalCase } from 'codemaker';\nimport { TypeGenerator } from 'json2jsii';\nimport { GenerateOptions, ImportBase } from './base';\nimport { emitHeader, generateConstruct } from './codegen';\nimport { ImportSpec } from '../config';\nimport { SafeReviver } from '../reviver';\nimport { download, safeParseYaml } from '../util';\n\nconst CRD_KIND = 'CustomResourceDefinition';\n\nexport interface ManifestObjectDefinition {\n  apiVersion?: string;\n  kind?: string;\n  items?: ManifestObjectDefinition[]; // if `kind` is \"List\"\n  metadata?: {\n    name?: string;\n  };\n  spec?: {\n    group: string;\n    names: {\n      kind: string;\n      [key: string]: any;\n    };\n    versions?: Array<{\n      name: string;\n      schema?: { openAPIV3Schema?: any };\n      [key: string]: any;\n    }>;\n    version?: string;\n    validation?: { openAPIV3Schema?: any };\n    [key: string]: any;\n  };\n}\n\n// all these APIs are compatible from our perspective.\nconst SUPPORTED_API_VERSIONS = [\n  'apiextensions.k8s.io/v1beta1',\n  'apiextensions.k8s.io/v1',\n];\n\ntype CustomResourceDefinitionVersion = { name: string; schema?: any };\n\nexport class CustomResourceDefinition {\n\n  private readonly kind: string;\n  private readonly versions: CustomResourceDefinitionVersion[] = [];\n\n  public readonly group: string;\n\n  constructor(manifest: ManifestObjectDefinition) {\n    const apiVersion = manifest?.apiVersion ?? 'undefined';\n    assert(SUPPORTED_API_VERSIONS.includes(apiVersion), `\"apiVersion\" is \"${apiVersion}\" but it should be one of: ${SUPPORTED_API_VERSIONS.map(x => `\"${x}\"`).join(', ')}`);\n    assert(manifest.kind === CRD_KIND, `\"kind\" must be \"${CRD_KIND}\"`);\n\n    const spec = manifest.spec;\n    if (!spec) {\n      throw new Error('manifest does not have a \"spec\" attribute');\n    }\n\n    this.group = spec.group;\n    this.kind = spec.names.kind;\n\n    if (spec.version) {\n      this.addVersions([{ name: spec.version, schema: spec.validation?.openAPIV3Schema }]);\n    } else {\n      this.addVersions((spec.versions ?? []).map(v => ({ name: v.name, schema: v.schema?.openAPIV3Schema ?? spec.validation?.openAPIV3Schema })));\n    }\n\n    if (this.versions.length === 0) {\n      throw new Error('unable to determine CRD versions');\n    }\n\n  }\n\n  public merge(crd: CustomResourceDefinition) {\n    this.addVersions(crd.versions);\n  }\n\n  private addVersions(versions: CustomResourceDefinitionVersion[]) {\n    for (const v of versions) {\n      const existingVersions = this.versions.map(ver => ver.name);\n      if (existingVersions.includes(v.name)) {\n        throw new Error(`Found multiple occurrences of version ${v.name} for ${this.key}`);\n      }\n      this.versions.push({ name: v.name, schema: v.schema });\n    }\n  }\n\n  public get key() {\n    return `${this.group}/${this.kind.toLocaleLowerCase()}`;\n  }\n\n  public async generateTypeScript(code: CodeMaker, options: GenerateOptions) {\n\n    for (let i = 0; i < this.versions.length; i++) {\n\n      const version = this.versions[i];\n\n      // to preseve backwards compatiblity, only append a suffix for\n      // the second version onwards.\n      const suffix = i === 0 ? '' : toPascalCase(version.name);\n\n      const types = new TypeGenerator({});\n\n      generateConstruct(types, {\n        group: this.group,\n        version: version.name,\n        kind: this.kind,\n        fqn: `${this.kind}${suffix}`,\n        schema: version.schema,\n        custom: true,\n        prefix: options.classNamePrefix,\n        suffix,\n      });\n\n      code.line(types.render());\n    }\n  }\n}\n\nexport class ImportCustomResourceDefinition extends ImportBase {\n  public static async fromSpec(importSpec: ImportSpec): Promise<ImportCustomResourceDefinition> {\n    const { source } = importSpec;\n    const manifest = await download(source);\n    return new ImportCustomResourceDefinition(manifest);\n  }\n\n  public readonly rawManifest: string;\n  private readonly groups: Record<string, CustomResourceDefinition[]> = { };\n\n  private constructor(rawManifest: string) {\n    super();\n\n    this.rawManifest = rawManifest;\n    const manifest = safeParseCrds(rawManifest);\n\n    const crds: Record<string, CustomResourceDefinition> = { };\n    const groups: Record<string, CustomResourceDefinition[]> = { };\n\n    for (const spec of manifest) {\n      const crd = new CustomResourceDefinition(spec);\n      const key = crd.key;\n\n      if (key in crds) {\n        // might contain different versions - lets try to merge them in\n        crds[key].merge(crd);\n      } else {\n        crds[key] = crd;\n      }\n    }\n\n    //sort to ensure consistent ordering for snapshot compare\n    const sortedCrds = Object.values(crds).sort((a: CustomResourceDefinition, b: CustomResourceDefinition) => a.key.localeCompare(b.key));\n\n    for (const crd of sortedCrds) {\n      const g = crd.group;\n      if ( !(g in groups) ) {\n        groups[g] = new Array<CustomResourceDefinition>();\n      }\n      groups[g].push(crd);\n    }\n\n    this.groups = groups;\n  }\n\n  public get moduleNames() {\n    return Object.keys(this.groups);\n  }\n\n  protected async generateTypeScript(code: CodeMaker, moduleName: string, options: GenerateOptions) {\n    const crds = this.groups[moduleName];\n\n\n    emitHeader(code, true);\n\n    for (const crd of crds) {\n      console.log(`  ${crd.key}`);\n      await crd.generateTypeScript(code, options);\n    }\n  }\n}\n\nfunction assert(condition: boolean, message: string) {\n  if (!condition) {\n    throw new Error(`invalid CustomResourceDefinition manifest: ${message}`);\n  }\n}\n\n\nexport function safeParseCrds(manifest: string): ManifestObjectDefinition[] {\n  const schemaPath = path.join(__dirname, '..', 'schemas', 'crd.schema.json');\n  const schema = JSON.parse(fs.readFileSync(schemaPath, { encoding: 'utf8' }));\n  const reviver = new SafeReviver({\n    sanitizers: [SafeReviver.DESCRIPTION_SANITIZER, SafeReviver.LEGAL_CHAR_SANITIZER],\n  });\n\n  // first parse and strip\n  const objects = safeParseYaml(manifest, reviver);\n\n  // since the manifest can contain non crds as well, we first\n  // collect all crds and only apply a schema validation on them.\n\n  const crds: any[] = [];\n\n  function collectCRDs(objs: any[]) {\n    for (const obj of objs.filter(o => o)) {\n      if (obj.kind === CRD_KIND) {\n        crds.push(obj);\n      }\n      if (obj.kind === 'List') {\n        collectCRDs(obj.items);\n      }\n    }\n  }\n\n  collectCRDs(objects);\n\n  const ajv = new Ajv();\n  const validate = ajv.compile(schema);\n  const errors = [];\n  for (const crd of crds) {\n    validate(crd);\n    if (validate.errors) {\n      errors.push(...validate.errors);\n    };\n  }\n  if (errors.length > 0) {\n    throw new Error(`Schema validation errors detected\\n ${errors.map(e => `* ${e.message}`).join('\\n')}`);\n  }\n  return crds;\n}\n"]}
195
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crd.js","sourceRoot":"","sources":["../../src/import/crd.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport Ajv from 'ajv';\nimport { CodeMaker, toPascalCase } from 'codemaker';\nimport { TypeGenerator } from 'json2jsii';\nimport { GenerateOptions, ImportBase } from './base';\nimport { emitHeader, generateConstruct } from './codegen';\nimport { ImportSpec } from '../config';\nimport { SafeReviver } from '../reviver';\nimport { download, safeParseYaml } from '../util';\n\nconst CRD_KIND = 'CustomResourceDefinition';\n\nexport interface ManifestObjectDefinition {\n  apiVersion?: string;\n  kind?: string;\n  items?: ManifestObjectDefinition[]; // if `kind` is \"List\"\n  metadata?: {\n    name?: string;\n  };\n  spec?: {\n    group: string;\n    names: {\n      kind: string;\n      [key: string]: any;\n    };\n    versions?: Array<{\n      name: string;\n      schema?: { openAPIV3Schema?: any };\n      [key: string]: any;\n    }>;\n    version?: string;\n    validation?: { openAPIV3Schema?: any };\n    [key: string]: any;\n  };\n}\n\n// all these APIs are compatible from our perspective.\nconst SUPPORTED_API_VERSIONS = [\n  'apiextensions.k8s.io/v1beta1',\n  'apiextensions.k8s.io/v1',\n];\n\ntype CustomResourceDefinitionVersion = { name: string; schema?: any };\n\nexport class CustomResourceDefinition {\n\n  private readonly kind: string;\n  private readonly versions: CustomResourceDefinitionVersion[] = [];\n\n  public readonly group: string;\n\n  constructor(manifest: ManifestObjectDefinition) {\n    const apiVersion = manifest?.apiVersion ?? 'undefined';\n    assert(SUPPORTED_API_VERSIONS.includes(apiVersion), `\"apiVersion\" is \"${apiVersion}\" but it should be one of: ${SUPPORTED_API_VERSIONS.map(x => `\"${x}\"`).join(', ')}`);\n    assert(manifest.kind === CRD_KIND, `\"kind\" must be \"${CRD_KIND}\"`);\n\n    const spec = manifest.spec;\n    if (!spec) {\n      throw new Error('manifest does not have a \"spec\" attribute');\n    }\n\n    this.group = spec.group;\n    this.kind = spec.names.kind;\n\n    if (spec.version) {\n      this.addVersions([{ name: spec.version, schema: spec.validation?.openAPIV3Schema }]);\n    } else {\n      this.addVersions((spec.versions ?? []).map(v => ({ name: v.name, schema: v.schema?.openAPIV3Schema ?? spec.validation?.openAPIV3Schema })));\n    }\n\n    if (this.versions.length === 0) {\n      throw new Error('unable to determine CRD versions');\n    }\n\n  }\n\n  public merge(crd: CustomResourceDefinition) {\n    this.addVersions(crd.versions);\n  }\n\n  private addVersions(versions: CustomResourceDefinitionVersion[]) {\n    for (const v of versions) {\n      const existingVersions = this.versions.map(ver => ver.name);\n      if (existingVersions.includes(v.name)) {\n        throw new Error(`Found multiple occurrences of version ${v.name} for ${this.key}`);\n      }\n      this.versions.push({ name: v.name, schema: v.schema });\n    }\n  }\n\n  public get key() {\n    return `${this.group}/${this.kind.toLocaleLowerCase()}`;\n  }\n\n  public async generateTypeScript(code: CodeMaker, options: GenerateOptions) {\n\n    for (let i = 0; i < this.versions.length; i++) {\n\n      const version = this.versions[i];\n\n      // to preseve backwards compatiblity, only append a suffix for\n      // the second version onwards.\n      const suffix = i === 0 ? '' : toPascalCase(version.name);\n\n      const types = new TypeGenerator({});\n\n      generateConstruct(types, {\n        group: this.group,\n        version: version.name,\n        kind: this.kind,\n        fqn: `${this.kind}${suffix}`,\n        schema: version.schema,\n        custom: true,\n        prefix: options.classNamePrefix,\n        suffix,\n      });\n\n      code.line(types.render());\n    }\n  }\n}\n\nexport class ImportCustomResourceDefinition extends ImportBase {\n  public static async fromSpec(importSpec: ImportSpec): Promise<ImportCustomResourceDefinition> {\n    const { source } = importSpec;\n    const manifest = await download(source);\n    return new ImportCustomResourceDefinition(manifest);\n  }\n\n  public readonly rawManifest: string;\n  private readonly groups: Record<string, CustomResourceDefinition[]> = { };\n\n  private constructor(rawManifest: string) {\n    super();\n\n    this.rawManifest = rawManifest;\n    const manifest = safeParseCrds(rawManifest);\n\n    const crds: Record<string, CustomResourceDefinition> = { };\n    const groups: Record<string, CustomResourceDefinition[]> = { };\n\n    for (const spec of manifest) {\n      const crd = new CustomResourceDefinition(spec);\n      const key = crd.key;\n\n      if (key in crds) {\n        // might contain different versions - lets try to merge them in\n        crds[key].merge(crd);\n      } else {\n        crds[key] = crd;\n      }\n    }\n\n    //sort to ensure consistent ordering for snapshot compare\n    const sortedCrds = Object.values(crds).sort((a: CustomResourceDefinition, b: CustomResourceDefinition) => a.key.localeCompare(b.key));\n\n    for (const crd of sortedCrds) {\n      const g = crd.group;\n      if ( !(g in groups) ) {\n        groups[g] = new Array<CustomResourceDefinition>();\n      }\n      groups[g].push(crd);\n    }\n\n    this.groups = groups;\n  }\n\n  public get moduleNames() {\n    return Object.keys(this.groups);\n  }\n\n  protected async generateTypeScript(code: CodeMaker, moduleName: string, options: GenerateOptions) {\n    const crds = this.groups[moduleName];\n\n\n    emitHeader(code, true);\n\n    for (const crd of crds) {\n      console.log(`  ${crd.key}`);\n      await crd.generateTypeScript(code, options);\n    }\n  }\n}\n\nfunction assert(condition: boolean, message: string) {\n  if (!condition) {\n    throw new Error(`invalid CustomResourceDefinition manifest: ${message}`);\n  }\n}\n\n\nexport function safeParseCrds(manifest: string): ManifestObjectDefinition[] {\n  const schemaPath = path.join(__dirname, '..', 'schemas', 'crd.schema.json');\n  const schema = JSON.parse(fs.readFileSync(schemaPath, { encoding: 'utf8' }));\n  const reviver = new SafeReviver({\n    sanitizers: [SafeReviver.DESCRIPTION_SANITIZER, SafeReviver.LEGAL_CHAR_SANITIZER],\n  });\n\n  // first parse and strip\n  const objects = safeParseYaml(manifest, reviver);\n\n  // since the manifest can contain non crds as well, we first\n  // collect all crds and only apply a schema validation on them.\n\n  const crds: any[] = [];\n\n  function collectCRDs(objs: any[]) {\n    for (const obj of objs.filter(o => o)) {\n      if (obj.kind === CRD_KIND) {\n        crds.push(obj);\n      }\n      if (obj.kind === 'List') {\n        collectCRDs(obj.items);\n      }\n    }\n  }\n\n  collectCRDs(objects);\n\n  const ajv = new Ajv();\n  const validate = ajv.compile(schema);\n  const errors = [];\n  for (const crd of crds) {\n    validate(crd);\n    if (validate.errors) {\n      errors.push(...validate.errors);\n    };\n  }\n  if (errors.length > 0) {\n    throw new Error(`Schema validation errors detected\\n ${errors.map(e => `* ${e.message}`).join('\\n')}`);\n  }\n  return crds;\n}\n"]}
@@ -22,7 +22,6 @@ exports.matchCrdsDevUrl = void 0;
22
22
  * @param source
23
23
  */
24
24
  function matchCrdsDevUrl(source) {
25
- var _a;
26
25
  const match = /^github:([A-Za-z0-9_.-]+)\/([A-Za-z0-9_.-]+)(?:\@([0-9]+)\.([0-9]+)(?:\.([0-9]+))?)?$/.exec(source);
27
26
  if (match) {
28
27
  const account = match[1];
@@ -33,7 +32,7 @@ function matchCrdsDevUrl(source) {
33
32
  let url = `https://doc.crds.dev/raw/github.com/${account}/${repo}`;
34
33
  if (major) {
35
34
  const minor = match[4];
36
- const patch = (_a = match[5]) !== null && _a !== void 0 ? _a : '0';
35
+ const patch = match[5] ?? '0';
37
36
  url = `https://doc.crds.dev/raw/github.com/${account}/${repo}@v${major}.${minor}.${patch}`;
38
37
  }
39
38
  return url;
@@ -41,4 +40,4 @@ function matchCrdsDevUrl(source) {
41
40
  return undefined;
42
41
  }
43
42
  exports.matchCrdsDevUrl = matchCrdsDevUrl;
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3Jkcy1kZXYuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW1wb3J0L2NyZHMtZGV2LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7R0FXRzs7O0FBRUg7Ozs7Ozs7R0FPRztBQUNILFNBQWdCLGVBQWUsQ0FBQyxNQUFjOztJQUM1QyxNQUFNLEtBQUssR0FBRyx1RkFBdUYsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDbkgsSUFBSSxLQUFLLEVBQUU7UUFDVCxNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDekIsTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3RCLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUV2QiwyQ0FBMkM7UUFDM0MsMkRBQTJEO1FBQzNELElBQUksR0FBRyxHQUFHLHVDQUF1QyxPQUFPLElBQUksSUFBSSxFQUFFLENBQUM7UUFDbkUsSUFBSSxLQUFLLEVBQUU7WUFDVCxNQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdkIsTUFBTSxLQUFLLEdBQUcsTUFBQSxLQUFLLENBQUMsQ0FBQyxDQUFDLG1DQUFJLEdBQUcsQ0FBQztZQUU5QixHQUFHLEdBQUcsdUNBQXVDLE9BQU8sSUFBSSxJQUFJLEtBQUssS0FBSyxJQUFJLEtBQUssSUFBSSxLQUFLLEVBQUUsQ0FBQztTQUM1RjtRQUVELE9BQU8sR0FBRyxDQUFDO0tBQ1o7SUFFRCxPQUFPLFNBQVMsQ0FBQztBQUNuQixDQUFDO0FBckJELDBDQXFCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICpcbiAqICAgICAgICAgICAgICBnaXRodWI6Y3Jvc3NwbGFuZS9jcm9zc3BsYW5lQDAuMTQuMFxuICogICAgICAgICAgICAgIHwtLV4tIHwgIF4gICAgICAgICBeICAgICAgICAgXiBeICBeXG4gKiAgICAgICAgICAgICAgICAgfCAgICAgfCAgICAgICAgIHwgICAgICAgICB8IHwgIHxcbiAqICAtIHByb3ZpZGVyIC0tLS0rICAgICB8ICAgICAgICAgfCAgICAgICAgIHwgfCAgfFxuICogIC0gYWNjb3VudCAtLS0tLS0tLS0tLSsgICAgICAgICB8ICAgICAgICAgfCB8ICB8XG4gKiAgLSByZXBvIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsgICAgICAgICB8IHwgIHxcbiAqICAtIG1ham9yIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsgfCAgfFxuICogIC0gbWlub3IgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rICB8XG4gKiAgLSBwYXRjaCAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLStcbiAqL1xuXG4vKipcbiAqIE1hdGNoZXMgYSBodHRwczovL2RvYy5jcmRzLmRldiByZXBvXG4gKlxuICogIC0gdXJsIGlmIGZvdW5kXG4gKiAgLSB1bmRlZmluZWQgaWYgbm90XG4gKlxuICogQHBhcmFtIHNvdXJjZVxuICovXG5leHBvcnQgZnVuY3Rpb24gbWF0Y2hDcmRzRGV2VXJsKHNvdXJjZTogc3RyaW5nKTogKHVuZGVmaW5lZCB8IHN0cmluZykge1xuICBjb25zdCBtYXRjaCA9IC9eZ2l0aHViOihbQS1aYS16MC05Xy4tXSspXFwvKFtBLVphLXowLTlfLi1dKykoPzpcXEAoWzAtOV0rKVxcLihbMC05XSspKD86XFwuKFswLTldKykpPyk/JC8uZXhlYyhzb3VyY2UpO1xuICBpZiAobWF0Y2gpIHtcbiAgICBjb25zdCBhY2NvdW50ID0gbWF0Y2hbMV07XG4gICAgY29uc3QgcmVwbyA9IG1hdGNoWzJdO1xuICAgIGNvbnN0IG1ham9yID0gbWF0Y2hbM107XG5cbiAgICAvL2RlZmF1bHQgdG8gbWFzdGVyIGlmIG5vIHZlcnNpb24gc3BlY2lmaWVkXG4gICAgLy9UT0RPOiBnZXQgbGF0ZXN0IHJlbGVhc2VkIHZlcnNpb24gZnJvbSBhdmFpbGFibGUgdmVyc2lvbnNcbiAgICBsZXQgdXJsID0gYGh0dHBzOi8vZG9jLmNyZHMuZGV2L3Jhdy9naXRodWIuY29tLyR7YWNjb3VudH0vJHtyZXBvfWA7XG4gICAgaWYgKG1ham9yKSB7XG4gICAgICBjb25zdCBtaW5vciA9IG1hdGNoWzRdO1xuICAgICAgY29uc3QgcGF0Y2ggPSBtYXRjaFs1XSA/PyAnMCc7XG5cbiAgICAgIHVybCA9IGBodHRwczovL2RvYy5jcmRzLmRldi9yYXcvZ2l0aHViLmNvbS8ke2FjY291bnR9LyR7cmVwb31AdiR7bWFqb3J9LiR7bWlub3J9LiR7cGF0Y2h9YDtcbiAgICB9XG5cbiAgICByZXR1cm4gdXJsO1xuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn1cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3Jkcy1kZXYuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW1wb3J0L2NyZHMtZGV2LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7R0FXRzs7O0FBRUg7Ozs7Ozs7R0FPRztBQUNILFNBQWdCLGVBQWUsQ0FBQyxNQUFjO0lBQzVDLE1BQU0sS0FBSyxHQUFHLHVGQUF1RixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNuSCxJQUFJLEtBQUssRUFBRTtRQUNULE1BQU0sT0FBTyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN6QixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEIsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRXZCLDJDQUEyQztRQUMzQywyREFBMkQ7UUFDM0QsSUFBSSxHQUFHLEdBQUcsdUNBQXVDLE9BQU8sSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUNuRSxJQUFJLEtBQUssRUFBRTtZQUNULE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN2QixNQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksR0FBRyxDQUFDO1lBRTlCLEdBQUcsR0FBRyx1Q0FBdUMsT0FBTyxJQUFJLElBQUksS0FBSyxLQUFLLElBQUksS0FBSyxJQUFJLEtBQUssRUFBRSxDQUFDO1NBQzVGO1FBRUQsT0FBTyxHQUFHLENBQUM7S0FDWjtJQUVELE9BQU8sU0FBUyxDQUFDO0FBQ25CLENBQUM7QUFyQkQsMENBcUJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKlxuICogICAgICAgICAgICAgIGdpdGh1Yjpjcm9zc3BsYW5lL2Nyb3NzcGxhbmVAMC4xNC4wXG4gKiAgICAgICAgICAgICAgfC0tXi0gfCAgXiAgICAgICAgIF4gICAgICAgICBeIF4gIF5cbiAqICAgICAgICAgICAgICAgICB8ICAgICB8ICAgICAgICAgfCAgICAgICAgIHwgfCAgfFxuICogIC0gcHJvdmlkZXIgLS0tLSsgICAgIHwgICAgICAgICB8ICAgICAgICAgfCB8ICB8XG4gKiAgLSBhY2NvdW50IC0tLS0tLS0tLS0tKyAgICAgICAgIHwgICAgICAgICB8IHwgIHxcbiAqICAtIHJlcG8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKyAgICAgICAgIHwgfCAgfFxuICogIC0gbWFqb3IgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKyB8ICB8XG4gKiAgLSBtaW5vciAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsgIHxcbiAqICAtIHBhdGNoIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tK1xuICovXG5cbi8qKlxuICogTWF0Y2hlcyBhIGh0dHBzOi8vZG9jLmNyZHMuZGV2IHJlcG9cbiAqXG4gKiAgLSB1cmwgaWYgZm91bmRcbiAqICAtIHVuZGVmaW5lZCBpZiBub3RcbiAqXG4gKiBAcGFyYW0gc291cmNlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBtYXRjaENyZHNEZXZVcmwoc291cmNlOiBzdHJpbmcpOiAodW5kZWZpbmVkIHwgc3RyaW5nKSB7XG4gIGNvbnN0IG1hdGNoID0gL15naXRodWI6KFtBLVphLXowLTlfLi1dKylcXC8oW0EtWmEtejAtOV8uLV0rKSg/OlxcQChbMC05XSspXFwuKFswLTldKykoPzpcXC4oWzAtOV0rKSk/KT8kLy5leGVjKHNvdXJjZSk7XG4gIGlmIChtYXRjaCkge1xuICAgIGNvbnN0IGFjY291bnQgPSBtYXRjaFsxXTtcbiAgICBjb25zdCByZXBvID0gbWF0Y2hbMl07XG4gICAgY29uc3QgbWFqb3IgPSBtYXRjaFszXTtcblxuICAgIC8vZGVmYXVsdCB0byBtYXN0ZXIgaWYgbm8gdmVyc2lvbiBzcGVjaWZpZWRcbiAgICAvL1RPRE86IGdldCBsYXRlc3QgcmVsZWFzZWQgdmVyc2lvbiBmcm9tIGF2YWlsYWJsZSB2ZXJzaW9uc1xuICAgIGxldCB1cmwgPSBgaHR0cHM6Ly9kb2MuY3Jkcy5kZXYvcmF3L2dpdGh1Yi5jb20vJHthY2NvdW50fS8ke3JlcG99YDtcbiAgICBpZiAobWFqb3IpIHtcbiAgICAgIGNvbnN0IG1pbm9yID0gbWF0Y2hbNF07XG4gICAgICBjb25zdCBwYXRjaCA9IG1hdGNoWzVdID8/ICcwJztcblxuICAgICAgdXJsID0gYGh0dHBzOi8vZG9jLmNyZHMuZGV2L3Jhdy9naXRodWIuY29tLyR7YWNjb3VudH0vJHtyZXBvfUB2JHttYWpvcn0uJHttaW5vcn0uJHtwYXRjaH1gO1xuICAgIH1cblxuICAgIHJldHVybiB1cmw7XG4gIH1cblxuICByZXR1cm4gdW5kZWZpbmVkO1xufVxuIl19
@@ -8,7 +8,6 @@ const k8s_1 = require("./k8s");
8
8
  const config_1 = require("../config");
9
9
  const util_1 = require("../util");
10
10
  async function importDispatch(imports, argv, options) {
11
- var _a;
12
11
  for (const importSpec of imports) {
13
12
  const importer = await matchImporter(importSpec, argv);
14
13
  if (!importer) {
@@ -19,7 +18,7 @@ async function importDispatch(imports, argv, options) {
19
18
  moduleNamePrefix: importSpec.moduleNamePrefix,
20
19
  ...options,
21
20
  });
22
- if ((_a = options.save) !== null && _a !== void 0 ? _a : true) {
21
+ if (options.save ?? true) {
23
22
  const spec = importSpec.moduleNamePrefix ? `${importSpec.moduleNamePrefix}${util_1.PREFIX_DELIM}${importSpec.source}` : importSpec.source;
24
23
  await (0, config_1.addImportToConfig)(spec);
25
24
  }
@@ -45,4 +44,4 @@ async function matchImporter(importSpec, argv) {
45
44
  return crd_1.ImportCustomResourceDefinition.fromSpec(importSpec);
46
45
  }
47
46
  exports.matchImporter = matchImporter;
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGF0Y2guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW1wb3J0L2Rpc3BhdGNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLCtCQUF1RDtBQUN2RCx5Q0FBNkM7QUFDN0MsaUNBQW9DO0FBQ3BDLCtCQUE0QztBQUM1QyxzQ0FBMEQ7QUFDMUQsa0NBQXVDO0FBRWhDLEtBQUssVUFBVSxjQUFjLENBQUMsT0FBcUIsRUFBRSxJQUFTLEVBQUUsT0FBc0I7O0lBQzNGLEtBQUssTUFBTSxVQUFVLElBQUksT0FBTyxFQUFFO1FBQ2hDLE1BQU0sUUFBUSxHQUFHLE1BQU0sYUFBYSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUV2RCxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2IsTUFBTSxJQUFJLEtBQUssQ0FBQyx3Q0FBd0MsVUFBVSxHQUFHLENBQUMsQ0FBQztTQUN4RTtRQUVELE9BQU8sQ0FBQyxLQUFLLENBQUMscURBQXFELENBQUMsQ0FBQztRQUVyRSxNQUFNLFFBQVEsQ0FBQyxNQUFNLENBQUM7WUFDcEIsZ0JBQWdCLEVBQUUsVUFBVSxDQUFDLGdCQUFnQjtZQUM3QyxHQUFHLE9BQU87U0FDWCxDQUFDLENBQUM7UUFFSCxJQUFJLE1BQUEsT0FBTyxDQUFDLElBQUksbUNBQUksSUFBSSxFQUFFO1lBQ3hCLE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsR0FBRyxVQUFVLENBQUMsZ0JBQWdCLEdBQUcsbUJBQVksR0FBRyxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUM7WUFDbkksTUFBTSxJQUFBLDBCQUFpQixFQUFDLElBQUksQ0FBQyxDQUFDO1NBQy9CO0tBQ0Y7QUFDSCxDQUFDO0FBcEJELHdDQW9CQztBQUVNLEtBQUssVUFBVSxhQUFhLENBQUMsVUFBc0IsRUFBRSxJQUFTO0lBRW5FLHFDQUFxQztJQUNyQyxNQUFNLEdBQUcsR0FBRyxNQUFNLHlCQUFtQixDQUFDLEtBQUssQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDOUQsSUFBSSxHQUFHLEVBQUU7UUFDUCxPQUFPLElBQUkseUJBQW1CLENBQUMsR0FBRyxDQUFDLENBQUM7S0FDckM7SUFFRCxNQUFNLE1BQU0sR0FBRyxVQUFVLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUUvQyxJQUFJLE1BQU0sS0FBSyxNQUFNLEVBQUU7UUFDckIsT0FBTyxpQkFBVSxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQztLQUN4QztJQUVELHFDQUFxQztJQUNyQyxNQUFNLFVBQVUsR0FBRyxJQUFBLDBCQUFlLEVBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3RELElBQUksVUFBVSxFQUFFO1FBQ2QsT0FBTyxvQ0FBOEIsQ0FBQyxRQUFRLENBQUMsRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLGdCQUFnQixFQUFFLFVBQVUsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7S0FDdkg7SUFFRCwwQkFBMEI7SUFDMUIsT0FBTyxvQ0FBOEIsQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUM7QUFDN0QsQ0FBQztBQXRCRCxzQ0FzQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbXBvcnRCYXNlLCBJbXBvcnRPcHRpb25zIH0gZnJvbSAnLi9iYXNlJztcbmltcG9ydCB7IEltcG9ydEN1c3RvbVJlc291cmNlRGVmaW5pdGlvbiB9IGZyb20gJy4vY3JkJztcbmltcG9ydCB7IG1hdGNoQ3Jkc0RldlVybCB9IGZyb20gJy4vY3Jkcy1kZXYnO1xuaW1wb3J0IHsgSW1wb3J0SGVsbSB9IGZyb20gJy4vaGVsbSc7XG5pbXBvcnQgeyBJbXBvcnRLdWJlcm5ldGVzQXBpIH0gZnJvbSAnLi9rOHMnO1xuaW1wb3J0IHsgSW1wb3J0U3BlYywgYWRkSW1wb3J0VG9Db25maWcgfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHsgUFJFRklYX0RFTElNIH0gZnJvbSAnLi4vdXRpbCc7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBpbXBvcnREaXNwYXRjaChpbXBvcnRzOiBJbXBvcnRTcGVjW10sIGFyZ3Y6IGFueSwgb3B0aW9uczogSW1wb3J0T3B0aW9ucykge1xuICBmb3IgKGNvbnN0IGltcG9ydFNwZWMgb2YgaW1wb3J0cykge1xuICAgIGNvbnN0IGltcG9ydGVyID0gYXdhaXQgbWF0Y2hJbXBvcnRlcihpbXBvcnRTcGVjLCBhcmd2KTtcblxuICAgIGlmICghaW1wb3J0ZXIpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdW5hYmxlIHRvIGRldGVybWluZSBpbXBvcnQgdHlwZSBmb3IgXCIke2ltcG9ydFNwZWN9XCJgKTtcbiAgICB9XG5cbiAgICBjb25zb2xlLmVycm9yKCdJbXBvcnRpbmcgcmVzb3VyY2VzLCB0aGlzIG1heSB0YWtlIGEgZmV3IG1vbWVudHMuLi4nKTtcblxuICAgIGF3YWl0IGltcG9ydGVyLmltcG9ydCh7XG4gICAgICBtb2R1bGVOYW1lUHJlZml4OiBpbXBvcnRTcGVjLm1vZHVsZU5hbWVQcmVmaXgsXG4gICAgICAuLi5vcHRpb25zLFxuICAgIH0pO1xuXG4gICAgaWYgKG9wdGlvbnMuc2F2ZSA/PyB0cnVlKSB7XG4gICAgICBjb25zdCBzcGVjID0gaW1wb3J0U3BlYy5tb2R1bGVOYW1lUHJlZml4ID8gYCR7aW1wb3J0U3BlYy5tb2R1bGVOYW1lUHJlZml4fSR7UFJFRklYX0RFTElNfSR7aW1wb3J0U3BlYy5zb3VyY2V9YCA6IGltcG9ydFNwZWMuc291cmNlO1xuICAgICAgYXdhaXQgYWRkSW1wb3J0VG9Db25maWcoc3BlYyk7XG4gICAgfVxuICB9XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBtYXRjaEltcG9ydGVyKGltcG9ydFNwZWM6IEltcG9ydFNwZWMsIGFyZ3Y6IGFueSk6IFByb21pc2U8SW1wb3J0QmFzZT4ge1xuXG4gIC8vIGZpcnN0IGNoZWNrIGlmIGl0cyBhIGBrOHNAYCBpbXBvcnRcbiAgY29uc3QgazhzID0gYXdhaXQgSW1wb3J0S3ViZXJuZXRlc0FwaS5tYXRjaChpbXBvcnRTcGVjLCBhcmd2KTtcbiAgaWYgKGs4cykge1xuICAgIHJldHVybiBuZXcgSW1wb3J0S3ViZXJuZXRlc0FwaShrOHMpO1xuICB9XG5cbiAgY29uc3QgcHJlZml4ID0gaW1wb3J0U3BlYy5zb3VyY2Uuc3BsaXQoJzonKVswXTtcblxuICBpZiAocHJlZml4ID09PSAnaGVsbScpIHtcbiAgICByZXR1cm4gSW1wb3J0SGVsbS5mcm9tU3BlYyhpbXBvcnRTcGVjKTtcbiAgfVxuXG4gIC8vIG5vdyBjaGVjayBpZiBpdHMgYSBjcmRzLmRldiBpbXBvcnRcbiAgY29uc3QgY3Jkc0RldlVybCA9IG1hdGNoQ3Jkc0RldlVybChpbXBvcnRTcGVjLnNvdXJjZSk7XG4gIGlmIChjcmRzRGV2VXJsKSB7XG4gICAgcmV0dXJuIEltcG9ydEN1c3RvbVJlc291cmNlRGVmaW5pdGlvbi5mcm9tU3BlYyh7IHNvdXJjZTogY3Jkc0RldlVybCwgbW9kdWxlTmFtZVByZWZpeDogaW1wb3J0U3BlYy5tb2R1bGVOYW1lUHJlZml4IH0pO1xuICB9XG5cbiAgLy8gZGVmYXVsdCB0byBhIG5vcm1hbCBDUkRcbiAgcmV0dXJuIEltcG9ydEN1c3RvbVJlc291cmNlRGVmaW5pdGlvbi5mcm9tU3BlYyhpbXBvcnRTcGVjKTtcbn0iXX0=
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGF0Y2guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW1wb3J0L2Rpc3BhdGNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLCtCQUF1RDtBQUN2RCx5Q0FBNkM7QUFDN0MsaUNBQW9DO0FBQ3BDLCtCQUE0QztBQUM1QyxzQ0FBMEQ7QUFDMUQsa0NBQXVDO0FBRWhDLEtBQUssVUFBVSxjQUFjLENBQUMsT0FBcUIsRUFBRSxJQUFTLEVBQUUsT0FBc0I7SUFDM0YsS0FBSyxNQUFNLFVBQVUsSUFBSSxPQUFPLEVBQUU7UUFDaEMsTUFBTSxRQUFRLEdBQUcsTUFBTSxhQUFhLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBRXZELElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixNQUFNLElBQUksS0FBSyxDQUFDLHdDQUF3QyxVQUFVLEdBQUcsQ0FBQyxDQUFDO1NBQ3hFO1FBRUQsT0FBTyxDQUFDLEtBQUssQ0FBQyxxREFBcUQsQ0FBQyxDQUFDO1FBRXJFLE1BQU0sUUFBUSxDQUFDLE1BQU0sQ0FBQztZQUNwQixnQkFBZ0IsRUFBRSxVQUFVLENBQUMsZ0JBQWdCO1lBQzdDLEdBQUcsT0FBTztTQUNYLENBQUMsQ0FBQztRQUVILElBQUksT0FBTyxDQUFDLElBQUksSUFBSSxJQUFJLEVBQUU7WUFDeEIsTUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxnQkFBZ0IsR0FBRyxtQkFBWSxHQUFHLFVBQVUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQztZQUNuSSxNQUFNLElBQUEsMEJBQWlCLEVBQUMsSUFBSSxDQUFDLENBQUM7U0FDL0I7S0FDRjtBQUNILENBQUM7QUFwQkQsd0NBb0JDO0FBRU0sS0FBSyxVQUFVLGFBQWEsQ0FBQyxVQUFzQixFQUFFLElBQVM7SUFFbkUscUNBQXFDO0lBQ3JDLE1BQU0sR0FBRyxHQUFHLE1BQU0seUJBQW1CLENBQUMsS0FBSyxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM5RCxJQUFJLEdBQUcsRUFBRTtRQUNQLE9BQU8sSUFBSSx5QkFBbUIsQ0FBQyxHQUFHLENBQUMsQ0FBQztLQUNyQztJQUVELE1BQU0sTUFBTSxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRS9DLElBQUksTUFBTSxLQUFLLE1BQU0sRUFBRTtRQUNyQixPQUFPLGlCQUFVLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0tBQ3hDO0lBRUQscUNBQXFDO0lBQ3JDLE1BQU0sVUFBVSxHQUFHLElBQUEsMEJBQWUsRUFBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDdEQsSUFBSSxVQUFVLEVBQUU7UUFDZCxPQUFPLG9DQUE4QixDQUFDLFFBQVEsQ0FBQyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FBQztLQUN2SDtJQUVELDBCQUEwQjtJQUMxQixPQUFPLG9DQUE4QixDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQztBQUM3RCxDQUFDO0FBdEJELHNDQXNCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEltcG9ydEJhc2UsIEltcG9ydE9wdGlvbnMgfSBmcm9tICcuL2Jhc2UnO1xuaW1wb3J0IHsgSW1wb3J0Q3VzdG9tUmVzb3VyY2VEZWZpbml0aW9uIH0gZnJvbSAnLi9jcmQnO1xuaW1wb3J0IHsgbWF0Y2hDcmRzRGV2VXJsIH0gZnJvbSAnLi9jcmRzLWRldic7XG5pbXBvcnQgeyBJbXBvcnRIZWxtIH0gZnJvbSAnLi9oZWxtJztcbmltcG9ydCB7IEltcG9ydEt1YmVybmV0ZXNBcGkgfSBmcm9tICcuL2s4cyc7XG5pbXBvcnQgeyBJbXBvcnRTcGVjLCBhZGRJbXBvcnRUb0NvbmZpZyB9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQgeyBQUkVGSVhfREVMSU0gfSBmcm9tICcuLi91dGlsJztcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGltcG9ydERpc3BhdGNoKGltcG9ydHM6IEltcG9ydFNwZWNbXSwgYXJndjogYW55LCBvcHRpb25zOiBJbXBvcnRPcHRpb25zKSB7XG4gIGZvciAoY29uc3QgaW1wb3J0U3BlYyBvZiBpbXBvcnRzKSB7XG4gICAgY29uc3QgaW1wb3J0ZXIgPSBhd2FpdCBtYXRjaEltcG9ydGVyKGltcG9ydFNwZWMsIGFyZ3YpO1xuXG4gICAgaWYgKCFpbXBvcnRlcikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGB1bmFibGUgdG8gZGV0ZXJtaW5lIGltcG9ydCB0eXBlIGZvciBcIiR7aW1wb3J0U3BlY31cImApO1xuICAgIH1cblxuICAgIGNvbnNvbGUuZXJyb3IoJ0ltcG9ydGluZyByZXNvdXJjZXMsIHRoaXMgbWF5IHRha2UgYSBmZXcgbW9tZW50cy4uLicpO1xuXG4gICAgYXdhaXQgaW1wb3J0ZXIuaW1wb3J0KHtcbiAgICAgIG1vZHVsZU5hbWVQcmVmaXg6IGltcG9ydFNwZWMubW9kdWxlTmFtZVByZWZpeCxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgfSk7XG5cbiAgICBpZiAob3B0aW9ucy5zYXZlID8/IHRydWUpIHtcbiAgICAgIGNvbnN0IHNwZWMgPSBpbXBvcnRTcGVjLm1vZHVsZU5hbWVQcmVmaXggPyBgJHtpbXBvcnRTcGVjLm1vZHVsZU5hbWVQcmVmaXh9JHtQUkVGSVhfREVMSU19JHtpbXBvcnRTcGVjLnNvdXJjZX1gIDogaW1wb3J0U3BlYy5zb3VyY2U7XG4gICAgICBhd2FpdCBhZGRJbXBvcnRUb0NvbmZpZyhzcGVjKTtcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1hdGNoSW1wb3J0ZXIoaW1wb3J0U3BlYzogSW1wb3J0U3BlYywgYXJndjogYW55KTogUHJvbWlzZTxJbXBvcnRCYXNlPiB7XG5cbiAgLy8gZmlyc3QgY2hlY2sgaWYgaXRzIGEgYGs4c0BgIGltcG9ydFxuICBjb25zdCBrOHMgPSBhd2FpdCBJbXBvcnRLdWJlcm5ldGVzQXBpLm1hdGNoKGltcG9ydFNwZWMsIGFyZ3YpO1xuICBpZiAoazhzKSB7XG4gICAgcmV0dXJuIG5ldyBJbXBvcnRLdWJlcm5ldGVzQXBpKGs4cyk7XG4gIH1cblxuICBjb25zdCBwcmVmaXggPSBpbXBvcnRTcGVjLnNvdXJjZS5zcGxpdCgnOicpWzBdO1xuXG4gIGlmIChwcmVmaXggPT09ICdoZWxtJykge1xuICAgIHJldHVybiBJbXBvcnRIZWxtLmZyb21TcGVjKGltcG9ydFNwZWMpO1xuICB9XG5cbiAgLy8gbm93IGNoZWNrIGlmIGl0cyBhIGNyZHMuZGV2IGltcG9ydFxuICBjb25zdCBjcmRzRGV2VXJsID0gbWF0Y2hDcmRzRGV2VXJsKGltcG9ydFNwZWMuc291cmNlKTtcbiAgaWYgKGNyZHNEZXZVcmwpIHtcbiAgICByZXR1cm4gSW1wb3J0Q3VzdG9tUmVzb3VyY2VEZWZpbml0aW9uLmZyb21TcGVjKHsgc291cmNlOiBjcmRzRGV2VXJsLCBtb2R1bGVOYW1lUHJlZml4OiBpbXBvcnRTcGVjLm1vZHVsZU5hbWVQcmVmaXggfSk7XG4gIH1cblxuICAvLyBkZWZhdWx0IHRvIGEgbm9ybWFsIENSRFxuICByZXR1cm4gSW1wb3J0Q3VzdG9tUmVzb3VyY2VEZWZpbml0aW9uLmZyb21TcGVjKGltcG9ydFNwZWMpO1xufSJdfQ==
@@ -65,10 +65,9 @@ class ImportHelm extends base_1.ImportBase {
65
65
  return [this.chartName];
66
66
  }
67
67
  async generateTypeScript(code) {
68
- var _a;
69
68
  (0, codegen_1.emitHelmHeader)(code);
70
69
  const types = new json2jsii_1.TypeGenerator({
71
- definitions: (_a = this.schema) === null || _a === void 0 ? void 0 : _a.definitions,
70
+ definitions: this.schema?.definitions,
72
71
  toJson: false,
73
72
  sanitizeEnums: true,
74
73
  });
@@ -171,4 +170,4 @@ function pullHelmRepo(chartUrl, chartName, chartVersion) {
171
170
  function cleanup(tmpDir) {
172
171
  fs.rmSync(tmpDir, { recursive: true });
173
172
  }
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helm.js","sourceRoot":"","sources":["../../src/import/helm.ts"],"names":[],"mappings":"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","sourcesContent":["import { spawnSync } from 'child_process';\nimport * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport { Yaml } from 'cdk8s';\nimport { CodeMaker } from 'codemaker';\nimport type { JSONSchema4 } from 'json-schema';\nimport { TypeGenerator } from 'json2jsii';\nimport * as semver from 'semver';\nimport { ImportBase } from './base';\nimport { emitHelmHeader, generateHelmConstruct } from './codegen';\nimport { ImportSpec } from '../config';\n\nconst MAX_HELM_BUFFER = 10 * 1024 * 1024;\nconst CHART_SCHEMA = 'values.schema.json';\nconst CHART_YAML = 'Chart.yaml';\n\nexport class ImportHelm extends ImportBase {\n  public static async fromSpec(importSpec: ImportSpec): Promise<ImportHelm> {\n    const { source } = importSpec;\n    return new ImportHelm(source);\n  }\n\n  private readonly chartName: string;\n  private readonly chartUrl: string;\n  private readonly chartVersion: string;\n  private readonly chartSchemaPath: string | undefined;\n  private readonly chartDependencies: string[] = [];\n  private readonly schema: JSONSchema4 | undefined;\n\n  private constructor(source: string) {\n    super();\n\n    const [chartUrl, chartName, chartVersion] = extractHelmChartDetails(source);\n\n    this.chartName = chartName;\n    this.chartUrl = chartUrl;\n    this.chartVersion = chartVersion;\n    const tmpDir = pullHelmRepo(chartUrl, chartName, chartVersion);\n\n    const chartYamlFilePath = path.join(tmpDir, this.chartName, CHART_YAML);\n    const contents = Yaml.load(chartYamlFilePath);\n\n    if (contents.length === 1 && contents[0].dependencies) {\n      for (const dependency of contents[0].dependencies) {\n        this.chartDependencies.push(dependency.name);\n      }\n    }\n\n    const potentialSchemaPath = path.join(tmpDir, this.chartName, CHART_SCHEMA);\n    this.chartSchemaPath = fs.existsSync(potentialSchemaPath) ? potentialSchemaPath : undefined;\n    this.schema = this.chartSchemaPath ? JSON.parse(fs.readFileSync(this.chartSchemaPath, 'utf-8')) : undefined;\n\n    cleanup(tmpDir);\n  }\n\n  public get moduleNames() {\n    return [this.chartName];\n  }\n\n  protected async generateTypeScript(code: CodeMaker) {\n    emitHelmHeader(code);\n\n    const types = new TypeGenerator({\n      definitions: this.schema?.definitions,\n      toJson: false,\n      sanitizeEnums: true,\n    });\n\n    generateHelmConstruct(types, {\n      schema: this.schema,\n      chartName: this.chartName,\n      chartUrl: this.chartUrl,\n      chartVersion: this.chartVersion,\n      chartDependencies: this.chartDependencies,\n      fqn: this.chartName,\n    });\n\n    code.line(types.render());\n  }\n}\n\n/**\n * Gets information about the helm chart from the helm url\n * @param url\n * @returns chartUrl, chartName and chartVersion\n */\nfunction extractHelmChartDetails(url: string) {\n\n  let chartUrl;\n  let chartName;\n  let chartVersion;\n\n  if (url.startsWith('helm:oci://')) {\n    // URL: helm:oci://registry-1.docker.io/bitnamicharts/wordpress@17.1.17\n    const helmRegex = /^helm:(oci:\\/\\/[A-Za-z0-9_.-:\\-]+)\\@([0-9]+)\\.([0-9]+)\\.([A-Za-z0-9-+]+)$/;\n    const helmDetails = helmRegex.exec(url);\n\n    if (!helmDetails) {\n      throw Error(`Invalid helm URL: ${url}. Must match the format: 'helm:<oci-registry-url>@<chart-version>'.`);\n    }\n\n    chartUrl = helmDetails[1];\n    const lastIndexOfSlash = chartUrl.lastIndexOf('/');\n    chartName = chartUrl.substring(lastIndexOfSlash + 1);\n\n    const major = helmDetails[2];\n    const minor = helmDetails[3];\n    const patch = helmDetails[4];\n    chartVersion = `${major}.${minor}.${patch}`;\n\n  } else {\n    // URL: helm:https://lacework.github.io/helm-charts/lacework-agent@6.9.0\n    const helmRegex = /^helm:([A-Za-z0-9_.-:\\-]+)\\/([A-Za-z0-9_.-:\\-]+)\\@([0-9]+)\\.([0-9]+)\\.([A-Za-z0-9-+]+)$/;\n    const helmDetails = helmRegex.exec(url);\n\n    if (!helmDetails) {\n      throw Error(`Invalid helm URL: ${url}. Must match the format: 'helm:<repo-url>/<chart-name>@<chart-version>'.`);\n    }\n\n    chartUrl = helmDetails[1];\n    chartName = helmDetails[2];\n\n    const major = helmDetails[3];\n    const minor = helmDetails[4];\n    const patch = helmDetails[5];\n    chartVersion = `${major}.${minor}.${patch}`;\n  }\n\n  if (!semver.valid(chartVersion)) {\n    throw new Error(`Invalid chart version (${chartVersion}) in URL: ${url}. Must follow SemVer-2 (see https://semver.org/).`);\n  }\n\n  return [chartUrl, chartName, chartVersion];\n}\n\n/**\n * Pulls the helm chart in a temporary directory\n * @param chartUrl Chart url\n * @param chartName Chart name\n * @param chartVersion Chart version\n * @returns Temporary directory path\n */\nfunction pullHelmRepo(chartUrl: string, chartName: string, chartVersion: string): string {\n  const workdir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk8s-helm-'));\n\n  const args = new Array<string>();\n  args.push('pull');\n\n  if (!chartUrl.startsWith('oci://')) {\n    args.push(chartName);\n    args.push('--repo', chartUrl);\n  } else {\n    args.push(chartUrl);\n  }\n\n  args.push('--version', chartVersion);\n  args.push('--untar');\n  args.push('--untardir', workdir);\n\n  const command = 'helm';\n\n  const helm = spawnSync(command, args, {\n    maxBuffer: MAX_HELM_BUFFER,\n  });\n\n  if (helm.error) {\n    const err = helm.error.message;\n    if (err.includes('ENOENT')) {\n      throw new Error(`Unable to execute '${command}' to pull the Helm chart. Is helm installed on your system?`);\n    }\n\n    throw new Error(`Failed pulling helm chart from URL (${chartUrl}): ${err}`);\n  }\n\n  if (helm.status !== 0) {\n    throw new Error(helm.stderr.toString());\n  }\n\n  return workdir;\n}\n\n/**\n * Cleanup temp directory created\n * @param tmpDir Temporary directory path\n */\nfunction cleanup(tmpDir: string) {\n  fs.rmSync(tmpDir, { recursive: true });\n}"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helm.js","sourceRoot":"","sources":["../../src/import/helm.ts"],"names":[],"mappings":"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","sourcesContent":["import { spawnSync } from 'child_process';\nimport * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport { Yaml } from 'cdk8s';\nimport { CodeMaker } from 'codemaker';\nimport type { JSONSchema4 } from 'json-schema';\nimport { TypeGenerator } from 'json2jsii';\nimport * as semver from 'semver';\nimport { ImportBase } from './base';\nimport { emitHelmHeader, generateHelmConstruct } from './codegen';\nimport { ImportSpec } from '../config';\n\nconst MAX_HELM_BUFFER = 10 * 1024 * 1024;\nconst CHART_SCHEMA = 'values.schema.json';\nconst CHART_YAML = 'Chart.yaml';\n\nexport class ImportHelm extends ImportBase {\n  public static async fromSpec(importSpec: ImportSpec): Promise<ImportHelm> {\n    const { source } = importSpec;\n    return new ImportHelm(source);\n  }\n\n  private readonly chartName: string;\n  private readonly chartUrl: string;\n  private readonly chartVersion: string;\n  private readonly chartSchemaPath: string | undefined;\n  private readonly chartDependencies: string[] = [];\n  private readonly schema: JSONSchema4 | undefined;\n\n  private constructor(source: string) {\n    super();\n\n    const [chartUrl, chartName, chartVersion] = extractHelmChartDetails(source);\n\n    this.chartName = chartName;\n    this.chartUrl = chartUrl;\n    this.chartVersion = chartVersion;\n    const tmpDir = pullHelmRepo(chartUrl, chartName, chartVersion);\n\n    const chartYamlFilePath = path.join(tmpDir, this.chartName, CHART_YAML);\n    const contents = Yaml.load(chartYamlFilePath);\n\n    if (contents.length === 1 && contents[0].dependencies) {\n      for (const dependency of contents[0].dependencies) {\n        this.chartDependencies.push(dependency.name);\n      }\n    }\n\n    const potentialSchemaPath = path.join(tmpDir, this.chartName, CHART_SCHEMA);\n    this.chartSchemaPath = fs.existsSync(potentialSchemaPath) ? potentialSchemaPath : undefined;\n    this.schema = this.chartSchemaPath ? JSON.parse(fs.readFileSync(this.chartSchemaPath, 'utf-8')) : undefined;\n\n    cleanup(tmpDir);\n  }\n\n  public get moduleNames() {\n    return [this.chartName];\n  }\n\n  protected async generateTypeScript(code: CodeMaker) {\n    emitHelmHeader(code);\n\n    const types = new TypeGenerator({\n      definitions: this.schema?.definitions,\n      toJson: false,\n      sanitizeEnums: true,\n    });\n\n    generateHelmConstruct(types, {\n      schema: this.schema,\n      chartName: this.chartName,\n      chartUrl: this.chartUrl,\n      chartVersion: this.chartVersion,\n      chartDependencies: this.chartDependencies,\n      fqn: this.chartName,\n    });\n\n    code.line(types.render());\n  }\n}\n\n/**\n * Gets information about the helm chart from the helm url\n * @param url\n * @returns chartUrl, chartName and chartVersion\n */\nfunction extractHelmChartDetails(url: string) {\n\n  let chartUrl;\n  let chartName;\n  let chartVersion;\n\n  if (url.startsWith('helm:oci://')) {\n    // URL: helm:oci://registry-1.docker.io/bitnamicharts/wordpress@17.1.17\n    const helmRegex = /^helm:(oci:\\/\\/[A-Za-z0-9_.-:\\-]+)\\@([0-9]+)\\.([0-9]+)\\.([A-Za-z0-9-+]+)$/;\n    const helmDetails = helmRegex.exec(url);\n\n    if (!helmDetails) {\n      throw Error(`Invalid helm URL: ${url}. Must match the format: 'helm:<oci-registry-url>@<chart-version>'.`);\n    }\n\n    chartUrl = helmDetails[1];\n    const lastIndexOfSlash = chartUrl.lastIndexOf('/');\n    chartName = chartUrl.substring(lastIndexOfSlash + 1);\n\n    const major = helmDetails[2];\n    const minor = helmDetails[3];\n    const patch = helmDetails[4];\n    chartVersion = `${major}.${minor}.${patch}`;\n\n  } else {\n    // URL: helm:https://lacework.github.io/helm-charts/lacework-agent@6.9.0\n    const helmRegex = /^helm:([A-Za-z0-9_.-:\\-]+)\\/([A-Za-z0-9_.-:\\-]+)\\@([0-9]+)\\.([0-9]+)\\.([A-Za-z0-9-+]+)$/;\n    const helmDetails = helmRegex.exec(url);\n\n    if (!helmDetails) {\n      throw Error(`Invalid helm URL: ${url}. Must match the format: 'helm:<repo-url>/<chart-name>@<chart-version>'.`);\n    }\n\n    chartUrl = helmDetails[1];\n    chartName = helmDetails[2];\n\n    const major = helmDetails[3];\n    const minor = helmDetails[4];\n    const patch = helmDetails[5];\n    chartVersion = `${major}.${minor}.${patch}`;\n  }\n\n  if (!semver.valid(chartVersion)) {\n    throw new Error(`Invalid chart version (${chartVersion}) in URL: ${url}. Must follow SemVer-2 (see https://semver.org/).`);\n  }\n\n  return [chartUrl, chartName, chartVersion];\n}\n\n/**\n * Pulls the helm chart in a temporary directory\n * @param chartUrl Chart url\n * @param chartName Chart name\n * @param chartVersion Chart version\n * @returns Temporary directory path\n */\nfunction pullHelmRepo(chartUrl: string, chartName: string, chartVersion: string): string {\n  const workdir = fs.mkdtempSync(path.join(os.tmpdir(), 'cdk8s-helm-'));\n\n  const args = new Array<string>();\n  args.push('pull');\n\n  if (!chartUrl.startsWith('oci://')) {\n    args.push(chartName);\n    args.push('--repo', chartUrl);\n  } else {\n    args.push(chartUrl);\n  }\n\n  args.push('--version', chartVersion);\n  args.push('--untar');\n  args.push('--untardir', workdir);\n\n  const command = 'helm';\n\n  const helm = spawnSync(command, args, {\n    maxBuffer: MAX_HELM_BUFFER,\n  });\n\n  if (helm.error) {\n    const err = helm.error.message;\n    if (err.includes('ENOENT')) {\n      throw new Error(`Unable to execute '${command}' to pull the Helm chart. Is helm installed on your system?`);\n    }\n\n    throw new Error(`Failed pulling helm chart from URL (${chartUrl}): ${err}`);\n  }\n\n  if (helm.status !== 0) {\n    throw new Error(helm.stderr.toString());\n  }\n\n  return workdir;\n}\n\n/**\n * Cleanup temp directory created\n * @param tmpDir Temporary directory path\n */\nfunction cleanup(tmpDir: string) {\n  fs.rmSync(tmpDir, { recursive: true });\n}"]}
@@ -17,7 +17,6 @@ var ApiLevel;
17
17
  * Parses a fully qualified type name such as to it's components.
18
18
  */
19
19
  function parseApiTypeName(fullname) {
20
- var _a, _b;
21
20
  const parts = fullname.split('.');
22
21
  const type = parts[parts.length - 1];
23
22
  const namespace = parts.slice(0, parts.length - 2).join('.');
@@ -28,8 +27,8 @@ function parseApiTypeName(fullname) {
28
27
  version: version ? {
29
28
  raw: version[0],
30
29
  major: parseInt(version[1]),
31
- level: (_a = version[3]) !== null && _a !== void 0 ? _a : ApiLevel.STABLE,
32
- subversion: parseInt((_b = version[4]) !== null && _b !== void 0 ? _b : '0'),
30
+ level: version[3] ?? ApiLevel.STABLE,
31
+ subversion: parseInt(version[4] ?? '0'),
33
32
  } : undefined,
34
33
  namespace: version ? namespace : `${namespace}.${prebase}`,
35
34
  basename: type,
@@ -47,4 +46,4 @@ function safeParseJsonSchema(text) {
47
46
  return schema;
48
47
  }
49
48
  exports.safeParseJsonSchema = safeParseJsonSchema;
50
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiazhzLXV0aWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW1wb3J0L2s4cy11dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLDhDQUFzQjtBQUl0Qix3Q0FBeUM7QUFDekMsa0NBQXdDO0FBNEJ4QyxJQUFLLFFBSUo7QUFKRCxXQUFLLFFBQVE7SUFDWCwyQkFBZSxDQUFBO0lBQ2YseUJBQWEsQ0FBQTtJQUNiLDZCQUFpQixDQUFBO0FBQ25CLENBQUMsRUFKSSxRQUFRLEtBQVIsUUFBUSxRQUlaO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixnQkFBZ0IsQ0FBQyxRQUFnQjs7SUFDL0MsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsQyxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUVyQyxNQUFNLFNBQVMsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM3RCxNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUN4QyxNQUFNLE9BQU8sR0FBRyxnQ0FBZ0MsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDL0QsT0FBTztRQUNMLFFBQVEsRUFBRSxRQUFRO1FBQ2xCLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1lBQ2pCLEdBQUcsRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO1lBQ2YsS0FBSyxFQUFFLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDM0IsS0FBSyxFQUFFLE1BQUEsT0FBTyxDQUFDLENBQUMsQ0FBYSxtQ0FBSSxRQUFRLENBQUMsTUFBTTtZQUNoRCxVQUFVLEVBQUUsUUFBUSxDQUFDLE1BQUEsT0FBTyxDQUFDLENBQUMsQ0FBQyxtQ0FBSSxHQUFHLENBQUM7U0FDeEMsQ0FBQyxDQUFDLENBQUMsU0FBUztRQUNiLFNBQVMsRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxTQUFTLElBQUksT0FBTyxFQUFFO1FBQzFELFFBQVEsRUFBRSxJQUFJO0tBQ2YsQ0FBQztBQUNKLENBQUM7QUFsQkQsNENBa0JDO0FBRUQsU0FBZ0IsbUJBQW1CLENBQUMsSUFBWTtJQUM5QyxNQUFNLE9BQU8sR0FBRyxJQUFJLHFCQUFXLENBQUM7UUFDOUIsZUFBZSxFQUFFLENBQUMsTUFBTSxFQUFFLFNBQVMsQ0FBQztRQUNwQyxVQUFVLEVBQUUsQ0FBQyxxQkFBVyxDQUFDLHFCQUFxQixFQUFFLHFCQUFXLENBQUMsb0JBQW9CLENBQUM7S0FDbEYsQ0FBQyxDQUFDO0lBQ0gsTUFBTSxNQUFNLEdBQUcsSUFBQSxvQkFBYSxFQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM1QyxNQUFNLEdBQUcsR0FBRyxJQUFJLGFBQUcsRUFBRSxDQUFDO0lBQ3RCLEdBQUcsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDcEIsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQVRELGtEQVNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFqdiBmcm9tICdhanYnO1xuLy8gd2UganVzdCBuZWVkIHRoZSB0eXBlcyBmcm9tIGpzb24tc2NoZW1hXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L25vLWV4dHJhbmVvdXMtZGVwZW5kZW5jaWVzXG5pbXBvcnQgeyBKU09OU2NoZW1hNCB9IGZyb20gJ2pzb24tc2NoZW1hJztcbmltcG9ydCB7IFNhZmVSZXZpdmVyIH0gZnJvbSAnLi4vcmV2aXZlcic7XG5pbXBvcnQgeyBzYWZlUGFyc2VKc29uIH0gZnJvbSAnLi4vdXRpbCc7XG5cblxuLyoqXG4gKlxuICogICAgIGlvLms4cy5hcGkuZXh0ZW5zaW9ucy52MWJldGExLkRlcGxveW1lbnRcbiAqICAgICB8LS0tLS0tLS0tIF4gLS0tLS0tLXwgIF4gIF4gXiB8LS0tXi0tLS18XG4gKiAgICAgICAgICAgICAgICB8ICAgICAgICAgICB8ICB8IHwgICAgIHxcbiAqICAtIG5hbWVzcGFjZSAtLSsgICAgICAgICAgIHwgIHwgfCAgICAgfFxuICogIC0gbWFqb3IgLS0tLS0tLS0tLS0tLS0tLS0tKyAgfCB8ICAgICB8XG4gKiAgLSBsZXZlbCAtLS0tLS0tLS0tLS0tLS0tLS0tLS0rIHwgICAgIHxcbiAqICAtIHN1YnZlcnNpb24gLS0tLS0tLS0tLS0tLS0tLS0tKyAgICAgfFxuICogIC0gYmFzZW5hbWUgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXBpVHlwZU5hbWUge1xuICBiYXNlbmFtZTogc3RyaW5nO1xuICBuYW1lc3BhY2U6IHN0cmluZztcbiAgZnVsbG5hbWU6IHN0cmluZztcbiAgdmVyc2lvbj86IEFwaVR5cGVWZXJzaW9uO1xufVxuXG5pbnRlcmZhY2UgQXBpVHlwZVZlcnNpb24ge1xuICByYXc6IHN0cmluZztcbiAgbGV2ZWw6IEFwaUxldmVsO1xuICBtYWpvcjogbnVtYmVyO1xuICBzdWJ2ZXJzaW9uOiBudW1iZXI7XG59XG5cbmVudW0gQXBpTGV2ZWwge1xuICBBTFBIQSA9ICdhbHBoYScsXG4gIEJFVEEgPSAnYmV0YScsXG4gIFNUQUJMRSA9ICdzdGFibGUnLFxufVxuXG4vKipcbiAqIFBhcnNlcyBhIGZ1bGx5IHF1YWxpZmllZCB0eXBlIG5hbWUgc3VjaCBhcyB0byBpdCdzIGNvbXBvbmVudHMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZUFwaVR5cGVOYW1lKGZ1bGxuYW1lOiBzdHJpbmcpOiBBcGlUeXBlTmFtZSB7XG4gIGNvbnN0IHBhcnRzID0gZnVsbG5hbWUuc3BsaXQoJy4nKTtcbiAgY29uc3QgdHlwZSA9IHBhcnRzW3BhcnRzLmxlbmd0aCAtIDFdO1xuXG4gIGNvbnN0IG5hbWVzcGFjZSA9IHBhcnRzLnNsaWNlKDAsIHBhcnRzLmxlbmd0aCAtIDIpLmpvaW4oJy4nKTtcbiAgY29uc3QgcHJlYmFzZSA9IHBhcnRzW3BhcnRzLmxlbmd0aCAtIDJdO1xuICBjb25zdCB2ZXJzaW9uID0gL152KFswLTldKykoKFthLXpdKykoWzAtOV0rKSk/JC8uZXhlYyhwcmViYXNlKTtcbiAgcmV0dXJuIHtcbiAgICBmdWxsbmFtZTogZnVsbG5hbWUsXG4gICAgdmVyc2lvbjogdmVyc2lvbiA/IHtcbiAgICAgIHJhdzogdmVyc2lvblswXSxcbiAgICAgIG1ham9yOiBwYXJzZUludCh2ZXJzaW9uWzFdKSxcbiAgICAgIGxldmVsOiB2ZXJzaW9uWzNdIGFzIEFwaUxldmVsID8/IEFwaUxldmVsLlNUQUJMRSxcbiAgICAgIHN1YnZlcnNpb246IHBhcnNlSW50KHZlcnNpb25bNF0gPz8gJzAnKSxcbiAgICB9IDogdW5kZWZpbmVkLFxuICAgIG5hbWVzcGFjZTogdmVyc2lvbiA/IG5hbWVzcGFjZSA6IGAke25hbWVzcGFjZX0uJHtwcmViYXNlfWAsXG4gICAgYmFzZW5hbWU6IHR5cGUsXG4gIH07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzYWZlUGFyc2VKc29uU2NoZW1hKHRleHQ6IHN0cmluZyk6IEpTT05TY2hlbWE0IHtcbiAgY29uc3QgcmV2aXZlciA9IG5ldyBTYWZlUmV2aXZlcih7XG4gICAgYWxsb3dsaXN0ZWRLZXlzOiBbJyRyZWYnLCAnJHNjaGVtYSddLFxuICAgIHNhbml0aXplcnM6IFtTYWZlUmV2aXZlci5ERVNDUklQVElPTl9TQU5JVElaRVIsIFNhZmVSZXZpdmVyLkxFR0FMX0NIQVJfU0FOSVRJWkVSXSxcbiAgfSk7XG4gIGNvbnN0IHNjaGVtYSA9IHNhZmVQYXJzZUpzb24odGV4dCwgcmV2aXZlcik7XG4gIGNvbnN0IGFqdiA9IG5ldyBBanYoKTtcbiAgYWp2LmNvbXBpbGUoc2NoZW1hKTtcbiAgcmV0dXJuIHNjaGVtYTtcbn1cbiJdfQ==
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiazhzLXV0aWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW1wb3J0L2s4cy11dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLDhDQUFzQjtBQUl0Qix3Q0FBeUM7QUFDekMsa0NBQXdDO0FBNEJ4QyxJQUFLLFFBSUo7QUFKRCxXQUFLLFFBQVE7SUFDWCwyQkFBZSxDQUFBO0lBQ2YseUJBQWEsQ0FBQTtJQUNiLDZCQUFpQixDQUFBO0FBQ25CLENBQUMsRUFKSSxRQUFRLEtBQVIsUUFBUSxRQUlaO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixnQkFBZ0IsQ0FBQyxRQUFnQjtJQUMvQyxNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2xDLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBRXJDLE1BQU0sU0FBUyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzdELE1BQU0sT0FBTyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ3hDLE1BQU0sT0FBTyxHQUFHLGdDQUFnQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMvRCxPQUFPO1FBQ0wsUUFBUSxFQUFFLFFBQVE7UUFDbEIsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDakIsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDZixLQUFLLEVBQUUsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUMzQixLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBYSxJQUFJLFFBQVEsQ0FBQyxNQUFNO1lBQ2hELFVBQVUsRUFBRSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLEdBQUcsQ0FBQztTQUN4QyxDQUFDLENBQUMsQ0FBQyxTQUFTO1FBQ2IsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLFNBQVMsSUFBSSxPQUFPLEVBQUU7UUFDMUQsUUFBUSxFQUFFLElBQUk7S0FDZixDQUFDO0FBQ0osQ0FBQztBQWxCRCw0Q0FrQkM7QUFFRCxTQUFnQixtQkFBbUIsQ0FBQyxJQUFZO0lBQzlDLE1BQU0sT0FBTyxHQUFHLElBQUkscUJBQVcsQ0FBQztRQUM5QixlQUFlLEVBQUUsQ0FBQyxNQUFNLEVBQUUsU0FBUyxDQUFDO1FBQ3BDLFVBQVUsRUFBRSxDQUFDLHFCQUFXLENBQUMscUJBQXFCLEVBQUUscUJBQVcsQ0FBQyxvQkFBb0IsQ0FBQztLQUNsRixDQUFDLENBQUM7SUFDSCxNQUFNLE1BQU0sR0FBRyxJQUFBLG9CQUFhLEVBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzVDLE1BQU0sR0FBRyxHQUFHLElBQUksYUFBRyxFQUFFLENBQUM7SUFDdEIsR0FBRyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNwQixPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBVEQsa0RBU0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQWp2IGZyb20gJ2Fqdic7XG4vLyB3ZSBqdXN0IG5lZWQgdGhlIHR5cGVzIGZyb20ganNvbi1zY2hlbWFcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQvbm8tZXh0cmFuZW91cy1kZXBlbmRlbmNpZXNcbmltcG9ydCB7IEpTT05TY2hlbWE0IH0gZnJvbSAnanNvbi1zY2hlbWEnO1xuaW1wb3J0IHsgU2FmZVJldml2ZXIgfSBmcm9tICcuLi9yZXZpdmVyJztcbmltcG9ydCB7IHNhZmVQYXJzZUpzb24gfSBmcm9tICcuLi91dGlsJztcblxuXG4vKipcbiAqXG4gKiAgICAgaW8uazhzLmFwaS5leHRlbnNpb25zLnYxYmV0YTEuRGVwbG95bWVudFxuICogICAgIHwtLS0tLS0tLS0gXiAtLS0tLS0tfCAgXiAgXiBeIHwtLS1eLS0tLXxcbiAqICAgICAgICAgICAgICAgIHwgICAgICAgICAgIHwgIHwgfCAgICAgfFxuICogIC0gbmFtZXNwYWNlIC0tKyAgICAgICAgICAgfCAgfCB8ICAgICB8XG4gKiAgLSBtYWpvciAtLS0tLS0tLS0tLS0tLS0tLS0rICB8IHwgICAgIHxcbiAqICAtIGxldmVsIC0tLS0tLS0tLS0tLS0tLS0tLS0tLSsgfCAgICAgfFxuICogIC0gc3VidmVyc2lvbiAtLS0tLS0tLS0tLS0tLS0tLS0rICAgICB8XG4gKiAgLSBiYXNlbmFtZSAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLStcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBcGlUeXBlTmFtZSB7XG4gIGJhc2VuYW1lOiBzdHJpbmc7XG4gIG5hbWVzcGFjZTogc3RyaW5nO1xuICBmdWxsbmFtZTogc3RyaW5nO1xuICB2ZXJzaW9uPzogQXBpVHlwZVZlcnNpb247XG59XG5cbmludGVyZmFjZSBBcGlUeXBlVmVyc2lvbiB7XG4gIHJhdzogc3RyaW5nO1xuICBsZXZlbDogQXBpTGV2ZWw7XG4gIG1ham9yOiBudW1iZXI7XG4gIHN1YnZlcnNpb246IG51bWJlcjtcbn1cblxuZW51bSBBcGlMZXZlbCB7XG4gIEFMUEhBID0gJ2FscGhhJyxcbiAgQkVUQSA9ICdiZXRhJyxcbiAgU1RBQkxFID0gJ3N0YWJsZScsXG59XG5cbi8qKlxuICogUGFyc2VzIGEgZnVsbHkgcXVhbGlmaWVkIHR5cGUgbmFtZSBzdWNoIGFzIHRvIGl0J3MgY29tcG9uZW50cy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHBhcnNlQXBpVHlwZU5hbWUoZnVsbG5hbWU6IHN0cmluZyk6IEFwaVR5cGVOYW1lIHtcbiAgY29uc3QgcGFydHMgPSBmdWxsbmFtZS5zcGxpdCgnLicpO1xuICBjb25zdCB0eXBlID0gcGFydHNbcGFydHMubGVuZ3RoIC0gMV07XG5cbiAgY29uc3QgbmFtZXNwYWNlID0gcGFydHMuc2xpY2UoMCwgcGFydHMubGVuZ3RoIC0gMikuam9pbignLicpO1xuICBjb25zdCBwcmViYXNlID0gcGFydHNbcGFydHMubGVuZ3RoIC0gMl07XG4gIGNvbnN0IHZlcnNpb24gPSAvXnYoWzAtOV0rKSgoW2Etel0rKShbMC05XSspKT8kLy5leGVjKHByZWJhc2UpO1xuICByZXR1cm4ge1xuICAgIGZ1bGxuYW1lOiBmdWxsbmFtZSxcbiAgICB2ZXJzaW9uOiB2ZXJzaW9uID8ge1xuICAgICAgcmF3OiB2ZXJzaW9uWzBdLFxuICAgICAgbWFqb3I6IHBhcnNlSW50KHZlcnNpb25bMV0pLFxuICAgICAgbGV2ZWw6IHZlcnNpb25bM10gYXMgQXBpTGV2ZWwgPz8gQXBpTGV2ZWwuU1RBQkxFLFxuICAgICAgc3VidmVyc2lvbjogcGFyc2VJbnQodmVyc2lvbls0XSA/PyAnMCcpLFxuICAgIH0gOiB1bmRlZmluZWQsXG4gICAgbmFtZXNwYWNlOiB2ZXJzaW9uID8gbmFtZXNwYWNlIDogYCR7bmFtZXNwYWNlfS4ke3ByZWJhc2V9YCxcbiAgICBiYXNlbmFtZTogdHlwZSxcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNhZmVQYXJzZUpzb25TY2hlbWEodGV4dDogc3RyaW5nKTogSlNPTlNjaGVtYTQge1xuICBjb25zdCByZXZpdmVyID0gbmV3IFNhZmVSZXZpdmVyKHtcbiAgICBhbGxvd2xpc3RlZEtleXM6IFsnJHJlZicsICckc2NoZW1hJ10sXG4gICAgc2FuaXRpemVyczogW1NhZmVSZXZpdmVyLkRFU0NSSVBUSU9OX1NBTklUSVpFUiwgU2FmZVJldml2ZXIuTEVHQUxfQ0hBUl9TQU5JVElaRVJdLFxuICB9KTtcbiAgY29uc3Qgc2NoZW1hID0gc2FmZVBhcnNlSnNvbih0ZXh0LCByZXZpdmVyKTtcbiAgY29uc3QgYWp2ID0gbmV3IEFqdigpO1xuICBhanYuY29tcGlsZShzY2hlbWEpO1xuICByZXR1cm4gc2NoZW1hO1xufVxuIl19
package/lib/import/k8s.js CHANGED
@@ -10,12 +10,11 @@ exports.DEFAULT_API_VERSION = '1.25.0';
10
10
  const DEFAULT_CLASS_NAME_PREFIX = 'Kube';
11
11
  class ImportKubernetesApi extends base_1.ImportBase {
12
12
  static async match(importSpec, argv) {
13
- var _a;
14
13
  const { source } = importSpec;
15
14
  if (source !== 'k8s' && !source.startsWith('k8s@')) {
16
15
  return undefined;
17
16
  }
18
- let k8sVersion = (_a = source.split('@')[1]) !== null && _a !== void 0 ? _a : exports.DEFAULT_API_VERSION;
17
+ let k8sVersion = source.split('@')[1] ?? exports.DEFAULT_API_VERSION;
19
18
  const k8sVersionRegex = /^\d+\.\d+\.\d+$/;
20
19
  if (!k8sVersionRegex.test(k8sVersion)) {
21
20
  throw new Error(`Expected k8s version "${k8sVersion}" to match format "<major>.<minor>.<patch>".`);
@@ -34,12 +33,11 @@ class ImportKubernetesApi extends base_1.ImportBase {
34
33
  return ['k8s'];
35
34
  }
36
35
  async generateTypeScript(code, moduleName, options) {
37
- var _a;
38
36
  const schema = await downloadSchema(this.options.apiVersion);
39
37
  if (moduleName !== 'k8s') {
40
38
  throw new Error(`unexpected module name "${moduleName}" when importing k8s types (expected "k8s")`);
41
39
  }
42
- const prefix = (_a = options.classNamePrefix) !== null && _a !== void 0 ? _a : DEFAULT_CLASS_NAME_PREFIX;
40
+ const prefix = options.classNamePrefix ?? DEFAULT_CLASS_NAME_PREFIX;
43
41
  const topLevelObjects = findApiObjectDefinitions(schema, prefix);
44
42
  const typeGenerator = new json2jsii_1.TypeGenerator({
45
43
  definitions: schema.definitions,
@@ -105,7 +103,6 @@ function findApiObjectDefinitions(schema, prefix) {
105
103
  }
106
104
  exports.findApiObjectDefinitions = findApiObjectDefinitions;
107
105
  function tryGetObjectName(def) {
108
- var _a;
109
106
  const objectNames = def[X_GROUP_VERSION_KIND];
110
107
  if (!objectNames) {
111
108
  return undefined;
@@ -117,7 +114,7 @@ function tryGetObjectName(def) {
117
114
  // skip definitions without "metadata". they are not API objects that can be defined
118
115
  // in manifests (example: io.k8s.apimachinery.pkg.apis.meta.v1.DeleteOptions)
119
116
  // they will be treated as data types
120
- if (!((_a = def.properties) === null || _a === void 0 ? void 0 : _a.metadata)) {
117
+ if (!def.properties?.metadata) {
121
118
  return undefined;
122
119
  }
123
120
  return objectName;
@@ -140,4 +137,4 @@ async function downloadSchema(apiVersion) {
140
137
  throw new Error(`Unable to parse schema at ${url}: ${e}`);
141
138
  }
142
139
  }
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"k8s.js","sourceRoot":"","sources":["../../src/import/k8s.ts"],"names":[],"mappings":"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","sourcesContent":["import { CodeMaker } from 'codemaker';\n\n// we just need the types from json-schema\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { JSONSchema4 } from 'json-schema';\n\nimport { TypeGenerator } from 'json2jsii';\nimport { GenerateOptions, ImportBase } from './base';\nimport { ApiObjectDefinition, emitHeader, generateConstruct, getPropsTypeName, getTypeName } from './codegen';\nimport { parseApiTypeName, safeParseJsonSchema } from './k8s-util';\nimport { ImportSpec } from '../config';\nimport { download } from '../util';\n\n\nexport const DEFAULT_API_VERSION = '1.25.0';\n\nconst DEFAULT_CLASS_NAME_PREFIX = 'Kube';\n\nexport interface ImportKubernetesApiOptions {\n  /**\n   * The API version to generate.\n   */\n  readonly apiVersion: string;\n\n  /**\n   * Do not import these types. Instead, represent them as \"any\".\n   *\n   * @default - include all types that derive from the root types.\n   */\n  readonly exclude?: string[];\n}\n\nexport class ImportKubernetesApi extends ImportBase {\n\n  public static async match(importSpec: ImportSpec, argv: any): Promise<ImportKubernetesApiOptions | undefined> {\n    const { source } = importSpec;\n    if (source !== 'k8s' && !source.startsWith('k8s@')) {\n      return undefined;\n    }\n\n    let k8sVersion = source.split('@')[1] ?? DEFAULT_API_VERSION;\n\n    const k8sVersionRegex = /^\\d+\\.\\d+\\.\\d+$/;\n    if (!k8sVersionRegex.test(k8sVersion)) {\n      throw new Error(`Expected k8s version \"${k8sVersion}\" to match format \"<major>.<minor>.<patch>\".`);\n    }\n\n    console.error(`Importing k8s v${k8sVersion}...`);\n\n    return {\n      apiVersion: k8sVersion,\n      exclude: argv.exclude,\n    };\n  }\n\n  constructor(private readonly options: ImportKubernetesApiOptions) {\n    super();\n  }\n\n  public get moduleNames() {\n    return ['k8s'];\n  }\n\n  protected async generateTypeScript(code: CodeMaker, moduleName: string, options: GenerateOptions) {\n    const schema = await downloadSchema(this.options.apiVersion);\n\n    if (moduleName !== 'k8s') {\n      throw new Error(`unexpected module name \"${moduleName}\" when importing k8s types (expected \"k8s\")`);\n    }\n\n    const prefix = options.classNamePrefix ?? DEFAULT_CLASS_NAME_PREFIX;\n    const topLevelObjects = findApiObjectDefinitions(schema, prefix);\n\n    const typeGenerator = new TypeGenerator({\n      definitions: schema.definitions,\n      exclude: this.options.exclude,\n      renderTypeName: (def: string) => {\n        const parsed = parseApiTypeName(def);\n        if (!parsed.version) {\n          // not a versioned api type. return basename\n          return parsed.basename;\n        }\n        return getTypeName(false, parsed.basename, parsed.version.raw);\n      },\n    });\n\n    // rename \"Props\" type from their original name based on the API object kind\n    // (e.g. `Deployment`) to their actual props type (`KubeDeploymentProps`) in\n    // order to avoid confusion between constructs (`KubeDeployment`) and those\n    // types. This is done by simply replacing their definition in the schema\n    // with a $ref to the definition of the props type.\n    for (const o of topLevelObjects) {\n      typeGenerator.addDefinition(o.fqn, { $ref: `#/definitions/${getPropsTypeName(o)}` });\n    }\n\n    // emit construct types (recursive)\n    for (const o of topLevelObjects) {\n      generateConstruct(typeGenerator, o);\n    }\n\n    emitHeader(code, false);\n\n    code.line(typeGenerator.render());\n  }\n}\n\n/**\n * Returns a map of all API objects in the spec (objects that have the\n * 'x-kubernetes-group-version-kind' annotation).\n *\n * The key is the base name of the type (i.e. `Deployment`). Since API objects\n * may have multiple versions, each value in the map is an array of type definitions\n * along with version information.\n *\n * @see https://kubernetes.io/docs/concepts/overview/kubernetes-api/#api-versioning\n */\nexport function findApiObjectDefinitions(schema: JSONSchema4, prefix: string): ApiObjectDefinition[] {\n  const result = new Array<ApiObjectDefinition>();\n\n  for (const [typename, apischema] of Object.entries(schema.definitions || { })) {\n    const objectName = tryGetObjectName(apischema);\n    if (!objectName) {\n      continue;\n    }\n\n    const type = parseApiTypeName(typename);\n    if (!type.version) {\n      throw new Error(`Unable to parse version for type: ${typename}`);\n    }\n    result.push({\n      custom: false, // not a CRD\n      fqn: type.fullname,\n      group: objectName.group,\n      kind: objectName.kind,\n      version: objectName.version,\n      schema: apischema,\n      prefix,\n    });\n  }\n\n  return result;\n}\n\nfunction tryGetObjectName(def: JSONSchema4): GroupVersionKind | undefined {\n  const objectNames = def[X_GROUP_VERSION_KIND] as GroupVersionKind[];\n  if (!objectNames) {\n    return undefined;\n  }\n\n  const objectName = objectNames[0];\n  if (!objectName) {\n    return undefined;\n  }\n\n  // skip definitions without \"metadata\". they are not API objects that can be defined\n  // in manifests (example: io.k8s.apimachinery.pkg.apis.meta.v1.DeleteOptions)\n  // they will be treated as data types\n  if (!def.properties?.metadata) {\n    return undefined;\n  }\n\n  return objectName;\n}\n\nexport interface GroupVersionKind {\n  readonly group: string;\n  readonly kind: string;\n  readonly version: string;\n}\n\nconst X_GROUP_VERSION_KIND = 'x-kubernetes-group-version-kind';\n\nasync function downloadSchema(apiVersion: string) {\n  const url = `https://raw.githubusercontent.com/cdk8s-team/cdk8s/master/kubernetes-schemas/v${apiVersion}/_definitions.json`;\n  let output;\n  try {\n    output = await download(url);\n  } catch (e) {\n    console.error(`Could not find a schema for k8s version ${apiVersion}. The current list of available schemas is at https://github.com/cdk8s-team/cdk8s/tree/master/kubernetes-schemas.`);\n    throw e;\n  }\n  try {\n    return safeParseJsonSchema(output) as JSONSchema4;\n  } catch (e) {\n    throw new Error(`Unable to parse schema at ${url}: ${e}`);\n  }\n}\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"k8s.js","sourceRoot":"","sources":["../../src/import/k8s.ts"],"names":[],"mappings":"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","sourcesContent":["import { CodeMaker } from 'codemaker';\n\n// we just need the types from json-schema\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { JSONSchema4 } from 'json-schema';\n\nimport { TypeGenerator } from 'json2jsii';\nimport { GenerateOptions, ImportBase } from './base';\nimport { ApiObjectDefinition, emitHeader, generateConstruct, getPropsTypeName, getTypeName } from './codegen';\nimport { parseApiTypeName, safeParseJsonSchema } from './k8s-util';\nimport { ImportSpec } from '../config';\nimport { download } from '../util';\n\n\nexport const DEFAULT_API_VERSION = '1.25.0';\n\nconst DEFAULT_CLASS_NAME_PREFIX = 'Kube';\n\nexport interface ImportKubernetesApiOptions {\n  /**\n   * The API version to generate.\n   */\n  readonly apiVersion: string;\n\n  /**\n   * Do not import these types. Instead, represent them as \"any\".\n   *\n   * @default - include all types that derive from the root types.\n   */\n  readonly exclude?: string[];\n}\n\nexport class ImportKubernetesApi extends ImportBase {\n\n  public static async match(importSpec: ImportSpec, argv: any): Promise<ImportKubernetesApiOptions | undefined> {\n    const { source } = importSpec;\n    if (source !== 'k8s' && !source.startsWith('k8s@')) {\n      return undefined;\n    }\n\n    let k8sVersion = source.split('@')[1] ?? DEFAULT_API_VERSION;\n\n    const k8sVersionRegex = /^\\d+\\.\\d+\\.\\d+$/;\n    if (!k8sVersionRegex.test(k8sVersion)) {\n      throw new Error(`Expected k8s version \"${k8sVersion}\" to match format \"<major>.<minor>.<patch>\".`);\n    }\n\n    console.error(`Importing k8s v${k8sVersion}...`);\n\n    return {\n      apiVersion: k8sVersion,\n      exclude: argv.exclude,\n    };\n  }\n\n  constructor(private readonly options: ImportKubernetesApiOptions) {\n    super();\n  }\n\n  public get moduleNames() {\n    return ['k8s'];\n  }\n\n  protected async generateTypeScript(code: CodeMaker, moduleName: string, options: GenerateOptions) {\n    const schema = await downloadSchema(this.options.apiVersion);\n\n    if (moduleName !== 'k8s') {\n      throw new Error(`unexpected module name \"${moduleName}\" when importing k8s types (expected \"k8s\")`);\n    }\n\n    const prefix = options.classNamePrefix ?? DEFAULT_CLASS_NAME_PREFIX;\n    const topLevelObjects = findApiObjectDefinitions(schema, prefix);\n\n    const typeGenerator = new TypeGenerator({\n      definitions: schema.definitions,\n      exclude: this.options.exclude,\n      renderTypeName: (def: string) => {\n        const parsed = parseApiTypeName(def);\n        if (!parsed.version) {\n          // not a versioned api type. return basename\n          return parsed.basename;\n        }\n        return getTypeName(false, parsed.basename, parsed.version.raw);\n      },\n    });\n\n    // rename \"Props\" type from their original name based on the API object kind\n    // (e.g. `Deployment`) to their actual props type (`KubeDeploymentProps`) in\n    // order to avoid confusion between constructs (`KubeDeployment`) and those\n    // types. This is done by simply replacing their definition in the schema\n    // with a $ref to the definition of the props type.\n    for (const o of topLevelObjects) {\n      typeGenerator.addDefinition(o.fqn, { $ref: `#/definitions/${getPropsTypeName(o)}` });\n    }\n\n    // emit construct types (recursive)\n    for (const o of topLevelObjects) {\n      generateConstruct(typeGenerator, o);\n    }\n\n    emitHeader(code, false);\n\n    code.line(typeGenerator.render());\n  }\n}\n\n/**\n * Returns a map of all API objects in the spec (objects that have the\n * 'x-kubernetes-group-version-kind' annotation).\n *\n * The key is the base name of the type (i.e. `Deployment`). Since API objects\n * may have multiple versions, each value in the map is an array of type definitions\n * along with version information.\n *\n * @see https://kubernetes.io/docs/concepts/overview/kubernetes-api/#api-versioning\n */\nexport function findApiObjectDefinitions(schema: JSONSchema4, prefix: string): ApiObjectDefinition[] {\n  const result = new Array<ApiObjectDefinition>();\n\n  for (const [typename, apischema] of Object.entries(schema.definitions || { })) {\n    const objectName = tryGetObjectName(apischema);\n    if (!objectName) {\n      continue;\n    }\n\n    const type = parseApiTypeName(typename);\n    if (!type.version) {\n      throw new Error(`Unable to parse version for type: ${typename}`);\n    }\n    result.push({\n      custom: false, // not a CRD\n      fqn: type.fullname,\n      group: objectName.group,\n      kind: objectName.kind,\n      version: objectName.version,\n      schema: apischema,\n      prefix,\n    });\n  }\n\n  return result;\n}\n\nfunction tryGetObjectName(def: JSONSchema4): GroupVersionKind | undefined {\n  const objectNames = def[X_GROUP_VERSION_KIND] as GroupVersionKind[];\n  if (!objectNames) {\n    return undefined;\n  }\n\n  const objectName = objectNames[0];\n  if (!objectName) {\n    return undefined;\n  }\n\n  // skip definitions without \"metadata\". they are not API objects that can be defined\n  // in manifests (example: io.k8s.apimachinery.pkg.apis.meta.v1.DeleteOptions)\n  // they will be treated as data types\n  if (!def.properties?.metadata) {\n    return undefined;\n  }\n\n  return objectName;\n}\n\nexport interface GroupVersionKind {\n  readonly group: string;\n  readonly kind: string;\n  readonly version: string;\n}\n\nconst X_GROUP_VERSION_KIND = 'x-kubernetes-group-version-kind';\n\nasync function downloadSchema(apiVersion: string) {\n  const url = `https://raw.githubusercontent.com/cdk8s-team/cdk8s/master/kubernetes-schemas/v${apiVersion}/_definitions.json`;\n  let output;\n  try {\n    output = await download(url);\n  } catch (e) {\n    console.error(`Could not find a schema for k8s version ${apiVersion}. The current list of available schemas is at https://github.com/cdk8s-team/cdk8s/tree/master/kubernetes-schemas.`);\n    throw e;\n  }\n  try {\n    return safeParseJsonSchema(output) as JSONSchema4;\n  } catch (e) {\n    throw new Error(`Unable to parse schema at ${url}: ${e}`);\n  }\n}\n"]}
@@ -38,13 +38,12 @@ class PluginManager {
38
38
  this.dir = dir;
39
39
  }
40
40
  load(options) {
41
- var _a, _b;
42
- const pkg = this.loadPackage(options.pkg, options.version, (_a = options.installEnv) !== null && _a !== void 0 ? _a : {});
41
+ const pkg = this.loadPackage(options.pkg, options.version, options.installEnv ?? {});
43
42
  const clazz = pkg.module[options.class];
44
43
  if (!clazz) {
45
44
  throw new Error(`Unable to locate class '${options.class}' in package '${options.pkg}@${options.version}'. Are you sure you exported it?`);
46
45
  }
47
- return { instance: new clazz((_b = options.properties) !== null && _b !== void 0 ? _b : {}), class: options.class, package: pkg };
46
+ return { instance: new clazz(options.properties ?? {}), class: options.class, package: pkg };
48
47
  }
49
48
  loadPackage(pkg, version, installEnv) {
50
49
  if (isRange(version)) {
@@ -103,7 +102,7 @@ class PluginManager {
103
102
  const modulePath = require.resolve(spec);
104
103
  // eslint-disable-next-line @typescript-eslint/no-require-imports
105
104
  const module = require(modulePath);
106
- return { version, pkg: pluginName !== null && pluginName !== void 0 ? pluginName : spec, path: modulePath, module };
105
+ return { version, pkg: pluginName ?? spec, path: modulePath, module };
107
106
  }
108
107
  pluginDir(pkg, version) {
109
108
  return path.join(this.dir, pkg, version, 'node_modules', pkg);
@@ -121,4 +120,4 @@ exports.PluginManager = PluginManager;
121
120
  function isRange(version) {
122
121
  return new semver.Range(version).range !== version;
123
122
  }
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"_manager.js","sourceRoot":"","sources":["../../src/plugins/_manager.ts"],"names":[],"mappings":"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","sourcesContent":["import * as child from 'child_process';\nimport * as path from 'path';\nimport * as url from 'url';\nimport * as fs from 'fs-extra';\nimport * as semver from 'semver';\n\nconst MODULE_NOT_FOUND_ERROR_CODE = 'MODULE_NOT_FOUND'; // TODO is there a known constant we can use here?\n\n/**\n * Information about a loaded plugin.\n */\nexport interface Plugin {\n\n  /**\n   * The instance of the plugin class.\n   */\n  readonly instance: unknown;\n\n  /**\n   * The plugin class name.\n   */\n  readonly class: string;\n\n  /**\n   * The plugin package.\n   */\n  readonly package: Package;\n\n}\n\n/**\n * Information about a plugin package.\n */\nexport interface Package {\n\n  /**\n   * The plugin module.\n   */\n  readonly module: ReturnType<NodeRequire>;\n\n  /**\n    * The npm package of the plugin.\n    */\n  readonly pkg: string;\n\n  /**\n    * The version of the plugin.\n    */\n  readonly version: string;\n\n  /**\n    * The path of the plugin on the local system (after its installed).\n    */\n  readonly path: string;\n\n}\n\n/**\n * Options for loading a plugin.\n */\nexport interface PluginManagerLoadOptions {\n\n  /**\n   * The plugin package name.\n   */\n  readonly pkg: string;\n\n  /**\n   * The plugin package version.\n   */\n  readonly version: string;\n\n  /**\n   * The plugin package class.\n   */\n  readonly class: string;\n\n  /**\n   * Installation environment (passed on to npm install)\n   */\n  readonly installEnv?: { [key: string]: any };\n\n  /**\n   * Plugin instantiation properties.\n   */\n  readonly properties?: { [key: string]: any };\n\n}\n\n/**\n * A `PluginManager` is responsible for loading (and installing) plugins.\n */\nexport class PluginManager {\n\n  constructor(private readonly dir: string) {}\n\n  public load(options: PluginManagerLoadOptions): Plugin {\n\n    const pkg = this.loadPackage(options.pkg, options.version, options.installEnv ?? {});\n\n    const clazz = pkg.module[options.class];\n    if (!clazz) {\n      throw new Error(`Unable to locate class '${options.class}' in package '${options.pkg}@${options.version}'. Are you sure you exported it?`);\n    }\n\n    return { instance: new clazz(options.properties ?? {}), class: options.class, package: pkg };\n  }\n\n  private loadPackage(pkg: string, version: string, installEnv: { [key: string]: any }): Package {\n\n    if (isRange(version)) {\n      // we forbid version ranges because it might give the false impression we will be installing\n      // the latest version (which we will not because it would mean contacting NPM on every synth)\n      throw new Error(`Unsupported version spec for package ${pkg}: ${version}. Cannot be a range.`);\n    }\n\n    const proto = url.parse(pkg).protocol;\n\n    if (proto) {\n      // urls are not supported because they don't provide a name with which we can 'require' the module.\n      // if needed, we can make the loader smarter and enable this, but not for now.\n      throw new Error(`Unsupported package reference: ${pkg}. Can either be an NPM package name, or a local path to a directory`);\n    }\n\n    const local = path.isAbsolute(pkg)\n      // assume relative paths start with '.' because otherise they\n      // are easily confused with npm package names.\n      || pkg.startsWith(`.${path.sep}`);\n\n    // local plugins are loaded directly, npm packages are loaded\n    // from the plugins directory.\n    const modulePath = local ? path.resolve(process.cwd(), pkg) : this.pluginDir(pkg, version);\n    const pluginName = local ? modulePath : pkg;\n\n    try {\n      return this.require(modulePath, version, pluginName);\n    } catch (e: any) {\n\n      if (![MODULE_NOT_FOUND_ERROR_CODE].includes(e.code)) {\n        // some unexpected error\n        throw e;\n      }\n\n      if (local) {\n        // if a local plugin is missing, nothing we can do about it\n        throw e;\n      }\n\n      // otherwise, we install from npm and re-require.\n      this.installPackage(pkg, version, installEnv);\n      return this.require(modulePath, version, pluginName);\n    }\n\n  }\n\n  private installPackage(pkg: string, version: string, env: { [key: string]: any }) {\n\n    const pluginDir = path.join(this.dir, pkg, version);\n    fs.mkdirpSync(pluginDir);\n\n    const command = [\n      'npm',\n      'install', `${pkg}@${version}`,\n      '--no-save',\n      '--prefix', pluginDir,\n    ].join(' ');\n\n    const finalEnv = { ...process.env };\n    for (const [key, value] of Object.entries(env)) {\n      finalEnv[key] = typeof value === 'string' ? key : JSON.stringify(value);\n    }\n    console.log(`Installing validation plugin: ${pkg}@${version} (this may take a while the first time around)`);\n    child.execSync(command, { stdio: ['ignore', 'pipe', 'pipe'], env: finalEnv });\n  }\n\n  private require(spec: string, version: string, pluginName: string): Package {\n\n    const modulePath = require.resolve(spec);\n\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const module = require(modulePath);\n\n    return { version, pkg: pluginName ?? spec, path: modulePath, module };\n  }\n\n  private pluginDir(pkg: string, version: string) {\n    return path.join(this.dir, pkg, version, 'node_modules', pkg);\n  }\n\n}\n\n/**\n * Checks if a given version represents a range, or a pinned version.\n * For example:\n *\n *   - '1.x expands to '>=1.0.0 <2.0.0-0'\n *   - `~1.2' expands to '>=1.2.0 <1.3.0-0'\n *   - '1.2.3' expands to '1.2.3'\n */\nfunction isRange(version: string) {\n  return new semver.Range(version).range !== version;\n}"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"_manager.js","sourceRoot":"","sources":["../../src/plugins/_manager.ts"],"names":[],"mappings":"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","sourcesContent":["import * as child from 'child_process';\nimport * as path from 'path';\nimport * as url from 'url';\nimport * as fs from 'fs-extra';\nimport * as semver from 'semver';\n\nconst MODULE_NOT_FOUND_ERROR_CODE = 'MODULE_NOT_FOUND'; // TODO is there a known constant we can use here?\n\n/**\n * Information about a loaded plugin.\n */\nexport interface Plugin {\n\n  /**\n   * The instance of the plugin class.\n   */\n  readonly instance: unknown;\n\n  /**\n   * The plugin class name.\n   */\n  readonly class: string;\n\n  /**\n   * The plugin package.\n   */\n  readonly package: Package;\n\n}\n\n/**\n * Information about a plugin package.\n */\nexport interface Package {\n\n  /**\n   * The plugin module.\n   */\n  readonly module: ReturnType<NodeRequire>;\n\n  /**\n    * The npm package of the plugin.\n    */\n  readonly pkg: string;\n\n  /**\n    * The version of the plugin.\n    */\n  readonly version: string;\n\n  /**\n    * The path of the plugin on the local system (after its installed).\n    */\n  readonly path: string;\n\n}\n\n/**\n * Options for loading a plugin.\n */\nexport interface PluginManagerLoadOptions {\n\n  /**\n   * The plugin package name.\n   */\n  readonly pkg: string;\n\n  /**\n   * The plugin package version.\n   */\n  readonly version: string;\n\n  /**\n   * The plugin package class.\n   */\n  readonly class: string;\n\n  /**\n   * Installation environment (passed on to npm install)\n   */\n  readonly installEnv?: { [key: string]: any };\n\n  /**\n   * Plugin instantiation properties.\n   */\n  readonly properties?: { [key: string]: any };\n\n}\n\n/**\n * A `PluginManager` is responsible for loading (and installing) plugins.\n */\nexport class PluginManager {\n\n  constructor(private readonly dir: string) {}\n\n  public load(options: PluginManagerLoadOptions): Plugin {\n\n    const pkg = this.loadPackage(options.pkg, options.version, options.installEnv ?? {});\n\n    const clazz = pkg.module[options.class];\n    if (!clazz) {\n      throw new Error(`Unable to locate class '${options.class}' in package '${options.pkg}@${options.version}'. Are you sure you exported it?`);\n    }\n\n    return { instance: new clazz(options.properties ?? {}), class: options.class, package: pkg };\n  }\n\n  private loadPackage(pkg: string, version: string, installEnv: { [key: string]: any }): Package {\n\n    if (isRange(version)) {\n      // we forbid version ranges because it might give the false impression we will be installing\n      // the latest version (which we will not because it would mean contacting NPM on every synth)\n      throw new Error(`Unsupported version spec for package ${pkg}: ${version}. Cannot be a range.`);\n    }\n\n    const proto = url.parse(pkg).protocol;\n\n    if (proto) {\n      // urls are not supported because they don't provide a name with which we can 'require' the module.\n      // if needed, we can make the loader smarter and enable this, but not for now.\n      throw new Error(`Unsupported package reference: ${pkg}. Can either be an NPM package name, or a local path to a directory`);\n    }\n\n    const local = path.isAbsolute(pkg)\n      // assume relative paths start with '.' because otherise they\n      // are easily confused with npm package names.\n      || pkg.startsWith(`.${path.sep}`);\n\n    // local plugins are loaded directly, npm packages are loaded\n    // from the plugins directory.\n    const modulePath = local ? path.resolve(process.cwd(), pkg) : this.pluginDir(pkg, version);\n    const pluginName = local ? modulePath : pkg;\n\n    try {\n      return this.require(modulePath, version, pluginName);\n    } catch (e: any) {\n\n      if (![MODULE_NOT_FOUND_ERROR_CODE].includes(e.code)) {\n        // some unexpected error\n        throw e;\n      }\n\n      if (local) {\n        // if a local plugin is missing, nothing we can do about it\n        throw e;\n      }\n\n      // otherwise, we install from npm and re-require.\n      this.installPackage(pkg, version, installEnv);\n      return this.require(modulePath, version, pluginName);\n    }\n\n  }\n\n  private installPackage(pkg: string, version: string, env: { [key: string]: any }) {\n\n    const pluginDir = path.join(this.dir, pkg, version);\n    fs.mkdirpSync(pluginDir);\n\n    const command = [\n      'npm',\n      'install', `${pkg}@${version}`,\n      '--no-save',\n      '--prefix', pluginDir,\n    ].join(' ');\n\n    const finalEnv = { ...process.env };\n    for (const [key, value] of Object.entries(env)) {\n      finalEnv[key] = typeof value === 'string' ? key : JSON.stringify(value);\n    }\n    console.log(`Installing validation plugin: ${pkg}@${version} (this may take a while the first time around)`);\n    child.execSync(command, { stdio: ['ignore', 'pipe', 'pipe'], env: finalEnv });\n  }\n\n  private require(spec: string, version: string, pluginName: string): Package {\n\n    const modulePath = require.resolve(spec);\n\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const module = require(modulePath);\n\n    return { version, pkg: pluginName ?? spec, path: modulePath, module };\n  }\n\n  private pluginDir(pkg: string, version: string) {\n    return path.join(this.dir, pkg, version, 'node_modules', pkg);\n  }\n\n}\n\n/**\n * Checks if a given version represents a range, or a pinned version.\n * For example:\n *\n *   - '1.x expands to '>=1.0.0 <2.0.0-0'\n *   - `~1.2' expands to '>=1.2.0 <1.3.0-0'\n *   - '1.2.3' expands to '1.2.3'\n */\nfunction isRange(version: string) {\n  return new semver.Range(version).range !== version;\n}"]}