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

napari-ufishPyPI

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

MAL-2026-5275
Immediate action
Remove the package, then rotate any secrets the build/runtime could reach.
pip uninstall napari-ufish

What this malware does

Versions 0.0.2, 0.0.3 were compromised.

Compromised packages start an obfuscated infostealer. The infostealer is a heavily obfuscated JavaScript code executed using Bun runtime on Python startup. It collectes all kinds of sensitive data, including API keys, credentials to package repositories, cryptocurrency assets, password manager data. Infostealer actively queries online services to collect additional secrets as well as attempts to gain persistence and spread further by publishing infected packages using collected credentials. Data are exfiltrated likely using Github. The code seems to threaten to wipe the user's data if it detects invalid GitHub tokens. Cleanup should be done with caution.

It seems to be related to the recent Mini Shai Hulud campaign.

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

Campaign: 2026-06-compr-woodpecker

Reasons (based on the campaign):

  • compromised-package

  • exfiltration-env-variables

  • exfiltration-cloud-tokens

  • exfiltration-credentials

  • abuses-pth

  • obfuscation

  • infostealer

  • The package contains code to detect if it is running in a sandbox environment.

  • exfiltration-crypto

  • files-exfiltration

  • destructive-actions

Malicious versions

2 flagged
0.0.20.0.3

Indicators of compromise (SHA-256)

08623bcaeb4e2270d7fb5bc9e4e51e338d1270b2a45188c6bddb01aa07ff32c6
5103d2b75fe554764a66f5e03957c303d4085a7d5133463f58aa0c83a87f5d7d
4537e4c888c7db13db173ca68bf6b578118b10308eb923a4625d9575a0054397
03d0f90ffc39a2887949a5f33ef6495b6d304e4ba82e78172ce7651f1366a818
0caba416a889043d4cd39d83cbb513e7169908ff9f3cdc5219575f12d7f212b4

Frequently asked questions

No. napari-ufish on PyPI has been identified as a malicious package (versions 0.0.2, 0.0.3 flagged). It should be removed immediately — do not install or keep it in your dependency tree.

Campaign

2026-06-compr-woodpecker

References

Credits

  • Kamil Mańkowski (kam193) · reporter

Scan your dependencies

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

Supply-chain protection
napari-ufish (PyPI) malicious package — MAL-2026-5275 | O3 Security