Package evidence
[email protected]
Install Lifecycle Remote Or Exec: postinstall="node -e \"require('fs').copyFileSync('node_modules/marked/lib/marked.umd.js','ui/marked.min.js')\""
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
- 105
- Versions published
- 32
- First published
- May 2026
- Publisher
- liebenbergb
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 Remote Or Exec: postinstall="node -e \"require('fs').copyFileSync('node_modules/marked/lib/marked.umd.js','ui/marked.min.js')\""
Not observed: package install, lifecycle script execution, or sandbox execution. PkgRadar only inspects on-disk artifacts.
Availability ledger
available
Status history (4 events)
- available → available · risk high · score 57 · status available -> available, risk high -> high, score 77 -> 57
- available → available · risk high · score 77 · status available -> available, risk high -> high, score 123 -> 77
- available → available · risk high · score 123 · status available -> available, risk high -> high, score 345 -> 123
- new → available · risk high · score 345 · status changed
Related candidates
Linked campaigns and clusters
liebenbergb
2 members · evidence strength 64Install-time lifecycle script — postinstall="node -e \"require('fs').copyfilesync('node_modules/marked/lib/marked.umd.js','ui/marked.min.js')\""
2 members · evidence strength 70Install Lifecycle Remote Or Exec — postinstall="node -e \"require('fs').copyfilesync('node_modules/marked/lib/marked.umd.js','ui/marked.min.js')\""
2 members · evidence strength 70Evidence
Static findings
5 static · 0 from release diff · showing high-signal first.
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| high | Install Lifecycle Remote Or Exec | package.json | postinstall="node -e \"require('fs').copyFileSync('node_modules/marked/lib/marked.umd.js','ui/marked.min.js')\"" | 30 |
| medium | Remote Payload | package/start.sh | matched "curl " | 12 |
Show all 5 findings (low-signal and informational)
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| high | Install Lifecycle Remote Or Exec | package.json | postinstall="node -e \"require('fs').copyFileSync('node_modules/marked/lib/marked.umd.js','ui/marked.min.js')\"" | 30 |
| medium | Remote Payload | package/start.sh | matched "curl " | 12 |
| low | Credential file access | package/dist/learning/promotionGate.js | matched ".aws/" | 5 |
| low | Messenger Bot Endpoint | package/dist/integrations/telegram.js | matched "api.telegram.org/bot" — messenger-bot URL without exfil context (likely a notification handler) | 5 |
| low | Install-time lifecycle script | package.json | postinstall="node -e \"require('fs').copyFileSync('node_modules/marked/lib/marked.umd.js','ui/marked.min.js')\"" | 5 |
Manifest
Package metadata
Scripts54
audit:automation-jobsnode scripts/audit-automation-jobs.jsaudit:triagenode scripts/audit-triage.jsautonomyts-node cookbook/task-loop.tsautonomy:debugnode -e "process.env.HARNESS_DEBUG_LOG='.forge-debug.jsonl';require('child_process').spawnSync(process.execPath,[require.resolve('ts-node/dist/bin'),'cookbook/task-loop.ts'],{stdio:'inherit',env:process.env})"autonomy:dryts-node cookbook/task-loop.ts --dry-runautonomy:resetnode -e "['.forge-stop','.forge-state.json'].forEach(f=>{try{require('fs').unlinkSync(f)}catch{}})"autonomy:stopnode -e "require('fs').writeFileSync('.forge-stop','stop')"buildtsccleanup:automation-jobsnode scripts/cleanup-automation-jobs.jsdebug:payloadsnode scripts/debug-payload-summary.jsdevts-node src/cli/index.tsdiagnose:gemma-toolnode scripts/lean-gemma-tool-probe.jsdiagnose:mistralnode scripts/mistral-roundtrip.jshelpnode scripts/help.jsjarvis:brief-telegramnode scripts/jarvis-brief-telegram.jsjarvis:compactnode scripts/jarvis-compact-kg.jsjarvis:export-laddernode scripts/jarvis-export-ladder.jsjarvis:import-laddernode scripts/jarvis-import-ladder.jsjarvis:mcpnode scripts/jarvis-mcp-serve.jsjarvis:seednode scripts/jarvis-seed-kg.jslinttsc --noEmitpostinstallnode -e "require('fs').copyFileSync('node_modules/marked/lib/marked.umd.js','ui/marked.min.js')"prepublishOnlynpm run buildrelease:bumpnode scripts/bump-version.jsrelease:dry-runnode scripts/release-dry-run.jsrelease:manifestnode scripts/release-manifest.jsrelease:notesnode scripts/release-notes.jsrelease:provenancenode scripts/generate-release-provenance.js --writerelease:readynode scripts/check-release-ready.jsservenode dist/web/server.js- …and 24 more.
Dependencies13
@types/ws^8.18.1discord.js^14.26.4docx^9.6.1exceljs^4.4.0express^5.2.1imapflow^1.3.3marked18.0.3nodemailer^8.0.7ollama^0.5.0pdfjs-dist^5.7.284pdfkit^0.18.0ws^8.20.0yahoo-finance2^3.14.0