Summary: The emergence of CoinLurker marks a significant evolution in fake update campaigns, utilizing advanced obfuscation and anti-analysis techniques to exfiltrate sensitive data while evading detection. This sophisticated malware exploits user trust through deceptive software update prompts and stealthy delivery methods.
Threat Actor: Unknown | CoinLurker Victim: Various Users | users of CoinLurker
Key Point :
- CoinLurker employs fake software update notifications, malvertising redirects, and phishing emails to initiate infections.
- Utilizes Microsoft Edge Webview2 to execute malware while mimicking legitimate browser update tools.
- Advanced techniques like EtherHiding and multi-stage payload delivery help evade traditional security measures.
- Targets cryptocurrency wallets and financial applications to harvest sensitive user data.
- Morphisec’s Automated Moving Target Defense technology can help mitigate these sophisticated attacks.
The evolution of fake update campaigns has advanced significantly with the emergence of CoinLurker, a sophisticated stealer designed to exfiltrate data while evading detection. Written in Go, CoinLurker employs cutting-edge obfuscation and anti-analysis techniques, making it a highly effective tool in modern cyberattacks.
Introduction
Building on the deceptive strategies of SocGolish, ClearFake, ClickFix and FakeCAPTCHA, attackers now combine highly convincing fake update prompts with stealthy payloads like CoinLurker. These campaigns leverage innovative methods, such as EtherHiding and in-memory execution, to bypass traditional security defenses and obscure the malware’s origin.
In this blog, we examine the evolution of fake update campaigns, the techniques enabling CoinLurker’s success, and actionable strategies for defending against this next-generation threat.
Delivery Tactics and Techniques
Fake update campaigns initiate infections through various deceptive entry points that exploit user trust in common actions like:
- Fake Software Update Notifications
Malicious websites prompt users to download fake updates, disguised as essential software patches. This vector is often observed on compromised WordPress sites, where attackers exploit vulnerabilities to deliver fake update prompts.
- Malvertising Redirects
Compromised ads on legitimate sites redirect users to malicious pages, prompting fake updates or CAPTCHA verifications.
- Phishing Emails
Emails link to spoofed update or CAPTCHA pages, tricking users into downloading malware disguised as security updates.
- Fake CAPTCHA Prompts
FakeCAPTCHA introduces malicious CAPTCHA prompts that deliver malware instead of verifying users.
- Direct Downloads from Fake or Compromised Sites
Malicious actors host fake updates on compromised or deceptive download sites, luring users into installing malware.
- Social Media and Messaging Links
Links shared on social platforms lead to malicious sites disguised as update or verification pages.
Each of these vectors effectively disguises malware as routine actions, initiating the infection chain with minimal user suspicion.
Leveraging Microsoft Edge Webview2 as a Stager
Microsoft Edge Webview2 is utilized by the stager to execute the malware, presenting a GUI that mimics legitimate browser update tools. Any interaction with the GUI—clicking buttons or even closing the window—triggers the payload execution.
Figure 1: Fake Browser Update Webview2 GUI
Figure 2: Chrome fake update Webview2 GUI
Webview2’s dependency on pre-installed components and user interaction complicates dynamic and sandbox analysis. Sandboxes often lack Webview2 or fail to replicate user actions, allowing the malware to evade automated detection.
Figure 3: Screenshot of Webview2 installation within Sandbox
The Obfuscation Chain: Smart Contracts to Trusted Platforms
Binance Smart Contract → Actor-controlled C2 → Bitbucket Repository
Fake update campaigns like those deploying CoinLurker have adopted advanced techniques to evade detection, including EtherHiding, which leverages Web3 infrastructure to conceal malicious payloads. This campaign employs a multi-stage chain to deliver its payload seamlessly while remaining under the radar.
- Binance Smart Contract:
This process begins with encoded data embedded within a Binance Smart Contract. By leveraging the decentralized and immutable properties of blockchain, attackers store payload instructions that are resistant to tampering or removal. - Actor-controlled Command-and-Control (C2) Server:
The encoded data directs the malware to an actor-controlled C2 server, which serves as a pivot point in the chain. Here, the server dynamically fetches further instructions or payload links, ensuring the malware does not carry any static indicators that could trigger detection. - Bitbucket Repository
The final stage involves a Bitbucket repository that initially hosts a benign executable. Once downloaded and deemed safe by security scans, this executable is later replaced by a malicious version. This tactic capitalizes on Bitbucket’s reputation as a trusted platform while reducing the chances of immediate detection. The use of a clean file in the initial stage ensures the campaign avoids raising alarms during early stages of distribution.
Figure 4: Screenshot of repositories used by the actor with high downloads count
Timeline of Filenames (August to October 2024)
CoinLurker’s evolution includes a notable timeline of filenames used in the Bitbucket repository, often masquerading as legitimate tools to enhance deception. From August to October 2024, the filenames observed include:
BrowserUpdateTool.exe |
BrowserTool.exe |
BrowserUpdater.exe |
UpdateNow.exe |
UpdateMe.exe |
Updater.exe |
UpdaterSetup.exe |
Updating.exe |
SecurityPatch.exe |
Each filename aligns with the fake update theme, designed to appear as genuine system utilities or browser update tools. Additionally, those executables are signed with a legitimate Extended Validation (EV) certificate, adding another layer of credibility. While the origin of the certificate cannot be confirmed, it is likely stolen, enabling the attackers to bypass security warnings and enhance the perceived legitimacy of the malicious files.
Figure 5: EV Certificate parsed in VirusTotal
Layered Injection Tactics to Evade Detection
CoinLurker utilizes a sophisticated multi-layered injector to stealthily deploy malicious payloads into multiple instances of legitimate msedge.exe processes. This approach ensures that the malware evades detection, blends seamlessly into legitimate system activity, and bypasses network security rules that rely on process behavior for filtering. Below are the key obfuscation techniques observed during analysis.
Infection Validation Through Registry Checks
CoinLurker employs a heavily obfuscated function to determine if the system has already been infected. This method dynamically constructs a unique registry key, such as SOFTWARE<GUID>-<ID>, using system-specific data like the machine’s GUID and custom input strings.
The malware then attempts to access the key using the Windows OpenKey API. If the key exists and contains the expected values, CoinLurker identifies the system as already infected and terminates its execution. If the key is missing or does not match the expected values, the malware proceeds with its infection routine.
While this technique serves as a mutex to prevent multiple infections, the obfuscation within the function—such as dynamic API resolution and a layered execution flow—makes it challenging for analysts to reverse-engineer the logic or identify the key construction process.
Figure 6: .gif – Runtime Validation Obfuscated Function
Runtime String Decoding and Injection
CoinLurker employs a sophisticated injection process that relies on dynamic string decoding and obfuscation to conceal its activities. The malware targets msedge.exe, launching each instance with unique, obfuscated command-line arguments. Examples include:
- WSCOGJJEZZWL
- NTOCBJPKZPNT
- XXEZGQVPKJGS
- PEQDTHUEORHX
- RLZXCUVFFESG
These arguments are dynamically generated and transformed at runtime, passing through layered transformations like Base64 decoding, UTF-16 conversion, and dynamic resource mapping. The final values only emerge during execution, leaving minimal static traces. The payload itself is decrypted in memory using obfuscated routines, ensuring traditional detection methods are bypassed.
Figure 7: Main Loader Function
The injection logic incorporates heavily obfuscated control flow, including nested state machines and conditional checks that obscure the actual execution path. Redundant resource assignments and iterative memory manipulations further complicate analysis, keeping critical data hidden until runtime.
Socket-Based Communication for C2 Operations
CoinLurker communicates with its C2 servers using a socket-based framework. It employs functions like GetAddrInfoW for DNS resolution, WSASocketW for socket creation, and ConnectEx for establishing connections. Data exchange is handled via WSASend and WSARecv, with asynchronous operations using CreateIoCompletionPort to enhance efficiency.
Domains dynamically resolved by CoinLurker include:
- zovik[.]info
- analfucker[.]lol
- paveldurov[.]sbs
File Enumeration Targeting Cryptocurrency Wallets
CoinLurker demonstrates a highly targeted approach to data collection, focusing on directories associated with cryptocurrency wallets and financial applications. Through systematic enumeration, it attempts to access a variety of locations that are commonly used for storing sensitive user data. Key targets include:
Major Cryptocurrency Wallets:
- Bitcoinwallets
- Ethereumkeystore
- Ledger LiveLocal Storageleveldb
- Exodusexodus.wallet
Alternative Cryptocurrencies and Lesser-Known Wallets:
- Examples include BBQCoin, Lucky7Coin, MemoryCoin, and many others, showcasing its effort to cover a wide range of cryptocurrencies.
Related Applications:
- Directories such as Telegram Desktoptdata, DiscordLocal Storageleveldb, and FileZilla
This comprehensive scanning underscores CoinLurker’s primary goal of harvesting valuable cryptocurrency-related data and user credentials. Its targeting of both mainstream and obscure wallets demonstrates its versatility and adaptability, making it a significant threat to users in the cryptocurrency ecosystem.
How Morphisec Can Help
Morphisec’s pioneering Automated Moving Target Defense (AMTD) technology stops sophisticated attacks at the earliest stage without relying on outdated signature or behavioral-based detection methods. By preemptively blocking memory and application-based attacks, Morphisec eliminates threats before they can take hold and become business impacting.
IOCs
Fake Installers SHA256:
- 324e1bf24f13d5a8f45cc5ee25d3dfe330a7e755b19901549976f2db02ca4fa4
- c8adb9bf6997a9fa2738a09600a60abc4fb6334aa54b24166cf042afdc5a1064
- 1f4624c44288f77327ec2e8d260399559b81c7cae442c31311736c2a2ec5f399
- a7eca930c2aa851cae3475cb4f5d599058816d51e1cc55a82ae976a030794aac
- be5e250168d37e7a9a4999d41a77cde19a6ac376a391f602b3496ace307ad0e8
- 93cc9759d86f8b087b71583f577a5534e975ce9ac19ec3ec140efa6bbfad6bd0
- 44521e1af289aa3473d7445d097766f1c3f3d8721d14b14ed6d5404994a03eb2
- 2198912e1a1f4a5b5f0dfe237b75d264c9be0b5b6f98f83a999117dd194e842c
- f79c62b820420bda78252197db842eabe63261a4e80fbdcec8d671ce3d0a43ef
- 8119a59487c6ffe5382c03e3de8c70b2c2e26899b51dcc4794066a8e1f358bcb
- 9a036f20d758107d9434bd3bed682ff7d81393dc9d49fd6fe70d4b549045eaa2
- a12809c76461d00760bef767c98baf5909a4aed48f2256d3c42eb1ca62835c14
- 487156ae20cc6d8e7d922cebe35b197c28ae43134f7e04c5f6bd0f3e164a7120
- 9116c7878f51e6d8173d41a5a0e63ca16105dac954afedeaf1d5e06594cc4d41
- cc2f65faf61154815b4fa151d9a27c01a160d7d46398c7e44169949a61c63c2b
- 7eede0e13ed9990afb465c2f612d85bc10c946dd2419323528a58707cef62899
- 2c8f611b0f2c157f010c20379d4fcd725a8c462a8d226ae0095e3e0fb110ddbe
- 6976c3e0ffbbbbb310995e70f24bf9501d017279d865ac4536aee25b316a92de
- 269c3b26b215d397f012a20e241c54b2c693667d4f64243ebf8dba1a5872c02d
- 397a0f6515a81f307b5289ff3e939a0e01a6c1a0f0515be9844ddc9c6031ad97
- 82cc0f3f4aa70a8215b62db7ee9deac1c3d4dd27cde25cf56ec2f82ca7d146a9
- 2181c60e8727d5cfe7e713aa9731018168660ad2c96f31b08a729d1503dfc19a
- 0b5fe211d558daa7d54207d2869f53d0a91ae16397343fd2605fd3a0f292dd21
- 9c0c9945f81977269542f941c10fa28dbefe91078b6df68e97d61b58318cac9a
- b761e91e77b67661db51d6b498ea39ccb6f143e51eeee18925a2dc4aab20adfa
- a612bca9b5cbda864f4b808992de3d616c67b9120d8b24cbfa8a836ccdde9142
- a3c7b289054635f5239d453fb4be718298037ea6c1f4bf16954af1e9da2a53e2
- 9ea70e081c13c4b0e30b43dd68a6a0e0cfb6926c990bbe8ddedd8d9693c953d6
- 0b420a565e5e6f6899ebcb1da2fc162b05f5a8b7bfe0f56f52a085f17abb253d
- 80b2950f1249d439105eac421660ddd15caab6de6afce3511f945deef1c0dd21
- c643c087c68e51dfe422ddb48614675ab8e6aaecbe5704759c9978ac22b15f83
- 3048030c0e3ff5e6e45bbb37e75d6e55fde8d77a928958dc34497177e077b69a
- 18f882b6c16641be3899f4e5123d10bb5c448ac7b7dafe7adb6144176acae304
- 15be79b09fa5efe3ca3440a94e436124d97232436af91f64917b7095b559a210
- 162e4277a4cb2e3703df74529d83d47b66a5b46b0a93b3ac902b56da3e588fe9
- 8d61f5b56f05daeef394dbc434abb96c1388aca8406e02445a72db1a65b9da3d
- 9374e1561a87a23b12ec586859661241b2eb5da822c0b4b874cdf9eda480363f
- Fff7637514c6238443100fbc4d1fef626cebf043eef1aefa3a0f5ab6d0103bf6
Stager URLs:
- md928zs[.]shop/endpoint
- smolcatkgi[.]shop/endpoint
- dais7nsa[.]shop/endpoint
- ajsdiaolke[.]shop/endpoint
- peskpdfgif[.]shop/endpoint
- ndas8m92[.]shop/endpoint
- test-1627838[.]shop/endpoint
- smkn1leuwimunding[.]com/Updating.zip
- bitbucket[.]org/browsertools/tools/downloads/
- bitbucket[.]org/targetfile/download/downloads/UpdateRequest.exe
- bitbucket[.]org/browserupdater/download/downloads/BrowserUpdater.exe
- bitbucket[.]org/cleopatrall/upds/downloads/updater.exe
- bitbucket[.]org/stoptrackme/updatings/downloads/UpdateMe.exe
- bitbucket[.]org/napoleon_bonaparte/browtool/downloads/BrowserUpdateTool.exe
C2 Domains:
- paveldurov[.]sbs
- zovik[.]info
- analfucker[.]lol
Sensitive data discovery paths:
- c:users<username>appdatalocalgoogle
- c:users<username>appdataroamingmozillafirefox
- c:users<username>appdatalocalmicrosoftedge
- c:users<username>appdatalocalbravesoftwarebrave-browser
- c:users<username>appdatalocal360chrome
- c:users<username>appdataroamingopera software
- c:users<username>appdatalocalvivaldi
- c:users<username>appdatalocalcoccoc
- c:users<username>appdatalocalyandex
- c:users<username>appdatalocalchromium
- c:users<username>appdatalocaltencent
- c:users<username>appdataroamingjupitercoin
- c:users<username>appdataroamingmemorycoin
- c:users<username>appdataroamingledger livelocal storageleveldb
- c:users<username>appdataroamingbbqcoin
- c:users<username>appdataroamingbitbar
- c:users<username>appdataroamingcrimecoin
- c:users<username>appdataroamingglobalcoin
- c:users<username>appdataroaminggrain
- c:users<username>appdataroaminglucky7coin
- c:users<username>appdataroamingmaples
- c:users<username>appdataroamingethereumkeystore
- c:users<username>appdataroamingbits
- c:users<username>appdataroamingcolossuscoin
- c:users<username>appdataroamingfrankocoin
- c:users<username>appdataroamingfreecoin
- c:users<username>appdataroamingzccoin
- c:users<username>appdataroamingzcash
- c:users<username>appdataroamingbountycoin
- c:users<username>appdataroamingearthcoin
- c:users<username>appdataroamingandroidstokens
- c:users<username>appdataroamingpeoplecoin
- c:users<username>appdataroamingredcoin
- c:users<username>appdataroamingflorincoin
- c:users<username>appdataroamingsexcoin
- c:users<username>appdataroaminglebowskis
- c:users<username>appdataroamingskycoin
- c:users<username>appdataroamingezcoin
- c:users<username>appdataroamingjoulecoin
- c:users<username>appdataroaminglast coin
- c:users<username>appdataroamingdogecoin
- c:users<username>appdataroamingmegacoin
- c:users<username>appdataroamingunobtanium
- c:users<username>appdataroamingextremecoin
- c:users<username>appdataroaminggrandcoin
- c:users<username>appdataroamingrichcoin
- c:users<username>appdataroaminginfinitecoin
- c:users<username>appdataroaminguscoin
- c:users<username>appdataroamingexodusexodus.wallet
- c:users<username>appdataroamingavingcoin
- c:users<username>appdataroaminggoldcoin
- c:users<username>appdataroamingatomic_qt
- c:users<username>appdataroamingbitcoinwallets
- c:users<username>appdataroamingnamecoin
- c:users<username>appdataroamingprimecoin
- c:users<username>appdataroamingluckycoin
- c:users<username>appdataroamingonecoin
- c:users<username>appdataroamingquarkcoin
- c:users<username>appdataroamingasiccoin
- c:users<username>appdataroamingcosmoscoin
- c:users<username>appdataroamingticketscoin
- c:users<username>appdataroamingcloudcoin
- c:users<username>appdataroamingmavro
- c:users<username>appdataroamingsecondscoin
- c:users<username>appdataroamingsupercoin
- c:users<username>appdataroamingtagcoin
- c:users<username>appdataroamingarmory
- c:users<username>appdataroamingbeaocoin
- c:users<username>appdataroamingfreicoin
- c:users<username>appdataroamingnanotokens
- c:users<username>appdataroamingorbitcoin
- c:users<username>appdataroamingroyalcoin
- c:users<username>appdataroamingworldcoin
- c:users<username>appdataroamingalphacoin
- c:users<username>appdataroamingferretcoin
- c:users<username>appdataroaminggalaxycoin
- c:users<username>appdataroamingunitedscryptcoin
- c:users<username>appdataroamingybcoin
- c:users<username>appdatalocalcoinomicoinomiwallets
- c:users<username>appdataroamingbottlecaps
- c:users<username>appdataroamingneocoin
- c:users<username>appdataroamingprotosharescoin
- c:users<username>appdataroamingnovacoin
- c:users<username>appdataroamingterracoin
- c:users<username>appdataroamingcom.liberty.jaxxindexeddbfile__0.indexeddb.leveldb
- c:users<username>appdataroamingamericancoin
- c:users<username>appdataroaminggamecoin
- c:users<username>appdataroamingkingcoin
- c:users<username>appdataroamingsecurecoin
- c:users<username>appdataroamingfranko
- c:users<username>appdataroamingnxtcoin
- c:users<username>appdataroamingwalletwasabiclientwallets
- c:users<username>appdataroamingfastcoin
- c:users<username>appdataroamingnuggets
- c:users<username>appdataroamingsifcoin
- c:users<username>appdataroamingargentum
- c:users<username>appdataroamingphilosopherstone
- c:users<username>appdataroamingxencoin
- c:users<username>appdataroamingdevcoin
- c:users<username>appdataroamingelephantcoin
- c:users<username>appdataroaminghobonickels
- c:users<username>appdataroamingprotoshares
- c:users<username>appdataroamingzetacoin
- c:users<username>appdataroamingatomiclocal storageleveldb
- c:users<username>appdataroamingcraftcoin
- c:users<username>appdataroamingcryptogenicbullion
- c:users<username>appdataroamingkrugercoin
- c:users<username>appdataroamingguarda
- c:users<username>appdataroamingvaluecoin
- c:users<username>appdataroamingbytecoin
- c:users<username>appdataroamingdiamond
- c:users<username>appdataroamingfeathercoin
- c:users<username>appdataroamingpennies
- c:users<username>appdataroamingrealcoin
- c:users<username>appdataroamingelectrumwallets
- c:users<username>appdataroamingixcoin
- c:users<username>appdataroamingnaanayam
- c:users<username>appdataroamingzenithcoin
- c:users<username>appdataroamingbitgem
- c:users<username>appdataroamingdigitalcoin
- c:users<username>appdataroamingppcoin
- c:users<username>appdataroamingmincoin
- c:users<username>appdataroamingpeercoin
- c:users<username>appdataroamingshitcoin
- c:users<username>appdataroamingliquidcoin
- c:users<username>appdataroamingmastercoin
- c:users<username>appdataroamingmemecoin
- c:users<username>appdataroamingtekcoin
- c:users<username>appdataroamingtumcoin
- c:users<username>appdataroamingyacoin
- c:users<username>appdataroamingnetcoin
- c:users<username>appdataroamingpaycoin
- c:users<username>appdataroamingspots
- c:users<username>appdataroamingchncoin
- c:users<username>appdataroamingdollarpounds
- c:users<username>appdataroamingplaytoken
- c:users<username>appdataroamingcryptogenicbullionc
- c:users<username>appdataroamingeaglecoin
- c:users<username>appdataroamingopensourcecoin
- c:users<username>appdataroamingphenixcoin
- c:users<username>appdataroamingsauron rings
- c:users<username>appdataroamingbitcoin
- c:users<username>appdataroaminganoncoin
- c:users<username>appdataroamingcopper bars
- c:users<username>appdataroaminggrowthcoin
- c:users<username>appdataroamingitalycoin
- c:users<username>appdataroaming42coin
- c:users<username>appdataroamingblakecoin
- c:users<username>appdataroamingcasinocoin
- c:users<username>appdataroamingghisler
- c:users<username>appdataroamingpsi+profilesdefault
- c:users<username>appdataroamingtelegram desktoptdata
- c:users<username>appdataroamingdiscordlocal storageleveldb
- c:users<username>appdataroamingfilezilla
Source: https://blog.morphisec.com/coinlurker-the-stealer-powering-the-next-generation-of-fake-updates