Компромитовањем процеса објављивања GitHub Actions у Red Hat-овим RedHatInsights репозиторијумима, нападачи су успели да објаве 64 злонамерне верзије 32 NPM пакета за Red Hat Cloud Services платформу у NPM директоријуму. Објављене су две злонамерне верзије сваког компромитованог NPM пакета, а свака је садржала код који је активирао нову варијанту црва mini-shai-hulud, који тражи токене и акредитиве у тренутном окружењу.
Црв је смештен у датотеку index.js и активиран путем преинсталационог хендлера који се позива приликом инсталирања зараженог пакета. Након активирања, црв је претраживао систем тражећи токене за NPM (~/.npmrc), PyPI, CircleCI, AWS, GCP, Docker, Azure, HashiCorp и KubernetesK8s, као и SSH приватне кључеве. Подаци које је пронашао послати су нападачима. Ако је пронађен NPM токен, црв је аутоматски објављивао нова злонамерна издања за пакете који су се развијали у тренутном окружењу, инфицирајући стабло зависности.
Приступ GitHub акцијама је добијен компромитовањем налога запосленог у Red Hat-у, што је омогућило нападачима да директно пошаљу commit-ове у javascript-clients, frontend-components и platform-frontend-ai-toolkit репозиторијуме без проласка кроз процес прегледа. Ови commit-ови су убацили ci.yaml датотеку у систем континуиране интеграције, који је, приликом покретања изградње, извршавао _index.js скрипту користећи bun платформу. Скрипта је користила дозволу „id-token: write“ да захтева OIDC (OpenID Connect) токен од GitHub-а, који је затим коришћен за аутентификацију са NPM-ом путем механизма „поузданог објављивања“.
НПМ пакети који садрже злонамерни код:
- @redhat-cloud-services/chrome (2.3.1, 2.3.2)
- @redhat-cloud-services/compliance-client (4.0.3, 4.0.4)
- @redhat-cloud-services/config-manager-client (5.0.4, 5.0.5)
- @redhat-cloud-services/entitlements-client (4.0.11, 4.0.12)
- @redhat-cloud-services/eslint-config-redhat-cloud-services (3.2.1, 3.2.2)
- @redhat-cloud-services/frontend-components (7.7.2, 7.7.3)
- @redhat-cloud-services/frontend-components-advisor-components (3.8.2)
- @redhat-cloud-services/frontend-components-config (6.11.3, 6.11.4)
- @redhat-cloud-services/frontend-components-config-utilities (4.11.2, 4.11.3)
- @redhat-cloud-services/frontend-components-notifications (6.9.2, 6.9.3)
- @redhat-cloud-services/frontend-components-remediations (4.9.2, 4.9.3)
- @redhat-cloud-services/frontend-components-testing (1.2.1, 1.2.2)
- @redhat-cloud-services/frontend-components-translations (4.4.1, 4.4.2)
- @redhat-cloud-services/frontend-components-utilities (7.4.1, 7.4.2)
- @redhat-cloud-services/hcc-feo-mcp (0.3.1, 0.3.2)
- @redhat-cloud-services/hcc-kessel-mcp (0.3.1, 0.3.2)
- @redhat-cloud-services/hcc-pf-mcp (0.6.1, 0.6.2)
- @redhat-cloud-services/host-inventory-client (5.0.3, 5.0.4)
- @redhat-cloud-services/insights-client (4.0.4, 4.0.5)
- @redhat-cloud-services/integrations-client (6.0.4, 6.0.5)
- @redhat-cloud-services/javascript-clients-shared (2.0.8, 2.0.9)
- @redhat-cloud-services/notifications-client (6.1.4, 6.1.5)
- @redhat-cloud-services/patch-client (4.0.4, 4.0.5)
- @redhat-cloud-services/quickstarts-client (4.0.11, 4.0.12)
- @redhat-cloud-services/rbac-client (9.0.3, 9.0.4)
- @redhat-cloud-services/remediations-client (4.0.4, 4.0.5)
- @redhat-cloud-services/rule-components (4.7.2, 4.7.3)
- @redhat-cloud-services/sources-client (3.0.10, 3.0.11)
- @redhat-cloud-services/topological-inventory-client (3.0.10, 3.0.11)
- @redhat-cloud-services/tsc-transform-imports (1.2.2)
- @redhat-cloud-services/types (3.6.1, 3.6.2, 3.6.4)
- @redhat-cloud-services/vulnerabilities-client (2.1.8, 2.1.9)
Извор: опеннет.ру
