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

requests-toolbelt-plusPyPI

Malicious code in requests-toolbelt-plus (PyPI) Remove it immediately and rotate any exposed credentials.

MAL-2026-5519
Immediate action
Remove the package, then rotate any secrets the build/runtime could reach.
pip uninstall requests-toolbelt-plus

What this malware does

The package impersonates the popular requests-toolbelt library but ships an empty requests_toolbelt_plus/__init__.py and places its real logic in setup.py. On pip install, setup.py checks /proc/version for WSL markers and, when matched, opens a TCP socket to the hardcoded IP 185.184.192.205 on port 4444, sends a JSON beacon containing os.getlogin(), os.uname().nodename, and os.getcwd(), then spawns a background thread that reads JSON commands from the socket and executes them via subprocess.run(cmd, shell=True, capture_output=True, text=True), returning stdout/stderr to the operator — full remote command execution against the installer's machine. setup.py also appends a Python one-liner to ~/.bashrc that re-opens the same socket, dup2s stdio onto it, and execs /bin/bash -i, giving the attacker a persistent interactive reverse shell that fires on every new login shell and survives package uninstall. The WSL-only gating is a deliberate evasion to stay dormant on non-WSL maintainer machines and execute only on targeted Windows-Subsystem-for-Linux developer hosts.

Installing the package or importing the module exfiltrates basic information about the host, and the package has no other purpose.

Category: PROBABLY_PENTEST - Packages looking like typical pentest packages, but also anything that looks like testing, exploring pre-prepared kits, research & co, with clearly low-harm possibilities.

Campaign: GENERIC-standard-pypi-install-pentest

Reasons (based on the campaign):

  • The package contains code to exfiltrate basic data from the system, like IP or username. It has a limited risk.

  • The package overrides the install command in setup.py to execute malicious code during installation.

Malicious versions

4 flagged
99.9.999.9.10100.0.02026.6.10.172624

Indicators of compromise (SHA-256)

bd626be82a68d95788077b8b3c87a960c87d971e55496791cedf85154d99087f
38c64ca050de4910f56bc4a652890b0a378082859cb62153762c6ae08b4b8eae
477b55b0e81d5897d1d7252951b472225226bbca8a8d13a70e31cab1e9d13c26

Frequently asked questions

No. requests-toolbelt-plus on PyPI has been identified as a malicious package (versions 99.9.9, 99.9.10, 100.0.0, 2026.6.10.172624 flagged). It should be removed immediately — do not install or keep it in your dependency tree.

Campaign

GENERIC-standard-pypi-install-pentestIN-MAL-2026-005283IN-MAL-2026-005294

References

Credits

  • Amazon Inspector · finder
  • Kamil Mańkowski (kam193) · reporter

Scan your dependencies

O3 Security blocks malicious packages like this at install time and in CI.

Supply-chain protection
requests-toolbelt-plus (PyPI) malicious package — MAL-2026-5519 | O3 Security