- npm
- yarn classic (v1)
- yarn 2+
- Applicable only for projects using
node_modules
installation.Plug'n'Play
is not currently supported.
- Applicable only for projects using
- pnpm
To start using License Auditor, in the root of your project run
npx @brainhubeu/lac init
Follow the configuration wizard and select the template which suits your project.
Caution
The default configuration should not be in any way interpreted as legal advice.
Next, to conduct license audit run
npx @brainhubeu/lac
The results will be printed in the console.
--verbose
- Verbose output (default: false)--filter [filter]
- Filter verbose output by license status - whitelist, blacklist, or unknown--json [json]
- Save the result to a JSON file. If no path is not provided, a file named license-auditor.results.json will be created in the current directory.--production
- Skip the audit for licenses in development dependencies (default: false)--default-config
- Run audit with default whitelist/blacklist configuration--filter-regex [regex]
- Run audit with a custom regex filter that will be applied to the package name--bail [number]
- Flag controls program process's exit status, causing it to exit with status 1 if the number of blacklisted licenses exceeds the specified value; by default, it is set to Infinity, meaning the process exits with status 0 regardless of blacklisted licenses unless the flag is explicitly set.
Important
Verify dev dependencies if they generate code, embed assets, or otherwise impact the final product, as their licenses might impose restrictions. Always prioritize reviewing both when in doubt or if your project may be redistributed or commercialized.
All licenses are sourced from SPDX license list
whitelist
- array of SPDX license identifiers of licenses permitted within the project,blacklist
- array of SPDX license identifiers of licenses prohibited within the project,overrides
- an object with the specified severity:warn
- package should be omitted from audit, but it will produce a warning,off
- package should be completely omitted from the audit.
To use ConfigType
and enable IntelliSense license suggestions in the configuration file, run:
npm i --save-dev @brainhubeu/lac
Then, in JS/MJS configuration at the top of the file add:
/**
* @type {import('@brainhubeu/lac').ConfigType}
*/
In TS configuration:
import type { ConfigType } from "@brainhubeu/lac";
const config: ConfigType = {
...
};
Caution
The default/strict configuration should not be in any way interpreted as legal advice.
LAC offers a default configuration for whitelist and blacklist, available by running the configuration wizard or using the --default-config
flag. The rationale for selecting licenses for each list is available in this Brainhub article about open source licenses. It describes licenses to be wary of as:
You need to be careful about a few restrictive licenses, like GPL 3.0 or AGPL. In the worst-case scenario, you may be required to release your software under the same license, royalty-free.
However, we shouldn't say these licenses are bad. They cause a legal risk or can make you rewrite the whole product, but only if you don't follow the rules associated with them.
The key in managing licenses is to understand how they work, follow their rules, and ideally use software that helps to track the licenses in your product, so as not to break the law or cause problems to your product through inattention.
Strict configuration offers a more restrictive whitelist/blacklist preset. The aim was to cover as many licenses as viable, keeping to the guidelines described in the article above.
"We’ve found a license file, but no matching licenses in it in path" or "We've found few license files, but we could not match a license for some of them for package"
When the license file is found, but we are not sure what license it contains, we show this warning. Some packages contain more licenses in a single license file, e.g. when the author decided to include bundled dependencies licenses. It is important to review the file manually.
The JSON output is a JSON object with the following structure:
type Output = {
"whitelist": Package[],
"blacklist": Package[],
"unknown": Package[],
"notFound": Package[]
}
type Package = {
packageName: string,
packagePath: string,
status: 'whitelist' | 'blacklist' | 'unknown',
licensePath: string[], // paths to all license sources: license files and package.json files
verificationStatus:
'ok'
| 'someButNotAllLicensesWhitelisted' // found multiple licenses, but some (not all) are not whitelisted
| 'licenseFilesExistButSomeAreUncertain' // found multiple license files but we couldn't detect license in some of them
| 'licenseFileExistsButUnknownLicense' // found a license file but we couldn't detect license
| 'licenseFileNotFound' // we couldn't find a license file
licenses: License[],
};
type License = {
// ... license details as fetched from SPDX database like license name and SPDX ID
source:
'package.json-license' // single license found in package.json in "license" field
| 'package.json-licenses' // license found in package.json in "licenses" field
| 'package.json-license-expression' // license found in package.json in "license" field but expression detected (e.g. "MIT OR Apache-2.0")
| 'package.json-legacy' // license found in package.json in "license" field but in outdated format (e.g. object)
| 'license-file-content' // license detected in license file content
| 'license-file-content-keywords' // license detected in license file content using keywords (e.g. "MIT" or "Apache-2.0")
};
You can add License Auditor to your CI pipeline to ensure that the project's dependencies comply with the license policy. To do so, add the following command to your CI configuration:
license-audit:
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v4
- name: Set up Node.js
uses: actions/setup-node@v4
with:
node-version: 20
- name: Install dependencies
run: npm ci
- name: Build
run: npm run build
### This part below should be added to your CI configuration file. ###
- name: Install lac
run: npm i -g @brainhubeu/lac
- name: Run audit
run: lac --default-config --bail 1
This is most likely caused by enabled legacy-peer-deps in npm, which makes npm skip installing peer dependencies. License auditor will show partial results (for packages found by npm until the error occurred). To see complete results you must turn the legacy-peer-deps off and fix any peer dependency conflicts.