node-backpack 0.0.557 → 1.0.0

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/README.md CHANGED
@@ -1,4 +1,7 @@
1
- # node-backpack
1
+ # node-bundle
2
+
3
+ > **NOTE:** This tool should only be used on packages in this repository,
4
+ > and is not intended for external usage.
2
5
 
3
6
  You can use this tool to help create bundled packages with minimal dependencies and appropriate license attributions.
4
7
 
@@ -80,14 +83,14 @@ only CLI applications.
80
83
  Run the tool from the root directory of your package.
81
84
 
82
85
  ```console
83
- $ node-backpack --help
84
- Usage: node-backpack COMMAND
86
+ $ node-bundle --help
87
+ Usage: node-bundle COMMAND
85
88
 
86
89
  Commands:
87
- node-backpack validate Validate the package is ready for bundling
88
- node-backpack write Write the bundled version of the project to a temp
90
+ node-bundle validate Validate the package is ready for bundling
91
+ node-bundle write Write the bundled version of the project to a temp
89
92
  directory
90
- node-backpack pack Write the bundle and create the tarball
93
+ node-bundle pack Write the bundle and create the tarball
91
94
 
92
95
  Options:
93
96
  --entrypoint List of entrypoints to bundle [array]
@@ -110,7 +113,7 @@ Options:
110
113
  You can also use the programmatic access:
111
114
 
112
115
  ```ts
113
- import { Bundle } from 'node-backpack';
116
+ import { Bundle } from '@aws-cdk/node-bundle';
114
117
 
