Package evidence
[email protected]
Install Lifecycle Suppresses Failure: postinstall="npx playwright install chromium 2>/dev/null || echo 'Note: Playwright browser install skipped (run npx playwright install chromium manually if scraping JS-rendered pages)'"
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
- 287
- Versions published
- 32Established · −30% score
- First published
- Jul 2025
- Publisher
- GitHub ActionsTrusted automation · −70% score
Effective trust discount applied: −70% (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 Lifecycle Suppresses Failure: postinstall="npx playwright install chromium 2>/dev/null || echo 'Note: Playwright browser install skipped (run npx playwright install chromium manually if scraping JS-rendered pages)'"
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 7 · status changed
Evidence
Static findings
2 static · 0 from release diff · showing high-signal first.
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| high | Install Lifecycle Suppresses Failure | package.json | postinstall="npx playwright install chromium 2>/dev/null || echo 'Note: Playwright browser install skipped (run npx playwright install chromium manually if scraping JS-rendered pages)'" | 20 |
Show all 2 findings (low-signal and informational)
| Severity | Kind | Path | Detail | Points |
|---|---|---|---|---|
| high | Install Lifecycle Suppresses Failure | package.json | postinstall="npx playwright install chromium 2>/dev/null || echo 'Note: Playwright browser install skipped (run npx playwright install chromium manually if scraping JS-rendered pages)'" | 20 |
| low | Install-time lifecycle script | package.json | postinstall="npx playwright install chromium 2>/dev/null || echo 'Note: Playwright browser install skipped (run npx playwright install chromium manually if scraping JS-rendered pages)'" | 5 |
Manifest
Package metadata
Scripts24
buildtscdevtsx watch src/server.tsinspectnpx @modelcontextprotocol/inspector node dist/server.jspostbuildnode -e "const f='dist/server.js';const c=require('fs').readFileSync(f,'utf8');if(!c.startsWith('#!'))require('fs').writeFileSync(f,'#!/usr/bin/env node\n'+c)"postinstallnpx playwright install chromium 2>/dev/null || echo 'Note: Playwright browser install skipped (run npx playwright install chromium manually if scraping JS-rendered pages)'preparenpm run buildprepublishOnlynpm run build && npm teststartnode dist/server.jstestnode --experimental-vm-modules --no-deprecation node_modules/jest/bin/jest.jstest:benchmarknode --experimental-vm-modules --no-deprecation node_modules/jest/bin/jest.js --testPathPattern=benchmark --verbosetest:coveragenode --experimental-vm-modules --no-deprecation node_modules/jest/bin/jest.js --coveragetest:e2enpm run build && npm run test:e2e:stdio && npm run test:e2e:sse && npm run test:e2e:youtubetest:e2e:inspectornode tests/e2e/mcp-inspector-e2e.mjstest:e2e:markdownnode --no-warnings tests/e2e/markdown-negotiation-e2e.mjstest:e2e:orphannode --no-deprecation tests/e2e/orphan-cleanup-e2e.mjstest:e2e:sse./scripts/run-sse-test.shtest:e2e:stdionode tests/e2e/e2e_stdio_mcp_client_test.mjstest:e2e:timeoutnpm run build && node --no-deprecation tests/e2e/comprehensive_timeout_test.jstest:e2e:youtubenode tests/e2e/youtube-transcript-e2e.mjstest:fixnode --experimental-vm-modules --no-deprecation node_modules/jest/bin/jest.js --no-cachetest:integrationnpm test -- --testPathPattern=server-integrationtest:unitnpm test -- --testPathPattern=spec --testPathIgnorePatterns=server-integrationtest:verbosenode --experimental-vm-modules --no-deprecation node_modules/jest/bin/jest.js --verbosetest:warningsnode --experimental-vm-modules node_modules/jest/bin/jest.js
Dependencies15
@danielxceron/youtube-transcript^1.2.6@modelcontextprotocol/sdk^1.26.0cheerio1.0.0-rc.12cors^2.8.5crawlee^3.13.2express^5.1.0express-rate-limit^8.3.1jsonwebtoken^9.0.2jszip^3.10.1jwks-rsa^3.2.0mammoth^1.11.0node-fetch^3.3.2pdf-parse^2.4.5playwright^1.58.2zod^3.25.0