惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

L
LangChain Blog
博客园 - 司徒正美
美团技术团队
WordPress大学
WordPress大学
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
人人都是产品经理
人人都是产品经理
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
T
Troy Hunt's Blog
S
Schneier on Security
T
The Exploit Database - CXSecurity.com
P
Proofpoint News Feed
云风的 BLOG
云风的 BLOG
Engineering at Meta
Engineering at Meta
Cisco Talos Blog
Cisco Talos Blog
T
Tor Project blog
B
Blog
NISL@THU
NISL@THU
月光博客
月光博客
博客园 - 【当耐特】
AWS News Blog
AWS News Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
腾讯CDC
L
Lohrmann on Cybersecurity
The Cloudflare Blog
L
LINUX DO - 最新话题
S
Security @ Cisco Blogs
S
Secure Thoughts
Spread Privacy
Spread Privacy
有赞技术团队
有赞技术团队
The Last Watchdog
The Last Watchdog
Project Zero
Project Zero
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
Vercel News
Vercel News
H
Hacker News: Front Page
S
SegmentFault 最新的问题
Schneier on Security
Schneier on Security
aimingoo的专栏
aimingoo的专栏
P
Privacy & Cybersecurity Law Blog
博客园 - 三生石上(FineUI控件)
Forbes - Security
Forbes - Security
C
CXSECURITY Database RSS Feed - CXSecurity.com
I
InfoQ
T
Tailwind CSS Blog
Application and Cybersecurity Blog
Application and Cybersecurity Blog
G
GRAHAM CLULEY
W
WeLiveSecurity
小众软件
小众软件
Recorded Future
Recorded Future
Cyberwarzone
Cyberwarzone
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org

Aikido Security's Blog

