TL;DR
The attack
An open source maintainer account (Qix) was compromised by a phishing attack, which allowed attackers to inject malicious code into 25 popular npm packages, including chalk
and debug
.
The impact
These packages collectively see hundreds of millions of weekly downloads. The blast radius is extensive because chalk
, debug
, and their peers are embedded in popular frameworks, developer tooling, and production services.
Endor Labs response
We are actively working with our customer base, some of whom have been affected by this incident. Endor Labs customers using malware policies are automatically notified when malware is discovered in their dependencies.
What happened?
Attackers compromised the npm account of Qix, a well-known maintainer. Once inside, they published malicious versions of his libraries, compromising 25 widely-used npm packages, including chalk
and debug
. The popularity of these packages means many teams may not even realize they are in use, since they are pulled in as transitive dependencies by other frameworks (e.g., React
, Express
, build systems).
The injected code attempts to steal sensitive information from the local environment by exfiltrating sensitive information from infected environments and could enable further compromise of developer machines or CI/CD pipelines. At time of writing, no CVE or GHSA identifiers have been assigned (this will surely change as the ecosystem responds).
Who was targeted?
This attack scans strings for crypto wallet addresses, so any organization writing applications related to cryptocurrency is potentially at risk. Additionally, if your organization is heavily reliant on AI generated code, you may see increased risk as these tools lack real-time security signals. How it works:
- Wallet hijacking: The malicious code is designed to intercept and manipulate cryptocurrency transactions on a compromised system.
- Targeted assets: It targets transactions across multiple crypto assets, including Ethereum, Bitcoin, Solana, Tron, Litecoin, and Bitcoin Cash.
- Hidden execution: The malware executes silently within the browser, rewriting wallet addresses and redirecting funds to attacker-controlled accounts without visible signs to the user.
The trend we’re seeing
This attack follows a now-familiar pattern: compromising high-value open source maintainers (see the xz utils attack). It’s particularly dangerous because it weaponizes the trust of the OSS ecosystem. Developers don’t usually audit every dependency; they rely on reputation, wide usage, and the security of registries like npm. Further, these libraries underpin countless JavaScript and Node.js projects, from developer tooling to production systems. The compromise highlights the systemic fragility, where a single maintainer account takeover can ripple across the internet.
What should you do?
Downgrade immediately
Pin dependencies to safe versions published prior to the compromise. Delete your node_modules folder and any lock files (package-lock.json or yarn.lock), then reinstall dependencies to ensure a clean version is installed.
Audit your projects
Immediately check your project's package-lock.json or yarn.lock file by running npm audit or using software composition analysis (SCA) tools to check for affected versions in your dependency tree.
- ansi-regex@6.2.1
- ansi-styles@6.2.2
- backslash@0.2.1
- chalk-template@1.1.1
- chalk@5.6.1
- color-convert@3.1.1
- color-name@2.0.1
- color-string@2.1.1
- color@5.0.1
- @coveops/abi@2.0.1
- debug@4.4.2
- @duckdb/duckdb-wasm@1.29.2
- @duckdb/node-api@1.3.3
- @duckdb/node-bindings@1.3.3
- duckdb@1.3.3
- has-ansi@6.0.1
- is-arrayish@0.3.3
- prebid@10.9.1
- prebid@10.9.2
- simple-swizzle@0.2.3
- slice-ansi@7.1.1
- strip-ansi@7.1.1
- supports-color@10.2.1
- supports-hyperlinks@4.1.1
- wrap-ansi@9.0.1
Monitor for Indicators of Compromise (IoCs)
Check build logs, developer environments, and outbound traffic for suspicious activity.
Harden developer accounts
Enable 2FA on npm and GitHub accounts. Consider scoped access tokens instead of passwords.
Adopt dependency hygiene
- Use lockfiles to avoid pulling in malicious updates automatically.
- Mirror critical dependencies internally.
- Regularly review transitive dependencies in critical paths.
Detect and block malware



What's next?
When you're ready to take the next step in securing your software supply chain, here are 3 ways Endor Labs can help: