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
- 5
- Versions published
- 3
- First published
- Oct 2025
- Publisher
- lukium
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":["@lukium/[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":["@lukium/[email protected]"],"fail_on":"review"}'Why flagged
What the scanner saw
Install-time lifecycle script: postinstall="husky install"
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 5 · 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="husky install" | 5 |
Manifest
Package metadata
Scripts33
benchmarkyarn build && node benchmarks/run.jsbenchmark:memoryyarn build && node --expose-gc benchmarks/memory-test.jsbuildyarn clean && yarn build:cjs && yarn build:esm && node scripts/finalize-builds.mjsbuild:chatyarn build && node examples/cross-browser-chat/build-bundle.mjsbuild:cjstsc -p tsconfig.cjs.jsonbuild:esmtsc -p tsconfig.esm.jsonbuild:pwa-vitevite build --config examples/pwa-vite/vite.config.tsbundle:sizenode scripts/measure-bundle-size.mjscleannode -e "const fs=require('fs');const path=require('path');for (const dir of ['lib/cjs','lib/esm']) { try { fs.rmSync(dir,{recursive:true,force:true}); } catch (err) { if (err.code !== 'ENOENT') throw err; } } try { for (const entry of fs.readdirSync('lib',{withFileTypes:true})) { if (entry.isDirectory()) continue; fs.rmSync(path.join('lib', entry.name), { force: true }); } } catch (err) { if (err.code !== 'ENOENT') throw err; }"dev:pwa-vitevite --config examples/pwa-vite/vite.config.tsdocs:apitypedoc --options typedoc.jsonexample:basicnode examples/basic-messaging/demo.mjsexample:chatyarn build:chat && node examples/cross-browser-chat/server.mjsexample:pwa-viteyarn dev:pwa-viteformatprettier '**/{*.{js?(on),ts?(x),md},.*.js?(on)}' --write --list-different --config prettier.config.jsformat:checkprettier '**/{*.{js?(on),ts?(x),md},.*.js?(on)}' --check --config prettier.config.jslinteslint 'src/**/*.ts' 'src/__test__/**/*.ts'lint:fixeslint 'src/**/*.ts' 'src/__test__/**/*.ts' --fixpostinstallhusky installpostversiongit push && git push --tagsprepareyarn run buildprepublishOnlyyarn release:betapreversionyarn run lint && yarn testpreview:pwa-viteyarn build:pwa-vite && vite preview --config examples/pwa-vite/vite.config.ts --host 127.0.0.1 --port 5174release:betayarn lint && yarn test && yarn bundle:size && yarn build && yarn smoke:build && yarn smoke:browsersmoke:browsernode scripts/smoke-browser-build.mjssmoke:buildnode scripts/smoke-build.mjstestjest --config jestconfig.jsontest:coveragejest --config jestconfig.json --coveragetest:e2ePLAYWRIGHT_BROWSERS_PATH=.playwright-browsers playwright test- …and 3 more.
Dependencies2
base64-js^1.5.1protobufjs^7.6.4