-= Per source details. Do not edit below this line.=-
The package installs funcdesc-setup.pth, which Python auto-executes at interpreter startup for any environment where this package is installed. The.pth file is obfuscated with single-letter aliases (_O, _T, _G, _o, _s, _u,...) and wraps its real payload in exec() over an inline string, gated by a /tmp/.bun_ran sentinel. On first run it calls urllib.request.urlretrieve to download the Bun JavaScript runtime release archive from https://github.com/oven-sh/bun/releases/download/bun-v1.3.13/bun-<platform>-<arch>.zip, extracts it to /tmp/b/bun, chmods it executable, and then invokes bun run _index.js against a bundled _index.js shipped inside the package. The advertised purpose of funcdesc is a Python function-description protocol; there is no legitimate reason for it to fetch and run an alternate JavaScript runtime, stage binaries in /tmp, or execute opaque bundled JS outside the documented Python API. The pattern (auto-loaded.pth, obfuscated exec, alternate-runtime dropper, mismatched purpose, in-file __version__ still reading 0.2.1) is consistent with a hijacked release rather than legitimate maintainer behavior. The harm fires automatically every time a Python interpreter starts in any environment where this version is installed, not only at pip install, giving the attacker arbitrary code execution on the installer's machine.
Versions 0.2.2, 0.2.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-packages-origins": [
{
"versions": [
"0.2.2",
"0.2.3"
],
"sha256": "c6f85c691f141dc4c962171ac49945286bb40e15cb8450d2f42d048a3f53bb22",
"modified_time": "2026-06-06T06:13:57Z",
"source": "kam193",
"import_time": "2026-06-08T01:02:35.770622085Z",
"id": "pypi/2026-06-compr-woodpecker/funcdesc"
},
{
"versions": [
"0.2.2",
"0.2.3"
],
"sha256": "72f65b090fe99d340a8b222992fa485d3b285c22d5ab062dfb982a714bad7d4d",
"source": "kam193",
"modified_time": "2026-06-06T06:13:57Z",
"import_time": "2026-06-08T11:41:02.524930803Z",
"id": "pypi/2026-06-compr-woodpecker/funcdesc"
},
{
"versions": [
"0.2.2",
"0.2.3"
],
"sha256": "cb003c7110c066c512861cf6f1fb69d124169cbf9af0e238b584f17ddd4603da",
"source": "kam193",
"modified_time": "2026-06-08T00:20:29.960571Z",
"import_time": "2026-06-08T19:19:19.179825045Z",
"id": "pypi/2026-06-compr-woodpecker/funcdesc"
},
{
"versions": [
"0.2.2",
"0.2.3"
],
"sha256": "7054d870b3afb07fc18e6e4b8b91939e0c0586e6c8a98dd5217eebc0ab446595",
"modified_time": "2026-06-08T00:20:29.960571Z",
"source": "kam193",
"id": "pypi/2026-06-compr-woodpecker/funcdesc",
"import_time": "2026-06-09T07:48:29.639601227Z"
},
{
"versions": [
"0.2.2"
],
"sha256": "4a5756a79331cdda67721e39889609f5c0b5e342b678dbce2de97c94ec2dbe29",
"source": "amazon-inspector",
"modified_time": "2026-06-12T19:02:55Z",
"import_time": "2026-06-12T19:43:38.15953801Z",
"id": "IN-MAL-2026-005833"
}
]
}{
"package_integrity": [
{
"filename": "funcdesc-0.2.2-py3-none-any.whl",
"hashes": {
"sha256": "be6b0a27eba6eeabe1e3c5d5ea1227f96e00291a079266d03d2e9e33f4912c96",
"md5": "2ea938b1b4e061aab5a1bcbaa5ec422f",
"blake2b_256": "06288e97d726678ea254e29cb85daa5645271b59d96cd61d1dc6ae2be8d61715"
}
}
],
"evidence_files": [
{
"sha256": "c539766062555d47716f8432e73adbe3a0c0c954a0b6c4005017a668975e275c",
"path": "funcdesc-setup.pth",
"tlsh": "4911c02e429385b0d975d646830b19f4afdb8ce28fc79506c8d8d4c1a7b2e50e3b7684"
}
]
}
"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/pypi/funcdesc/MAL-2026-5300.json"
[
{
"description": "The product contains code that appears to be malicious in nature.",
"name": "Embedded Malicious Code",
"cweId": "CWE-506"
}
]