-= Per source details. Do not edit below this line.=-
During installation package downloads and runs a malicious executable. Likely continuation of 2026-03-rowrap.
The campaign is built over a malicious Roblox API wrapper. The roboat[.]pro (later robase[.]app) domain advertises a wrapper that is either directly malicious (as roboat collected in the campaign 2026-03-rowrap) or uses a malicious dependencies (like roboat-utils). New versions are published simultaneously with malicious dependencies and quickly removed. Another advertisement channel is https://github.com/Addi9000/roboat referencing two active contributors: https://github.com/Addi9000 and https://github.com/RoCruise
Category: MALICIOUS - The campaign has clearly malicious intent, like infostealers.
Campaign: 2026-03-roboat-addition
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.
The malicious code is intentionally included in a dependency of the package
malware
clones-real-package
{
"iocs": {
"domains": [
"jolly-violet-def9.staraledreamer.workers.dev",
"holy-sun-41ff.staraledreamer.workers.dev",
"spring-math-9df3.aledreamsaledreams2.workers.dev",
"i-like-boys.com",
"femboy.rich"
],
"urls": [
"https://jolly-violet-def9.staraledreamer.workers.dev/DDDD.exe",
"https://holy-sun-41ff.staraledreamer.workers.dev/gore.vbs",
"https://github.com/betonme27/flies/releases/download/a/s22s.zhr",
"https://dawn-thunder-f821.staraledreamer.workers.dev/gore.vbs",
"https://green-shadow-38d7.aledreamsaledreams2.workers.dev/tree.vbs",
"https://spring-math-9df3.aledreamsaledreams2.workers.dev/winre.bat",
"https://github.com/aledreamsaledreqms-source/frakenstein/raw/refs/heads/main/tree.vbs",
"https://lingering-field-4351.aledreamer1234.workers.dev/yy.bat",
"https://github.com/aledreamsaledreqms-source/frakenstein/raw/refs/heads/main/ee.exe",
"https://i-like-boys.com/tree.vbs",
"https://femboy.rich/imafaggot.vbs"
]
},
"malicious-packages-origins": [
{
"source": "kam193",
"modified_time": "2026-04-25T20:27:44.465466Z",
"sha256": "334524bfbf6438acc5016e76054740cdb532bdd9921695cbcc1852c568226708",
"import_time": "2026-04-25T20:47:18.922526901Z",
"versions": [
"2.3.0"
],
"id": "pypi/2026-03-roboat-addition/quicksolving"
},
{
"source": "kam193",
"modified_time": "2026-04-25T20:27:44.465466Z",
"sha256": "6ce7101503fd7e3f5a973cf98552f2403086e47a50dd13fb7170b51497354160",
"import_time": "2026-04-26T17:18:12.831982802Z",
"versions": [
"2.3.0"
],
"id": "pypi/2026-03-roboat-addition/quicksolving"
},
{
"source": "kam193",
"modified_time": "2026-04-25T20:27:44.465466Z",
"sha256": "f4e30d78acb51b567e6bdb96eb7f5acb1da10b32c670c377cb9495610579c028",
"import_time": "2026-04-27T21:50:25.226136092Z",
"versions": [
"2.3.0"
],
"id": "pypi/2026-03-roboat-addition/quicksolving"
},
{
"source": "kam193",
"modified_time": "2026-04-25T20:27:44.465466Z",
"sha256": "6348b0a1cc0eb321b58ad555f936c8c2adcc3430ee33c086ec8081cbfb2c7e0c",
"import_time": "2026-04-28T22:49:44.409547542Z",
"versions": [
"2.3.0"
],
"id": "pypi/2026-03-roboat-addition/quicksolving"
}
]
}