115
118
  const bundle = new Bundle({
116
119
  packageDir: process.cwd(),
@@ -124,15 +127,15 @@ bundle.pack();
124
127
 
125
128
  We recommend to integrate this tool in the following way:
126
129
 
127
- 1. Add a `node-backpack validate` command as a post compile step.
128
- 2. Set your packaging command to `node-backpack pack`.
130
+ 1. Add a `node-bundle validate` command as a post compile step.
131
+ 2. Set your packaging command to `node-bundle pack`.
129
132
 
130
133
  This way, you can validate local dev builds not to break any functionality needed for bundling.
131
- In addition, developers can run `node-backpack validate --fix` to automatically fix any (fixable) violations
134
+ In addition, developers can run `node-bundle validate --fix` to automatically fix any (fixable) violations
132
135
  and commit that to source control.
133
136
 
134
137
  For example, if a dependency is added but the attribution file has not been re-generated,
135
- you can use `node-backpack validate` to catch this, and regenerate it with `node-backpack validate --fix`.
138
+ you can use `node-bundle validate` to catch this, and regenerate it with `node-bundle validate --fix`.
136
139
 
137
140
  ## Take into account
138
141
 
@@ -148,13 +151,4 @@ Note that this will balloon up the package size significantly.
148
151
  If you are bundling a CLI application that also has top level exports, we suggest to extract
149
152
  the CLI functionality into a function, and add this function as an export to `index.js`.
150
153
 
151
- > See [aws-cdk](https://github.com/aws/aws-cdk/blob/master/packages/aws-cdk/bin/cdk.ts) as an example.
152
-
153
- ## Security
154
-
155
- See [CONTRIBUTING](CONTRIBUTING.md#security-issue-notifications) for more information.
156
-
157
- ## License
158
-
159
- This project is licensed under the Apache-2.0 License.
160
-
154
+ > See [aws-cdk](https://github.com/aws/aws-cdk-cli/blob/main/packages/aws-cdk/bin/cdk) as an example.
@@ -157,4 +157,4 @@ class Attributions {
157
157
  }
158
158
  }
159
159
  exports.Attributions = Attributions;
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"]}
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 type { Violation } from './violation';\nimport { ViolationType, ViolationsReport } from './violation';\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  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    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    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  private generateAttributions(): Map<string, Attribution> {\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 * 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"]}
@@ -51,6 +51,45 @@ export interface BundleProps {
51
51
  * @default - no check.
52
52
  */
53
53
  readonly test?: string;
54
+ /**
55
+ * Include a sourcemap in the bundle.
56
+ *
57
+ * @default "inline"
58
+ */
59
+ readonly sourcemap?: 'linked' | 'inline' | 'external' | 'both';
60
+ /**
61
+ * Minifies the bundled code.
62
+ *
63
+ * @default false
64
+ */
65
+ readonly minify?: boolean;
66
+ /**
67
+ * Removes whitespace from the code.
68
+ * This is enabled by default when `minify` is used.
69
+ *
70
+ * @default false
71
+ */
72
+ readonly minifyWhitespace?: boolean;
73
+ /**
74
+ * Renames local variables to be shorter.
75
+ * This is enabled by default when `minify` is used.
76
+ *
77
+ * @default false
78
+ */
79
+ readonly minifyIdentifiers?: boolean;
80
+ /**
81
+ * Rewrites syntax to a more compact format.
82
+ * This is enabled by default when `minify` is used.
83
+ *
84
+ * @default false
85
+ */
86
+ readonly minifySyntax?: boolean;
87
+ /**
88
+ * Write the metafile into this location.
89
+ *
90
+ * @default - no metafile is written
91
+ */
92
+ readonly metafile?: string;
54
93
  }
55
94
  /**
56
95
  * Options for `Bundle.pack`.
@@ -116,6 +155,12 @@ export declare class Bundle {
116
155
  private readonly allowedLicenses;
117
156
  private readonly dontAttribute?;
118
157
  private readonly test?;
158
+ private readonly sourcemap?;
159
+ private readonly minify?;
160
+ private readonly minifyWhitespace?;
161
+ private readonly minifyIdentifiers?;
162
+ private readonly minifySyntax?;
163
+ private readonly metafile?;
119
164
  private _bundle?;
120
165
  private _dependencies?;
121
166
  private _dependenciesRoot?;
package/lib/api/bundle.js CHANGED
@@ -38,6 +38,7 @@ const DEFAULT_ALLOWED_LICENSES = [
38
38
  'ISC',
39
39
  'BSD-2-Clause',
40
40
  '0BSD',
41
+ 'MIT OR Apache-2.0',
41
42
  ];
42
43
  /**
43
44
  * Bundle class to validate and pack nodejs bundles.
@@ -53,6 +54,12 @@ class Bundle {
53
54
  this.allowedLicenses = props.allowedLicenses ?? DEFAULT_ALLOWED_LICENSES;
54
55
  this.dontAttribute = props.dontAttribute;
55
56
  this.entryPoints = {};
57
+ this.sourcemap = props.sourcemap;
58
+ this.minify = props.minify;
59
+ this.minifyWhitespace = props.minifyWhitespace;
60
+ this.minifyIdentifiers = props.minifyIdentifiers;
61
+ this.minifySyntax = props.minifySyntax;
62
+ this.metafile = props.metafile;
56
63
  const entryPoints = props.entryPoints ?? (this.manifest.main ? [this.manifest.main] : []);
57
64
  if (entryPoints.length === 0) {
58
65
  throw new Error('Must configure at least 1 entrypoint');
@@ -140,7 +147,7 @@ class Bundle {
140
147
  try {
141
148
  if (this.test) {
142
149
  const command = `${path.join(bundleDir, this.test)}`;
143
- console.log(`Running santiy test: ${command}`);
150
+ console.log(`Running sanity test: ${command}`);
144
151
  (0, _shell_1.shell)(command, { cwd: bundleDir });
145
152
  }
146
153
  // create the tarball
@@ -167,7 +174,7 @@ class Bundle {
167
174
  }
168
175
  const inputs = Object.keys(this.bundle.metafile.inputs);
169
176
  const packages = new Set(Array.from(inputs).map(i => this.closestPackagePath(path.join(this.packageDir, i))));
170
- this._dependencies = Array.from(packages).map(p => this.createPackage(p)).filter(d => d.name !== this.manifest.name);
177
+ this._dependencies = Array.from(packages).map(p => this.createPackage(p)).filter(d => d.name !== undefined && d.name !== this.manifest.name);
171
178
  return this._dependencies;
172
179
  }
173
180
  get dependenciesRoot() {
@@ -235,10 +242,14 @@ class Bundle {
235
242
  const bundle = esbuild.buildSync({
236
243
  entryPoints: this.entryPoints,
237
244
  bundle: true,
238
- target: 'node12',
245
+ target: 'node18',
239
246
  platform: 'node',
240
- sourcemap: 'inline',
247
+ sourcemap: this.sourcemap,
241
248
  metafile: true,
249
+ minify: this.minify,
250
+ minifyWhitespace: this.minifyWhitespace,
251
+ minifyIdentifiers: this.minifyIdentifiers,
252
+ minifySyntax: this.minifySyntax,
242
253
  treeShaking: true,
243
254
  absWorkingDir: this.packageDir,
244
255
  external: [...(this.externals.dependencies ?? []), ...(this.externals.optionalDependencies ?? [])],
@@ -246,6 +257,10 @@ class Bundle {
246
257
  outdir: this.packageDir,
247
258
  allowOverwrite: true,
248
259
  });
260
+ // Write metafile only when requested
261
+ if (this.metafile) {
262
+ fs.writeFileSync(this.metafile, JSON.stringify(bundle.metafile, null, 2));
263
+ }
249
264
  if (bundle.warnings.length > 0) {
250
265
  // esbuild warnings are usually important, lets try to be strict here.
251
266
  // the warnings themselves are printed on screen.
@@ -341,4 +356,4 @@ function longestCommonParent(paths) {
341
356
  }
342
357
  return paths.reduce(_longestCommonParent);
343
358
  }
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"]}
359
+ //# 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 type { Violation } from './violation';\nimport { 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  'MIT OR Apache-2.0',\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   * Include a sourcemap in the bundle.\n   *\n   * @default \"inline\"\n   */\n  readonly sourcemap?: 'linked' | 'inline' | 'external' | 'both';\n\n  /**\n   * Minifies the bundled code.\n   *\n   * @default false\n   */\n  readonly minify?: boolean;\n\n  /**\n   * Removes whitespace from the code.\n   * This is enabled by default when `minify` is used.\n   *\n   * @default false\n   */\n  readonly minifyWhitespace?: boolean;\n\n  /**\n   * Renames local variables to be shorter.\n   * This is enabled by default when `minify` is used.\n   *\n   * @default false\n   */\n  readonly minifyIdentifiers?: boolean;\n\n  /**\n   * Rewrites syntax to a more compact format.\n   * This is enabled by default when `minify` is used.\n   *\n   * @default false\n   */\n  readonly minifySyntax?: boolean;\n\n  /**\n   * Write the metafile into this location.\n   *\n   * @default - no metafile is written\n   */\n  readonly metafile?: 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  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  private readonly sourcemap?: 'linked' | 'inline' | 'external' | 'both';\n  private readonly minify?: boolean;\n  private readonly minifyWhitespace?: boolean;\n  private readonly minifyIdentifiers?: boolean;\n  private readonly minifySyntax?: boolean;\n  private readonly metafile?: 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    this.sourcemap = props.sourcemap;\n    this.minify = props.minify;\n    this.minifyWhitespace = props.minifyWhitespace;\n    this.minifyIdentifiers = props.minifyIdentifiers;\n    this.minifySyntax = props.minifySyntax;\n    this.metafile = props.metafile;\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    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    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    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      if (this.test) {\n        const command = `${path.join(bundleDir, this.test)}`;\n        console.log(`Running sanity 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 !== undefined && 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    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    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    const bundle = esbuild.buildSync({\n      entryPoints: this.entryPoints,\n      bundle: true,\n      target: 'node18',\n      platform: 'node',\n      sourcemap: this.sourcemap,\n      metafile: true, // this is always required for some of our validation rules\n      minify: this.minify,\n      minifyWhitespace: this.minifyWhitespace,\n      minifyIdentifiers: this.minifyIdentifiers,\n      minifySyntax: this.minifySyntax,\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    // Write metafile only when requested\n    if (this.metafile) {\n      fs.writeFileSync(this.metafile, JSON.stringify(bundle.metafile, null, 2));\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    // 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  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  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/lib/api/index.js CHANGED
@@ -16,4 +16,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./bundle"), exports);
18
18
  __exportStar(require("./violation"), exports);
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXBpL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBeUI7QUFDekIsOENBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9idW5kbGUnO1xuZXhwb3J0ICogZnJvbSAnLi92aW9sYXRpb24nOyJdfQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXBpL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBeUI7QUFDekIsOENBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9idW5kbGUnO1xuZXhwb3J0ICogZnJvbSAnLi92aW9sYXRpb24nO1xuIl19
@@ -68,4 +68,4 @@ class ViolationsReport {
68
68
  }
69
69
  }
70
70
  exports.ViolationsReport = ViolationsReport;
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlvbGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwaS92aW9sYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDSCxJQUFZLGFBcUNYO0FBckNELFdBQVksYUFBYTtJQUV2Qjs7T0FFRztJQUNILG9EQUFtQyxDQUFBO0lBRW5DOztPQUVHO0lBQ0gsZ0VBQStDLENBQUE7SUFFL0M7O09BRUc7SUFDSCxrREFBaUMsQ0FBQTtJQUVqQzs7T0FFRztJQUNILG9EQUFtQyxDQUFBO0lBRW5DOztPQUVHO0lBQ0gsMENBQXlCLENBQUE7SUFFekI7O09BRUc7SUFDSCxzREFBcUMsQ0FBQTtJQUVyQzs7T0FFRztJQUNILHNEQUFxQyxDQUFBO0FBRXZDLENBQUMsRUFyQ1csYUFBYSxHQUFiLHFCQUFhLEtBQWIscUJBQWEsUUFxQ3hCO0FBcUJEOztHQUVHO0FBQ0gsTUFBYSxnQkFBZ0I7SUFFM0IsWUFBNkIsV0FBd0I7UUFBeEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7SUFBRyxDQUFDO0lBRXpEOztPQUVHO0lBQ0gsSUFBVyxVQUFVO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxPQUFPO1FBQ2hCLE1BQU0sT0FBTyxHQUFHO1lBQ2QsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sc0JBQXNCO1NBQ2pELENBQUM7UUFDRixLQUFLLE1BQU0sQ0FBQyxJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDaEMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7U0FDdkU7UUFDRCxPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDNUIsQ0FBQztDQUVGO0FBL0JELDRDQStCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVmlvbGF0aW9uIHR5cGVzLlxuICovXG5leHBvcnQgZW51bSBWaW9sYXRpb25UeXBlIHtcblxuICAvKipcbiAgICogQ2lyY3VsYXIgaW1wb3J0IG9uIHRoZSBwYWNrYWdlIG9yIG9uZSBvZiBpdHMgZGVwZW5kZW5jaWVzLlxuICAgKi9cbiAgQ0lSQ1VMQVJfSU1QT1JUID0gJ2NpcmN1bGFyLWltcG9ydCcsXG5cbiAgLyoqXG4gICAqIE91dGRhdGVkIGF0dHJpYnV0aW9ucyBmaWxlLlxuICAgKi9cbiAgT1VUREFURURfQVRUUklCVVRJT05TID0gJ291dGRhdGVkLWF0dHJpYnV0aW9ucycsXG5cbiAgLyoqXG4gICAqIE1pc3Npbmcgbm90aWNlIGZpbGUuXG4gICAqL1xuICBNSVNTSU5HX05PVElDRSA9ICdtaXNzaW5nLW5vdGljZScsXG5cbiAgLyoqXG4gICAqIEludmFsaWQgbGljZW5zZS5cbiAgICovXG4gIElOVkFMSURfTElDRU5TRSA9ICdpbnZhbGlkLWxpY2Vuc2UnLFxuXG4gIC8qKlxuICAgKiBObyBsaWNlbnNlLlxuICAgKi9cbiAgTk9fTElDRU5TRSA9ICduby1saWNlbnNlJyxcblxuICAvKipcbiAgICogTXVsdGlwbGUgbGljZW5zZXMuXG4gICAqL1xuICBNVUxUSVBMRV9MSUNFTlNFID0gJ211bHRpcGxlLWxpY2Vuc2UnLFxuXG4gIC8qKlxuICAgKiBNaXNzaW5nIHJlc291cmNlIGZpbGUuXG4gICAqL1xuICBNSVNTSU5HX1JFU09VUkNFID0gJ21pc3NpbmctcmVzb3VyY2UnLFxuXG59XG5cbi8qKlxuICogQSB2YWxpZGF0aW9uIHZpb2xhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBWaW9sYXRpb24ge1xuICAvKipcbiAgICogVGhlIHZpb2xhdGlvbiB0eXBlLlxuICAgKi9cbiAgcmVhZG9ubHkgdHlwZTogVmlvbGF0aW9uVHlwZTtcbiAgLyoqXG4gICAqIFRoZSB2aW9sYXRpb24gbWVzc2FnZS5cbiAgICovXG4gIHJlYWRvbmx5IG1lc3NhZ2U6IHN0cmluZztcbiAgLyoqXG4gICAqIEEgZml4ZXIgZnVuY3Rpb24uXG4gICAqIElmIHVuZGVmaW5lZCwgdGhpcyB2aW9sYXRpb24gY2Fubm90IGJlIGZpeGVkIGF1dG9tYXRpY2FsbHkuXG4gICAqL1xuICByZWFkb25seSBmaXg/OiAoKSA9PiB2b2lkO1xufVxuXG4vKipcbiAqIFJlcG9ydCBlbmNhcHN1bGF0aW5nIGEgbGlzdCBvZiB2aW9sYXRpb25zLlxuICovXG5leHBvcnQgY2xhc3MgVmlvbGF0aW9uc1JlcG9ydCB7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBfdmlvbGF0aW9uczogVmlvbGF0aW9uW10pIHt9XG5cbiAgLyoqXG4gICAqIFRoZSBsaXN0IG9mIHZpb2xhdGlvbnMuXG4gICAqL1xuICBwdWJsaWMgZ2V0IHZpb2xhdGlvbnMoKTogcmVhZG9ubHkgVmlvbGF0aW9uW10ge1xuICAgIHJldHVybiB0aGlzLl92aW9sYXRpb25zO1xuICB9XG5cbiAgLyoqXG4gICAqIFRydWUgd2hlbiBubyB2aW9sYXRpb25zIGV4aXN0LiBGYWxzZSBvdGhlcndpc2UuXG4gICAqL1xuICBwdWJsaWMgZ2V0IHN1Y2Nlc3MoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMudmlvbGF0aW9ucy5sZW5ndGggPT09IDA7XG4gIH1cblxuICAvKipcbiAgICogU3VtbWFyeSBvZiB0aGUgdmlvbGF0aW9uIGluIHRoZSByZXBvcnQuXG4gICAqL1xuICBwdWJsaWMgZ2V0IHN1bW1hcnkoKTogc3RyaW5nIHtcbiAgICBjb25zdCBzdW1tYXJ5ID0gW1xuICAgICAgYCR7dGhpcy5fdmlvbGF0aW9ucy5sZW5ndGh9IHZpb2xhdGlvbnMgZGV0ZWN0ZWRgLFxuICAgIF07XG4gICAgZm9yIChjb25zdCB2IG9mIHRoaXMuX3Zpb2xhdGlvbnMpIHtcbiAgICAgIHN1bW1hcnkucHVzaChgLSAke3YudHlwZX06ICR7di5tZXNzYWdlfSR7di5maXggPyAnIChmaXhhYmxlKScgOiAnJ31gKTtcbiAgICB9XG4gICAgcmV0dXJuIHN1bW1hcnkuam9pbignXFxuJyk7XG4gIH1cblxufVxuIl19
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlvbGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwaS92aW9sYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDSCxJQUFZLGFBcUNYO0FBckNELFdBQVksYUFBYTtJQUV2Qjs7T0FFRztJQUNILG9EQUFtQyxDQUFBO0lBRW5DOztPQUVHO0lBQ0gsZ0VBQStDLENBQUE7SUFFL0M7O09BRUc7SUFDSCxrREFBaUMsQ0FBQTtJQUVqQzs7T0FFRztJQUNILG9EQUFtQyxDQUFBO0lBRW5DOztPQUVHO0lBQ0gsMENBQXlCLENBQUE7SUFFekI7O09BRUc7SUFDSCxzREFBcUMsQ0FBQTtJQUVyQzs7T0FFRztJQUNILHNEQUFxQyxDQUFBO0FBRXZDLENBQUMsRUFyQ1csYUFBYSxHQUFiLHFCQUFhLEtBQWIscUJBQWEsUUFxQ3hCO0FBcUJEOztHQUVHO0FBQ0gsTUFBYSxnQkFBZ0I7SUFDM0IsWUFBNkIsV0FBd0I7UUFBeEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7SUFDckQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxVQUFVO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxPQUFPO1FBQ2hCLE1BQU0sT0FBTyxHQUFHO1lBQ2QsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sc0JBQXNCO1NBQ2pELENBQUM7UUFDRixLQUFLLE1BQU0sQ0FBQyxJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDaEMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7U0FDdkU7UUFDRCxPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDNUIsQ0FBQztDQUNGO0FBOUJELDRDQThCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVmlvbGF0aW9uIHR5cGVzLlxuICovXG5leHBvcnQgZW51bSBWaW9sYXRpb25UeXBlIHtcblxuICAvKipcbiAgICogQ2lyY3VsYXIgaW1wb3J0IG9uIHRoZSBwYWNrYWdlIG9yIG9uZSBvZiBpdHMgZGVwZW5kZW5jaWVzLlxuICAgKi9cbiAgQ0lSQ1VMQVJfSU1QT1JUID0gJ2NpcmN1bGFyLWltcG9ydCcsXG5cbiAgLyoqXG4gICAqIE91dGRhdGVkIGF0dHJpYnV0aW9ucyBmaWxlLlxuICAgKi9cbiAgT1VUREFURURfQVRUUklCVVRJT05TID0gJ291dGRhdGVkLWF0dHJpYnV0aW9ucycsXG5cbiAgLyoqXG4gICAqIE1pc3Npbmcgbm90aWNlIGZpbGUuXG4gICAqL1xuICBNSVNTSU5HX05PVElDRSA9ICdtaXNzaW5nLW5vdGljZScsXG5cbiAgLyoqXG4gICAqIEludmFsaWQgbGljZW5zZS5cbiAgICovXG4gIElOVkFMSURfTElDRU5TRSA9ICdpbnZhbGlkLWxpY2Vuc2UnLFxuXG4gIC8qKlxuICAgKiBObyBsaWNlbnNlLlxuICAgKi9cbiAgTk9fTElDRU5TRSA9ICduby1saWNlbnNlJyxcblxuICAvKipcbiAgICogTXVsdGlwbGUgbGljZW5zZXMuXG4gICAqL1xuICBNVUxUSVBMRV9MSUNFTlNFID0gJ211bHRpcGxlLWxpY2Vuc2UnLFxuXG4gIC8qKlxuICAgKiBNaXNzaW5nIHJlc291cmNlIGZpbGUuXG4gICAqL1xuICBNSVNTSU5HX1JFU09VUkNFID0gJ21pc3NpbmctcmVzb3VyY2UnLFxuXG59XG5cbi8qKlxuICogQSB2YWxpZGF0aW9uIHZpb2xhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBWaW9sYXRpb24ge1xuICAvKipcbiAgICogVGhlIHZpb2xhdGlvbiB0eXBlLlxuICAgKi9cbiAgcmVhZG9ubHkgdHlwZTogVmlvbGF0aW9uVHlwZTtcbiAgLyoqXG4gICAqIFRoZSB2aW9sYXRpb24gbWVzc2FnZS5cbiAgICovXG4gIHJlYWRvbmx5IG1lc3NhZ2U6IHN0cmluZztcbiAgLyoqXG4gICAqIEEgZml4ZXIgZnVuY3Rpb24uXG4gICAqIElmIHVuZGVmaW5lZCwgdGhpcyB2aW9sYXRpb24gY2Fubm90IGJlIGZpeGVkIGF1dG9tYXRpY2FsbHkuXG4gICAqL1xuICByZWFkb25seSBmaXg/OiAoKSA9PiB2b2lkO1xufVxuXG4vKipcbiAqIFJlcG9ydCBlbmNhcHN1bGF0aW5nIGEgbGlzdCBvZiB2aW9sYXRpb25zLlxuICovXG5leHBvcnQgY2xhc3MgVmlvbGF0aW9uc1JlcG9ydCB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgX3Zpb2xhdGlvbnM6IFZpb2xhdGlvbltdKSB7XG4gIH1cblxuICAvKipcbiAgICogVGhlIGxpc3Qgb2YgdmlvbGF0aW9ucy5cbiAgICovXG4gIHB1YmxpYyBnZXQgdmlvbGF0aW9ucygpOiByZWFkb25seSBWaW9sYXRpb25bXSB7XG4gICAgcmV0dXJuIHRoaXMuX3Zpb2xhdGlvbnM7XG4gIH1cblxuICAvKipcbiAgICogVHJ1ZSB3aGVuIG5vIHZpb2xhdGlvbnMgZXhpc3QuIEZhbHNlIG90aGVyd2lzZS5cbiAgICovXG4gIHB1YmxpYyBnZXQgc3VjY2VzcygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy52aW9sYXRpb25zLmxlbmd0aCA9PT0gMDtcbiAgfVxuXG4gIC8qKlxuICAgKiBTdW1tYXJ5IG9mIHRoZSB2aW9sYXRpb24gaW4gdGhlIHJlcG9ydC5cbiAgICovXG4gIHB1YmxpYyBnZXQgc3VtbWFyeSgpOiBzdHJpbmcge1xuICAgIGNvbnN0IHN1bW1hcnkgPSBbXG4gICAgICBgJHt0aGlzLl92aW9sYXRpb25zLmxlbmd0aH0gdmlvbGF0aW9ucyBkZXRlY3RlZGAsXG4gICAgXTtcbiAgICBmb3IgKGNvbnN0IHYgb2YgdGhpcy5fdmlvbGF0aW9ucykge1xuICAgICAgc3VtbWFyeS5wdXNoKGAtICR7di50eXBlfTogJHt2Lm1lc3NhZ2V9JHt2LmZpeCA/ICcgKGZpeGFibGUpJyA6ICcnfWApO1xuICAgIH1cbiAgICByZXR1cm4gc3VtbWFyeS5qb2luKCdcXG4nKTtcbiAgfVxufVxuIl19
@@ -0,0 +1 @@
1
+ export declare function cliMain(cliArgs: string[]): Promise<void>;
@@ -0,0 +1,140 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.cliMain = void 0;
27
+ const path = __importStar(require("path"));
28
+ const fs = __importStar(require("fs-extra"));
29
+ const yargs = __importStar(require("yargs"));
30
+ const api_1 = require("./api");
31
+ function versionNumber() {
32
+ return fs.readJSONSync(path.join(__dirname, '..', 'package.json')).version;
33
+ }
34
+ async function cliMain(cliArgs) {
35
+ const argv = await yargs
36
+ .usage('Usage: node-bundle COMMAND')
37
+ .option('entrypoint', { type: 'array', nargs: 1, desc: 'List of entrypoints to bundle' })
38
+ .option('external', { type: 'array', nargs: 1, default: [], desc: 'Packages in this list will be excluded from the bundle and added as dependencies (example: fsevents:optional)' })
39
+ .option('allowed-license', { type: 'array', nargs: 1, default: [], desc: 'List of valid licenses' })
40
+ .option('resource', { type: 'array', nargs: 1, default: [], desc: 'List of resources that need to be explicitly copied to the bundle (example: node_modules/proxy-agent/contextify.js:bin/contextify.js)' })
41
+ .option('dont-attribute', { type: 'string', desc: 'Dependencies matching this regular expressions wont be added to the notice file' })
42
+ .option('test', { type: 'string', desc: 'Validation command to sanity test the bundle after its created' })
43
+ .option('minify-whitespace', { type: 'boolean', default: false, desc: 'Minify whitespace' })
44
+ .option('metafile', { type: 'string', desc: 'Produce a metafile about the build that can be analyzed' })
45
+ .command('validate', 'Validate the package is ready for bundling', args => args
46
+ .option('fix', { type: 'boolean', default: false, alias: 'f', desc: 'Fix any fixable violations' }))
47
+ .command('write', 'Write the bundled version of the project to a temp directory')
48
+ .command('pack', 'Write the bundle and create the tarball', args => args
49
+ .option('destination', { type: 'string', desc: 'Directory to write the tarball to', nargs: 1, requiresArg: true }))
50
+ .demandCommand() // require a subcommand
51
+ .strict() // require a VALID subcommand, and only supported options
52
+ .fail((msg, err) => {
53
+ // Throw an error in test mode, exit with an error code otherwise
54
+ if (err) {
55
+ throw err;
56
+ }
57
+ if (process.env.NODE_ENV === 'test') {
58
+ throw new Error(msg);
59
+ }
60
+ console.error(msg);
61
+ process.exit(1); // exit() not exitCode, we must not return.
62
+ })
63
+ .help()
64
+ .version(versionNumber())
65
+ .parse(cliArgs);
66
+ const command = argv._[0];
67
+ function undefinedIfEmpty(arr) {
68
+ if (!arr || arr.length === 0)
69
+ return undefined;
70
+ return arr;
71
+ }
72
+ const resources = {};
73
+ for (const resource of argv.resource) {
74
+ const parts = resource.split(':');
75
+ resources[parts[0]] = parts[1];
76
+ }
77
+ const optionalExternals = [];
78
+ const runtimeExternals = [];
79
+ for (const external of argv.external) {
80
+ const parts = external.split(':');
81
+ const name = parts[0];
82
+ const type = parts[1];
83
+ switch (type) {
84
+ case 'optional':
85
+ optionalExternals.push(name);
86
+ break;
87
+ case 'runtime':
88
+ runtimeExternals.push(name);
89
+ break;
90
+ default:
91
+ throw new Error(`Unsupported dependency type '${type}' for external package '${name}'. Supported types are: ['optional', 'runtime']`);
92
+ }
93
+ }
94
+ const props = {
95
+ packageDir: process.cwd(),
96
+ entryPoints: undefinedIfEmpty(argv.entrypoint),
97
+ externals: { dependencies: runtimeExternals, optionalDependencies: optionalExternals },
98
+ allowedLicenses: undefinedIfEmpty(argv['allowed-license']),
99
+ resources: resources,
100
+ dontAttribute: argv['dont-attribute'],
101
+ test: argv.test,
102
+ minifyWhitespace: argv['minify-whitespace'],
103
+ metafile: argv.metafile,
104
+ };
105
+ const bundle = new api_1.Bundle(props);
106
+ switch (command) {
107
+ case 'validate':
108
+ // When using `yargs.command(command, builder [, handler])` without the handler
109
+ // as we do here, there is no typing for command-specific options. So force a cast.
110
+ const fix = argv.fix;
111
+ validate(bundle, { fix });
112
+ break;
113
+ case 'write':
114
+ write(bundle);
115
+ break;
116
+ case 'pack':
117
+ const target = argv.destination;
118
+ pack(bundle, {
119
+ target,
120
+ });
121
+ break;
122
+ default:
123
+ throw new Error(`Unknown command: ${command}`);
124
+ }
125
+ }
126
+ exports.cliMain = cliMain;
127
+ function write(bundle) {
128
+ const bundleDir = bundle.write();
129
+ console.log(bundleDir);
130
+ }
131
+ function validate(bundle, options = {}) {
132
+ const report = bundle.validate(options);
133
+ if (!report.success) {
134
+ throw new Error(report.summary);
135
+ }
136
+ }
137
+ function pack(bundle, options) {
138
+ bundle.pack(options);
139
+ }
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli-main.js","sourceRoot":"","sources":["../src/cli-main.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA6B;AAC7B,6CAA+B;AAC/B,6CAA+B;AAE/B,+BAA+B;AAE/B,SAAS,aAAa;IACpB,OAAO,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,OAAO,CAAC;AAC7E,CAAC;AAEM,KAAK,UAAU,OAAO,CAAC,OAAiB;IAC7C,MAAM,IAAI,GAAG,MAAM,KAAK;SACrB,KAAK,CAAC,4BAA4B,CAAC;SACnC,MAAM,CAAC,YAAY,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,+BAA+B,EAAE,CAAC;SACxF,MAAM,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,+GAA+G,EAAE,CAAC;SACnL,MAAM,CAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,wBAAwB,EAAE,CAAC;SACnG,MAAM,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,uIAAuI,EAAE,CAAC;SAC3M,MAAM,CAAC,gBAAgB,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,iFAAiF,EAAE,CAAC;SACrI,MAAM,CAAC,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,gEAAgE,EAAE,CAAC;SAC1G,MAAM,CAAC,mBAAmB,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,mBAAmB,EAAE,CAAC;SAC3F,MAAM,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,yDAAyD,EAAE,CAAC;SACvG,OAAO,CAAC,UAAU,EAAE,4CAA4C,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI;SAC5E,MAAM,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,4BAA4B,EAAE,CAAC,CACpG;SACA,OAAO,CAAC,OAAO,EAAE,8DAA8D,CAAC;SAChF,OAAO,CAAC,MAAM,EAAE,yCAAyC,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI;SACrE,MAAM,CAAC,aAAa,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,mCAAmC,EAAE,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CACnH;SACA,aAAa,EAAE,CAAC,uBAAuB;SACvC,MAAM,EAAE,CAAC,yDAAyD;SAClE,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;QACjB,iEAAiE;QACjE,IAAI,GAAG,EAAE;YACP,MAAM,GAAG,CAAC;SACX;QACD,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,MAAM,EAAE;YACnC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;SACtB;QACD,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACnB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,2CAA2C;IAC9D,CAAC,CAAC;SACD,IAAI,EAAE;SACN,OAAO,CAAC,aAAa,EAAE,CAAC;SACxB,KAAK,CAAC,OAAO,CAAC,CAAC;IAElB,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAE1B,SAAS,gBAAgB,CAAC,GAAW;QACnC,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,SAAS,CAAC;QAC/C,OAAO,GAAe,CAAC;IACzB,CAAC;IAED,MAAM,SAAS,GAAQ,EAAE,CAAC;IAC1B,KAAK,MAAM,QAAQ,IAAK,IAAI,CAAC,QAAqB,EAAE;QAClD,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAClC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;KAChC;IAED,MAAM,iBAAiB,GAAG,EAAE,CAAC;IAC7B,MAAM,gBAAgB,GAAG,EAAE,CAAC;IAE5B,KAAK,MAAM,QAAQ,IAAK,IAAI,CAAC,QAAqB,EAAE;QAClD,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAClC,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACtB,QAAQ,IAAI,EAAE;YACZ,KAAK,UAAU;gBACb,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC7B,MAAM;YACR,KAAK,SAAS;gBACZ,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC5B,MAAM;YACR;gBACE,MAAM,IAAI,KAAK,CAAC,gCAAgC,IAAI,2BAA2B,IAAI,iDAAiD,CAAC,CAAC;SACzI;KACF;IAED,MAAM,KAAK,GAAgB;QACzB,UAAU,EAAE,OAAO,CAAC,GAAG,EAAE;QACzB,WAAW,EAAE,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC;QAC9C,SAAS,EAAE,EAAE,YAAY,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,iBAAiB,EAAE;QACtF,eAAe,EAAE,gBAAgB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC1D,SAAS,EAAE,SAAS;QACpB,aAAa,EAAE,IAAI,CAAC,gBAAgB,CAAC;QACrC,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,gBAAgB,EAAE,IAAI,CAAC,mBAAmB,CAAC;QAC3C,QAAQ,EAAE,IAAI,CAAC,QAAQ;KACxB,CAAC;IAEF,MAAM,MAAM,GAAG,IAAI,YAAM,CAAC,KAAK,CAAC,CAAC;IAEjC,QAAQ,OAAO,EAAE;QACf,KAAK,UAAU;YACb,+EAA+E;YAC/E,mFAAmF;YACnF,MAAM,GAAG,GAAG,IAAI,CAAC,GAA0B,CAAC;YAC5C,QAAQ,CAAC,MAAM,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;YAC1B,MAAM;QACR,KAAK,OAAO;YACV,KAAK,CAAC,MAAM,CAAC,CAAC;YACd,MAAM;QACR,KAAK,MAAM;YACT,MAAM,MAAM,GAAG,IAAI,CAAC,WAAiC,CAAC;YACtD,IAAI,CAAC,MAAM,EAAE;gBACX,MAAM;aACP,CAAC,CAAC;YACH,MAAM;QACR;YACE,MAAM,IAAI,KAAK,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAC;KAClD;AACH,CAAC;AApGD,0BAoGC;AAED,SAAS,KAAK,CAAC,MAAc;IAC3B,MAAM,SAAS,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;IACjC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;AACzB,CAAC;AAED,SAAS,QAAQ,CAAC,MAAc,EAAE,UAAiC,EAAE;IACnE,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACxC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;QACnB,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;KACjC;AACH,CAAC;AAED,SAAS,IAAI,CAAC,MAAc,EAAE,OAA2B;IACvD,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AACvB,CAAC","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport * as yargs from 'yargs';\nimport type { BundlePackOptions, BundleProps, BundleValidateOptions } from './api';\nimport { Bundle } from './api';\n\nfunction versionNumber(): string {\n  return fs.readJSONSync(path.join(__dirname, '..', 'package.json')).version;\n}\n\nexport async function cliMain(cliArgs: string[]) {\n  const argv = await yargs\n    .usage('Usage: node-bundle COMMAND')\n    .option('entrypoint', { type: 'array', nargs: 1, desc: 'List of entrypoints to bundle' })\n    .option('external', { type: 'array', nargs: 1, default: [], desc: 'Packages in this list will be excluded from the bundle and added as dependencies (example: fsevents:optional)' })\n    .option('allowed-license', { type: 'array', nargs: 1, default: [], desc: 'List of valid licenses' })\n    .option('resource', { type: 'array', nargs: 1, default: [], desc: 'List of resources that need to be explicitly copied to the bundle (example: node_modules/proxy-agent/contextify.js:bin/contextify.js)' })\n    .option('dont-attribute', { type: 'string', desc: 'Dependencies matching this regular expressions wont be added to the notice file' })\n    .option('test', { type: 'string', desc: 'Validation command to sanity test the bundle after its created' })\n    .option('minify-whitespace', { type: 'boolean', default: false, desc: 'Minify whitespace' })\n    .option('metafile', { type: 'string', desc: 'Produce a metafile about the build that can be analyzed' })\n    .command('validate', 'Validate the package is ready for bundling', args => args\n      .option('fix', { type: 'boolean', default: false, alias: 'f', desc: 'Fix any fixable violations' }),\n    )\n    .command('write', 'Write the bundled version of the project to a temp directory')\n    .command('pack', 'Write the bundle and create the tarball', args => args\n      .option('destination', { type: 'string', desc: 'Directory to write the tarball to', nargs: 1, requiresArg: true }),\n    )\n    .demandCommand() // require a subcommand\n    .strict() // require a VALID subcommand, and only supported options\n    .fail((msg, err) => {\n      // Throw an error in test mode, exit with an error code otherwise\n      if (err) {\n        throw err;\n      }\n      if (process.env.NODE_ENV === 'test') {\n        throw new Error(msg);\n      }\n      console.error(msg);\n      process.exit(1); // exit() not exitCode, we must not return.\n    })\n    .help()\n    .version(versionNumber())\n    .parse(cliArgs);\n\n  const command = argv._[0];\n\n  function undefinedIfEmpty(arr?: any[]): string[] | undefined {\n    if (!arr || arr.length === 0) return undefined;\n    return arr as string[];\n  }\n\n  const resources: any = {};\n  for (const resource of (argv.resource as string[])) {\n    const parts = resource.split(':');\n    resources[parts[0]] = parts[1];\n  }\n\n  const optionalExternals = [];\n  const runtimeExternals = [];\n\n  for (const external of (argv.external as string[])) {\n    const parts = external.split(':');\n    const name = parts[0];\n    const type = parts[1];\n    switch (type) {\n      case 'optional':\n        optionalExternals.push(name);\n        break;\n      case 'runtime':\n        runtimeExternals.push(name);\n        break;\n      default:\n        throw new Error(`Unsupported dependency type '${type}' for external package '${name}'. Supported types are: ['optional', 'runtime']`);\n    }\n  }\n\n  const props: BundleProps = {\n    packageDir: process.cwd(),\n    entryPoints: undefinedIfEmpty(argv.entrypoint),\n    externals: { dependencies: runtimeExternals, optionalDependencies: optionalExternals },\n    allowedLicenses: undefinedIfEmpty(argv['allowed-license']),\n    resources: resources,\n    dontAttribute: argv['dont-attribute'],\n    test: argv.test,\n    minifyWhitespace: argv['minify-whitespace'],\n    metafile: argv.metafile,\n  };\n\n  const bundle = new Bundle(props);\n\n  switch (command) {\n    case 'validate':\n      // When using `yargs.command(command, builder [, handler])` without the handler\n      // as we do here, there is no typing for command-specific options. So force a cast.\n      const fix = argv.fix as boolean | undefined;\n      validate(bundle, { fix });\n      break;\n    case 'write':\n      write(bundle);\n      break;\n    case 'pack':\n      const target = argv.destination as string | undefined;\n      pack(bundle, {\n        target,\n      });\n      break;\n    default:\n      throw new Error(`Unknown command: ${command}`);\n  }\n}\n\nfunction write(bundle: Bundle) {\n  const bundleDir = bundle.write();\n  console.log(bundleDir);\n}\n\nfunction validate(bundle: Bundle, options: BundleValidateOptions = {}) {\n  const report = bundle.validate(options);\n  if (!report.success) {\n    throw new Error(report.summary);\n  }\n}\n\nfunction pack(bundle: Bundle, options?: BundlePackOptions) {\n  bundle.pack(options);\n}\n"]}
package/lib/cli.js CHANGED
@@ -1,119 +1,9 @@
1
1
  "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
2
  Object.defineProperty(exports, "__esModule", { value: true });
26
- const path = __importStar(require("path"));
27
- const fs = __importStar(require("fs-extra"));
28
- const yargs = __importStar(require("yargs"));
29
- const api_1 = require("./api");
30
- function versionNumber() {
31
- return fs.readJSONSync(path.join(__dirname, '..', 'package.json')).version;
32
- }
33
- async function buildCommands() {
34
- const argv = yargs
35
- .usage('Usage: node-bundle COMMAND')
36
- .option('entrypoint', { type: 'array', nargs: 1, desc: 'List of entrypoints to bundle' })
37
- .option('external', { type: 'array', nargs: 1, default: [], desc: 'Packages in this list will be excluded from the bundle and added as dependencies (example: fsevents:optional)' })
38
- .option('allowed-license', { type: 'array', nargs: 1, default: [], desc: 'List of valid licenses' })
39
- .option('resource', { type: 'array', nargs: 1, default: [], desc: 'List of resources that need to be explicitly copied to the bundle (example: node_modules/proxy-agent/contextify.js:bin/contextify.js)' })
40
- .option('dont-attribute', { type: 'string', desc: 'Dependencies matching this regular expressions wont be added to the notice file' })
41
- .option('test', { type: 'string', desc: 'Validation command to sanity test the bundle after its created' })
42
- .command('validate', 'Validate the package is ready for bundling', args => args
43
- .option('fix', { type: 'boolean', default: false, alias: 'f', desc: 'Fix any fixable violations' }))
44
- .command('write', 'Write the bundled version of the project to a temp directory')
45
- .command('pack', 'Write the bundle and create the tarball')
46
- .help()
47
- .version(versionNumber())
48
- .argv;
49
- const command = argv._[0];
50
- function undefinedIfEmpty(arr) {
51
- if (!arr || arr.length === 0)
52
- return undefined;
53
- return arr;
54
- }
55
- const resources = {};
56
- for (const resource of argv.resource) {
57
- const parts = resource.split(':');
58
- resources[parts[0]] = parts[1];
59
- }
60
- const optionalExternals = [];
61
- const runtimeExternals = [];
62
- for (const external of argv.external) {
63
- const parts = external.split(':');
64
- const name = parts[0];
65
- const type = parts[1];
66
- switch (type) {
67
- case 'optional':
68
- optionalExternals.push(name);
69
- break;
70
- case 'runtime':
71
- runtimeExternals.push(name);
72
- break;
73
- default:
74
- throw new Error(`Unsupported dependency type '${type}' for external package '${name}'. Supported types are: ['optional', 'runtime']`);
75
- }
76
- }
77
- const props = {
78
- packageDir: process.cwd(),
79
- entryPoints: undefinedIfEmpty(argv.entrypoint),
80
- externals: { dependencies: runtimeExternals, optionalDependencies: optionalExternals },
81
- allowedLicenses: undefinedIfEmpty(argv['allowed-license']),
82
- resources: resources,
83
- dontAttribute: argv['dont-attribute'],
84
- test: argv.test,
85
- };
86
- const bundle = new api_1.Bundle(props);
87
- switch (command) {
88
- case 'validate':
89
- validate(bundle, { fix: argv.fix });
90
- break;
91
- case 'write':
92
- write(bundle);
93
- break;
94
- case 'pack':
95
- pack(bundle);
96
- break;
97
- default:
98
- throw new Error(`Unknown command: ${command}`);
99
- }
100
- }
101
- function write(bundle) {
102
- const bundleDir = bundle.write();
103
- console.log(bundleDir);
104
- }
105
- function validate(bundle, options = {}) {
106
- const report = bundle.validate(options);
107
- if (!report.success) {
108
- throw new Error(report.summary);
109
- }
110
- }
111
- function pack(bundle) {
112
- bundle.pack();
113
- }
114
- buildCommands()
3
+ const cli_main_1 = require("./cli-main");
4
+ (0, cli_main_1.cliMain)(process.argv.slice(2))
115
5
  .catch((err) => {
116
6
  console.error(`Error: ${err.message}`);
117
7
  process.exitCode = 1;
118
8
  });
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs-extra';\nimport * as yargs from 'yargs';\nimport { Bundle, BundleProps, BundleValidateOptions } from './api';\n\nfunction versionNumber(): string {\n  return fs.readJSONSync(path.join(__dirname, '..', 'package.json')).version;\n}\n\nasync function buildCommands() {\n\n  const argv = yargs\n    .usage('Usage: node-bundle COMMAND')\n    .option('entrypoint', { type: 'array', nargs: 1, desc: 'List of entrypoints to bundle' })\n    .option('external', { type: 'array', nargs: 1, default: [], desc: 'Packages in this list will be excluded from the bundle and added as dependencies (example: fsevents:optional)' })\n    .option('allowed-license', { type: 'array', nargs: 1, default: [], desc: 'List of valid licenses' })\n    .option('resource', { type: 'array', nargs: 1, default: [], desc: 'List of resources that need to be explicitly copied to the bundle (example: node_modules/proxy-agent/contextify.js:bin/contextify.js)' })\n    .option('dont-attribute', { type: 'string', desc: 'Dependencies matching this regular expressions wont be added to the notice file' })\n    .option('test', { type: 'string', desc: 'Validation command to sanity test the bundle after its created' })\n    .command('validate', 'Validate the package is ready for bundling', args => args\n      .option('fix', { type: 'boolean', default: false, alias: 'f', desc: 'Fix any fixable violations' }),\n    )\n    .command('write', 'Write the bundled version of the project to a temp directory')\n    .command('pack', 'Write the bundle and create the tarball')\n    .help()\n    .version(versionNumber())\n    .argv;\n\n  const command = argv._[0];\n\n  function undefinedIfEmpty(arr?: any[]): string[] | undefined {\n    if (!arr || arr.length === 0) return undefined;\n    return arr as string[];\n  }\n\n  const resources: any = {};\n  for (const resource of (argv.resource as string[])) {\n    const parts = resource.split(':');\n    resources[parts[0]] = parts[1];\n  }\n\n  const optionalExternals = [];\n  const runtimeExternals = [];\n\n  for (const external of (argv.external as string[])) {\n    const parts = external.split(':');\n    const name = parts[0];\n    const type = parts[1];\n    switch (type) {\n      case 'optional':\n        optionalExternals.push(name);\n        break;\n      case 'runtime':\n        runtimeExternals.push(name);\n        break;\n      default:\n        throw new Error(`Unsupported dependency type '${type}' for external package '${name}'. Supported types are: ['optional', 'runtime']`);\n    }\n  }\n\n  const props: BundleProps = {\n    packageDir: process.cwd(),\n    entryPoints: undefinedIfEmpty(argv.entrypoint),\n    externals: { dependencies: runtimeExternals, optionalDependencies: optionalExternals },\n    allowedLicenses: undefinedIfEmpty(argv['allowed-license']),\n    resources: resources,\n    dontAttribute: argv['dont-attribute'],\n    test: argv.test,\n  };\n\n  const bundle = new Bundle(props);\n\n  switch (command) {\n    case 'validate':\n      validate(bundle, { fix: argv.fix });\n      break;\n    case 'write':\n      write(bundle);\n      break;\n    case 'pack':\n      pack(bundle);\n      break;\n    default:\n      throw new Error(`Unknown command: ${command}`);\n  }\n}\n\nfunction write(bundle: Bundle) {\n  const bundleDir = bundle.write();\n  console.log(bundleDir);\n}\n\nfunction validate(bundle: Bundle, options: BundleValidateOptions = {}) {\n  const report = bundle.validate(options);\n  if (!report.success) {\n    throw new Error(report.summary);\n  }\n}\n\nfunction pack(bundle: Bundle) {\n  bundle.pack();\n}\n\nbuildCommands()\n  .catch((err: Error) => {\n    console.error(`Error: ${err.message}`);\n    process.exitCode = 1;\n  });\n"]}
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NsaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHlDQUFxQztBQUVyQyxJQUFBLGtCQUFPLEVBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDM0IsS0FBSyxDQUFDLENBQUMsR0FBVSxFQUFFLEVBQUU7SUFDcEIsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZDLE9BQU8sQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDO0FBQ3ZCLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY2xpTWFpbiB9IGZyb20gJy4vY2xpLW1haW4nO1xuXG5jbGlNYWluKHByb2Nlc3MuYXJndi5zbGljZSgyKSlcbiAgLmNhdGNoKChlcnI6IEVycm9yKSA9PiB7XG4gICAgY29uc29sZS5lcnJvcihgRXJyb3I6ICR7ZXJyLm1lc3NhZ2V9YCk7XG4gICAgcHJvY2Vzcy5leGl0Q29kZSA9IDE7XG4gIH0pO1xuIl19
package/lib/index.js CHANGED
@@ -15,4 +15,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./api"), exports);
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHdDQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXBpJzsiXX0=
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHdDQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXBpJztcbiJdfQ==
package/package.json CHANGED
@@ -51,6 +51,7 @@
51
51
  "eslint-plugin-import": "^2.31.0",
52
52
  "jest": "^27",
53
53
  "jest-junit": "^16",
54
+ "prettier": "^2.8",
54
55
  "projen": "^0.92.9",
55
56
  "ts-jest": "^27",
56
57
  "ts-node": "^10.9.2",
@@ -69,7 +70,7 @@
69
70
  "publishConfig": {
70
71
  "access": "public"
71
72
  },
72
- "version": "0.0.557",
73
+ "version": "1.0.0",
73
74
  "jest": {
74
75
  "coverageProvider": "v8",
75
76
  "testMatch": [
package/CONTRIBUTING.md DELETED
@@ -1,59 +0,0 @@
1
- # Contributing Guidelines
2
-
3
- Thank you for your interest in contributing to our project. Whether it's a bug report, new feature, correction, or additional
4
- documentation, we greatly value feedback and contributions from our community.
5
-
6
- Please read through this document before submitting any issues or pull requests to ensure we have all the necessary
7
- information to effectively respond to your bug report or contribution.
8
-
9
-
10
- ## Reporting Bugs/Feature Requests
11
-
12
- We welcome you to use the GitHub issue tracker to report bugs or suggest features.
13
-
14
- When filing an issue, please check existing open, or recently closed, issues to make sure somebody else hasn't already
15
- reported the issue. Please try to include as much information as you can. Details like these are incredibly useful:
16
-
17
- * A reproducible test case or series of steps
18
- * The version of our code being used
19
- * Any modifications you've made relevant to the bug
20
- * Anything unusual about your environment or deployment
21
-
22
-
23
- ## Contributing via Pull Requests
24
- Contributions via pull requests are much appreciated. Before sending us a pull request, please ensure that:
25
-
26
- 1. You are working against the latest source on the *main* branch.
27
- 2. You check existing open, and recently merged, pull requests to make sure someone else hasn't addressed the problem already.
28
- 3. You open an issue to discuss any significant work - we would hate for your time to be wasted.
29
-
30
- To send us a pull request, please:
31
-
32
- 1. Fork the repository.
33
- 2. Modify the source; please focus on the specific change you are contributing. If you also reformat all the code, it will be hard for us to focus on your change.
34
- 3. Ensure local tests pass.
35
- 4. Commit to your fork using clear commit messages.
36
- 5. Send us a pull request, answering any default questions in the pull request interface.
37
- 6. Pay attention to any automated CI failures reported in the pull request, and stay involved in the conversation.
38
-
39
- GitHub provides additional document on [forking a repository](https://help.github.com/articles/fork-a-repo/) and
40
- [creating a pull request](https://help.github.com/articles/creating-a-pull-request/).
41
-
42
-
43
- ## Finding contributions to work on
44
- Looking at the existing issues is a great way to find something to contribute on. As our projects, by default, use the default GitHub issue labels (enhancement/bug/duplicate/help wanted/invalid/question/wontfix), looking at any 'help wanted' issues is a great place to start.
45
-
46
-
47
- ## Code of Conduct
48
- This project has adopted the [Amazon Open Source Code of Conduct](https://aws.github.io/code-of-conduct).
49
- For more information see the [Code of Conduct FAQ](https://aws.github.io/code-of-conduct-faq) or contact
50
- opensource-codeofconduct@amazon.com with any additional questions or comments.
51
-
52
-
53
- ## Security issue notifications
54
- If you discover a potential security issue in this project we ask that you notify AWS/Amazon Security via our [vulnerability reporting page](http://aws.amazon.com/security/vulnerability-reporting/). Please do **not** create a public github issue.
55
-
56
-
57
- ## Licensing
58
-
59
- See the [LICENSE](LICENSE) file for our project's licensing. We will ask you to confirm the licensing of your contribution.