MAL-2026-5282
Vulnerability from ossf_malicious_packages
Published
2026-06-06 06:13
Modified
2026-06-12 19:46
Summary
Malicious code in mrbios (PyPI)
Details

-= Per source details. Do not edit below this line.=-

Source: amazon-inspector (8d1c97dced5d8f917e2e9901e0ed99fb0034bfafb5a3d46ad47eeba76a883c57)

The 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.

Source: kam193 (3bc0ad232af6f3dafcf2d02441531485e0b459c2659542375c62f4f7003c9e08)

Versions 0.1.1, 0.1.2 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

CWE
  • CWE-506 - The product contains code that appears to be malicious in nature.

{
  "affected": [
    {
      "database_specific": {
        "cwes": [
          {
            "cweId": "CWE-506",
            "description": "The product contains code that appears to be malicious in nature.",
            "name": "Embedded Malicious Code"
          }
        ],
        "indicators": {
          "evidence_files": [
            {
              "path": "mrbios-setup.pth",
              "sha256": "c539766062555d47716f8432e73adbe3a0c0c954a0b6c4005017a668975e275c",
              "tlsh": "4911c02e429385b0d975d646830b19f4afdb8ce28fc79506c8d8d4c1a7b2e50e3b7684"
            }
          ],
          "package_integrity": [
            {
              "filename": "mrbios-0.1.1-py3-none-any.whl",
              "hashes": {
                "blake2b_256": "3fa6ec2fd95e0a575e8a94859e34fe212184dff0520ac7bc3c85f6c1e4d53a52",
                "md5": "6c59a9b4053f012bb83246378b820b2d",
                "sha256": "efd8de3d3a52962532b7c3fe9601883a1212be14415c77ed9d670c44761e53a8"
              }
            }
          ]
        }
      },
      "package": {
        "ecosystem": "PyPI",
        "name": "mrbios"
      },
      "versions": [
        "0.1.1",
        "0.1.2"
      ]
    }
  ],
  "credits": [
    {
      "contact": [
        "inspector-research@amazon.com"
      ],
      "name": "Amazon Inspector",
      "type": "FINDER"
    },
    {
      "contact": [
        "https://github.com/kam193",
        "https://bad-packages.kam193.eu/"
      ],
      "name": "Kamil Ma\u0144kowski (kam193)",
      "type": "REPORTER"
    }
  ],
  "database_specific": {
    "malicious-packages-origins": [
      {
        "id": "pypi/2026-06-compr-woodpecker/mrbios",
        "import_time": "2026-06-06T07:59:00.774264442Z",
        "modified_time": "2026-06-06T06:13:57Z",
        "sha256": "3bc0ad232af6f3dafcf2d02441531485e0b459c2659542375c62f4f7003c9e08",
        "source": "kam193",
        "versions": [
          "0.1.1",
          "0.1.2"
        ]
      },
      {
        "id": "pypi/2026-06-compr-woodpecker/mrbios",
        "import_time": "2026-06-08T11:41:02.531997444Z",
        "modified_time": "2026-06-06T06:13:57Z",
        "sha256": "046c822ab1c4c0f6cc1192cb38fe49c16aa7044dc4b06eb6272087bcfe716019",
        "source": "kam193",
        "versions": [
          "0.1.1",
          "0.1.2"
        ]
      },
      {
        "id": "pypi/2026-06-compr-woodpecker/mrbios",
        "import_time": "2026-06-08T19:19:19.187401089Z",
        "modified_time": "2026-06-06T06:27:15Z",
        "sha256": "f5d5f4158dd95dcc1ccbd12390ba2fd3d323319f48a653b088008f8d27d6febf",
        "source": "kam193",
        "versions": [
          "0.1.1",
          "0.1.2"
        ]
      },
      {
        "id": "pypi/2026-06-compr-woodpecker/mrbios",
        "import_time": "2026-06-09T07:48:29.64614485Z",
        "modified_time": "2026-06-06T06:27:15Z",
        "sha256": "e9144071d7cdac22d13cb876dee11f000d73d11e1767a5aa6c0a6b3a87c369b6",
        "source": "kam193",
        "versions": [
          "0.1.1",
          "0.1.2"
        ]
      },
      {
        "id": "IN-MAL-2026-006178",
        "import_time": "2026-06-12T19:44:16.637036236Z",
        "modified_time": "2026-06-12T19:10:40Z",
        "sha256": "8d1c97dced5d8f917e2e9901e0ed99fb0034bfafb5a3d46ad47eeba76a883c57",
        "source": "amazon-inspector",
        "versions": [
          "0.1.1"
        ]
      }
    ]
  },
  "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 \u2014 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 \u0027bioinformatics scripts management tool\u0027 and has no documented need for a JavaScript runtime; the JS payload runs outside Python\u0027s 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\u0027s 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",
  "id": "MAL-2026-5282",
  "modified": "2026-06-12T19:46:18Z",
  "published": "2026-06-06T06:13:57Z",
  "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/"
    }
  ],
  "schema_version": "1.7.4",
  "summary": "Malicious code in mrbios (PyPI)"
}


Log in or create an account to share your comment.




Tags
Taxonomy of the tags.


Loading…

Loading…

Loading…

Forecast uses a logistic model when the trend is rising, or an exponential decay model when the trend is falling. Fitted via linearized least squares.

Sightings

Author Source Type Date Other

Nomenclature

  • Seen: The vulnerability was mentioned, discussed, or observed by the user.
  • Confirmed: The vulnerability has been validated from an analyst's perspective.
  • Published Proof of Concept: A public proof of concept is available for this vulnerability.
  • Exploited: The vulnerability was observed as exploited by the user who reported the sighting.
  • Patched: The vulnerability was observed as successfully patched by the user who reported the sighting.
  • Not exploited: The vulnerability was not observed as exploited by the user who reported the sighting.
  • Not confirmed: The user expressed doubt about the validity of the vulnerability.
  • Not patched: The vulnerability was not observed as successfully patched by the user who reported the sighting.

Loading…

Detection rules are retrieved from Rulezet.

Loading…

Loading…