data:image/s3,"s3://crabby-images/0c8d1/0c8d103f51d5f8dcece84455e5fb352fa4196de8" alt="Hacker deploys macOS stealer disguised as CleanMyMac crack (Header image)"
A new threat has emerged that is targeting macOS users. At Moonlock Lab, we discovered a malware sample that has evaded detection on VirusTotal since its first submission on May 17, 2024.
Most notable is that this time, we find a tie between this strain and a particular threat actor. Plus, this stealer leverages osascript to execute its malicious payload, making it difficult to detect.
data:image/s3,"s3://crabby-images/77b3b/77b3b3a1c664c524e8350edfc3d994ebd894e682" alt="A screenshot of VirusTotal showing 0 flags."
Under the hood of the macOS stealer
It’s worth noting that the osascript script is downloaded from a fake domain and executed through the system() function. This is an old trick that allows it to remain hidden for some time.
data:image/s3,"s3://crabby-images/cc59f/cc59f88657bc6cb872c53d54fca5e05bb8c5563f" alt="A screenshot of the osascript downloaded from a fake domain."
The primary payload, a Mach-O file, is distributed via DMG installers with file names such as Launcher.dmg or CleanMyMacCrack.dmg.
Considering the name, it is probable that the infection chain started from downloading a cracked app. Downloading cracked apps is a dangerous practice that we outlined in a previous article.
data:image/s3,"s3://crabby-images/645bb/645bb749a38fd9383cd64c540ca8af965aea9d9d" alt="An image showing the CleanMyMacCrack.dmg launcher."
This file downloads an AppleScript from hxxps://forked-project[.]com/check_updates and executes it using the system command.
![A screenshot of the AppleScript downloaded from forked-project[.]com.](https://moonlock.com/2024/06/4_forkedprojectcheckupdates.webp)
Notably, this version of the stealer is signed, a feature not observed in previous iterations.
It’s also important to mention that this time, the attackers did not use a phishing bypass of Gatekeeper with an installer image. Instead, they utilized a team ID.
data:image/s3,"s3://crabby-images/fb935/fb935d2442f1f212e68b484f5f51beb9db773047" alt="An image from the script showing developer ID certification."
The script sets up directories and paths, verifies user credentials, and collects data from various sources, including browsers, files, and system information. It then transmits the collected data to a server using the “curl” command.
A close examination of the stealer’s script reveals the specific browsers and cryptocurrency wallets it targets.
data:image/s3,"s3://crabby-images/c2e45/c2e451946b3cf38cd0f8ce1cd6c2f0044564dfa1" alt="A screenshot revealing the browsers and crypto wallets targeted by the script."
How the script works
Here is a detailed breakdown of what the script does:
- Collects user information: The script retrieves the current username using the command system attribute USER. It then stores the username and other system-related paths for further operations.
- Sets up directories: The script creates a temporary directory to store the stolen data before exfiltration.
- Extracts browser data: Several browsers are targeted by the script to collect sensitive information. This information includes browsing history, cookies, saved passwords, and other user data. Targeted browsers include Google Chrome, Brave, Microsoft Edge, Vivaldi, Opera, OperaGX, and Firefox.
- Extracts cryptocurrency wallet data: A key function of the script is to identify and access directories where popular cryptocurrency wallets store their data. From there, it can steal wallet files, potentially allowing the attacker to access the victim’s crypto assets. Wallets targeted include Electrum, Coinomi, Exodus, Atomic Wallet, Wasabi Wallet, Ledger Live, Feather (Monero), Bitcoin Core, Litecoin Core, Dash Core, Electrum-LTC, Electron Cash, Guarda Wallet, Dogecoin Core, Binance, and TonKeeper.
- Collects specific files and data: The script copies the login.keychain-db file, which contains macOS keychain data, potentially including passwords and other sensitive credentials. It also grabs data from the Apple Notes application, extracting NoteStore.sqlite and associated files. Plus, it steals cookies from Safari by accessing Cookies.binarycookies.
- Gathers general user information: General user information is also collected, possibly including system details, user activities, and other relevant metadata.
- Exfiltrates data: After collecting the necessary files and data, the script likely prepares the data for exfiltration.
After all this, the script uses the send_data(writemind) function to send the collected data to the attacker’s server hxxp://79.137.192.4/p2p.
data:image/s3,"s3://crabby-images/07f6f/07f6f4fe63141d60ee66150cf0a5284f2868d691" alt="An image of the send_data(writemind) script function."
Infection chain
The infection chain begins when a user visits a pirated software site and downloads a file named CleanMyMacCrack.dmg, believing it to be a cracked version of CleanMyMac. Upon launching the DMG file, a Mach-O file is executed, which then downloads an AppleScript from hxxps://forked-project[.]com/check_updates. This AppleScript is executed via the system command, creating a temporary directory for data collection. The script proceeds to steal sensitive information, including browser cookies, passwords, and cryptocurrency wallet data. Finally, the stolen data is compressed and sent to a Command and Control (C2) server at hxxp://79[.]137[.]192[.]4/p2p
data:image/s3,"s3://crabby-images/4cc28/4cc2874c5ea1e6c7a9c3ff3204f6cede6a807970" alt="Infection chain for the macOS stealer disguised as a CleanMyMac crack"
Attribution
This stealer is allegedly linked to Rodrigo4, a notorious Russian-speaking threat actor active on the XSS underground forum. In a post on XSS, Rodrigo4 was seen seeking partners to distribute the stealer through SEO manipulation and Google Ads, suggesting this as their possible method of distribution.
data:image/s3,"s3://crabby-images/c54dc/c54dc168d4dc338ce6fdedf70a3beba3ff4b5603" alt="A screenshot of a post by Rodrigo4 on XXS."
Moonlock Lab has noticed the stealer communicates with its command-and-control (C2) server at hxxp://79.137.192.4. An investigation into this IP address revealed an authorization form (hxxp://79.137.192.4/login/). The form closely resembles others found in posts advertised by Rodrigo4 on the XSS forum, suggesting a direct connection to the threat actor.
data:image/s3,"s3://crabby-images/cd732/cd732e01acba52744b3faf90d1bfd3b4421a39fe" alt="A screenshot of the authorization form linked to Rodrigo4."
data:image/s3,"s3://crabby-images/3a202/3a202853431a1eba5b4cba924b85505b38073f46" alt="An image showing the total statistics for the threat actor linked to the macOS stealer."
data:image/s3,"s3://crabby-images/b6ff8/b6ff8cf02f3558e775b9e3cbf6e4b612f0771033" alt="An image showing more known details about the threat actor linked to the macOS stealer."
Further, we discovered a logo associated with Rodrigo4 on the server (hxxp://79.137.192.4/assets), providing additional evidence of this link.
data:image/s3,"s3://crabby-images/e00ff/e00ff6abff48941914dad719c3885bbfb30529e8" alt="A screenshot of the assets page on the server under investigation."
data:image/s3,"s3://crabby-images/b76b3/b76b3abbc6c53f15ac2c07cf00f771f988215820" alt="A browser window showing a logo potentially linked to Rodrigo4, discovered on the server under investigation."
Our findings were bolstered by the keen observations of @birchb0y, a senior detection engineer from Huntress, who shed light on the payload’s rising popularity among Atomic Stealer variants over the past 6 months.
The observation connects the dots from 79.137.192.4 using URLScan.io, uncovering related URLs such as rodrigos[.]io. This trail led to an A record for 185.172.128[.]72, a real hive of crypto-related domains.
data:image/s3,"s3://crabby-images/e08b0/e08b049a0ea6148dcbcf3da086903428b457b57c" alt="A screenshot of the post by user @birchb0y about the macOS stealer."
data:image/s3,"s3://crabby-images/33605/33605097302b60efc12462422646df5d4cf1ab57" alt="A screenshot of a post by @birchb0y related to Atomic Stealer."
Conclusion
The discovery of this hidden stealer strain highlights the increasing diversity of cyber threats. Linked to the known threat actor Rodrigo4 and using advanced evasion methods, this malware poses a danger to macOS users.
Here are several tips to help you protect yourself from this macOS malware:
- Be cautious with downloads: Only download software from trusted sources, such as the official App Store or verified websites. Also, avoid clicking on suspicious links or email attachments.
- Keep software updated: Always install the latest updates for your macOS and applications. Updates often include security patches that fixes to vulnerabilities.
- Use security software: Use reputable anti-malware software, such as CleanMyMac X powered by Moonlock Engine, and regularly scan your system for threats.
Indicators of Compromise (IOC)
Indicators | Indicator Type | Description |
30b89622c779dd06faa909e7e0b8e88f3b75ca78fad00c4cf0ef7db320e3b218 | SHA256 | Mach-O |
30b89622c779dd06faa909e7e0b8e88f3b75ca78fad00c4cf0ef7db320e3b218 | SHA256 | DMG |
79[.]137[.]192[.]4 | IP | Atomic Stealer C2 |
109[.]120[.]178[.]3 | IP | Atomic Stealer C2 |
pixelcommunity[.]xyz | Domain | Associated Domain |
newparadigm[.]dev | Domain | Associated Domain |
mantanetwork[.]dev | Domain | Associated Domain |
rodrigos[.]io | Domain | Associated Domain |
altllayer[.]com | Domain | Associated Domain |
lfgjupiter[.]com | Domain | Associated Domain |
earlymodenetwork[.]com | Domain | Associated Domain |
leaderwallets[.]org | Domain | Associated Domain |
hxxps://forked-project[.]com/check_updates | URL | Payload URL |
hxxps[://]xss[.]is/threads/97296/ | URL | Rodrigo4 post on XSS |