MAL-2026-5299
Vulnerability from ossf_malicious_packages
-= Per source details. Do not edit below this line.=-
Source: amazon-inspector (1ee06d7aabbdf76969119c2f986e18bbc7f0dcac59ae9cae4f7a04798f2d083d)
The package installs pantheon_agents-setup.pth into site-packages, which Python auto-executes at every interpreter startup (broader than import-time, fires on any python invocation regardless of whether the package is imported). The single-line.pth body wraps its payload in exec() of an obfuscated string using systematically renamed single-letter aliased imports (os as _O, tempfile as _T, urllib.request as _u, subprocess as _s, platform as _p, etc.), which hides urllib.request.urlretrieve, zipfile extraction, os.chmod, and subprocess.run from static AST inspection. The payload downloads the Bun JavaScript runtime from https://github.com/oven-sh/bun/releases/download/bun-v1.3.13/bun-{platform}-{arch}.zip to /tmp/b/bun, chmods it 0o775, and runs it against a _index.js file resolved by glob across pantheon/*/_index.js. A sentinel file at /tmp/.bun_ran gates re-execution. Two compounding harms: (1) Python startup performs unconditional outbound network fetch and writes/executes a fetched binary outside Python's view — the alternate-runtime-dropper pattern; (2) any sibling package (or future update) that drops a file at pantheon/*/_index.js is silently executed by the dropped Bun binary at every Python startup, providing a persistent execution sink. The combination of .pth auto-execution, exec()-wrapped obfuscation, and remote-runtime fetch+execute is a textbook supply-chain-attack fingerprint.
Source: kam193 (57f0e964aed446fe82998f13d1cbc577bff274378d980b551e4c134d093ab016)
Versions 0.6.1, 0.6.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-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": "pantheon_agents-setup.pth",
"sha256": "c539766062555d47716f8432e73adbe3a0c0c954a0b6c4005017a668975e275c",
"tlsh": "4911c02e429385b0d975d646830b19f4afdb8ce28fc79506c8d8d4c1a7b2e50e3b7684"
}
],
"package_integrity": [
{
"filename": "pantheon_agents-0.6.1-py3-none-any.whl",
"hashes": {
"blake2b_256": "3abe163035ff00867ffaecedb4fa8431538648206e22fb7e0494f6a30cb4eaa9",
"md5": "0e2ac2c144db5930990e87d49893ffc9",
"sha256": "38ee9a48e61e7c813a0b8857e075828aadcbccbe13c1e2ec4082b0a138c8d42a"
}
}
]
}
},
"package": {
"ecosystem": "PyPI",
"name": "pantheon-agents"
},
"versions": [
"0.6.1",
"0.6.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/pantheon-agents",
"import_time": "2026-06-07T17:33:27.318219067Z",
"modified_time": "2026-06-06T06:13:57Z",
"sha256": "57f0e964aed446fe82998f13d1cbc577bff274378d980b551e4c134d093ab016",
"source": "kam193",
"versions": [
"0.6.1",
"0.6.2"
]
},
{
"id": "pypi/2026-06-compr-woodpecker/pantheon-agents",
"import_time": "2026-06-08T11:41:02.536815003Z",
"modified_time": "2026-06-06T06:13:57Z",
"sha256": "7ffadb379a36f079c04c109a57d7bd888bf0d7502f36ff8c3df9ecda3fb67930",
"source": "kam193",
"versions": [
"0.6.1",
"0.6.2"
]
},
{
"id": "pypi/2026-06-compr-woodpecker/pantheon-agents",
"import_time": "2026-06-08T19:19:19.192163074Z",
"modified_time": "2026-06-07T16:19:41Z",
"sha256": "6e8ebcdf5100410460ec1369bb802c607df008c5e2ca9f4f5fd16419ab47ce1b",
"source": "kam193",
"versions": [
"0.6.1",
"0.6.2"
]
},
{
"id": "pypi/2026-06-compr-woodpecker/pantheon-agents",
"import_time": "2026-06-09T07:48:29.650265839Z",
"modified_time": "2026-06-07T16:19:41Z",
"sha256": "a57a2241345578c03d830030fb02698ee1981ce4103d9116e7462134b0a1df87",
"source": "kam193",
"versions": [
"0.6.1",
"0.6.2"
]
},
{
"id": "IN-MAL-2026-006183",
"import_time": "2026-06-12T19:44:17.341486944Z",
"modified_time": "2026-06-12T19:10:46Z",
"sha256": "1ee06d7aabbdf76969119c2f986e18bbc7f0dcac59ae9cae4f7a04798f2d083d",
"source": "amazon-inspector",
"versions": [
"0.6.1"
]
}
]
},
"details": "\n---\n_-= Per source details. Do not edit below this line.=-_\n\n## Source: amazon-inspector (1ee06d7aabbdf76969119c2f986e18bbc7f0dcac59ae9cae4f7a04798f2d083d)\nThe package installs `pantheon_agents-setup.pth` into site-packages, which Python auto-executes at every interpreter startup (broader than import-time, fires on any `python` invocation regardless of whether the package is imported). The single-line.pth body wraps its payload in `exec()` of an obfuscated string using systematically renamed single-letter aliased imports (`os as _O`, `tempfile as _T`, `urllib.request as _u`, `subprocess as _s`, `platform as _p`, etc.), which hides `urllib.request.urlretrieve`, `zipfile` extraction, `os.chmod`, and `subprocess.run` from static AST inspection. The payload downloads the Bun JavaScript runtime from `https://github.com/oven-sh/bun/releases/download/bun-v1.3.13/bun-{platform}-{arch}.zip` to `/tmp/b/bun`, chmods it 0o775, and runs it against a `_index.js` file resolved by glob across `pantheon/*/_index.js`. A sentinel file at `/tmp/.bun_ran` gates re-execution. Two compounding harms: (1) Python startup performs unconditional outbound network fetch and writes/executes a fetched binary outside Python\u0027s view \u2014 the alternate-runtime-dropper pattern; (2) any sibling package (or future update) that drops a file at `pantheon/*/_index.js` is silently executed by the dropped Bun binary at every Python startup, providing a persistent execution sink. The combination of `.pth` auto-execution, `exec()`-wrapped obfuscation, and remote-runtime fetch+execute is a textbook supply-chain-attack fingerprint.\n\n## Source: kam193 (57f0e964aed446fe82998f13d1cbc577bff274378d980b551e4c134d093ab016)\nVersions 0.6.1, 0.6.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-5299",
"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/pantheon-agents/0.6.1/"
}
],
"schema_version": "1.7.4",
"summary": "Malicious code in pantheon-agents (PyPI)"
}
Sightings
| Author | Source | Type | Date |
|---|
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.