Axios CVE-2026-40175: a critical bug that’s… not exploitable GlassWorm goes native: New Zig dropper infects every IDE on your machine Aikido Attack finds multiple 0-days in Hoppscotch The cybersecurity doomerism around Mythos doesn't match what we see on the ground axios compromised on npm: maintainer account hijacked, RAT deployed Popular telnyx package compromised on PyPI by TeamPCP Aikido × Lovable: Vibe, Fix, Ship CanisterWorm Gets Teeth: TeamPCP's Kubernetes Wiper Targets Iran TeamPCP deploys CanisterWorm on NPM following Trivy compromise Security testing is validating software that no longer exists Aikido Recognized by Frost & Sullivan with the 2026 Customer Value Leadership Award in ASPM GlassWorm Hides a RAT Inside a Malicious Chrome Extension fast-draft Open VSX Extension Compromised by BlokTrooper Glassworm Strikes Popular React Native Phone Number Packages Glassworm Is Back: A New Wave of Invisible Unicode Attacks Hits Hundreds of Repositories How Security Teams Fight Back Against AI-Powered Hackers Introducing Betterleaks, an open source secrets scanner by the author of Gitleaks Trump’s 2026 cybersecurity strategy: From compliance to consequence How does AI pentesting work with compliance? What continuous pentesting actually requires Rare Not Random: Using Token Efficiency for Secrets Scanning Persistent XSS/RCE using WebSockets in Storybook’s dev server Why Determinism Is Still a Necessity in Security WAF vs. RASP vs. ADR Introducing Aikido Infinite: A new model of self-securing software How Aikido secures AI pentesting agents by design Astro Full-Read SSRF via Host Header Injection How to Get Your Board to Care About Security (Before a Breach Forces the Issue) What is Slopsquatting? The AI Package Hallucination Attack Already Happening SvelteSpill: A Cache Deception Bug in SvelteKit + Vercel Top 6 Wiz Code Alternatives Aikido recognized as Platform Leader in Latio Tech's 2026 Application Security Report From detection to prevention: How Zen stops IDOR vulnerabilities at runtime npm backdoor lets hackers hijack gambling outcomes Introducing Upgrade Impact Analysis: When breaking changes actually matter to your code Why Trying to Secure OpenClaw is Ridiculous Claude Opus 4.6 found 500 vulnerabilities. What does this change for software security? Introducing Aikido Expansion Packs: Safer defaults inside the IDE International AI Safety Report 2026: What It Means for Autonomous AI Systems Self-Securing Software: What It Is, Why It Matters, and How It Works What Is Continuous Pentesting? Introducing Aikido Package Health: a Better Way to Trust Your Dependencies AI Pentesting: Minimum Safety Requirements for Security Testing Secure SDLC for Engineering Teams (+ Checklist) Fake Clawdbot VS Code Extension Installs ScreenConnect RAT G_Wagon: npm Package Deploys Python Stealer Targeting 100+ Crypto Wallets Gone Phishin': npm Packages Serving Custom Credential Harvesting Pages Malicious PyPI Packages spellcheckpy and spellcheckerpy Deliver Python RAT Top 10 AI Security Tools For 2026 Agent Skills Are Spreading Hallucinated npx Commands Understanding Open-Source License Risk in Modern Software The CISO Vibe Coding Checklist for Security Top 6 Graphite alternatives for AI code review in 2026 From “No Bullsh*t Security” to $1B: We Just Raised Our $60m Series B Critical n8n Vulnerability Allows Unauthenticated Remote Code Execution (CVE-2026-21858) Top 14 VS Code Extensions for 2026 AI-Driven Pentesting of Coolify: Seven CVEs Identified Top Continuous Pentesting Tools in 2026 SAST vs SCA: Securing the Code You Write and the Code You Depend On JavaScript, MSBuild, and the Blockchain: Anatomy of the NeoShadow npm Supply-Chain Attack How Engineering and Security Teams Can Meet DORA’s Technical Requirements IDOR Vulnerabilities Explained: Why They Persist in Modern Applications Shai Hulud strikes again - The golden path MongoBleed: MongoDB Zlib Vulnerability (CVE-2025-14847) and How to Fix It First Sophisticated Malware Discovered on Maven Central via Typosquatting Attack on Jackson The Fork Awakens: Why GitHub’s Invisible Networks Break Package Security Top 10 Cyber Security Tools For 2026 SAST in the IDE is now free: Moving SAST to where development actually happens AI Pentesting in Action: A TL;DV Recap of Our Live Demo The Top 7 Threat Intelligence Tools in 2026 React & Next.js DoS Vulnerability (CVE-2025-55184): What You Need to Fix After React2Shell OWASP Top 10 for Agentic Applications (2026): What Developers and Security Teams Need to Know DAST vs Pentesting v AI Pentesting: Why DAST Cannot Replace Modern Pentesting PromptPwnd: Prompt Injection Vulnerabilities in GitHub Actions Using AI Agents Top 7 Cloud Security Vulnerabilities Critical React & Next.js RCE Vulnerability (CVE-2025-55182): What You Need to Fix Now How to Comply With the UK Cybersecurity & Resilience Bill: A Practical Guide for Modern Engineering Teams Shai Hulud 2.0: What the Unknown Wonderer Tells Us About the Attackers’ Endgame SCA Everywhere: Scan and Fix Open-Source Dependencies in Your IDE Safe Chain now enforces a minimum package age before install Shai Hulud Attacks Persist Through GitHub Actions Vulnerabilities Shai Hulud Launches Second Supply-Chain Attack: Zapier, ENS, AsyncAPI, PostHog, Postman Compromised CORS Security: Beyond Basic Configuration Revolut Selects Aikido Security to Power Developer-First Software Security The Future of Pentesting Is Autonomous How Aikido and Deloitte are bringing developer-first security to enterprise Secrets Detection: A Practical Guide to Finding and Preventing Leaked Credentials Invisible Unicode Malware Strikes OpenVSX, Again AI as a Power Tool: How Windsurf and Devin Are Changing Secure Coding Building Fast, Staying Secure: Supabase’s Approach to Secure-by-Default Development OWASP Top 10 2025: Official List, Changes, and What Developers Need to Know Top 10 JavaScript Security Vulnerabilities in Modern Web Apps The Return of the Invisible Threat: Hidden PUA Unicode Hits GitHub repositorties Top 7 Black Duck Alternatives in 2026 What Is IaC Security Scanning? Terraform, Kubernetes & Cloud Misconfigurations Explained AutoTriage and the Swiss Cheese Model of Security Noise Reduction Top Software Supply Chain Security Vulnerabilities Explained The Top 7 Kubernetes Security Tools Top 10 Web Application Security Vulnerabilities Every Team Should Know What Is CSPM (and CNAPP)? Cloud Security Posture Management Explained
npx Confusion: Packages That Forgot to Claim Their Own Name
Charlie Eriksen · 2026-02-04 · via Aikido Security's Blog

Back in July 2025, I was prototyping a new project and decided to try out MikroORM. The docs said to run npx mikro-orm-esm for migrations. So I did.

npm ERR! code E404
npm ERR! 404 Not Found - GET https://registry.npmjs.org/mikro-orm-esm

Package doesn't exist, that’s strange! Then it hit me: what if someone had registered this? I would've seen:

Need to install the following packages:
mikro-orm-esm@1.0.0
Ok to proceed? (y)

