{"id":"MAL-2026-5282","summary":"Malicious code in mrbios (PyPI)","details":"\n---\n_-= Per source details. Do not edit below this line.=-_\n\n## Source: amazon-inspector (8d1c97dced5d8f917e2e9901e0ed99fb0034bfafb5a3d46ad47eeba76a883c57)\nThe package installs `mrbios-setup.pth` into site-packages. Python auto-loads.pth files at every interpreter startup, so the contained payload runs unconditionally for any `python` invocation on a machine where mrbios has been installed — not just when the package is explicitly imported. The payload is wrapped in an `exec()` of a string built from single-letter aliased imports (`_o`, `_s`, `_u`, `_p`, `_y`, `_T`, `_G`) to evade static review. When executed, it downloads the Bun JavaScript runtime from `https://github.com/oven-sh/bun/releases/download/bun-v1.3.13/bun-{os}-{arch}.zip` to `/tmp/b/bun`, chmods it executable (mode 509 / 0o775), and invokes it to run a sibling `_index.js` shipped in the package. A `/tmp/.bun_ran` sentinel gates re-execution per temp directory. The package advertises itself as a 'bioinformatics scripts management tool' and has no documented need for a JavaScript runtime; the JS payload runs outside Python's introspectable surface, so its behavior is not visible to ordinary Python tooling. The combination of unconditional auto-execution via.pth, deliberate obfuscation, alien-runtime fetch from a non-publisher source, and execution of bundled JavaScript whose contents are opaque to the Python ecosystem constitutes an install/startup-time remote code execution surface against any installer.\n\n## Source: kam193 (3bc0ad232af6f3dafcf2d02441531485e0b459c2659542375c62f4f7003c9e08)\nVersions 0.1.1, 0.1.2 were compromised.\n\n\nCompromised 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.\n\nIt seems to be related to the recent Mini Shai Hulud campaign.\n\n\n---\n\nCategory: MALICIOUS - The campaign has clearly malicious intent, like infostealers.\n\n\nCampaign: 2026-06-compr-woodpecker\n\n\nReasons (based on the campaign):\n\n\n - compromised-package\n\n\n - exfiltration-env-variables\n\n\n - exfiltration-cloud-tokens\n\n\n - exfiltration-credentials\n\n\n - abuses-pth\n\n\n - obfuscation\n\n\n - infostealer\n\n\n - The package contains code to detect if it is running in a sandbox environment.\n\n\n - exfiltration-crypto\n\n\n - files-exfiltration\n\n\n - destructive-actions\n","modified":"2026-06-12T20:01:50.158528516Z","published":"2026-06-06T06:13:57Z","database_specific":{"malicious-packages-origins":[{"id":"pypi/2026-06-compr-woodpecker/mrbios","modified_time":"2026-06-06T06:13:57Z","import_time":"2026-06-06T07:59:00.774264442Z","sha256":"3bc0ad232af6f3dafcf2d02441531485e0b459c2659542375c62f4f7003c9e08","source":"kam193","versions":["0.1.1","0.1.2"]},{"id":"pypi/2026-06-compr-woodpecker/mrbios","modified_time":"2026-06-06T06:13:57Z","import_time":"2026-06-08T11:41:02.531997444Z","sha256":"046c822ab1c4c0f6cc1192cb38fe49c16aa7044dc4b06eb6272087bcfe716019","source":"kam193","versions":["0.1.1","0.1.2"]},{"id":"pypi/2026-06-compr-woodpecker/mrbios","modified_time":"2026-06-06T06:27:15Z","import_time":"2026-06-08T19:19:19.187401089Z","sha256":"f5d5f4158dd95dcc1ccbd12390ba2fd3d323319f48a653b088008f8d27d6febf","source":"kam193","versions":["0.1.1","0.1.2"]},{"id":"pypi/2026-06-compr-woodpecker/mrbios","modified_time":"2026-06-06T06:27:15Z","import_time":"2026-06-09T07:48:29.64614485Z","sha256":"e9144071d7cdac22d13cb876dee11f000d73d11e1767a5aa6c0a6b3a87c369b6","source":"kam193","versions":["0.1.1","0.1.2"]},{"id":"IN-MAL-2026-006178","modified_time":"2026-06-12T19:10:40Z","import_time":"2026-06-12T19:44:16.637036236Z","sha256":"8d1c97dced5d8f917e2e9901e0ed99fb0034bfafb5a3d46ad47eeba76a883c57","source":"amazon-inspector","versions":["0.1.1"]}]},"references":[{"type":"WEB","url":"https://socket.dev/blog/mini-shai-hulud-campaign-hits-red-hat-cloud-services-npm-packages"},{"type":"WEB","url":"https://bad-packages.kam193.eu/pypi/campaign/2026-06-compr-woodpecker"},{"type":"WEB","url":"https://socket.dev/blog/shai-hulud-descends-to-hades-miasma-pypi-wave"},{"type":"WEB","url":"https://o3.security/blog/pypi-supply-chain-attack-pth-file-miasma"},{"type":"WEB","url":"https://socket.dev/blog/mini-shai-hulud-miasma-and-hades-worms-target-bioinformatics-and-mcp-developers-via-malicious"},{"type":"PACKAGE","url":"https://pypi.org/project/mrbios/0.1.1/"}],"affected":[{"package":{"name":"mrbios","ecosystem":"PyPI","purl":"pkg:pypi/mrbios"},"versions":["0.1.1","0.1.2"],"database_specific":{"cwes":[{"name":"Embedded Malicious Code","description":"The product contains code that appears to be malicious in nature.","cweId":"CWE-506"}],"indicators":{"package_integrity":[{"hashes":{"md5":"6c59a9b4053f012bb83246378b820b2d","sha256":"efd8de3d3a52962532b7c3fe9601883a1212be14415c77ed9d670c44761e53a8","blake2b_256":"3fa6ec2fd95e0a575e8a94859e34fe212184dff0520ac7bc3c85f6c1e4d53a52"},"filename":"mrbios-0.1.1-py3-none-any.whl"}],"evidence_files":[{"path":"mrbios-setup.pth","tlsh":"4911c02e429385b0d975d646830b19f4afdb8ce28fc79506c8d8d4c1a7b2e50e3b7684","sha256":"c539766062555d47716f8432e73adbe3a0c0c954a0b6c4005017a668975e275c"}]},"source":"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/pypi/mrbios/MAL-2026-5282.json"}}],"schema_version":"1.7.5","credits":[{"name":"Amazon Inspector","contact":["inspector-research@amazon.com"],"type":"FINDER"},{"name":"Kamil Mańkowski (kam193)","contact":["https://github.com/kam193","https://bad-packages.kam193.eu/"],"type":"REPORTER"}]}