PkgRadar

Package evidence

[email protected]

New Account With Lifecycle Hook: package first published 12 day(s) ago, 4 total version(s), has lifecycle hook

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
18
Versions published
4
First published
Jun 2026
Publisher
kelvinwww

Recommended action

Block this update

Static 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"}'
Publisherkelvinwww
Artifact bytes420,547
Previous version0.1.2
Published2026-06-14T15:38:16.855Z
SHA-256bea912928a6dc21c63e84fe824188c49d1d5649584b171562f17e4920a002f3a

Why flagged

What the scanner saw

New Account With Lifecycle Hook: package first published 12 day(s) ago, 4 total version(s), has lifecycle hook

1 candidate cluster(s) currently reference this release.

Not observed: package install, lifecycle script execution, or sandbox execution. PkgRadar only inspects on-disk artifacts.

Availability ledger

available

high
Last checked
highRisk
15Score
1.0.4Version
Status history (1 event)
  1. newavailable · risk high · score 15 · status changed

Related candidates

Linked campaigns and clusters

Repeated static TTPactive

New Account With Lifecycle Hook — package first published 12 day(s) ago, 4 total version(s), has lifecycle hook

11 members · evidence strength 72
Repeated static TTPcandidate

New Account With Lifecycle Hook — package first published 12 day(s) ago, 4 total version(s), has lifecycle hook

11 members · max score 57

Evidence

Static findings

4 static · 0 from release diff · showing high-signal first.

SeverityKindPathDetailPoints
highNew Account With Lifecycle Hookpackage.jsonpackage first published 12 day(s) ago, 4 total version(s), has lifecycle hook25
Show all 4 findings (low-signal and informational)
SeverityKindPathDetailPoints
highNew Account With Lifecycle Hookpackage.jsonpackage first published 12 day(s) ago, 4 total version(s), has lifecycle hook25
lowCredential file accesspackage/dist/renderer/assets/index-Ykdmh9_C.jsmatched ".npmrc"5
lowInstall-time lifecycle scriptpackage.jsonpreinstall="node scripts/check-node-version.mjs"5
lowInstall-time lifecycle scriptpackage.jsonpostinstall="node scripts/ensure-native-deps.mjs"5

Manifest

Package metadata

Scripts28
  • buildnpm run build:renderer && npm run build:server
  • build:renderervite build --config vite.renderer.config.ts
  • build:servernode scripts/build-server.mjs
  • check:nodenode scripts/check-node-version.mjs
  • check:renderer-cssnode scripts/check-renderer-css.mjs
  • dev:desktopnpm run build && electron dist-server/electron/main.js
  • dev:remotenpm run build:renderer && ALLOW_REMOTE=true tsx src/server/index.ts
  • dev:webnpm run build:renderer && tsx watch src/server/index.ts
  • ensure:nativenode scripts/ensure-native-deps.mjs
  • postinstallnode scripts/ensure-native-deps.mjs
  • prebuildnpm run check:node && npm run ensure:native
  • prebuild:renderernpm run check:node && npm run check:renderer-css
  • prebuild:servernpm run check:node
  • predev:desktopnpm run check:node && npm run ensure:native
  • predev:remotenpm run check:node && npm run ensure:native
  • predev:webnpm run check:node && npm run ensure:native
  • preinstallnode scripts/check-node-version.mjs
  • prepacknpm run build
  • prereset-passwordnpm run check:node && npm run ensure:native
  • prestartnpm run check:node && npm run ensure:native
  • prestart:remotenpm run check:node && npm run ensure:native
  • pretestnpm run check:node && npm run ensure:native
  • pretypechecknpm run check:node
  • reset-passwordnode scripts/reset-password.mjs
  • startnode dist-server/server/index.js
  • start:remoteALLOW_REMOTE=true node dist-server/server/index.js
  • testvitest run
  • typechecktsc --noEmit
Dependencies30
  • @agentclientprotocol/sdk^0.18.2
  • @modelcontextprotocol/sdk^1.20.0
  • @radix-ui/react-dialog^1.1.16
  • @radix-ui/react-dropdown-menu^2.1.17
  • @radix-ui/react-radio-group^1.4.0
  • @radix-ui/react-scroll-area^1.2.11
  • @radix-ui/react-select^2.3.0
  • @radix-ui/react-slot^1.2.5
  • @tailwindcss/vite^4.3.1
  • bcrypt^6.0.0
  • better-sqlite3^12.4.1
  • class-variance-authority^0.7.1
  • clsx^2.1.1
  • cookie^1.0.2
  • cookie-parser^1.4.7
  • express^5.1.0
  • jsonwebtoken^9.0.2
  • lucide-react^1.18.0
  • pino^10.3.1
  • react^19.1.0
  • react-dom^19.1.0
  • react-markdown^10.1.0
  • rehype-sanitize^6.0.0
  • remark-gfm^4.0.1
  • sonner^2.0.7
  • tailwind-merge^3.6.0
  • tailwindcss^4.3.1
  • ulid^3.0.2
  • ws^8.18.3
  • zod^3.25.76