Код Читати оригінал на Ox 2 хв читання 1

npm-пакет mouse5212 крав файли і злив власний GitHub-токен

Дослідники компанії OX Security виявили шкідливий npm-пакет mouse5212-super-formatter, який маскувався під утиліту синхронізації архівів, але насправді крав файли з директорії "/mnt/user-data" на пристрої жертви та завантажував їх у GitHub-репозиторій зловмисника. Пакет набрав 676 завантажень і на момент публікації звіту залишався доступним у реєстрі npm. Ключова помилка зловмисника — він вшив власний приватний GitHub-токен безпосередньо в код пакету, що дозволило дослідникам відстежити близько семи активних сесій ексфільтрації у репозиторії загрози. Обліковий запис GitHub загрозливого актора був створений за кілька годин до завантаження першої шкідливої версії та видалений після того, як атаку виявили. OX Security пов'язує подібну недбалість у сфері операційної безпеки з використанням штучного інтелекту для написання малвари без розуміння базових принципів opsec. Усім, хто встановив пакет, рекомендовано негайно відкликати GitHub-токени та вважати файли з директорії "/mnt/user-data" скомпрометованими.

Ретро-телевізор із екраном "OX NEWS" стоїть на яскраво-фіолетовому тлі, перекресленому діагональними жовтими смугами.
Ретро-телевізор із екраном "OX NEWS" стоїть на яскраво-фіолетовому тлі, перекресленому діагональними жовтими смугами. · Джерело зображення: Ox

За даними Ox, шкідливий пакет mouse5212-super-formatter у постінсталяційному скрипті представлявся як внутрішня утиліта "archive deployment sync". Під цим прикриттям він автентифікувався в GitHub, перевіряв наявність цільового репозиторію, створював його за потреби та рекурсивно проходив по локальних директоріях, завантажуючи кожен знайдений файл через GitHub Contents API. Для приховання слідів малвара зберігала викрадені дані у папках із випадково згенерованими назвами — щоб оператор міг розрізняти окремі сесії крадіжки. Додатково скрипт записував фейковий журнал «мережевих з'єднань», імітуючи діагностику та відволікаючи увагу від реального призначення програми.

Деталі атаки

Технічний аналіз показав, що для автентифікації пакет спирався або на змінну середовища, або на хардкодований запасний токен, якщо змінна була відсутня. Саме цей запасний токен виявився власним приватним GitHub-токеном зловмисника — критична помилка opsec, яка повністю розкрила інфраструктуру загрози. Дані перед завантаженням кодувалися у base64, а кожна сесія ексфільтрації отримувала унікальну папку для зручного розмежування жертв. Коментарі та повідомлення до комітів у репозиторії були навмисно написані в нейтральному технічному стилі, щоб знизити підозру.

Обліковий запис загрозливого актора на GitHub був зареєстрований за кілька годин до публікації першої версії пакету. Ще до повноцінного розгортання атаки зловмисник уже тестував шкідливі можливості у тестовому репозиторії. OX Security зафіксувала близько семи активних завантажень файлів до моменту видалення репозиторію — більшість із них є тестовими сесіями самого загрозливого актора. Обліковий запис GitHub було видалено після викриття, проте сам npm-пакет залишався доступним у реєстрі на момент публікації звіту.

Рекомендовані дії

OX Security надала конкретні рекомендації для тих, хто встановив пакет:

  • Негайно відкликати всі GitHub access tokens, пов'язані зі середовищем, де було встановлено пакет.
  • Перевірити вміст директорії "/mnt/user-data" та вважати всі файли в ній скомпрометованими.
  • Провести аудит постінсталяційних скриптів усіх npm-залежностей у своїх проєктах.

Перспективи

OX Security вказує на ширшу тенденцію: поріг входу для написання малвари значно знизився завдяки інструментам штучного інтелекту. Нові загрозливі актори здатні генерувати робочий шкідливий код без розуміння базових принципів операційної безпеки — що й призводить до таких помилок, як витік власного токена. Дослідники прогнозують зростання кількості подібних «sloppy malware»: погано написаних, але функціональних інфостілерів, що наслідують техніки APT-груп. Ця тенденція триватиме до того часу, поки npm не запровадить автоматичне блокування шкідливих пакетів на рівні реєстру.

Контекст для України

Українські розробники активно використовують npm у щоденній роботі, і подібні інфостілери становлять реальну загрозу для корпоративних середовищ. Спільноти DOU та dev.ua регулярно публікують попередження про шкідливі пакети в npm-реєстрі. Враховуючи, що значна частина українських IT-команд працює у розподіленому режимі з доступом до GitHub і чутливих файлових систем, компрометація директорій типу "/mnt/user-data" може призвести до витоку конфіденційних даних або ключів доступу до хмарної інфраструктури. Security-спеціалісти рекомендують додати перевірку постінсталяційних скриптів до стандарту code review в українських командах.
Telegram

Свіжі новини у нашому Telegram

Отримуйте миттєві сповіщення про нові публікації в рубриці «Код»

@procodeandevenmore