node-backpack 0.0.556 → 0.0.557

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.
@@ -109,7 +109,6 @@ class Attributions {
109
109
  .join('\n');
110
110
  }
111
111
  generateAttributions() {
112
- var _a, _b;
113
112
  if (this.dependencies.length === 0) {
114
113
  return new Map();
115
114
  }
@@ -131,7 +130,7 @@ class Attributions {
131
130
  // sometimes the dependency might not exist from fetching information globally,
132
131
  // so we try fetching a concrete package. this can happen for example when
133
132
  // two different major versions exist of the same dependency.
134
- const info = (_a = infos[key]) !== null && _a !== void 0 ? _a : fetchInfos(dep.path, [pkg(dep)])[key];
133
+ const info = infos[key] ?? fetchInfos(dep.path, [pkg(dep)])[key];
135
134
  if (!info) {
136
135
  // make sure all dependencies are accounted for.
137
136
  throw new Error(`Unable to locate license information for ${key} (${dep.path})`);
@@ -141,7 +140,7 @@ class Attributions {
141
140
  // text. this seems strange, disabling that for now.
142
141
  // see https://github.com/davglass/license-checker/blob/master/lib/license-files.js#L9
143
142
  // note that a non existing license file is ok as long as the license type could be extracted.
144
- const licenseFile = ((_b = info.licenseFile) === null || _b === void 0 ? void 0 : _b.toLowerCase().endsWith('.md')) ? undefined : info.licenseFile;
143
+ const licenseFile = info.licenseFile?.toLowerCase().endsWith('.md') ? undefined : info.licenseFile;
145
144
  const licenseText = licenseFile ? fs.readFileSync(licenseFile, { encoding: 'utf-8' }) : undefined;
146
145
  // the licenses key comes in different types but we convert it here
147
146
  // to always be an array.
@@ -149,7 +148,7 @@ class Attributions {
149
148
  attributions.set(key, {
150
149
  package: key,
151
150
  url: `https://www.npmjs.com/package/${dep.name}/v/${dep.version}`,
152
- licenses: licenses !== null && licenses !== void 0 ? licenses : [],
151
+ licenses: licenses ?? [],
153
152
  licenseText,
154
153
  noticeText,
155
154
  });
@@ -158,4 +157,4 @@ class Attributions {
158
157
  }
159
158
  }
160
159
  exports.Attributions = Attributions;
161
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"_attributions.js","sourceRoot":"","sources":["../../src/api/_attributions.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport type { ModuleInfo } from 'license-checker';\nimport { shell } from './_shell';\nimport type { Package } from './bundle';\nimport { Violation, ViolationType, ViolationsReport } from './violation';\n\n\nconst ATTRIBUTION_SEPARATOR = '\\n----------------\\n';\n\n/**\n * Properties for `Attributions`.\n */\nexport interface AttributionsProps {\n  /**\n   * The package root directory.\n   */\n  readonly packageDir: string;\n  /**\n   * The name of the package.\n   */\n  readonly packageName: string;\n  /**\n   * Package dependencies.\n   */\n  readonly dependencies: Package[];\n  /**\n   * The parent directory underwhich all dependencies live.\n   */\n  readonly dependenciesRoot: string;\n  /**\n   * Path to the notice file to created / validated.\n   */\n  readonly filePath: string;\n  /**\n   * List of allowed licenses.\n   *\n   */\n  readonly allowedLicenses: string[];\n  /**\n   * Dependencies matching this pattern will be excluded from attribution.\n   *\n   * @default - no exclusions.\n   */\n  readonly exclude?: string;\n}\n\n/**\n * `Attributions` represents an attributions file containing third-party license information.\n */\nexport class Attributions {\n\n  private readonly packageDir: string;\n  private readonly packageName: string;\n  private readonly dependencies: Package[];\n  private readonly allowedLicenses: string[];\n  private readonly dependenciesRoot: string;\n  private readonly filePath: string;\n\n  private readonly attributions: Map<string, Attribution>;\n  private readonly content: string;\n\n  constructor(props: AttributionsProps) {\n    this.packageDir = props.packageDir;\n    this.packageName = props.packageName;\n    this.filePath = path.join(this.packageDir, props.filePath);\n    this.dependencies = props.dependencies.filter(d => !props.exclude || !new RegExp(props.exclude).test(d.name));\n    this.allowedLicenses = props.allowedLicenses.map(l => l.toLowerCase());\n    this.dependenciesRoot = props.dependenciesRoot;\n\n    // without the generated notice content, this object is pretty much\n    // useless, so lets generate those of the bat.\n    this.attributions = this.generateAttributions();\n    this.content = this.render(this.attributions);\n  }\n\n  /**\n   * Validate the current notice file.\n   *\n   * This method never throws. The Caller is responsible for inspecting the report returned and act accordinagly.\n   */\n  public validate(): ViolationsReport {\n\n    const violations: Violation[] = [];\n    const relNoticePath = path.relative(this.packageDir, this.filePath);\n\n    const fix = () => this.flush();\n\n    const missing = !fs.existsSync(this.filePath);\n    const attributions = missing ? undefined : fs.readFileSync(this.filePath, { encoding: 'utf-8' });\n    const outdated = attributions !== undefined && attributions !== this.content;\n\n    if (missing) {\n      violations.push({ type: ViolationType.MISSING_NOTICE, message: `${relNoticePath} is missing`, fix });\n    }\n\n    if (outdated) {\n      violations.push({ type: ViolationType.OUTDATED_ATTRIBUTIONS, message: `${relNoticePath} is outdated`, fix });\n    }\n\n    const invalidLicense: Violation[] = Array.from(this.attributions.values())\n      .filter(a => a.licenses.length === 1 && !this.allowedLicenses.includes(a.licenses[0].toLowerCase()))\n      .map(a => ({ type: ViolationType.INVALID_LICENSE, message: `Dependency ${a.package} has an invalid license: ${a.licenses[0]}` }));\n\n    const noLicense: Violation[] = Array.from(this.attributions.values())\n      .filter(a => a.licenses.length === 0)\n      .map(a => ({ type: ViolationType.NO_LICENSE, message: `Dependency ${a.package} has no license` }));\n\n    const multiLicense: Violation[] = Array.from(this.attributions.values())\n      .filter(a => a.licenses.length > 1)\n      .map(a => ({ type: ViolationType.MULTIPLE_LICENSE, message: `Dependency ${a.package} has multiple licenses: ${a.licenses}` }));\n\n    violations.push(...invalidLicense);\n    violations.push(...noLicense);\n    violations.push(...multiLicense);\n\n    return new ViolationsReport(violations);\n  }\n\n  /**\n   * Flush the generated notice file to disk.\n   */\n  public flush() {\n    fs.writeFileSync(this.filePath, this.content);\n  }\n\n  private render(attributions: Map<string, Attribution>): string {\n\n    const content = [];\n\n    if (attributions.size > 0) {\n      content.push(`The ${this.packageName} package includes the following third-party software/licensing:`);\n      content.push('');\n    }\n\n    // sort the attributions so the file doesn't change due to ordering issues\n    const ordered = Array.from(attributions.values()).sort((a1, a2) => a1.package.localeCompare(a2.package));\n\n    for (const attr of ordered) {\n      content.push(`** ${attr.package} - ${attr.url} | ${attr.licenses[0]}`);\n\n      // prefer notice over license\n      if (attr.noticeText) {\n        content.push(attr.noticeText);\n      } else if (attr.licenseText) {\n        content.push(attr.licenseText);\n      }\n      content.push(ATTRIBUTION_SEPARATOR);\n    }\n\n    return content\n      // since we are embedding external files, those can different line\n      // endings, so we standardize to LF.\n      .map(l => l.replace(/\\r\\n/g, '\\n'))\n      .join('\\n');\n\n  }\n\n  private generateAttributions(): Map<string, Attribution> {\n\n    if (this.dependencies.length === 0) {\n      return new Map();\n    }\n\n    const attributions: Map<string, Attribution> = new Map();\n\n    const pkg = (d: Package) => `${d.name}@${d.version}`;\n\n    const packages = this.dependencies.map(d => pkg(d));\n\n    function fetchInfos(_cwd: string, _packages: string[]) {\n      // we don't use the programmatic API since it only offers an async API.\n      // prefer to stay sync for now since its easier to integrate with other tooling.\n      // will offer an async API further down the road.\n      const command = `${require.resolve('license-checker/bin/license-checker')} --json --packages \"${_packages.join(';')}\"`;\n      const output = shell(command, { cwd: _cwd, quiet: true });\n      return JSON.parse(output);\n    }\n\n    // first run a global command to fetch as much information in one shot\n    const infos = fetchInfos(this.dependenciesRoot, packages);\n\n    for (const dep of this.dependencies) {\n      const key = pkg(dep);\n\n      // sometimes the dependency might not exist from fetching information globally,\n      // so we try fetching a concrete package. this can happen for example when\n      // two different major versions exist of the same dependency.\n      const info: ModuleInfo = infos[key] ?? fetchInfos(dep.path, [pkg(dep)])[key];\n\n      if (!info) {\n        // make sure all dependencies are accounted for.\n        throw new Error(`Unable to locate license information for ${key} (${dep.path})`);\n      }\n\n      const noticeText = info.noticeFile ? fs.readFileSync(info.noticeFile, { encoding: 'utf-8' }) : undefined;\n\n      // for some reason, the license-checker package falls back to the README.md file of the package for license\n      // text. this seems strange, disabling that for now.\n      // see https://github.com/davglass/license-checker/blob/master/lib/license-files.js#L9\n      // note that a non existing license file is ok as long as the license type could be extracted.\n      const licenseFile = info.licenseFile?.toLowerCase().endsWith('.md') ? undefined : info.licenseFile;\n      const licenseText = licenseFile ? fs.readFileSync(licenseFile, { encoding: 'utf-8' }) : undefined;\n\n      // the licenses key comes in different types but we convert it here\n      // to always be an array.\n      const licenses = !info.licenses ? undefined : (Array.isArray(info.licenses) ? info.licenses : [info.licenses]);\n\n      attributions.set(key, {\n        package: key,\n        url: `https://www.npmjs.com/package/${dep.name}/v/${dep.version}`,\n        licenses: licenses ?? [],\n        licenseText,\n        noticeText,\n      });\n    }\n\n    return attributions;\n  }\n\n}\n\n/**\n * Attribution of a specific dependency.\n */\ninterface Attribution {\n  /**\n   * Attributed package (name + version)\n   */\n  readonly package: string;\n  /**\n   * URL to the package.\n   */\n  readonly url: string;\n  /**\n   * Package licenses.\n   *\n   * Note that some packages will may have multiple licenses,\n   * which is why this is an array. In such cases, the license\n   * validation will fail since we currently disallow this.\n   */\n  readonly licenses: string[];\n  /**\n   * Package license content.\n   *\n   * In case a package has multiple licenses, this will\n   * contain...one of them. It currently doesn't matter which\n   * one since it will not pass validation anyway.\n   */\n  readonly licenseText?: string;\n  /**\n   * Package notice.\n   */\n  readonly noticeText?: string;\n}\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"_attributions.js","sourceRoot":"","sources":["../../src/api/_attributions.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport type { ModuleInfo } from 'license-checker';\nimport { shell } from './_shell';\nimport type { Package } from './bundle';\nimport { Violation, ViolationType, ViolationsReport } from './violation';\n\n\nconst ATTRIBUTION_SEPARATOR = '\\n----------------\\n';\n\n/**\n * Properties for `Attributions`.\n */\nexport interface AttributionsProps {\n  /**\n   * The package root directory.\n   */\n  readonly packageDir: string;\n  /**\n   * The name of the package.\n   */\n  readonly packageName: string;\n  /**\n   * Package dependencies.\n   */\n  readonly dependencies: Package[];\n  /**\n   * The parent directory underwhich all dependencies live.\n   */\n  readonly dependenciesRoot: string;\n  /**\n   * Path to the notice file to created / validated.\n   */\n  readonly filePath: string;\n  /**\n   * List of allowed licenses.\n   *\n   */\n  readonly allowedLicenses: string[];\n  /**\n   * Dependencies matching this pattern will be excluded from attribution.\n   *\n   * @default - no exclusions.\n   */\n  readonly exclude?: string;\n}\n\n/**\n * `Attributions` represents an attributions file containing third-party license information.\n */\nexport class Attributions {\n\n  private readonly packageDir: string;\n  private readonly packageName: string;\n  private readonly dependencies: Package[];\n  private readonly allowedLicenses: string[];\n  private readonly dependenciesRoot: string;\n  private readonly filePath: string;\n\n  private readonly attributions: Map<string, Attribution>;\n  private readonly content: string;\n\n  constructor(props: AttributionsProps) {\n    this.packageDir = props.packageDir;\n    this.packageName = props.packageName;\n    this.filePath = path.join(this.packageDir, props.filePath);\n    this.dependencies = props.dependencies.filter(d => !props.exclude || !new RegExp(props.exclude).test(d.name));\n    this.allowedLicenses = props.allowedLicenses.map(l => l.toLowerCase());\n    this.dependenciesRoot = props.dependenciesRoot;\n\n    // without the generated notice content, this object is pretty much\n    // useless, so lets generate those of the bat.\n    this.attributions = this.generateAttributions();\n    this.content = this.render(this.attributions);\n  }\n\n  /**\n   * Validate the current notice file.\n   *\n   * This method never throws. The Caller is responsible for inspecting the report returned and act accordinagly.\n   */\n  public validate(): ViolationsReport {\n\n    const violations: Violation[] = [];\n    const relNoticePath = path.relative(this.packageDir, this.filePath);\n\n    const fix = () => this.flush();\n\n    const missing = !fs.existsSync(this.filePath);\n    const attributions = missing ? undefined : fs.readFileSync(this.filePath, { encoding: 'utf-8' });\n    const outdated = attributions !== undefined && attributions !== this.content;\n\n    if (missing) {\n      violations.push({ type: ViolationType.MISSING_NOTICE, message: `${relNoticePath} is missing`, fix });\n    }\n\n    if (outdated) {\n      violations.push({ type: ViolationType.OUTDATED_ATTRIBUTIONS, message: `${relNoticePath} is outdated`, fix });\n    }\n\n    const invalidLicense: Violation[] = Array.from(this.attributions.values())\n      .filter(a => a.licenses.length === 1 && !this.allowedLicenses.includes(a.licenses[0].toLowerCase()))\n      .map(a => ({ type: ViolationType.INVALID_LICENSE, message: `Dependency ${a.package} has an invalid license: ${a.licenses[0]}` }));\n\n    const noLicense: Violation[] = Array.from(this.attributions.values())\n      .filter(a => a.licenses.length === 0)\n      .map(a => ({ type: ViolationType.NO_LICENSE, message: `Dependency ${a.package} has no license` }));\n\n    const multiLicense: Violation[] = Array.from(this.attributions.values())\n      .filter(a => a.licenses.length > 1)\n      .map(a => ({ type: ViolationType.MULTIPLE_LICENSE, message: `Dependency ${a.package} has multiple licenses: ${a.licenses}` }));\n\n    violations.push(...invalidLicense);\n    violations.push(...noLicense);\n    violations.push(...multiLicense);\n\n    return new ViolationsReport(violations);\n  }\n\n  /**\n   * Flush the generated notice file to disk.\n   */\n  public flush() {\n    fs.writeFileSync(this.filePath, this.content);\n  }\n\n  private render(attributions: Map<string, Attribution>): string {\n\n    const content = [];\n\n    if (attributions.size > 0) {\n      content.push(`The ${this.packageName} package includes the following third-party software/licensing:`);\n      content.push('');\n    }\n\n    // sort the attributions so the file doesn't change due to ordering issues\n    const ordered = Array.from(attributions.values()).sort((a1, a2) => a1.package.localeCompare(a2.package));\n\n    for (const attr of ordered) {\n      content.push(`** ${attr.package} - ${attr.url} | ${attr.licenses[0]}`);\n\n      // prefer notice over license\n      if (attr.noticeText) {\n        content.push(attr.noticeText);\n      } else if (attr.licenseText) {\n        content.push(attr.licenseText);\n      }\n      content.push(ATTRIBUTION_SEPARATOR);\n    }\n\n    return content\n      // since we are embedding external files, those can different line\n      // endings, so we standardize to LF.\n      .map(l => l.replace(/\\r\\n/g, '\\n'))\n      .join('\\n');\n\n  }\n\n  private generateAttributions(): Map<string, Attribution> {\n\n    if (this.dependencies.length === 0) {\n      return new Map();\n    }\n\n    const attributions: Map<string, Attribution> = new Map();\n\n    const pkg = (d: Package) => `${d.name}@${d.version}`;\n\n    const packages = this.dependencies.map(d => pkg(d));\n\n    function fetchInfos(_cwd: string, _packages: string[]) {\n      // we don't use the programmatic API since it only offers an async API.\n      // prefer to stay sync for now since its easier to integrate with other tooling.\n      // will offer an async API further down the road.\n      const command = `${require.resolve('license-checker/bin/license-checker')} --json --packages \"${_packages.join(';')}\"`;\n      const output = shell(command, { cwd: _cwd, quiet: true });\n      return JSON.parse(output);\n    }\n\n    // first run a global command to fetch as much information in one shot\n    const infos = fetchInfos(this.dependenciesRoot, packages);\n\n    for (const dep of this.dependencies) {\n      const key = pkg(dep);\n\n      // sometimes the dependency might not exist from fetching information globally,\n      // so we try fetching a concrete package. this can happen for example when\n      // two different major versions exist of the same dependency.\n      const info: ModuleInfo = infos[key] ?? fetchInfos(dep.path, [pkg(dep)])[key];\n\n      if (!info) {\n        // make sure all dependencies are accounted for.\n        throw new Error(`Unable to locate license information for ${key} (${dep.path})`);\n      }\n\n      const noticeText = info.noticeFile ? fs.readFileSync(info.noticeFile, { encoding: 'utf-8' }) : undefined;\n\n      // for some reason, the license-checker package falls back to the README.md file of the package for license\n      // text. this seems strange, disabling that for now.\n      // see https://github.com/davglass/license-checker/blob/master/lib/license-files.js#L9\n      // note that a non existing license file is ok as long as the license type could be extracted.\n      const licenseFile = info.licenseFile?.toLowerCase().endsWith('.md') ? undefined : info.licenseFile;\n      const licenseText = licenseFile ? fs.readFileSync(licenseFile, { encoding: 'utf-8' }) : undefined;\n\n      // the licenses key comes in different types but we convert it here\n      // to always be an array.\n      const licenses = !info.licenses ? undefined : (Array.isArray(info.licenses) ? info.licenses : [info.licenses]);\n\n      attributions.set(key, {\n        package: key,\n        url: `https://www.npmjs.com/package/${dep.name}/v/${dep.version}`,\n        licenses: licenses ?? [],\n        licenseText,\n        noticeText,\n      });\n    }\n\n    return attributions;\n  }\n\n}\n\n/**\n * Attribution of a specific dependency.\n */\ninterface Attribution {\n  /**\n   * Attributed package (name + version)\n   */\n  readonly package: string;\n  /**\n   * URL to the package.\n   */\n  readonly url: string;\n  /**\n   * Package licenses.\n   *\n   * Note that some packages will may have multiple licenses,\n   * which is why this is an array. In such cases, the license\n   * validation will fail since we currently disallow this.\n   */\n  readonly licenses: string[];\n  /**\n   * Package license content.\n   *\n   * In case a package has multiple licenses, this will\n   * contain...one of them. It currently doesn't matter which\n   * one since it will not pass validation anyway.\n   */\n  readonly licenseText?: string;\n  /**\n   * Package notice.\n   */\n  readonly noticeText?: string;\n}\n"]}
package/lib/api/bundle.js CHANGED
@@ -44,17 +44,16 @@ const DEFAULT_ALLOWED_LICENSES = [
44
44
  */
45
45
  class Bundle {
46
46
  constructor(props) {
47
- var _a, _b, _c, _d, _e;
48
47
  this.packageDir = props.packageDir;
49
- this.noticePath = (_a = props.attributionsFile) !== null && _a !== void 0 ? _a : 'THIRD_PARTY_LICENSES';
48
+ this.noticePath = props.attributionsFile ?? 'THIRD_PARTY_LICENSES';
50
49
  this.manifest = fs.readJsonSync(path.join(this.packageDir, 'package.json'));
51
- this.externals = (_b = props.externals) !== null && _b !== void 0 ? _b : {};
52
- this.resources = (_c = props.resources) !== null && _c !== void 0 ? _c : {};
50
+ this.externals = props.externals ?? {};
51
+ this.resources = props.resources ?? {};
53
52
  this.test = props.test;
54
- this.allowedLicenses = (_d = props.allowedLicenses) !== null && _d !== void 0 ? _d : DEFAULT_ALLOWED_LICENSES;
53
+ this.allowedLicenses = props.allowedLicenses ?? DEFAULT_ALLOWED_LICENSES;
55
54
  this.dontAttribute = props.dontAttribute;
56
55
  this.entryPoints = {};
57
- const entryPoints = (_e = props.entryPoints) !== null && _e !== void 0 ? _e : (this.manifest.main ? [this.manifest.main] : []);
56
+ const entryPoints = props.entryPoints ?? (this.manifest.main ? [this.manifest.main] : []);
58
57
  if (entryPoints.length === 0) {
59
58
  throw new Error('Must configure at least 1 entrypoint');
60
59
  }
@@ -75,8 +74,7 @@ class Bundle {
75
74
  * returned report and act accordingly.
76
75
  */
77
76
  validate(options = {}) {
78
- var _a;
79
- const fix = (_a = options.fix) !== null && _a !== void 0 ? _a : false;
77
+ const fix = options.fix ?? false;
80
78
  // first validate
81
79
  const circularImports = this.validateCircularImports();
82
80
  const resources = this.validateResources();
@@ -124,8 +122,7 @@ class Bundle {
124
122
  * Returns the location of the tarball.
125
123
  */
126
124
  pack(options = {}) {
127
- var _a;
128
- const target = (_a = options.target) !== null && _a !== void 0 ? _a : this.packageDir;
125
+ const target = options.target ?? this.packageDir;
129
126
  const report = this.validate();
130
127
  if (!report.success) {
131
128
  throw new Error(`Unable to pack due to validation errors.\n\n${report.summary}`);
@@ -196,15 +193,14 @@ class Bundle {
196
193
  return this._attributions;
197
194
  }
198
195
  findExternalDependencyVersion(name) {
199
- var _a, _b;
200
196
  const versions = new Set();
201
197
  // external dependencies will not exist in the dependencies list
202
198
  // since esbuild skips over them. but they will exist as a dependency of
203
199
  // one of them (or of us)
204
200
  for (const pkg of [...this.dependencies, this.createPackage(this.packageDir)]) {
205
201
  const manifest = fs.readJSONSync(path.join(pkg.path, 'package.json'));
206
- const runtime = ((_a = manifest.dependencies) !== null && _a !== void 0 ? _a : {})[name];
207
- const optional = ((_b = manifest.optionalDependencies) !== null && _b !== void 0 ? _b : {})[name];
202
+ const runtime = (manifest.dependencies ?? {})[name];
203
+ const optional = (manifest.optionalDependencies ?? {})[name];
208
204
  const pin = (version) => (version.startsWith('^') || version.startsWith('~')) ? version.substring(1) : version;
209
205
  if (runtime) {
210
206
  versions.add(pin(runtime));
@@ -236,7 +232,6 @@ class Bundle {
236
232
  return { path: packageDir, name: manifest.name, version: manifest.version };
237
233
  }
238
234
  esbuild() {
239
- var _a, _b;
240
235
  const bundle = esbuild.buildSync({
241
236
  entryPoints: this.entryPoints,
242
237
  bundle: true,
@@ -246,7 +241,7 @@ class Bundle {
246
241
  metafile: true,
247
242
  treeShaking: true,
248
243
  absWorkingDir: this.packageDir,
249
- external: [...((_a = this.externals.dependencies) !== null && _a !== void 0 ? _a : []), ...((_b = this.externals.optionalDependencies) !== null && _b !== void 0 ? _b : [])],
244
+ external: [...(this.externals.dependencies ?? []), ...(this.externals.optionalDependencies ?? [])],
250
245
  write: false,
251
246
  outdir: this.packageDir,
252
247
  allowOverwrite: true,
@@ -295,31 +290,28 @@ class Bundle {
295
290
  return this.attributions.validate().violations;
296
291
  }
297
292
  addExternals(manifest) {
298
- var _a, _b, _c, _d;
299
293
  // external dependencies should be specified as runtime dependencies
300
- for (const external of (_a = this.externals.dependencies) !== null && _a !== void 0 ? _a : []) {
294
+ for (const external of this.externals.dependencies ?? []) {
301
295
  const version = this.findExternalDependencyVersion(external);
302
- manifest.dependencies = (_b = manifest.dependencies) !== null && _b !== void 0 ? _b : {};
296
+ manifest.dependencies = manifest.dependencies ?? {};
303
297
  manifest.dependencies[external] = version;
304
298
  }
305
299
  // external dependencies should be specified as optional dependencies
306
- for (const external of (_c = this.externals.optionalDependencies) !== null && _c !== void 0 ? _c : []) {
300
+ for (const external of this.externals.optionalDependencies ?? []) {
307
301
  const version = this.findExternalDependencyVersion(external);
308
- manifest.optionalDependencies = (_d = manifest.optionalDependencies) !== null && _d !== void 0 ? _d : {};
302
+ manifest.optionalDependencies = manifest.optionalDependencies ?? {};
309
303
  manifest.optionalDependencies[external] = version;
310
304
  }
311
305
  }
312
306
  removeDependencies(manifest) {
313
- var _a;
314
307
  for (const [d, v] of Object.entries(this.manifest.dependencies)) {
315
- manifest.devDependencies = (_a = manifest.devDependencies) !== null && _a !== void 0 ? _a : {};
308
+ manifest.devDependencies = manifest.devDependencies ?? {};
316
309
  manifest.devDependencies[d] = v;
317
310
  delete manifest.dependencies[d];
318
311
  }
319
312
  }
320
313
  writeOutputs(workDir) {
321
- var _a;
322
- for (const output of (_a = this.bundle.outputFiles) !== null && _a !== void 0 ? _a : []) {
314
+ for (const output of this.bundle.outputFiles ?? []) {
323
315
  const out = output.path.replace(this.packageDir, workDir);
324
316
  fs.writeFileSync(out, output.contents);
325
317
  }
@@ -349,4 +341,4 @@ function longestCommonParent(paths) {
349
341
  }
350
342
  return paths.reduce(_longestCommonParent);
351
343
  }
352
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle.js","sourceRoot":"","sources":["../../src/api/bundle.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as path from 'path';\nimport * as esbuild from 'esbuild';\nimport * as fs from 'fs-extra';\nimport { Attributions } from './_attributions';\nimport { shell } from './_shell';\nimport { Violation, ViolationType, ViolationsReport } from './violation';\n\nconst DEFAULT_ALLOWED_LICENSES = [\n  'Apache-2.0',\n  'MIT',\n  'BSD-3-Clause',\n  'ISC',\n  'BSD-2-Clause',\n  '0BSD',\n];\n\n/**\n * Bundling properties.\n */\nexport interface BundleProps {\n\n  /**\n   * Directory where the package to bundle is located at.\n   */\n  readonly packageDir: string;\n\n  /**\n   * List of entry-points to bundle.\n   *\n   * @default - the 'main' file as specified in package.json.\n   */\n  readonly entryPoints?: string[];\n\n  /**\n   * Path to attributions file that will be created / validated.\n   * This path is relative to the package directory.\n   *\n   * @default 'THIRD_PARTY_LICENSES'\n   */\n  readonly attributionsFile?: string;\n\n  /**\n   * External packages that cannot be bundled.\n   *\n   * @default - no external references.\n   */\n  readonly externals?: Externals;\n\n  /**\n   * External resources that need to be embedded in the bundle.\n   *\n   * These will be copied over to the appropriate paths before packaging.\n   */\n  readonly resources?: {[src: string]: string};\n\n  /**\n   * A list of licenses that are allowed for bundling.\n   * If any dependency contains a license not in this list, bundling will fail.\n   *\n   * @default - Default list\n   */\n  readonly allowedLicenses?: string[];\n\n  /**\n   * Packages matching this regular expression will be excluded from attribution.\n   */\n  readonly dontAttribute?: string;\n\n  /**\n   * Basic sanity check to run against the created bundle.\n   *\n   * @default - no check.\n   */\n  readonly test?: string;\n}\n\n/**\n * Options for `Bundle.pack`.\n */\nexport interface BundlePackOptions {\n  /**\n   * The target directory to create the package in.\n   *\n   * @default - the package directory.\n   */\n  readonly target?: string;\n}\n\nexport interface BundleValidateOptions {\n  /**\n   * Automatically fix any (fixable) violations.\n   *\n   * @default false\n   */\n  readonly fix?: boolean;\n}\n\n/**\n * Package on the local file system.\n */\nexport interface Package {\n  /**\n   * Path of the dependency on the local file system.\n   */\n  readonly path: string;\n  /**\n   * Dependency name.\n   */\n  readonly name: string;\n  /**\n   * Dependency version.\n   */\n  readonly version: string;\n}\n\n/**\n * External packages that cannot be bundled.\n */\nexport interface Externals {\n\n  /**\n   * External packages that should be listed in the `dependencies` section\n   * of the manifest.\n   */\n  readonly dependencies?: readonly string[];\n\n  /**\n   * External packages that should be listed in the `optionalDependencies` section\n   * of the manifest.\n   */\n  readonly optionalDependencies?: readonly string[];\n\n}\n\n/**\n * Bundle class to validate and pack nodejs bundles.\n */\nexport class Bundle {\n\n  private readonly manifest: any;\n  private readonly noticePath: string;\n\n  private readonly packageDir: string;\n  private readonly entryPoints: Record<string, string>;\n  private readonly externals: Externals;\n  private readonly resources: {[src: string]: string};\n  private readonly allowedLicenses: string[];\n  private readonly dontAttribute?: string;\n  private readonly test?: string;\n\n  private _bundle?: esbuild.BuildResult;\n  private _dependencies?: Package[];\n  private _dependenciesRoot?: string;\n\n  private _attributions?: Attributions;\n\n  constructor(props: BundleProps) {\n    this.packageDir = props.packageDir;\n    this.noticePath = props.attributionsFile ?? 'THIRD_PARTY_LICENSES';\n    this.manifest = fs.readJsonSync(path.join(this.packageDir, 'package.json'));\n    this.externals = props.externals ?? {};\n    this.resources = props.resources ?? {};\n    this.test = props.test;\n    this.allowedLicenses = props.allowedLicenses ?? DEFAULT_ALLOWED_LICENSES;\n    this.dontAttribute = props.dontAttribute;\n    this.entryPoints = {};\n\n    const entryPoints = props.entryPoints ?? (this.manifest.main ? [this.manifest.main] : []);\n\n    if (entryPoints.length === 0) {\n      throw new Error('Must configure at least 1 entrypoint');\n    }\n\n    for (const entrypoint of entryPoints) {\n      if (!fs.existsSync(path.join(this.packageDir, entrypoint))) {\n        throw new Error(`Unable to locate entrypoint: ${entrypoint}`);\n      }\n      this.entryPoints[entrypoint.replace('.js', '')] = entrypoint;\n    }\n  }\n\n  /**\n   * Validate the bundle for violations.\n   *\n   * If `fix` is set to true, this method will return the remaining\n   * violations after the fixes were applied.\n   *\n   * This method never throws. The Caller is responsible for inspecting the\n   * returned report and act accordingly.\n   */\n  public validate(options: BundleValidateOptions = {}): ViolationsReport {\n\n    const fix = options.fix ?? false;\n\n    // first validate\n    const circularImports = this.validateCircularImports();\n    const resources = this.validateResources();\n    const attributions = this.validateAttributions();\n\n    const report = new ViolationsReport([...circularImports, ...resources, ...attributions]);\n\n    if (!fix) {\n      return report;\n    }\n\n    for (const violation of report.violations) {\n      if (violation.fix) {\n        violation.fix();\n      }\n    }\n\n    // return the un fixable violations\n    return new ViolationsReport(report.violations.filter(v => !v.fix));\n  }\n\n  /**\n   * Write the bundle version of the project to a temp directory.\n   * This directory is what the tool will end up packing.\n   *\n   * Returns the temp directory location.\n   */\n  public write(): string {\n\n    const target = fs.mkdtempSync(path.join(os.tmpdir(), 'bundle-write-'));\n\n    // we definitely don't need these directories in the package\n    // so no need to copy them over.\n    const ignoreDirectories = ['node_modules', '.git'];\n\n    // copy the entire project since we are retaining the original files.\n    fs.copySync(this.packageDir, target, { filter: n => !n.split(path.sep).some((p => ignoreDirectories.includes(p))) });\n\n    // clone the original manifest since we are going to\n    // to mutate it.\n    const manifest = { ...this.manifest };\n\n    // manifest mutations\n    this.removeDependencies(manifest);\n    this.addExternals(manifest);\n\n    // write artifacts\n    this.writeOutputs(target);\n    this.writeResources(target);\n    this.writeManifest(target, manifest);\n\n    return target;\n  }\n\n  /**\n   * Write the bundle and create the tarball.\n   *\n   * Returns the location of the tarball.\n   */\n  public pack(options: BundlePackOptions = {}): string {\n\n    const target = options.target ?? this.packageDir;\n\n    const report = this.validate();\n    if (!report.success) {\n      throw new Error(`Unable to pack due to validation errors.\\n\\n${report.summary}`);\n    }\n\n    if (!fs.existsSync(target)) {\n      throw new Error(`Target doesnt exist: ${target}`);\n    }\n\n    // resolve symlinks.\n    const realTarget = fs.realpathSync(target);\n\n    if (!fs.lstatSync(realTarget).isDirectory()) {\n      throw new Error(`Target must be a directory: ${target}`);\n    }\n\n    console.log('Writing bundle');\n    const bundleDir = this.write();\n    try {\n\n      if (this.test) {\n        const command = `${path.join(bundleDir, this.test)}`;\n        console.log(`Running santiy test: ${command}`);\n        shell(command, { cwd: bundleDir });\n      }\n\n      // create the tarball\n      console.log('Packing');\n      const tarball = shell('npm pack', { quiet: true, cwd: bundleDir }).trim();\n      const dest = path.join(realTarget, tarball);\n      fs.copySync(path.join(bundleDir, tarball), dest, { recursive: true });\n      return dest;\n    } finally {\n      fs.removeSync(bundleDir);\n    }\n  }\n\n  private get bundle(): esbuild.BuildResult {\n    if (this._bundle) {\n      return this._bundle;\n    }\n    this._bundle = this.esbuild();\n    return this._bundle;\n  }\n\n  private get dependencies(): Package[] {\n    if (this._dependencies) {\n      return this._dependencies;\n    }\n    const inputs = Object.keys(this.bundle.metafile!.inputs);\n    const packages = new Set(Array.from(inputs).map(i => this.closestPackagePath(path.join(this.packageDir, i))));\n    this._dependencies = Array.from(packages).map(p => this.createPackage(p)).filter(d => d.name !== this.manifest.name);\n    return this._dependencies;\n  }\n\n  private get dependenciesRoot(): string {\n    if (this._dependenciesRoot) {\n      return this._dependenciesRoot;\n    }\n    const lcp = longestCommonParent(this.dependencies.map(d => d.path));\n    this._dependenciesRoot = this.closestPackagePath(lcp);\n    return this._dependenciesRoot;\n  }\n\n  private get attributions(): Attributions {\n    if (this._attributions == null) {\n      this._attributions = new Attributions({\n        packageDir: this.packageDir,\n        packageName: this.manifest.name,\n        filePath: this.noticePath,\n        dependencies: this.dependencies,\n        dependenciesRoot: this.dependenciesRoot,\n        exclude: this.dontAttribute,\n        allowedLicenses: this.allowedLicenses,\n      });\n    }\n    return this._attributions;\n  }\n\n  private findExternalDependencyVersion(name: string): string {\n\n    const versions = new Set<string>();\n\n    // external dependencies will not exist in the dependencies list\n    // since esbuild skips over them. but they will exist as a dependency of\n    // one of them (or of us)\n    for (const pkg of [...this.dependencies, this.createPackage(this.packageDir)]) {\n      const manifest = fs.readJSONSync(path.join(pkg.path, 'package.json'));\n      const runtime = (manifest.dependencies ?? {})[name];\n      const optional = (manifest.optionalDependencies ?? {})[name];\n\n      const pin = (version: string) => (version.startsWith('^') || version.startsWith('~')) ? version.substring(1) : version;\n\n      if (runtime) {\n        versions.add(pin(runtime));\n      }\n      if (optional) {\n        versions.add(pin(optional));\n      }\n    }\n\n    if (versions.size === 0) {\n      throw new Error(`Unable to detect version for external dependency: ${name}`);\n    }\n\n    if (versions.size > 1) {\n      throw new Error(`Multiple versions detected for external dependency: ${name} (${Array.from(versions).join(',')})`);\n    }\n\n    return versions.values().next().value;\n  }\n\n  private closestPackagePath(fdp: string): string {\n\n    if (fs.existsSync(path.join(fdp, 'package.json'))) {\n      return fdp;\n    }\n\n    if (path.dirname(fdp) === fdp) {\n      throw new Error('Unable to find package manifest');\n    }\n\n    return this.closestPackagePath(path.dirname(fdp));\n  }\n\n  private createPackage(packageDir: string): Package {\n    const manifestPath = path.join(packageDir, 'package.json');\n    const manifest = fs.readJSONSync(manifestPath);\n    return { path: packageDir, name: manifest.name, version: manifest.version };\n  }\n\n  private esbuild(): esbuild.BuildResult {\n\n    const bundle = esbuild.buildSync({\n      entryPoints: this.entryPoints,\n      bundle: true,\n      target: 'node12',\n      platform: 'node',\n      sourcemap: 'inline',\n      metafile: true,\n      treeShaking: true,\n      absWorkingDir: this.packageDir,\n      external: [...(this.externals.dependencies ?? []), ...(this.externals.optionalDependencies ?? [])],\n      write: false,\n      outdir: this.packageDir,\n      allowOverwrite: true,\n    });\n\n    if (bundle.warnings.length > 0) {\n      // esbuild warnings are usually important, lets try to be strict here.\n      // the warnings themselves are printed on screen.\n      throw new Error(`Found ${bundle.warnings.length} bundling warnings (See above)`);\n    }\n\n    return bundle;\n  }\n\n  private validateCircularImports(): Violation[] {\n    console.log('Validating circular imports');\n    const violations: Violation[] = [];\n    const packages = [this.packageDir, ...this.dependencies.map(d => d.path)];\n    try {\n      // we don't use the programmatic API since it only offers an async API.\n      // prefer to stay sync for now since its easier to integrate with other tooling.\n      // will offer an async API further down the road.\n      const command = `${require.resolve('madge/bin/cli.js')} --json --warning --no-color --no-spinner --circular --extensions js ${packages.join(' ')}`;\n      shell(command, { quiet: true });\n    } catch (e: any) {\n      const imports: string[][] = JSON.parse(e.stdout.toString().trim());\n      for (const imp of imports) {\n        violations.push({ type: ViolationType.CIRCULAR_IMPORT, message: `${imp.join(' -> ')}` });\n      }\n    }\n\n    return violations;\n  }\n\n  private validateResources(): Violation[] {\n    console.log('Validating resources');\n    const violations = [];\n    for (const [src, _] of Object.entries(this.resources)) {\n      if (!fs.existsSync(path.join(this.packageDir, src))) {\n        violations.push({\n          type: ViolationType.MISSING_RESOURCE,\n          message: `Unable to find resource (${src}) relative to the package directory`,\n        });\n      }\n    }\n    return violations;\n  }\n\n  private validateAttributions(): readonly Violation[] {\n    console.log('Validating attributions');\n    return this.attributions.validate().violations;\n  }\n\n  private addExternals(manifest: any) {\n\n    // external dependencies should be specified as runtime dependencies\n    for (const external of this.externals.dependencies ?? []) {\n      const version = this.findExternalDependencyVersion(external);\n      manifest.dependencies = manifest.dependencies ?? {};\n      manifest.dependencies[external] = version;\n    }\n\n    // external dependencies should be specified as optional dependencies\n    for (const external of this.externals.optionalDependencies ?? []) {\n      const version = this.findExternalDependencyVersion(external);\n      manifest.optionalDependencies = manifest.optionalDependencies ?? {};\n      manifest.optionalDependencies[external] = version;\n    }\n\n  }\n\n  private removeDependencies(manifest: any) {\n    for (const [d, v] of Object.entries(this.manifest.dependencies)) {\n      manifest.devDependencies = manifest.devDependencies ?? {};\n      manifest.devDependencies[d] = v;\n      delete manifest.dependencies[d];\n    }\n  }\n\n  private writeOutputs(workDir: string) {\n    for (const output of this.bundle.outputFiles ?? []) {\n      const out = output.path.replace(this.packageDir, workDir);\n      fs.writeFileSync(out, output.contents);\n    }\n  }\n\n  private writeResources(workdir: string) {\n    for (const [src, dst] of Object.entries(this.resources)) {\n      const to = path.join(workdir, dst);\n      fs.copySync(path.join(this.packageDir, src), to, { recursive: true });\n    }\n  }\n\n  private writeManifest(workDir: string, manifest: any) {\n    fs.writeFileSync(path.join(workDir, 'package.json'), JSON.stringify(manifest, null, 2));\n  }\n}\n\nfunction longestCommonParent(paths: string[]) {\n\n  function _longestCommonParent(p1: string, p2: string): string {\n    const dirs1 = p1.split(path.sep);\n    const dirs2 = p2.split(path.sep);\n    const parent = [];\n    for (let i = 0; i < Math.min(dirs1.length, dirs2.length); i++) {\n      if (dirs1[i] !== dirs2[i]) break;\n      parent.push(dirs1[i]);\n    }\n    return parent.join(path.sep);\n  }\n\n  return paths.reduce(_longestCommonParent);\n}\n"]}
344
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle.js","sourceRoot":"","sources":["../../src/api/bundle.ts"],"names":[],"mappings":"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","sourcesContent":["import * as os from 'os';\nimport * as path from 'path';\nimport * as esbuild from 'esbuild';\nimport * as fs from 'fs-extra';\nimport { Attributions } from './_attributions';\nimport { shell } from './_shell';\nimport { Violation, ViolationType, ViolationsReport } from './violation';\n\nconst DEFAULT_ALLOWED_LICENSES = [\n  'Apache-2.0',\n  'MIT',\n  'BSD-3-Clause',\n  'ISC',\n  'BSD-2-Clause',\n  '0BSD',\n];\n\n/**\n * Bundling properties.\n */\nexport interface BundleProps {\n\n  /**\n   * Directory where the package to bundle is located at.\n   */\n  readonly packageDir: string;\n\n  /**\n   * List of entry-points to bundle.\n   *\n   * @default - the 'main' file as specified in package.json.\n   */\n  readonly entryPoints?: string[];\n\n  /**\n   * Path to attributions file that will be created / validated.\n   * This path is relative to the package directory.\n   *\n   * @default 'THIRD_PARTY_LICENSES'\n   */\n  readonly attributionsFile?: string;\n\n  /**\n   * External packages that cannot be bundled.\n   *\n   * @default - no external references.\n   */\n  readonly externals?: Externals;\n\n  /**\n   * External resources that need to be embedded in the bundle.\n   *\n   * These will be copied over to the appropriate paths before packaging.\n   */\n  readonly resources?: { [src: string]: string };\n\n  /**\n   * A list of licenses that are allowed for bundling.\n   * If any dependency contains a license not in this list, bundling will fail.\n   *\n   * @default - Default list\n   */\n  readonly allowedLicenses?: string[];\n\n  /**\n   * Packages matching this regular expression will be excluded from attribution.\n   */\n  readonly dontAttribute?: string;\n\n  /**\n   * Basic sanity check to run against the created bundle.\n   *\n   * @default - no check.\n   */\n  readonly test?: string;\n}\n\n/**\n * Options for `Bundle.pack`.\n */\nexport interface BundlePackOptions {\n  /**\n   * The target directory to create the package in.\n   *\n   * @default - the package directory.\n   */\n  readonly target?: string;\n}\n\nexport interface BundleValidateOptions {\n  /**\n   * Automatically fix any (fixable) violations.\n   *\n   * @default false\n   */\n  readonly fix?: boolean;\n}\n\n/**\n * Package on the local file system.\n */\nexport interface Package {\n  /**\n   * Path of the dependency on the local file system.\n   */\n  readonly path: string;\n  /**\n   * Dependency name.\n   */\n  readonly name: string;\n  /**\n   * Dependency version.\n   */\n  readonly version: string;\n}\n\n/**\n * External packages that cannot be bundled.\n */\nexport interface Externals {\n\n  /**\n   * External packages that should be listed in the `dependencies` section\n   * of the manifest.\n   */\n  readonly dependencies?: readonly string[];\n\n  /**\n   * External packages that should be listed in the `optionalDependencies` section\n   * of the manifest.\n   */\n  readonly optionalDependencies?: readonly string[];\n\n}\n\n/**\n * Bundle class to validate and pack nodejs bundles.\n */\nexport class Bundle {\n\n  private readonly manifest: any;\n  private readonly noticePath: string;\n\n  private readonly packageDir: string;\n  private readonly entryPoints: Record<string, string>;\n  private readonly externals: Externals;\n  private readonly resources: { [src: string]: string };\n  private readonly allowedLicenses: string[];\n  private readonly dontAttribute?: string;\n  private readonly test?: string;\n\n  private _bundle?: esbuild.BuildResult;\n  private _dependencies?: Package[];\n  private _dependenciesRoot?: string;\n\n  private _attributions?: Attributions;\n\n  constructor(props: BundleProps) {\n    this.packageDir = props.packageDir;\n    this.noticePath = props.attributionsFile ?? 'THIRD_PARTY_LICENSES';\n    this.manifest = fs.readJsonSync(path.join(this.packageDir, 'package.json'));\n    this.externals = props.externals ?? {};\n    this.resources = props.resources ?? {};\n    this.test = props.test;\n    this.allowedLicenses = props.allowedLicenses ?? DEFAULT_ALLOWED_LICENSES;\n    this.dontAttribute = props.dontAttribute;\n    this.entryPoints = {};\n\n    const entryPoints = props.entryPoints ?? (this.manifest.main ? [this.manifest.main] : []);\n\n    if (entryPoints.length === 0) {\n      throw new Error('Must configure at least 1 entrypoint');\n    }\n\n    for (const entrypoint of entryPoints) {\n      if (!fs.existsSync(path.join(this.packageDir, entrypoint))) {\n        throw new Error(`Unable to locate entrypoint: ${entrypoint}`);\n      }\n      this.entryPoints[entrypoint.replace('.js', '')] = entrypoint;\n    }\n  }\n\n  /**\n   * Validate the bundle for violations.\n   *\n   * If `fix` is set to true, this method will return the remaining\n   * violations after the fixes were applied.\n   *\n   * This method never throws. The Caller is responsible for inspecting the\n   * returned report and act accordingly.\n   */\n  public validate(options: BundleValidateOptions = {}): ViolationsReport {\n\n    const fix = options.fix ?? false;\n\n    // first validate\n    const circularImports = this.validateCircularImports();\n    const resources = this.validateResources();\n    const attributions = this.validateAttributions();\n\n    const report = new ViolationsReport([...circularImports, ...resources, ...attributions]);\n\n    if (!fix) {\n      return report;\n    }\n\n    for (const violation of report.violations) {\n      if (violation.fix) {\n        violation.fix();\n      }\n    }\n\n    // return the un fixable violations\n    return new ViolationsReport(report.violations.filter(v => !v.fix));\n  }\n\n  /**\n   * Write the bundle version of the project to a temp directory.\n   * This directory is what the tool will end up packing.\n   *\n   * Returns the temp directory location.\n   */\n  public write(): string {\n\n    const target = fs.mkdtempSync(path.join(os.tmpdir(), 'bundle-write-'));\n\n    // we definitely don't need these directories in the package\n    // so no need to copy them over.\n    const ignoreDirectories = ['node_modules', '.git'];\n\n    // copy the entire project since we are retaining the original files.\n    fs.copySync(this.packageDir, target, { filter: n => !n.split(path.sep).some((p => ignoreDirectories.includes(p))) });\n\n    // clone the original manifest since we are going to\n    // to mutate it.\n    const manifest = { ...this.manifest };\n\n    // manifest mutations\n    this.removeDependencies(manifest);\n    this.addExternals(manifest);\n\n    // write artifacts\n    this.writeOutputs(target);\n    this.writeResources(target);\n    this.writeManifest(target, manifest);\n\n    return target;\n  }\n\n  /**\n   * Write the bundle and create the tarball.\n   *\n   * Returns the location of the tarball.\n   */\n  public pack(options: BundlePackOptions = {}): string {\n\n    const target = options.target ?? this.packageDir;\n\n    const report = this.validate();\n    if (!report.success) {\n      throw new Error(`Unable to pack due to validation errors.\\n\\n${report.summary}`);\n    }\n\n    if (!fs.existsSync(target)) {\n      throw new Error(`Target doesnt exist: ${target}`);\n    }\n\n    // resolve symlinks.\n    const realTarget = fs.realpathSync(target);\n\n    if (!fs.lstatSync(realTarget).isDirectory()) {\n      throw new Error(`Target must be a directory: ${target}`);\n    }\n\n    console.log('Writing bundle');\n    const bundleDir = this.write();\n    try {\n\n      if (this.test) {\n        const command = `${path.join(bundleDir, this.test)}`;\n        console.log(`Running santiy test: ${command}`);\n        shell(command, { cwd: bundleDir });\n      }\n\n      // create the tarball\n      console.log('Packing');\n      const tarball = shell('npm pack', { quiet: true, cwd: bundleDir }).trim();\n      const dest = path.join(realTarget, tarball);\n      fs.copySync(path.join(bundleDir, tarball), dest, { recursive: true });\n      return dest;\n    } finally {\n      fs.removeSync(bundleDir);\n    }\n  }\n\n  private get bundle(): esbuild.BuildResult {\n    if (this._bundle) {\n      return this._bundle;\n    }\n    this._bundle = this.esbuild();\n    return this._bundle;\n  }\n\n  private get dependencies(): Package[] {\n    if (this._dependencies) {\n      return this._dependencies;\n    }\n    const inputs = Object.keys(this.bundle.metafile!.inputs);\n    const packages = new Set(Array.from(inputs).map(i => this.closestPackagePath(path.join(this.packageDir, i))));\n    this._dependencies = Array.from(packages).map(p => this.createPackage(p)).filter(d => d.name !== this.manifest.name);\n    return this._dependencies;\n  }\n\n  private get dependenciesRoot(): string {\n    if (this._dependenciesRoot) {\n      return this._dependenciesRoot;\n    }\n    const lcp = longestCommonParent(this.dependencies.map(d => d.path));\n    this._dependenciesRoot = this.closestPackagePath(lcp);\n    return this._dependenciesRoot;\n  }\n\n  private get attributions(): Attributions {\n    if (this._attributions == null) {\n      this._attributions = new Attributions({\n        packageDir: this.packageDir,\n        packageName: this.manifest.name,\n        filePath: this.noticePath,\n        dependencies: this.dependencies,\n        dependenciesRoot: this.dependenciesRoot,\n        exclude: this.dontAttribute,\n        allowedLicenses: this.allowedLicenses,\n      });\n    }\n    return this._attributions;\n  }\n\n  private findExternalDependencyVersion(name: string): string {\n\n    const versions = new Set<string>();\n\n    // external dependencies will not exist in the dependencies list\n    // since esbuild skips over them. but they will exist as a dependency of\n    // one of them (or of us)\n    for (const pkg of [...this.dependencies, this.createPackage(this.packageDir)]) {\n      const manifest = fs.readJSONSync(path.join(pkg.path, 'package.json'));\n      const runtime = (manifest.dependencies ?? {})[name];\n      const optional = (manifest.optionalDependencies ?? {})[name];\n\n      const pin = (version: string) => (version.startsWith('^') || version.startsWith('~')) ? version.substring(1) : version;\n\n      if (runtime) {\n        versions.add(pin(runtime));\n      }\n      if (optional) {\n        versions.add(pin(optional));\n      }\n    }\n\n    if (versions.size === 0) {\n      throw new Error(`Unable to detect version for external dependency: ${name}`);\n    }\n\n    if (versions.size > 1) {\n      throw new Error(`Multiple versions detected for external dependency: ${name} (${Array.from(versions).join(',')})`);\n    }\n\n    return versions.values().next().value;\n  }\n\n  private closestPackagePath(fdp: string): string {\n\n    if (fs.existsSync(path.join(fdp, 'package.json'))) {\n      return fdp;\n    }\n\n    if (path.dirname(fdp) === fdp) {\n      throw new Error('Unable to find package manifest');\n    }\n\n    return this.closestPackagePath(path.dirname(fdp));\n  }\n\n  private createPackage(packageDir: string): Package {\n    const manifestPath = path.join(packageDir, 'package.json');\n    const manifest = fs.readJSONSync(manifestPath);\n    return { path: packageDir, name: manifest.name, version: manifest.version };\n  }\n\n  private esbuild(): esbuild.BuildResult {\n\n    const bundle = esbuild.buildSync({\n      entryPoints: this.entryPoints,\n      bundle: true,\n      target: 'node12',\n      platform: 'node',\n      sourcemap: 'inline',\n      metafile: true,\n      treeShaking: true,\n      absWorkingDir: this.packageDir,\n      external: [...(this.externals.dependencies ?? []), ...(this.externals.optionalDependencies ?? [])],\n      write: false,\n      outdir: this.packageDir,\n      allowOverwrite: true,\n    });\n\n    if (bundle.warnings.length > 0) {\n      // esbuild warnings are usually important, lets try to be strict here.\n      // the warnings themselves are printed on screen.\n      throw new Error(`Found ${bundle.warnings.length} bundling warnings (See above)`);\n    }\n\n    return bundle;\n  }\n\n  private validateCircularImports(): Violation[] {\n    console.log('Validating circular imports');\n    const violations: Violation[] = [];\n    const packages = [this.packageDir, ...this.dependencies.map(d => d.path)];\n    try {\n      // we don't use the programmatic API since it only offers an async API.\n      // prefer to stay sync for now since its easier to integrate with other tooling.\n      // will offer an async API further down the road.\n      const command = `${require.resolve('madge/bin/cli.js')} --json --warning --no-color --no-spinner --circular --extensions js ${packages.join(' ')}`;\n      shell(command, { quiet: true });\n    } catch (e: any) {\n      const imports: string[][] = JSON.parse(e.stdout.toString().trim());\n      for (const imp of imports) {\n        violations.push({ type: ViolationType.CIRCULAR_IMPORT, message: `${imp.join(' -> ')}` });\n      }\n    }\n\n    return violations;\n  }\n\n  private validateResources(): Violation[] {\n    console.log('Validating resources');\n    const violations = [];\n    for (const [src, _] of Object.entries(this.resources)) {\n      if (!fs.existsSync(path.join(this.packageDir, src))) {\n        violations.push({\n          type: ViolationType.MISSING_RESOURCE,\n          message: `Unable to find resource (${src}) relative to the package directory`,\n        });\n      }\n    }\n    return violations;\n  }\n\n  private validateAttributions(): readonly Violation[] {\n    console.log('Validating attributions');\n    return this.attributions.validate().violations;\n  }\n\n  private addExternals(manifest: any) {\n\n    // external dependencies should be specified as runtime dependencies\n    for (const external of this.externals.dependencies ?? []) {\n      const version = this.findExternalDependencyVersion(external);\n      manifest.dependencies = manifest.dependencies ?? {};\n      manifest.dependencies[external] = version;\n    }\n\n    // external dependencies should be specified as optional dependencies\n    for (const external of this.externals.optionalDependencies ?? []) {\n      const version = this.findExternalDependencyVersion(external);\n      manifest.optionalDependencies = manifest.optionalDependencies ?? {};\n      manifest.optionalDependencies[external] = version;\n    }\n\n  }\n\n  private removeDependencies(manifest: any) {\n    for (const [d, v] of Object.entries(this.manifest.dependencies)) {\n      manifest.devDependencies = manifest.devDependencies ?? {};\n      manifest.devDependencies[d] = v;\n      delete manifest.dependencies[d];\n    }\n  }\n\n  private writeOutputs(workDir: string) {\n    for (const output of this.bundle.outputFiles ?? []) {\n      const out = output.path.replace(this.packageDir, workDir);\n      fs.writeFileSync(out, output.contents);\n    }\n  }\n\n  private writeResources(workdir: string) {\n    for (const [src, dst] of Object.entries(this.resources)) {\n      const to = path.join(workdir, dst);\n      fs.copySync(path.join(this.packageDir, src), to, { recursive: true });\n    }\n  }\n\n  private writeManifest(workDir: string, manifest: any) {\n    fs.writeFileSync(path.join(workDir, 'package.json'), JSON.stringify(manifest, null, 2));\n  }\n}\n\nfunction longestCommonParent(paths: string[]) {\n\n  function _longestCommonParent(p1: string, p2: string): string {\n    const dirs1 = p1.split(path.sep);\n    const dirs2 = p2.split(path.sep);\n    const parent = [];\n    for (let i = 0; i < Math.min(dirs1.length, dirs2.length); i++) {\n      if (dirs1[i] !== dirs2[i]) break;\n      parent.push(dirs1[i]);\n    }\n    return parent.join(path.sep);\n  }\n\n  return paths.reduce(_longestCommonParent);\n}\n"]}
package/package.json CHANGED
@@ -35,22 +35,23 @@
35
35
  "organization": true
36
36
  },
37
37
  "devDependencies": {
38
+ "@stylistic/eslint-plugin": "^2",
38
39
  "@types/fs-extra": "^9.0.13",
39
40
  "@types/jest": "^27.5.2",
40
41
  "@types/license-checker": "^25.0.6",
41
42
  "@types/madge": "^5.0.3",
42
43
  "@types/node": "^18",
43
- "@typescript-eslint/eslint-plugin": "^7",
44
- "@typescript-eslint/parser": "^7",
45
- "cdklabs-projen-project-types": "^0.1.204",
44
+ "@typescript-eslint/eslint-plugin": "^8",
45
+ "@typescript-eslint/parser": "^8",
46
+ "cdklabs-projen-project-types": "^0.3.1",
46
47
  "commit-and-tag-version": "^12",
47
48
  "constructs": "^10.0.0",
48
- "eslint": "^8",
49
+ "eslint": "^9",
49
50
  "eslint-import-resolver-typescript": "^2.7.1",
50
51
  "eslint-plugin-import": "^2.31.0",
51
52
  "jest": "^27",
52
- "jest-junit": "^15",
53
- "projen": "^0.87.4",
53
+ "jest-junit": "^16",
54
+ "projen": "^0.92.9",
54
55
  "ts-jest": "^27",
55
56
  "ts-node": "^10.9.2",
56
57
  "typescript": "^4.9.5"
@@ -68,7 +69,7 @@
68
69
  "publishConfig": {
69
70
  "access": "public"
70
71
  },
71
- "version": "0.0.556",
72
+ "version": "0.0.557",
72
73
  "jest": {
73
74
  "coverageProvider": "v8",
74
75
  "testMatch": [