cd /news/developer-tools/one-npm-account-publishes-964-millio… · home topics developer-tools article
[ARTICLE · art-32724] src=dev.to ↗ pub= topic=developer-tools verified=true sentiment=↓ negative

One npm Account Publishes 964 Million Downloads Per Week. None Have Provenance.

The npm account 'ai' publishes seven packages that collectively receive 964 million weekly downloads, yet none have npm provenance attestations. This single-publisher, no-provenance pattern mirrors recent supply-chain attacks on axios, LiteLLM, and the Shai-Hulud worm, exposing a critical attack surface. The PostCSS ecosystem, including postcss, autoprefixer, and browserslist, is entirely behind this account, amplifying the risk of a compromised token.

read2 min views1 publishedJun 18, 2026

The npm account ai

publishes seven packages. Combined, they install 964 million times per week:

Package Weekly downloads Publishers Risk
postcss 245,612,332 1 CRITICAL
nanoid 206,588,788 1 CRITICAL
caniuse-lite 173,435,668 1 CRITICAL
browserslist 167,746,012 1 CRITICAL
autoprefixer 63,517,741 1 CRITICAL
postcss-nested 54,486,292 1 CRITICAL
postcss-js 52,771,544 1 CRITICAL

That's 50 billion installs per year behind a single set of npm credentials. None of them have npm provenance attestations.

npm provenance uses OIDC tokens from GitHub Actions instead of long-lived npm tokens. If a package has provenance, you can verify that the published code came from a specific commit in a specific repository — not from someone's compromised laptop.

Without provenance, there's no way to distinguish a legitimate release from one pushed by a stolen token. The blast radius here is nearly a billion installs per week.

This isn't theoretical. axios was attacked on March 30, 2026 through a stolen npm token — same single-publisher, no-provenance pattern. LiteLLM was hit the same way a month earlier. The Shai-Hulud worm in May 2026 exploited stolen tokens to republish 637 package versions in 39 minutes.

PostCSS is interesting because it's not just one critical package. It's an entire ecosystem of critical packages, all behind the same account. chalk is one package, one publisher, 432M downloads/week. Bad enough. But ai

controls seven independent packages that each cross the 10M threshold.

A compromised ai

token doesn't just hit postcss. It hits the CSS build pipeline (postcss + autoprefixer + postcss-nested + postcss-js), the browser compatibility layer (browserslist + caniuse-lite), and one of the most popular ID generators in the ecosystem (nanoid).

And caniuse-lite

was flagged with a dormant publisher warning — 61 months of inactivity on the publishing account. postcss-nested hasn't had a release in over 12 months.

fast-xml-parser (88M downloads/week, single publisher) had the same problem. After the community raised the issue, the maintainer set up GitHub Actions OIDC publishing. Within days, version 5.9.1 shipped with SLSA provenance attestations. Then 5.9.2 added environment gates and SHA-pinned actions. The structural gap closed in under a week.

I filed an issue on PostCSS yesterday proposing the same approach. The fix is a one-line change — add provenance: true

to the npm publish step — and it requires zero stored secrets.

If you want to see which packages in your project have this concentration risk:

npx proof-of-commitment

Run it in any project directory. It auto-detects your lockfile and flags packages where a single npm publisher controls more than 10M weekly downloads. That's the exact attack surface that's been exploited three times in four months.

The full PostCSS ecosystem audit data comes from Commit, which scores packages on behavioral signals rather than declared metadata.

── more in #developer-tools 4 stories · sorted by recency
── more on @npm 3 stories trending now
sponsored brought to you by zahid.host 4,200+ EU-deployed projects
reading about agents? ship yours in a single git push.

Run your AI side-project on zahid.host

EU-based hosting, git-push deploys, automatic HTTPS, no cold starts. Free tier with a custom domain — perfect for shipping the agent you just read about.

$git push zahid main
Live at https://your-agent.zahid.host
Get free account → Pricing
from €0/mo · no card required
LIVE [news/one-npm-account-publ…] indexed:0 read:2min 2026-06-18 ·