Combine cutting-edge XDR technology, multi-signal threat intelligence and 24/7 Elite Threat Hunters to help you build a world-class security operation.
Our team delivers the fastest response time in the industry. Threat suppression within just 4 hours of being engaged.
Cyber risk and advisory programs that identify security gaps and build security strategies to address them.
24/7 SOC-as-a-Service with unlimited threat hunting and incident handling.
XDR with machine learning that eliminates noise, enables real-time detection and response, and automatically blocks threats.
Seamless integration and threat investigation across your existing tech stack.
Defend brute force attacks, active intrusions and unauthorized scans.
Guard endpoints by isolating and remediating threats to prevent lateral spread.
Investigation and threat detection across multi-cloud or hybrid environments.
Remediate misconfigurations, vulnerabilities and policy violations.
Investigate and respond to compromised identities and insider threats.
Stop ransomware before it spreads.
Meet regulatory compliance mandates.
Detect and respond to zero-day exploits.
End misconfigurations and policy violations.
Defend third-party and supply chain risk.
Prevent disruption by outsourcing MDR.
Adopt a risk-based security approach.
Meet insurability requirements with MDR.
Protect your most sensitive data.
Build a proven security program.
Operationalize timely, accurate, and actionable cyber threat intelligence.
THE THREATExploitation of the recently disclosed critical SonicWall vulnerability CVE-2024-40766 (CVSS:9.3) has now been confirmed. CVE-2024-40766 was disclosed on August 22nd and impacts…
Aug 19, 2024THE THREATThe critical severity vulnerability CVE-2024-28986 (CVSS: 9.8), identified in SolarWinds' Web Help Desk (WHD) software, is a Remote Code Execution (RCE) flaw resulting from a Java…
eSentire is The Authority in Managed Detection and Response Services, protecting the critical data and applications of 2000+ organizations in 80+ countries from known and unknown cyber threats. Founded in 2001, the company’s mission is to hunt, investigate and stop cyber threats before they become business disrupting events.
We provide sophisticated cybersecurity solutions for Managed Security Service Providers (MSSPs), Managed Service Providers (MSPs), and Value-Added Resellers (VARs). Find out why you should partner with eSentire, the Authority in Managed Detection and Response, today.
Multi-Signal MDR with 300+ technology integrations to support your existing investments.
24/7 SOC-as-a-Service with unlimited threat hunting and incident handling.
Three MDR package tiers are available based on per-user pricing and level of risk tolerance.
The latest security advisories, blogs, reports, industry publications and webinars published by TRU.
Compare eSentire to other Managed Detection and Response vendors to see how we stack up against the competition.
See why 2000+ organizations globally have chosen eSentire for their MDR Solution.
Adversaries don’t work 9-5 and neither do we. At eSentire, our 24/7 SOCs are staffed with Elite Threat Hunters and Cyber Analysts who hunt, investigate, contain and respond to threats within minutes.
We have discovered some of the most dangerous threats and nation state attacks in our space – including the Kaseya MSP breach and the more_eggs malware.
Our Security Operations Centers are supported with Threat Intelligence, Tactical Threat Response and Advanced Threat Analytics driven by our Threat Response Unit – the TRU team.
In TRU Positives, eSentire’s Threat Response Unit (TRU) provides a summary of a recent threat investigation. We outline how we responded to the confirmed threat and what recommendations we have going forward.
Here’s the latest from our TRU Team…
Since the beginning of August 2023, the eSentire Threat Response Unit (TRU) has observed 5 cases of Lumma Stealer infections across manufacturing, retail, and business industries.
The infostealer was delivered via drive-by downloads disguised as fake installers such as Chrome and Edge browser installers. and some of them were distributed via PrivateLoader (a loader known to drop malware such as Redline, DCRat, and RaccoonStealer in the past).
eSentire TRU recently published a TRU Positive on LummaC2 delivering Amadey and PrivateLoader; you can access the article here.
Lumma Stealer, also known as LummaC2, first appeared on Russian-speaking forums at the end of 2022. The stealer is written in C++, and the build size is approximately 150-396 KB. The pricing for the stealer is divided into three categories:
The stealer features a non-resident loader that is capable of delivering additional payloads via EXE, DLL, and PowerShell:
Some other notable features of the stealer include:
From the previous versions of the stealer (the sample we observed in June, MD5: a4e04604c178fe4fd19996b4d48b8885), as an obfuscation method, the stealer appends strings such as “576xe” to the data.
But with the latest versions (version 4.0), the stealer obfuscates the strings with an XOR algorithm. It converts the hexadecimal characters in the string into the decimal value. The first four bytes of the byte array of the string are used as the XOR key. Each subsequent byte in the array is XORed with the mentioned four bytes in a cyclic manner. The decryption is shown algorithm is shown in the screenshot below.
We implemented the string decrypter for LummaC2 in Python, which you can access here.
The stealer uses MurmurHash2 hashing algorithm to resolve the APIs, in our example the seed is 0x20. The API hashing function is obfuscated with control flow flattening as the rest of the code (Figure 8).
We wrote the script to produce the hash values based on the seed for each API call within the DLL library found in the stealer.
Upon the initial infection, the stealer retrieves the configuration from the C2 (/c2conf). @Jane_0sint provided insights on decrypting the configuration using the first 32-byte of the base64-encoded string as the key. That means that the crypto wallet extensions, applications, and list of browsers are not embedded in the stealer build anymore compared to previous versions of the stealer.
Here is the example of the decrypted configuration retrieved from C2 (JSON format):
{ "v": 1, "c": [ { "t": 0, "p": "%userprofile%", "m": "*.txt", "z": "Important Files/Profile", "d": 1 }, { "t": 0, "p": "%userprofile%", "m": "*key*", "z": "Important Files/Profile", "d": 1 }, { "t": 0, "p": "%userprofile%", "m": "*bitcoin*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*binance*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*exodus*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*coinbase*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*wallet*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*seed*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*pass*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*ledger*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*trezor*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*metamask*", "z": "Important Files/Profile", "d": 3 }, { "t": 0, "p": "%userprofile%", "m": "*crypto*", "z": "Important Files/Profile", "d": 1 }, { "t": 0, "p": "%appdata%\\Binance", "m": "app-store.json", "z": "Wallets/Binance", "d": 1 }, { "t": 0, "p": "%appdata%\\Binance", "m": ".finger-print.fp", "z": "Wallets/Binance", "d": 1 }, { "t": 0, "p": "%appdata%\\Binance", "m": "simple-storage.json", "z": "Wallets/Binance", "d": 1 }, { "t": 0, "p": "%appdata%\\Electrum\\wallets", "m": "*", "z": "Wallets/Electrum", "d": 1 }, { "t": 0, "p": "%appdata%\\Ethereum", "m": "keystore", "z": "Wallets/Ethereum", "d": 1 }, { "t": 0, "p": "%appdata%\\Exodus\\exodus.wallet", "m": "*", "z": "Wallets/Exodus", "d": 2 }, { "t": 0, "p": "%appdata%\\Ledger Live", "m": "*", "z": "Wallets/Ledger Live", "d": 2 }, { "t": 0, "p": "%appdata%\\atomic\\Local Storage\\leveldb", "m": "*", "z": "Wallets/Atomic", "d": 2 }, { "t": 0, "p": "%localappdata%\\Coinomi\\Coinomi\\wallets", "m": "*", "z": "Wallets/Coinomi", "d": 2 }, { "t": 0, "p": "%appdata%\\Authy Desktop\\Local Storage\\leveldb", "m": "*", "z": "Wallets/Authy Desktop", "d": 2 }, { "t": 0, "p": "%appdata%\\Bitcoin\\wallets", "m": "*", "z": "Wallets/Bitcoin core", "d": 2 }, { "t": 0, "p": "%appdata%\\com.liberty.jaxx\\IndexedDB", "m": "*.leveldb", "z": "Wallets/JAXX New Version", "d": 2 }, { "t": 0, "p": "%appdata%\\Electrum\\wallets", "m": "*", "z": "Wallets/Electrum", "d": 2 }, { "t": 0, "p": "%appdata%\\AnyDesk", "m": "*.conf", "z": "Applications/AnyDesk", "d": 2 }, { "t": 0, "p": "%appdata%\\FileZilla", "m": "recentservers.xml", "z": "Applications/FileZilla", "d": 2 }, { "t": 0, "p": "%appdata%\\FileZilla", "m": "sitemanager.xml", "z": "Applications/FileZilla", "d": 2 }, { "t": 0, "p": "%userprofile%", "m": "*.kbdx", "z": "Applications/KeePass", "d": 2 }, { "t": 0, "p": "%programfiles%\\Steam", "m": "ssfn*", "z": "Applications/Steam", "d": 2 }, { "t": 0, "p": "%programfiles%\\Steam\\config", "m": "*", "z": "Applications/Steam/config", "d": 2 }, { "t": 0, "p": "%appdata%\\Telegram Desktop", "m": "*s", "z": "Applications/Telegram", "d": 2 }, { "t": 1, "e": [ { "en": "ejbalbakoplchlghecdalmeeeajnimhm", "ez": "MetaMask" }, { "en": "nkbihfbeogaeaoehlefnkodbefgpgknn", "ez": "MetaMask" }, { "en": "egjidjbpglichdcondbcbdnbeeppgdph", "ez": "Trust Wallet" }, { "en": "ibnejdfjmmkpcnlpebklmnkoeoihofec", "ez": "TronLink" }, { "en": "fnjhmkhhmkbjkkabndcnnogagogbneec", "ez": "Ronin Wallet" }, { "en": "fhbohimaelbohpjbbldcngcnapndodjp", "ez": "Binance Chain Wallet" }, { "en": "ffnbelfdoeiohenkjibnmadjiehjhajb", "ez": "Yoroi" }, { "en": "jbdaocneiiinmjbjlgalhcelgbejmnid", "ez": "Nifty" }, { "en": "afbcbjpbpfadlkmhmclhkeeodmamcflc", "ez": "Math" }, { "en": "hnfanknocfeofbddgcijnmhnfnkdnaad", "ez": "Coinbase" }, { "en": "hpglfhgfnhbgpjdenjgmdgoeiappafln", "ez": "Guarda" }, { "en": "blnieiiffboillknjnepogjhkgnoapac", "ez": "EQUA" }, { "en": "cjelfplplebdjjenllpjcblmjkfcffne", "ez": "Jaxx Liberty" }, { "en": "fihkakfobkmkjojpchpfgcmhfjnmnfpi", "ez": "BitApp" }, { "en": "kncchdigobghenbbaddojjnnaogfppfj", "ez": "iWlt" }, { "en": "kkpllkodjeloidieedojogacfhpaihoh", "ez": "EnKrypt" }, { "en": "amkmjjmmflddogmhpjloimipbofnfjih", "ez": "Wombat" }, { "en": "nlbmnnijcnlegkjjpcfjclmcfggfefdm", "ez": "MEW CX" }, { "en": "nanjmdknhkinifnkgdcggcfnhdaammmj", "ez": "Guild" }, { "en": "nkddgncdjgjfcddamfgcmfnlhccnimig", "ez": "Saturn" }, { "en": "cphhlgmgameodnhkjdmkpanlelnlohao", "ez": "NeoLine" }, { "en": "nhnkbkgjikgcigadomkphalanndcapjk", "ez": "Clover" }, { "en": "kpfopkelmapcoipemfendmdcghnegimn", "ez": "Liquality" }, { "en": "aiifbnbfobpmeekipheeijimdpnlpgpp", "ez": "Terra Station" }, { "en": "dmkamcknogkgcdfhhbddcghachkejeap", "ez": "Keplr" }, { "en": "fhmfendgdocmcbmfikdcogofphimnkno", "ez": "Sollet" }, { "en": "cnmamaachppnkjgnildpdmkaakejnhae", "ez": "Auro" }, { "en": "jojhfeoedkpkglbfimdfabpdfjaoolaf", "ez": "Polymesh" }, { "en": "flpiciilemghbmfalicajoolhkkenfe", "ez": "ICONex" }, { "en": "nknhiehlklippafakaeklbeglecifhad", "ez": "Nabox" }, { "en": "hcflpincpppdclinealmandijcmnkbgn", "ez": "KHC" }, { "en": "ookjlbkiijinhpmnjffcofjonbfbgaoc", "ez": "Temple" }, { "en": "mnfifefkajgofkcjkemidiaecocnkjeh", "ez": "TezBox" }, { "en": "lodccjjbdhfakaekdiahmedfbieldgik", "ez": "DAppPlay" }, { "en": "ijmpgkjfkbfhoebgogflfebnmejmfbm", "ez": "BitClip" }, { "en": "lkcjlnjfpbikmcmbachjpdbijejflpcm", "ez": "Steem Keychain" }, { "en": "onofpnbbkehpmmoabgpcpmigafmmnjh", "ez": "Nash Extension" }, { "en": "bcopgchhojmggmffilplmbdicgaihlkp", "ez": "Hycon Lite Client" }, { "en": "klnaejjgbibmhlephnhpmaofohgkpgkd", "ez": "ZilPay" }, { "en": "aeachknmefphepccionboohckonoeemg", "ez": "Coin98" }, { "en": "bhghoamapcdpbohphigoooaddinpkbai", "ez": "Authenticator" }, { "en": "dkdedlpgdmmkkfjabffeganieamfklkm", "ez": "Cyano" }, { "en": "nlgbhdfgdhgbiamfdfmbikcdghidoadd", "ez": "Byone" }, { "en": "infeboajgfhgbjpjbeppbkgnabfdkdaf", "ez": "OneKey" }, { "en": "cihmoadaighcejopammfbmddcmdekcje", "ez": "Leaf" }, { "en": "gaedmjdfmmahhbjefcbgaolhhanlaolb", "ez": "Authy" }, { "en": "oeljdldpnmdbchonielidgobddfffla", "ez": "EOS Authenticator" }, { "en": "ilgcnhelpchnceeipipijaljkblbcob", "ez": "GAuth Authenticator" }, { "en": "imloifkgjagghnncjkhggdhalmcnfklk", "ez": "Trezor Password Manager" }, { "en": "bfnaelmomeimhlpmgjnjophhpkkoljpa", "ez": "Phantom" }, { "en": "ppbibelpcjmhbdihakflkdcoccbgbkpo", "ez": "UniSat" } ], "n": [ { "p": "%localappdata%\\Google\\Chrome\\User Data", "z": "Chrome" }, { "p": "%localappdata%\\Chromium\\User Data", "z": "Chromium" }, { "p": "%localappdata%\\Microsoft\\Edge\\User Data", "z": "Edge" }, { "p": "%localappdata%\\Kometa\\User Data", "z": "Kometa" }, { "p": "%appdata%\\Opera Software\\Opera Stable", "z": "Opera Stable" }, { "p": "%appdata%\\Opera Software\\Opera GX Stable", "z": "Opera GX Stable" }, { "p": "%appdata%\\Opera Software\\Opera Neon\\User Data", "z": "Opera Neon" }, { "p": "%localappdata%\\BraveSoftware\\Brave-Browser\\User Data", "z": "Brave Software" }, { "p": "%localappdata%\\Comodo\\Dragon\\User Data", "z": "Comodo" }, { "p": "%localappdata%\\CocCoc\\Browser\\User Data", "z": "CocCoc" } ] }, { "t": 2, "p": "%appdata%\\Mozilla\\Firefox\\Profiles", "z": "Mozilla Firefox" } ] }
We wrote the configuration retrieval script in Python, which you can access here. You can also access the configuration extractor for the builder here.
Example of additional data obtained from C2: lid=KjGtqi--VIKKY&j=e799236f7a828928688bbd10d343328e&ver=4.0, where the lid is the LummaC2 ID, the value “VIKKY” is likely the build ID assigned and the stealer version (ver=). The logs are exfiltrated over the ZIP archive, as shown in the screenshot below (/c2sock).
Protecting against information stealers requires a multi-layered defense approach to defend endpoints from malware and detect or block unauthorized login activity against applications and remote access services. Therefore, we recommend:
Name |
Indicators |
C2 |
gservice-node[.]io |
C2 |
gstatic-node[.]io |
C2 |
balancelag[.]xyz |
C2 |
doorblu[.]xyz |
Payload |
c9094685ae4851fd5a5b886b73c7b07efd9b47ea0bdae3f823d035cf1b3b9e48 |
Payload |
3bf4b365d61c1e9807d20e71375627450b8fea1635cb6ddb85f2956e8f6b3ec3 |
Payload |
a9c7c4df7e39b8bc7b03b7d4053066d26154bc76c3e261fff84f2339d44a474e |
Payload |
b803e8d9da6efe7b0220f654c7afb784d21dc222afd4a4e41396e74f861cbf30 |
rule LummaC2 { meta: author = "RussianPanda" description = "LummaC2 Detection" strings: $p1="lid=%s&j=%s&ver" $p2= {89 ca 83 e2 03 8a 54 14 08 32 54 0d 04} condition: all of them and filesize <= 500KB }
The eSentire Threat Response Unit (TRU) is an industry-leading threat research team committed to helping your organization become more resilient. TRU is an elite team of threat hunters and researchers that supports our 24/7 Security Operations Centers (SOCs), builds threat detection models across the eSentire XDR Cloud Platform, and works as an extension of your security team to continuously improve our Managed Detection and Response service. By providing complete visibility across your attack surface and performing global threat sweeps and proactive hypothesis-driven threat hunts augmented by original threat research, we are laser-focused on defending your organization against known and unknown threats.