nsp
The Node Security (nodesecurity.io) command line interface
Supply chain provenance
Status for the latest visible version.
Without SLSA provenance there is no cryptographic link between this tarball and the public source — the axios compromise (March 2026) relied on exactly this gap.
Maintainers
Keywords
Accepted risks
Findings the reviewer chose to accept rather than block on.
| Source | Rule | Reason | Accepted by | When |
|---|---|---|---|---|
| maintainer-change | maintainer-removed | AI (maintainer-change): tomsteele's removal reflects an internal org change at ^Lift Security; adam_baldwin is the original author and primary maintainer. Not a hostile takeover signal. | ai | |
| phantom-deps | phantom-dep:subcommand | AI (phantom-deps): subcommand is a CLI framework dependency used via config/bin wiring rather than direct require(); consistent with CLI tool architecture. | ai | |
| dependencies | unvetted-dep:requiresafe-npm-utils | AI (dependencies): requiresafe-npm-utils is a first-party utility from the same organization (RequireSafe/^Lift Security) that publishes nsp; not a third-party risk. | ai | |
| provenance | publisher-changed | AI (provenance): Publisher change adam_baldwin→nlf in 2017 was a documented internal transition within the Node Security Project org. nlf has a strong track record (3581 approved packages). Not a suspicious takeover. | ai | |
| semgrep | semgrep:dynamic-require | AI (semgrep): Dynamic require is an intentional plugin-loading pattern (nsp-preprocessor-*) in this security CLI tool; not attacker-controllable in normal usage. | ai | |
| phantom-deps | phantom-dep:yargs | AI (phantom-deps): yargs is properly declared in dependencies and is the expected CLI argument parser for this tool; false positive from the phantom-dep analyzer. | ai |
Versions (showing 46 of 46)
| Version | Deps | Published |
|---|---|---|
| 3.2.1 | 9 / 6 | |
| 3.2.0 | 9 / 6 | |
| 3.1.0 | 9 / 6 | |
| 3.0.0 | 9 / 6 | |
| 2.8.1 | 11 / 8 | |
| 2.8.0 | 11 / 8 | |
| 2.7.0 | 11 / 8 | |
| 2.6.3 | 11 / 8 | |
| 2.6.2 | 10 / 8 | |
| 2.6.1 | 10 / 8 | |
| 2.6.0 | 10 / 8 | |
| 2.5.0 | 10 / 8 | |
| 2.4.0 | 10 / 8 | |
| 2.3.3 | 10 / 8 | |
| 2.3.2 | 10 / 8 | |
| 2.3.1 | 10 / 8 | |
| 2.3.0 | 10 / 8 | |
| 2.2.2 | 10 / 8 | |
| 2.2.1 | 10 / 8 | |
| 2.2.0 | 10 / 8 | |
| 2.1.0 | 10 / 8 | |
| 2.0.2 | 9 / 8 | |
| 2.0.1 | 9 / 6 | |
| 2.0.0 | 9 / 6 | |
| 1.1.0 | 14 / 8 | |
| 1.0.3 | 14 / 8 | |
| 1.0.2 | 14 / 8 | |
| 1.0.1 | 14 / 8 | |
| 1.0.0 | 14 / 8 | |
| 0.6.1 | 15 / 8 | |
| 0.6.0 | 15 / 7 | |
| 0.5.2 | 15 / 5 | |
| 0.4.2 | 15 / 2 | |
| 0.4.1 | 15 / 2 | |
| 0.4.0 | 15 / 2 | |
| 0.3.0 | 15 / 2 | |
| 0.2.8 | 14 / 2 | |
| 0.2.6 | 13 / 2 | |
| 0.2.5 | 12 / 2 | |
| 0.2.4 | 12 / 2 | |
| 0.2.3 | 12 / 2 | |
| 0.2.2 | 12 / 2 | |
| 0.2.1 | 15 / 1 | |
| 0.2.0 | 15 / 1 | |
| 0.0.2 | 11 / 1 | |
| 0.0.1 | 11 / 1 |
v3.2.1
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v3.2.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v3.1.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v3.0.0
2 findingsThis version was published by a different npm account than previous versions on 2017-10-04. This could indicate a legitimate maintainer transition or an account compromise.
Package was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.8.1
2 findingsPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
[Accepted risk] This version was published by a different npm account than previous versions on 2017-09-27. This could indicate a legitimate maintainer transition or an account compromise.
v2.8.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.7.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.6.3
2 findingsPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
[Accepted risk] This version was published by a different npm account than previous versions on 2017-03-06. This could indicate a legitimate maintainer transition or an account compromise.
v2.6.2
2 findingsPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
[Accepted risk] This version was published by a different npm account than previous versions on 2016-10-03. This could indicate a legitimate maintainer transition or an account compromise.
v2.6.1
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.6.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.5.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.4.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.3.3
2 findingsPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
[Accepted risk] This version was published by a different npm account than previous versions on 2016-05-10. This could indicate a legitimate maintainer transition or an account compromise.
v2.3.2
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.3.1
2 findingsPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
[Accepted risk] This version was published by a different npm account than previous versions on 2016-04-21. This could indicate a legitimate maintainer transition or an account compromise.
v2.3.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.2.2
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.2.1
2 findingsPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
[Accepted risk] This version was published by a different npm account than previous versions on 2016-03-09. This could indicate a legitimate maintainer transition or an account compromise.
v2.2.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.1.0
2 findingsPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
[Accepted risk] This version was published by a different npm account than previous versions on 2015-12-02. This could indicate a legitimate maintainer transition or an account compromise.
v2.0.2
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
v2.0.1
2 findingsPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.
[Accepted risk] This version was published by a different npm account than previous versions on 2015-11-03. This could indicate a legitimate maintainer transition or an account compromise.
v2.0.0
1 findingPackage was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.