I would've just hit y. Everyone does. And nothing in that prompt tells you whether you're about to install malware or a legitimate tool.

The docs pointed to a non-existent package. How many other phantom package references are floating around? How many have already been claimed by attackers? I had to know.

So I started digging. Wrote scripts to scan npm for packages referenced in READMEs and scripts but never actually published. Cross-referenced thousands of npx invocations. Found dozens. Claimed 14 of them before anyone else could. Then S1ngularity happened, and the research got shelved.

Six months later, I was reminded of my research thanks to the community researching similar things. I finally checked the download counts: 121,539 downloads!

People had been hitting these non-existent commands thousands of times a week. For months. While the packages just sat there collecting data. 

Six Months of Data

Downloads didn't stay flat. They grew. Started slow in late July. Recent peak hit 4,236 downloads in a single day (January 16th, 2026).

121,539 Downloads Over 7 Months

128 phantom npx packages, July 2025 to January 2026

121,539

Total Downloads

3,903

Weekly Average

4,236

Peak Day (Jan 16)

4K 3K 2K 1K 🎄 Holiday dip Peak: 4,236 Jul Aug Sep Oct Nov Dec Jan

Weekly download volume grew steadily from July 2025 through January 2026

  • Total: 121,539 downloads across 128 packages
  • Weekly average: 3,903
  • Peak day: 4,236 downloads (Jan 16, 2026)

Quick note on noise: every time you publish a new version of a package, it automatically gets 60-100 downloads from security scanners and mirrors. That's baseline noise per release. Packages with multiple versions accumulate noise quickly. Anything consistently above that threshold is real usage.

Notice the dip around late December? Holidays. Even phantom package downloads take Christmas off.

The Big Three

Three packages account for 79% of all downloads:

  • openapi-generator-cli: 48,356 downloads (actual package: @openapitools/openapi-generator-cli)
  • cucumber-js: 32,110 downloads (actual package: @cucumber/cucumber)
  • depcruise: 15,637 downloads (actual package: dependency-cruiser)

The Big Three: 79% of All Traffic

Three phantom packages account for 96,103 of 121,539 total downloads

openapi-generator-cli → actual: @openapitools/openapi-generator-cli
23 npm refs650 GitHub results3,994 last 7 days
cucumber-js → actual: @cucumber/cucumber
28 npm refs856 GitHub results
depcruise → actual: dependency-cruiser
27 npm refs836 GitHub results

openapi-generator-cli saw 3,994 downloads in just the last 7 days. That's nearly 4,000 times someone tried to run a command that doesn't exist. In one week.

The Long Tail

The remaining packages with significant downloads:

  • jsdoc2md: 4,641 downloads
  • grpc_tools_node_protoc: 4,518 downloads
  • vue-demi-switch: 1,166 downloads
  • styleguidist: 805 downloads
  • mikro-orm-esm: 314 downloads
  • pvbase64: 142 downloads
  • cromwell: 106 downloads

The Long Tail

Remaining packages with notable download counts (excluding the Big Three)

jsdoc2md 4,641
grpc_tools_node_protoc 4,518
vue-demi-switch 1,166
styleguidist 805
mikro-orm-esm 314
pvbase64 142
cromwell 106
📊 Noise threshold: Each version release generates 60-100 scanner downloads. Packages under ~100 total (shown in gray) are likely all noise. Everything above that represents real machines, real environments, real credentials.

1K+ downloads100-1K downloadsAt noise threshold

Remember that 60-100 download baseline per version? A package with 3 versions could have 180-300 downloads of pure noise. fathym with 83 downloads total is likely all noise. But mikro-orm-esm with 314? Even accounting for multiple versions, that's real attempts.

styleguidist with 805 downloads means hundreds of real executions. Could be CI/CD hitting it repeatedly. Could be dozens of different developers. Either way, it's real usage of a package that shouldn't exist.

How We Found These

We run a full npm registry mirror at Aikido. Parsed every package.json and README across the entire registry. Extracted npx commands. Cross-referenced against what's actually registered. We also searched GitHub's code search to see how widely these phantom commands appear in the wild, in documentation, CI configs, scripts, anywhere developers might reference them.

Three data points for each package:

  • Registry references: How many npm packages mention this command in their package.json or README
  • GitHub results: How many code files or repos reference this command on GitHub
  • Downloads: How many times people actually tried to run it

We claimed 14 in July 2025. When I picked the research back up in January, we expanded our analysis and found many more. At this point, we’ve claimed 128 packages in total.

Complete Package Breakdown

npm refs, GitHub code search results, and downloads for all claimed packages

