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

gt-tester-exp-profiler-exp-00000015PyPI

Malicious code in gt-tester-exp-profiler-exp-00000015 (PyPI) Remove it immediately and rotate any exposed credentials.

MAL-2026-4752
Immediate action
Remove the package, then rotate any secrets the build/runtime could reach.
pip uninstall gt-tester-exp-profiler-exp-00000015

What this malware does

setup.py installs a.pth file containing import gt_tester_exp_profiler_exp_00000015.probe; probe.run_probe(), causing every Python interpreter start on the installer's machine to execute the package's probe module. The probe issues a plaintext HTTP GET to http://104.131.173.16/exp-<tag>-<hash16>, leaking the installer's source IP, interpreter-launch cadence, and a per-call hash to a hardcoded third-party host with no opt-in. Because.pth files auto-execute on every python invocation (not only when the package is imported), this constitutes installer-side persistence: the beacon fires for unrelated Python processes long after the user has forgotten the package is installed. The destination is a bare IPv4 address over cleartext HTTP with no integrity verification, so any future operator of that IP — or any on-path attacker — can serve arbitrary responses to the beacon. The User-Agent only references an opt-OUT URL, confirming the author knew consent was absent.

Malicious versions

1 flagged
1.0.0

Indicators of compromise (SHA-256)

55fc219f03cbaeeedb660ad423cc7af08ff1d29154c8b8989b7b0c5d7d5c3d75

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 gt-tester-exp-profiler-exp-00000015 (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 gt-tester-exp-profiler-exp-00000015 across your stack and pipelines.

  2. If you installed it — respond

    gt-tester-exp-profiler-exp-00000015 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 gt-tester-exp-profiler-exp-00000015 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 gt-tester-exp-profiler-exp-00000015 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. gt-tester-exp-profiler-exp-00000015 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

IN-MAL-2026-004170

References

Credits

  • Amazon Inspector · finder

Detect & block this

O3 blocks gt-tester-exp-profiler-exp-00000015-class packages before install and in CI — and if it already ran, its runtime egress monitoring catches the C2 callback and severs the channel.

gt-tester-exp-profiler-exp-00000015 (PyPI) malicious package — MAL-2026-4752 | O3 Security