regexp-tsnpm
Malicious code in regexp-ts (npm) Remove it immediately and rotate any exposed credentials.
What this malware does
regexp-ts masquerades as the pino logger (description, keywords, and module.exports.pino export) but is actually a remote-code-execution loader. When a consumer imports the package and invokes its middleware export, index.js unconditionally spawns lib/caller.js as a detached Node process. caller.js performs an HTTP GET to https://jsonkeeper.com/b/U2BTS, takes the cookie field of the JSON response, and runs it via new Function.constructor('require', s)(require) — executing arbitrary attacker-controlled JavaScript with full Node.js privileges and access to the host's require. Additional payload URLs (https://jsonkeeper.com/b/XRGF3 and https://jsonkeeper.com/b/4NAKK) are hidden as base64 strings in lib/const.js under cover names like DEV_API_KEY/DEV_SECRET_KEY to evade casual review. Because the payload host is a free anonymous JSON paste service, the executed code is mutable at any time without a package update.
Any computer that has this package installed or running should be considered fully compromised. All secrets and keys stored on that computer should be rotated immediately from a different computer. The package should be removed, but as full control of the computer may have been given to an outside entity, there is no guarantee that removing the package will remove all malicious software resulting from installing it.
Malicious versions
Indicators of compromise (SHA-256)
Frequently asked questions
Campaign
References
Credits
- Amazon Inspector · finder
Scan your dependencies
O3 Security blocks malicious packages like this at install time and in CI.
Supply-chain protection