npm RefsGitHub ResultsDownloads

🔴 Major Attack Vectors (10K+ downloads)

Package Refs GitHub Downloads
openapi-generator-cli 23 650 48,356
cucumber-js 28 856 32,110
depcruise 27 836 15,637

🟡 Significant Attack Vectors (1K-10K downloads)

Package Refs GitHub Downloads
jsdoc2md 92 155 4,641
grpc_tools_node_protoc 83 226 4,518
vue-demi-switch 70 80 1,166

Moderate Risk + Noise Threshold

Package Refs GitHub Downloads
styleguidist HIGH EXPOSURE 246 286 805
mikro-orm-esm DOCS ONLY 0 80 314
pvbase64 18 70 142
cromwell 31 23 106
git-scripts-pre-push LOW CONVERSION 126 133 93
fathym LOW CONVERSION 119 9 83
aofl, flatjs-forge 42, 30 30, 2 99, 91

Key insight: High npm refs don't always equal high downloads. styleguidist has 246 refs but 805 downloads, while mikro-orm-esm has 0 refs but 314 downloads from docs alone.

Some patterns worth noting:

Major attack vectors (10K+ downloads): openapi-generator-cli, cucumber-js, and depcruise all show strong correlation between npm references, GitHub mentions, and actual downloads. These would be devastating in attacker hands.

High exposure, low conversion: styleguidist has 246 npm references and 286 GitHub results, but only 805 downloads. git-scripts-pre-push has 126 references but just 93 downloads. Visibility doesn't always equal execution.

Documentation-only vectors: mikro-orm-esm has zero npm package references but 80 GitHub results and 314 downloads. Proof that documentation alone can drive hundreds of installs, even without any npm ecosystem references.

Why This Is Dangerous

The attack is simple.

An attacker registers the package. Adds a postinstall script that exfiltrates environment variables: npm tokens, cloud credentials, API keys, whatever's lying around. Then waits.

At peak, that's potentially ~4,000 compromised machines per week. Developer workstations. CI servers. Build environments. Many are possibly running with credentials in environment variables. There’s no phishing needed. No supply chain compromise of existing packages. Just claim the name and wait for npx to bring victims to you.

When someone runs the command, they see:

Need to install the following packages:
openapi-generator-cli@1.0.0
Ok to proceed? (y)

The prompt doesn't show who published it. Doesn't show when. Doesn't show whether it's what you're looking for. You might see this prompt regularly for legitimate tools. Muscle memory takes over, because we’re humans. You type y, as everybody else does. That's it. That's the entire attack.

We closed 128 gaps across multiple rounds. We’ve caught the worst cases. But there’s a long tail of thousands.

A Note on npm's Protections

npm does have typosquatting protection. When we tried to claim certain names, npm rejected them with similarity errors. Names like rsbuild, vuedoc, napi, t-ci were all too close to existing packages. That's good. It means npm is actively blocking obvious squatting attempts.

But these phantom commands aren't typos. They're names that were never registered in the first place. npm's similarity check doesn't catch those because there's nothing to be "similar to."

What You Should Do

Use npx --no-install

npx --no-install your-command

This forces npx to only use local binaries. No registry fallback. If it's not installed, it fails. That's what you want.

Install CLI tools explicitly. Don't rely on npx to fetch them:

{
  "devDependencies": {
    "@openapitools/openapi-generator-cli": "^2.7.0"
  }
}

Verify before running. Documentation says to run npx something? Check that the package actually exists first. Check it's the right one. Especially in CI/CD.

Claim your namespace. If you maintain a CLI tool, register the obvious aliases and misspellings. Cheap insurance against someone else doing it maliciously.

How to Tell If You're Affected

If you are an Aikido user, check your central feed and filter on malware issues. Any phantom package vulnerabilities will surface as a 100/100 critical issue in the feed. Aikido rescans your repos nightly, though we recommend triggering a full rescan as well.

If you are not yet an Aikido user, set up a free account and connect your repos. Our proprietary malware coverage is included in the free plan (no credit card required).

For future protection, consider using Aikido SafeChain (open source), a secure wrapper for npm, npx, yarn, and pnpm. SafeChain sits in your current workflows, intercepting package install commands and verifying packages against Aikido Intel (our open source threat intelligence) before they hit your machine. Stop threats at the gate.

The Math

121,539 downloads in seven months. 3,903 per week on average. Peak of 4,236 in a single day. 128 packages claimed total (14 in July, rest in January).

The npm ecosystem has millions of packages. Developers run npx commands thousands of times daily. The gap between "convenient default" and "arbitrary code execution" is one unclaimed package name.