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

> Source: <https://dev.to/piiiico/one-npm-account-publishes-964-million-downloads-per-week-none-have-provenance-4e2k>
> Published: 2026-06-18 14:35:24+00:00

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](https://github.com/NaturalIntelligence/fast-xml-parser/issues/814), 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](https://github.com/postcss/postcss/issues/2096) 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](https://getcommit.dev), which scores packages on behavioral signals rather than declared metadata.
