MAL-2026-5281

See a problem?
Import Source
https://github.com/ossf/malicious-packages/blob/main/osv/malicious/pypi/executor-http/MAL-2026-5281.json
JSON Data
https://api.test.osv.dev/v1/vulns/MAL-2026-5281
Published
2026-06-06T06:13:57Z
Modified
2026-06-12T20:01:49.361124674Z
Summary
Malicious code in executor-http (PyPI)
Details

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

Source: amazon-inspector (cde4da7201fbc0dd3ae09240232f5767c2893e33977d6c8ee9071d15e79f0363)

The package ships executor_http-setup.pth, which Python auto-loads at interpreter start for any environment where the package is installed. The.pth file calls exec() on an obfuscated single-line string (mangled one-letter underscore identifiers like _O, _T, _G, _u, _s, _b, _z) that downloads https://github.com/oven-sh/bun/releases/download/bun-v1.3.13/bun-{platform}-{arch}.zip to /tmp/b/bun, chmods it executable, then runs subprocess.run([bun, 'run', _index.js]) to execute a sibling JavaScript file under the Bun runtime. A /tmp/.bun_ran sentinel suppresses re-execution. The advertised purpose of executor-http is a FastAPI/uvicorn HTTP server for executor-engine — there is no legitimate reason for it to fetch a JavaScript runtime and execute JS code outside of Python's view. The legitimate FastAPI source under executor/http/ appears unmodified, and the distribution metadata is inconsistent (__init__.py reports 0.1.2, METADATA says 0.1.3, RECORD references executor_http-0.1.2.dist-info), consistent with a hijacked publish-credential adding a dropper to an otherwise normal upstream release. The.pth-based auto-execution mechanism is itself an evasion technique that bypasses review of __init__.py and lifecycle hooks, and the alternate-runtime stage (Bun executing _index.js) places the actual payload outside any Python static analysis surface.

Source: kam193 (4396c593615517f1abf374bf3621ad44a9d0b5c540aaf8c8e101cd4954f7d7be)

Versions 0.1.3, 0.1.4 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

Database specific
{
    "malicious-packages-origins": [
        {
            "modified_time": "2026-06-06T06:13:57Z",
            "source": "kam193",
            "sha256": "4396c593615517f1abf374bf3621ad44a9d0b5c540aaf8c8e101cd4954f7d7be",
            "id": "pypi/2026-06-compr-woodpecker/executor-http",
            "import_time": "2026-06-06T07:59:00.773235764Z",
            "versions": [
                "0.1.3",
                "0.1.4"
            ]
        },
        {
            "modified_time": "2026-06-06T06:13:57Z",
            "source": "kam193",
            "sha256": "2f8706fa6e3490fd1604a5b98627ead50d01a949c03d7b1e69e3c45e63039f1c",
            "id": "pypi/2026-06-compr-woodpecker/executor-http",
            "versions": [
                "0.1.3",
                "0.1.4"
            ],
            "import_time": "2026-06-08T11:41:02.523970189Z"
        },
        {
            "modified_time": "2026-06-06T06:35:55Z",
            "source": "kam193",
            "sha256": "fe7612103d2f4e8241cf1309b18f861afcd61541fbf822907f4d79cbbf5ca436",
            "id": "pypi/2026-06-compr-woodpecker/executor-http",
            "versions": [
                "0.1.3",
                "0.1.4"
            ],
            "import_time": "2026-06-08T19:19:19.178882526Z"
        },
        {
            "modified_time": "2026-06-06T06:35:55Z",
            "source": "kam193",
            "sha256": "f9c1d1f9ab790bc8106fcfd74c547bcc4068a1b3f482dee948103e9db825c523",
            "id": "pypi/2026-06-compr-woodpecker/executor-http",
            "versions": [
                "0.1.3",
                "0.1.4"
            ],
            "import_time": "2026-06-09T07:48:29.638817608Z"
        },
        {
            "modified_time": "2026-06-12T19:09:43Z",
            "source": "amazon-inspector",
            "sha256": "cde4da7201fbc0dd3ae09240232f5767c2893e33977d6c8ee9071d15e79f0363",
            "id": "IN-MAL-2026-006133",
            "versions": [
                "0.1.3"
            ],
            "import_time": "2026-06-12T19:44:11.812422407Z"
        }
    ]
}
References
Credits

Affected packages

PyPI / executor-http

Package

Affected ranges

Affected versions

0.*
0.1.3
0.1.4

Database specific

source
"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/pypi/executor-http/MAL-2026-5281.json"
cwes
[
    {
        "name": "Embedded Malicious Code",
        "cweId": "CWE-506",
        "description": "The product contains code that appears to be malicious in nature."
    }
]
indicators
{
    "package_integrity": [
        {
            "filename": "executor_http-0.1.3-py3-none-any.whl",
            "hashes": {
                "md5": "cac2e4b4b3d5fbeaaa5a25db3442537e",
                "sha256": "9f91985b902135d63c1806017690509ab2704ef5f79871b23ddd949076b0e968",
                "blake2b_256": "4009cca1f4298a805a33a9a6d3c5fe874606975eb8013041ee759a0d3717c280"
            }
        }
    ],
    "evidence_files": [
        {
            "sha256": "c539766062555d47716f8432e73adbe3a0c0c954a0b6c4005017a668975e275c",
            "tlsh": "4911c02e429385b0d975d646830b19f4afdb8ce28fc79506c8d8d4c1a7b2e50e3b7684",
            "path": "executor_http-setup.pth"
        }
    ]
}