Your RSA-2048 keys break in 2030. Find every one of them before attackers do.
Malicious package

react-ui-polyfillsnpm

Malicious code in react-ui-polyfills (npm) Remove it immediately and rotate any exposed credentials.

MAL-2026-4784
Immediate action
Remove the package, then rotate any secrets the build/runtime could reach.
npm uninstall react-ui-polyfills

What this malware does

Package advertises itself as React polyfills / UI compatibility helpers but ships no React or polyfill code. The exported getPlugin() function returns a closure that fetches JSON from https://jsonkeeper.com/b/GMIHS (an anonymous, mutable paste-style host with no integrity verification) and passes the parsed.cookie field directly to eval(), executing attacker-controlled JavaScript in the consumer's process. The mismatch between the package's advertised purpose (React polyfills) and its actual contents (SVG utilities + remote-eval backdoor) indicates the name is engineered to lure React developers. Any application that imports this package and invokes getPlugin() will execute whatever JavaScript the attacker chooses to host at the jsonkeeper URL at that moment.

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

2 flagged
1.0.01.2.7

Indicators of compromise (SHA-256)

63c43460df1ee670b8a5982d77e7028aef7df25fa38922f743489fd52b41b5ea
983903a0ea0bc54186092f0509ca55ed8861039835e4fbc91a0452c99b177637
1980d59ba145376faa2b0e3ee80c62c47d0721390a39ab80e5046976cefc157c
95822dbefead1d7a8b78540dea5bbf1eb3605d600910f7b46dc8f7d46b853b5b
258097416cb997b01e098f8838dd386a7310cb665d40c38f5e146535090d516a

Detection & response playbook

Backdoor / remote access
  1. Find it

    Scan your lockfiles (package-lock.json, pnpm-lock.yaml, yarn.lock, requirements.txt, poetry.lock, etc.) and build artifacts for react-ui-polyfills (2 malicious versions). O3 Security's supply-chain scanner checks every dependency against known-malicious package intelligence at install time and in CI, flagging react-ui-polyfills across your stack and pipelines.

  2. If you installed it — respond

    react-ui-polyfills establishes remote access, so treat any host that installed it as fully compromised. Isolate the machine, remove the package, rotate all credentials it could reach, and rebuild from a trusted image rather than cleaning in place — a backdoor may have planted additional persistence.

  3. Did it already run?

    If react-ui-polyfills was ever installed, its post-install/runtime payload may have already executed. O3's L7 egress monitoring and runtime eBPF sensors detect the credential exfiltration or command-and-control callback after install and block the malicious outbound channel, so you catch and contain the actual compromise — not just the presence of the package.

  4. How O3 protects you

    O3 blocks react-ui-polyfills before install through its supply-chain scanner, and if it has already run, detects and severs the exfiltration or C2 callback at runtime through L7 egress monitoring and eBPF.

Frequently asked questions

No. react-ui-polyfills on npm has been identified as a malicious package (versions 1.0.0, 1.2.7 flagged). It should be removed immediately — do not install or keep it in your dependency tree.

Campaign

IN-MAL-2026-004860IN-MAL-2026-004861IN-MAL-2026-004864IN-MAL-2026-004865GHSA-v7mj-pmr3-7x4p

References

Credits

  • Amazon Inspector · finder

Detect & block this

O3 blocks react-ui-polyfills-class packages before install and in CI — and if it already ran, its runtime egress monitoring catches the C2 callback and severs the channel.

react-ui-polyfills (npm) malicious package — MAL-2026-4784 | O3 Security