Package evidence
[email protected]
Install-time lifecycle script: postinstall="node scripts/install-hooks.mjs"
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
- 1,339Niche · −30% score
- Versions published
- 26
- First published
- Apr 2026
- Publisher
- chandshy
Effective trust discount applied: −30% (max across signals — discounts don’t stack). New install-lifecycle deltas vs the previous release would clear the discount.
Recommended action
Review before promotingMixed signals: the package has indicators worth reading before allowing the update in automated dependency flows.
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":"review"}'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":"review"}'Why flagged
What the scanner saw
Install-time lifecycle script: postinstall="node scripts/install-hooks.mjs"
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 review · score 3 · status changed
Evidence
Static findings
1 static · 0 from release diff · showing high-signal first.
No high-signal findings — see all findings below.
Show all 1 findings (low-signal and informational)
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| low | Install-time lifecycle script | package.json | postinstall="node scripts/install-hooks.mjs" | 5 |
Manifest
Package metadata
Scripts30
buildtscbuild:cleannpm run clean && npm run buildcheck:bulk:livenode scripts/check-bulk-live.mjscheck:licensesnode scripts/check-licenses.mjscheck:npm-auditnode scripts/check-npm-audit.mjscheck:secretsnode scripts/check-secrets.mjscheck:tarballnode scripts/smoke-tarball.mjscheck:version-syncnode scripts/check-version-sync.mjscleannode -e "for(const d of ['dist','coverage'])require('fs').rmSync(d,{recursive:true,force:true})"devtsc --watchlinttsc --noEmitlint:fixtsc --noEmitpostinstallnode scripts/install-hooks.mjspreparenpm run buildprepublishOnlynpm run preship:releasepreshipnode scripts/preship.mjspreship:fastnode scripts/preship.mjs fastpreship:releasenode scripts/preship.mjs releasesettingsnode dist/settings-main.jsstartnode dist/index.jstestvitest run --exclude test/agent-harness.test.tstest:coveragevitest run --coverage --exclude test/agent-harness.test.tstest:e2e:bridgevitest run --config vitest.config.e2e.ts --reporter=verbose --testTimeout=60000test:e2e:bridge:cleanupnode test/e2e/support/cleanup-bridge.mjstest:e2e:bridge:safeMAILPOUCH_E2E_SAFE=1 vitest run --config vitest.config.e2e.ts test/e2e/scenarios/safe-bridge.e2e.test.ts --reporter=verbose --testTimeout=60000test:e2e:localdocker compose -f test/e2e/fixtures/greenmail-compose.yml up -d && node scripts/wait-for-port.mjs 127.0.0.1 3143 30 && vitest run --config vitest.config.e2e.ts; r=$?; docker compose -f test/e2e/fixtures/greenmail-compose.yml down; exit $rtest:e2e:local:keepvitest run --config vitest.config.e2e.tstest:harnessvitest run test/agent-harness.test.ts --reporter=verbose --testTimeout=30000test:watchvitest --exclude test/agent-harness.test.tstypechecktsc --noEmit
Dependencies5
@modelcontextprotocol/sdk~1.29.0better-sqlite3^12.9.0imapflow~1.3.1mailparser~3.9.8nodemailer~8.0.7
Optional dependencies2
@napi-rs/keyring~1.3.0systray2~2.1.4