-= Per source details. Do not edit below this line.=-
The campaign consists of multiple packages. The trigger sits in the package 'procwire,' which depends on two others. During installation, procwire uses schemavault and bytekit packages. The first one holds the URL holding malware (in two places, once as steganography in the bundled image and once as a fallback just as a list of encoded bytes). The bytekit implements simple custom decoding used to retrieve back the URL in the fallback method. Additionally, procwire is also a dependency of confighub, turning another package into malware. The downloaded executable is run and quickly removed. The executable likely contains an infostealer and contacts the domain 030502[.]xyz
Category: MALICIOUS - The campaign has clearly malicious intent, like infostealers.
Campaign: 2026-07-procwire
Reasons (based on the campaign):
The package overrides the install command in setup.py to execute malicious code during installation.
Downloads and executes a remote executable.
obfuscation
The malicious code is intentionally included in a dependency of the package
malware
steganography
{
"malicious-packages-origins": [
{
"versions": [
"5.2.3",
"5.2.5",
"5.2.6",
"5.2.7"
],
"sha256": "5e465ac29ecfc7a7bcac06972f14b2cf4e28be162c5ee6b2e7741f6d80a07938",
"modified_time": "2026-07-03T23:38:06.661131Z",
"source": "kam193",
"import_time": "2026-07-03T23:51:45.554550018Z",
"id": "pypi/2026-07-procwire/procwire"
},
{
"versions": [
"5.2.3",
"5.2.5",
"5.2.6",
"5.2.7"
],
"sha256": "92d2bc612f55308246f0b90c37ab81a90a1954c37a57b36dfdf244b8fc77495f",
"modified_time": "2026-07-03T23:38:06.661131Z",
"source": "kam193",
"import_time": "2026-07-04T00:45:00.561403958Z",
"id": "pypi/2026-07-procwire/procwire"
}
],
"iocs": {
"urls": [
"https://gofilecdn-cf.pd1.workers.dev/w5Unkv"
],
"domains": [
"gofilecdn-cf.pd1.workers.dev"
]
}
}