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.
- Versions published
- 39Established · −30% score
- First published
- Nov 2025
- Publisher
- towfiqi
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":["@plutonhq/[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":["@plutonhq/[email protected]"],"fail_on":"review"}'Why flagged
What the scanner saw
Credential file access: matched ".aws"
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 | Credential file access | package/dist/utils/providers/_s3Options.js | matched ".aws" | 5 |
Manifest
Package metadata
Scripts14
buildpnpm run clean && node ./scripts/build.js && pnpm run copy:frontendbuild:pkgnode ./scripts/build-pkg.jscheckUpdatesnpx npm-check -ucleannode -e "require('fs').rmSync('dist',{recursive:true,force:true});require('fs').rmSync('public',{recursive:true,force:true})"copy:frontendnode -e "const fs=require('fs');const path=require('path');const src='../frontend/dist';if(!fs.existsSync(src)){console.log('Skipping copy:frontend - frontend dist not found');process.exit(0)};function copyDir(s,d){fs.mkdirSync(d,{recursive:true});fs.readdirSync(s,{withFileTypes:true}).forEach(e=>{const sp=path.join(s,e.name),dp=path.join(d,e.name);e.isDirectory()?copyDir(sp,dp):fs.copyFileSync(sp,dp)})};copyDir(src,'public')"db:studionpx drizzle-kit studio --port 4983devcross-env NODE_ENV=development tsx watch -r dotenv/config src/index.tsgenerate-migrationnpx drizzle-kit generatelinteslint src/**/*.tsmigrate-dbtsx -r dotenv/config src/db/migrate.tspackagenode ./scripts/build.jsprepublishOnlypnpm run clean && node ./scripts/build.jsstartnode dist/index.jstestcross-env NODE_OPTIONS='--max-old-space-size=8192' jest --config jest.config.ts
Dependencies25
@napi-rs/keyring^1.2.0bcryptjs^3.0.3better-sqlite312.2.0cookies^0.9.1cors^2.8.5croner^9.0.0cryptr^6.3.0drizzle-orm^0.44.7drizzle-zod^0.8.3ejs^3.1.10express^5.2.1express-rate-limit^7.5.1express-session^1.19.0helmet^8.1.0jsonwebtoken^9.0.3memorystore^1.6.8nanoid^5.0.9node-ssh^13.2.0nodemailer8.0.1otpauth^9.5.0pino^9.6.0qrcode^1.5.4systeminformation^5.31.0tsx^4.21.0zod^4.1.12