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

pygments-richstylePyPI

Malicious code in pygments-richstyle (PyPI) Remove it immediately and rotate any exposed credentials.

MAL-2025-191654
Immediate action
Remove the package, then rotate any secrets the build/runtime could reach.
pip uninstall pygments-richstyle

What this malware does

Packages silently decrypt content hidden in a dependency and load them as Python extension modules.

In the first wave, those are copies of legitimate aiohttp and aiohappyeyeballs packages. In the second wave, malicious packages created good-looking forks of legitimate rich and pigments packages.

Category: MALICIOUS - The campaign has clearly malicious intent, like infostealers.

Campaign: 2025-10-asynhttp

Reasons (based on the campaign):

  • typosquatting

  • exfiltration-generic

  • obfuscation

  • clones-real-package

  • native-extension

Malicious versions

1 flagged
1.0.0

Indicators of compromise (SHA-256)

6b49aa9502d6164b44069711b872ae64859f1ee6c43f5cd65745a3fd13cc5d6f
1a522c8b8020b2bc892dccb2ac852a0a95c0eeb3fc0f94f7e4fff0da98979fa1
ed44cafe4fd7aebba15cdc8a14058888e3071523ae21ea13f827a1b9713033cd
a965f61b1e51e6c96a8987633eaf2f23001320e4c6b884c33603230c66798e74
93c92401274f72ed49706fcca3207624059529f6f2e375ce2033a831a85d17e3

Detection & response playbook

Credential / info stealer
  1. Find it

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

  2. If you installed it — respond

    pygments-richstyle is built to steal secrets, so assume every credential the build or runtime could read is compromised. Remove it from your project and lockfile, then rotate ALL exposed secrets — npm/registry tokens, cloud keys, CI/CD secrets, SSH keys, and any .env values — from a known-clean machine. Audit logs for unauthorized use of those credentials.

  3. Did it already run?

    If pygments-richstyle 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 pygments-richstyle 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. pygments-richstyle on PyPI has been identified as a malicious package (version 1.0.0 flagged). It should be removed immediately — do not install or keep it in your dependency tree.

Campaign

RLMA-2025-056282025-10-asynhttpRLUA-2026-00634

References

Credits

  • Kamil Mańkowski (kam193)
  • ReversingLabs · finder

Detect & block this

O3 blocks pygments-richstyle-class packages before install and in CI — and if it already ran, its runtime egress monitoring catches the credential exfiltration and severs the channel.

pygments-richstyle (PyPI) malicious package — MAL-2025-191654 | O3 Security