{"id":"MAL-2026-2555","summary":"Malicious code in api-feature (PyPI)","details":"\n---\n_-= Per source details. Do not edit below this line.=-_\n\n## Source: kam193 (c86a3079da8157aef32d5d4c4f2420239981a142fc1150eb0ac2e695be2779e9)\nDuring installation package downloads and runs a malicious executable. Likely continuation of 2026-03-rowrap.\n\nThe 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\n\n\n---\n\nCategory: MALICIOUS - The campaign has clearly malicious intent, like infostealers.\n\n\nCampaign: 2026-03-roboat-addition\n\n\nReasons (based on the campaign):\n\n\n - The package overrides the install command in setup.py to execute malicious code during installation.\n\n\n - Downloads and executes a remote executable.\n\n\n - The malicious code is intentionally included in a dependency of the package\n\n\n - malware\n\n\n - clones-real-package\n","modified":"2026-05-28T05:01:08.758402248Z","published":"2026-04-11T14:04:25Z","database_specific":{"malicious-packages-origins":[{"source":"kam193","sha256":"d2d6ce181ca33dae84d7f82c8720ad731f3667dcfa0cc5488616f0f25e886dd0","modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","versions":["0.0.8"],"import_time":"2026-04-11T14:16:26.230555929Z"},{"source":"kam193","versions":["0.0.8"],"modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","import_time":"2026-04-12T21:46:35.79681907Z","sha256":"95a86b3b34e693c4d4c63388af6aecc013b1e7e16da45b1a6189959ad657cd58"},{"source":"kam193","sha256":"c86a3079da8157aef32d5d4c4f2420239981a142fc1150eb0ac2e695be2779e9","modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","versions":["0.0.8"],"import_time":"2026-04-12T22:12:37.17301908Z"},{"source":"kam193","modified_time":"2026-04-11T14:04:25.507031Z","import_time":"2026-04-16T07:38:24.999434808Z","id":"pypi/2026-03-roboat-addition/api-feature","sha256":"98eeadd28f443f5d879bbcd7eaade847dd466e639159a157c8a8cf4d1e11ebc3","versions":["0.0.8"]},{"source":"kam193","sha256":"331f20e4013049472607be3e8887600f9a8d3cc70f289b6b85e3dece57dc2978","modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","versions":["0.0.8"],"import_time":"2026-04-25T08:25:00.382819703Z"},{"source":"kam193","versions":["0.0.8"],"modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","import_time":"2026-04-26T17:18:12.812943945Z","sha256":"2ba231b1937a3fd9a108bffeb323b3c7bc661761a6ff64b4d701fb07ebfabfae"},{"source":"kam193","import_time":"2026-04-27T21:50:25.204713694Z","modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","sha256":"933d5d30242c6dc59beac2c0b9688ec0367a331f9d87b0acc9a339a3be54440c","versions":["0.0.8"]},{"source":"kam193","versions":["0.0.8"],"modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","import_time":"2026-04-28T22:49:44.391178453Z","sha256":"1dd524ea6a4bc1b0a21dff26384ccb8dbed7380d21a3e8f9a6cce8270aec3b05"},{"source":"kam193","versions":["0.0.8"],"modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","import_time":"2026-05-03T20:48:01.270011691Z","sha256":"c1baafe2215ae32376f02fb1618200dfdb511e513a5108c39a299060a46f2fad"},{"source":"kam193","versions":["0.0.8"],"modified_time":"2026-04-11T14:04:25.507031Z","id":"pypi/2026-03-roboat-addition/api-feature","import_time":"2026-05-28T04:57:09.757777846Z","sha256":"d3a16e156533684c864124cc8b1eb017741b950d34e36ea17850c27e5ec975ea"}],"iocs":{"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"],"domains":["jolly-violet-def9.staraledreamer.workers.dev","holy-sun-41ff.staraledreamer.workers.dev","spring-math-9df3.aledreamsaledreams2.workers.dev"]}},"references":[{"type":"EVIDENCE","url":"https://www.virustotal.com/gui/file/9f14d239ab8f1289bc7aedeb67d3d72b467ee6c11b201890ab14c5c4f7c175d2/detection"},{"type":"EVIDENCE","url":"https://www.virustotal.com/gui/file/48b108261d5de97a42eff81cf1a60a32286f72bf8b5f130959e0daa86b783608"},{"type":"EVIDENCE","url":"https://www.virustotal.com/gui/file/ef20289b52ab23ec23c5ff885a2293523ce8456fb00e3d67f1b084c28f7d282a/detection"},{"type":"WEB","url":"https://github.com/Addi9000/roboat/blob/331166c8ea3bd080f08fe6d571202e3b47017ed7/README.md#L31"},{"type":"WEB","url":"https://github.com/Addi9000/roboat/commit/331166c8ea3bd080f08fe6d571202e3b47017ed7"},{"type":"WEB","url":"https://github.com/Addi9000"},{"type":"WEB","url":"https://github.com/RoCruise"},{"type":"WEB","url":"https://www.roboat.pro/"},{"type":"WEB","url":"https://bad-packages.kam193.eu/pypi/package/api-feature"}],"affected":[{"package":{"name":"api-feature","ecosystem":"PyPI","purl":"pkg:pypi/api-feature"},"versions":["0.0.8"],"database_specific":{"source":"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/pypi/api-feature/MAL-2026-2555.json"}}],"schema_version":"1.7.5","credits":[{"name":"Kamil Mańkowski (kam193)","contact":["https://github.com/kam193","https://bad-packages.kam193.eu/"],"type":"REPORTER"}]}