Package evidence
[email protected]
Install Lifecycle Suppresses Failure: postinstall="node ./src/install/postinstall.mjs || true"
Trust signals
Why this verdict
PkgRadar discounts a release’s score when public reputation argues against novel malware. The verdict above already reflects these — the panel just explains what was applied.
- Weekly downloads
- 24
- Versions published
- 6
- First published
- May 2026
- Publisher
- frederico-kluser
Recommended action
Block this updateStatic evidence trips multiple high-signal indicators. Quarantine the release until the publisher validates the change or you can rule out the indicators below.
Block this release in CIcurl · GitHub Actions
Fail the build when this package version is added or upgraded. Replace $PKGRADAR_TOKEN with a Pro / Team API key from your dashboard.
curl -fsS https://pkgradar.com/gate/npm \
-H "Authorization: Bearer $PKGRADAR_TOKEN" \
-H "Content-Type: application/json" \
-d '{"specs":["[email protected]"],"fail_on":"high"}'GitHub Actions step:
- name: PkgRadar gate
run: |
curl -fsS https://pkgradar.com/gate/npm \
-H "Authorization: Bearer ${{ secrets.PKGRADAR_TOKEN }}" \
-H "Content-Type: application/json" \
-d '{"specs":["[email protected]"],"fail_on":"high"}'Why flagged
What the scanner saw
Install Lifecycle Suppresses Failure: postinstall="node ./src/install/postinstall.mjs || true"
Not observed: package install, lifecycle script execution, or sandbox execution. PkgRadar only inspects on-disk artifacts.
Availability ledger
available
Status history (1 event)
- new → available · risk high · score 25 · status changed
Evidence
Static findings
3 static · 0 from release diff · showing high-signal first.
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| high | Install Lifecycle Suppresses Failure | package.json | postinstall="node ./src/install/postinstall.mjs || true" | 20 |
| medium | New Account With Lifecycle Hook | package.json | package first published 22 day(s) ago, 6 total version(s), has lifecycle hook | 10 |
Show all 3 findings (low-signal and informational)
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| high | Install Lifecycle Suppresses Failure | package.json | postinstall="node ./src/install/postinstall.mjs || true" | 20 |
| medium | New Account With Lifecycle Hook | package.json | package first published 22 day(s) ago, 6 total version(s), has lifecycle hook | 10 |
| low | Install-time lifecycle script | package.json | postinstall="node ./src/install/postinstall.mjs || true" | 5 |
Manifest
Package metadata
Scripts13
buildnpm run test:syntaxdevnode ./bin/surf.mjsdev:installSURF_DEV=1 node ./src/install/postinstall.mjsdev:plannode ./bin/surf-plan-skill.mjsdev:searchnode ./bin/surf-search-skill.mjsdev:uninstallSURF_DEV=1 node ./src/install/preuninstall.mjspostinstallnode ./src/install/postinstall.mjs || truepredevnpm run buildpredev:installnpm run buildpredev:plannpm run buildpredev:searchnpm run buildpreuninstallnode ./src/install/preuninstall.mjs || truetest:syntaxnode --check bin/surf.mjs && node --check bin/surf-search-skill.mjs && node --check bin/surf-plan-skill.mjs && for f in src/index.mjs src/env.mjs src/install/*.mjs src/lib/*.mjs src/lib/providers/*.mjs src/lib/api/*.mjs src/plan/*.mjs src/validators/*.mjs; do node --check "$f" || exit 1; done && echo syntax-ok