Authors Jyoti Naveen and Kiran Raj
McAfee Labs is watching a spike in a phishing campaign that uses the macro capabilities of Microsoft Office. These malicious documents reach victims through mass spam e-mail campaigns and usually evoke instantaneous, fearful or similar emotions, prompting unsuspecting users to quickly open them. The purpose of these spam activities is to distribute contaminated payloads to as many people as possible.
A recent spam campaign Ursnif Trojan is using malicious word documents to download and run. Ursnif is a high-risk Trojan designed to record various sensitive information. It usually saves this sensitive data and sends it back to a command-and-control server.
This blog describes how attackers can download and execute Ursnif Trojan using document features and some other tactics.
Summary of threats
- The initial attack vector is a phishing email with a Microsoft Word document attachment.
- After opening the document, VBA executes a malicious shellcode
- Shellcode Remote Payload, downloads Ursnif and calls rundll32.exe to run it.
Transmission chain
The malware comes via a phishing email that contains a Microsoft Word document as an attachment When the document is opened and the macro is activated, Word downloads a DLL (Ursnif payload). The Ursnif payload is then executed using rundll32.exe
data:image/s3,"s3://crabby-images/45cc0/45cc059131ed51535aec03de98a7c683f273ef8b" alt="Figure 1- Flowchart of transmission chain"
Word analysis
Macros are disabled by default and malware authors are aware of this and therefore present an image to entice victims to enable them.
data:image/s3,"s3://crabby-images/e7a3d/e7a3dba280f4c05ca1254e15000d1c2a7f55b325" alt="Figure 2- Images of what the user sees while opening the document"
VBA macro analysis of word document
Stable analysis of the sample with ‘oleId’ and ‘olevba’ indicates suspicious vectors.
data:image/s3,"s3://crabby-images/a4c53/a4c5336430548b57f72a46ab3319e59df3e18d53" alt="Figure 3- Oleid output"
data:image/s3,"s3://crabby-images/40b14/40b14de3e7b50afbec55aa0f3c4b821b26143105" alt="Figure 4- Olevba output"
The VBA macro is compatible with the x32 and x64 architectures and is extremely obscure as shown in Figure 5.
data:image/s3,"s3://crabby-images/557ed/557ede719405026a18186d4b539a1c51390ff3cb" alt="Figure 5- Obscure VBA macro"
To better understand the functionality, we have obscured the contents in the 2 statistics shown below.
data:image/s3,"s3://crabby-images/737d6/737d66500f1ec43cd3ee4748565151d7d2b77df1" alt="Figure 6- De-opaque VBA macro (Phase 1)"
data:image/s3,"s3://crabby-images/d52e1/d52e19e1cd435243374b41baa3203e4ecc6ae934" alt="Figure 7- D-Unspotted VBA Macro (Phase 2)"
An interesting feature of this template is that some strings such as CLSID, URL for downloading Ursnif and the name of the environment variable are stored in custom document properties as opposed to. As shown in Figure 7, the VBA function is used to restore the “ActiveDocument.CustomDocumentProperties ()” properties and uses “StrReverse” to reverse the content.
We can see the features of the document in Figure-8
data:image/s3,"s3://crabby-images/b8302/b8302038b8e81886ecee8c5dfc88301bf2f7d205" alt="Figure 8- Document Features"
Payload Download and Execution:
The macro macro retrieves the hidden shellcode from a custom property called “Company” using the “CDEC” function, which converts the shellcode from a string to a decimal / hex value and executes it. The shell code is shown below.
data:image/s3,"s3://crabby-images/18eff/18eff1b584aa0ea35f68d6566953779270e1e90b" alt="Figure 9- Raw company property"
The Shellcode Is Written Per Memories and Access protection Changes Page_EXECUTE_READWRITE.
data:image/s3,"s3://crabby-images/d6396/d63962b885288825ec27c809f6c6ac0afe36542e" alt="Figure 10 - Virtual Protect Code"
data:image/s3,"s3://crabby-images/f79a5/f79a545bc04b017fb3b59060102d316dddaa34a5" alt="Figure 11- Shellcode memory and security after calling VirtualProtect ()"
Later Add Shellcode in memory, The Environmental variables containing harmful URL of Ursnif The payload is made. This environment will be changeable Later used by Shellcode.
data:image/s3,"s3://crabby-images/aff2d/aff2d8c3bb6561fc79ec306abe9da118ac7170ad" alt="Figure 12- Environment variables are set in the Winword.exe space"
The shellcode is executed using the SetTimer API. SetTimer generates a timer with the specified time-out value specified and notifies a function as time passes. 4M The parameter used to make the SetTimer call is the pointer to the memory shellcode that will be used after the specified time has elapsed.
data:image/s3,"s3://crabby-images/65895/65895643add251d0b0dc65bc96d2fe47d8c5f53b" alt="Figure 13- SetTimer Function (Implementing Shellcode)"
Shellcode downloads the file from the URL stored in the environmental variable and saves it as “y9C4A.tmp.dll” and executes it using rundll32.exe.
URL | hxxp: //docmasterpassb.top/kdv/x7t1QUUADWPEIQyxM6DT3vtrornV4uJcP4GvD9vM/ |
CMD | rundll32 “C: \ Users \ user \ AppData \ Local \ Temp \ y9C4A.tmp.dll”, DllRegisterServer |
data:image/s3,"s3://crabby-images/26bf3/26bf3afe71c89c90702e398fcdd858903bad8ed2" alt="Figure 14- Download DLL Export"
After the shellcode is successfully executed, the environment variable is removed.
data:image/s3,"s3://crabby-images/9594b/9594bf68c5c112473cb552a4ace60585e42990fa" alt="Figure 15- Variable removal of environment"
IOC
Type | Price | Products | Identification name |
Key word document | 6cf97570d317b42ef8bfd4ee4df21d217d5f27b73ff236049d70c37c5337909f | McAfee Livesafe and Total Protection | X97M / Downloader.CJG |
dll has been downloaded | 41ae907a2bb73794bb2cff40b429e62305847a3e1a95f188b596f1cf925c4547 | McAfee Livesafe and Total Protection | Ursnif-FULJ |
URL to download dll | hxxp: //docmasterpassb.top/kdv/x7t1QUUADWPEIQyxM6DT3vtrornV4uJcP4GvD9vM/ | Web Advisor | Blocked |
MITER Attack Framework
Technic ID | Strategy | Description of technology | Description |
T1566.001 | Early access | Spear fishing attachment | Manual execution by user |
T1059.005 | The death penalty | Visual Basic | Harmful VBA macros |
T1218.011 | Defense evasion | Sign in Binary Abuse | Rundll32.exe is used |
T1027 | Defense evasion | Opacity strategy | VBA and PowerShell Base 64 Execution |
T1086 | The death penalty | PowerShell Execution | PowerShell command abuse |
Conclusion
Macros are disabled by default in Microsoft Office applications, we recommend keeping it that way unless the document is retrieved from a trusted source. The transition chain discussed in the blog is not limited to Word or Excel. Further threats could use other live-of-the-land tools to download its payloads.
McAfee customers are protected against malicious files and sites detailed in this blog with McAfee LiveSafe / Total Protection and McAfee Web Advisor.
The post-phishing campaign Ursnif appeared on the first McAfee blog featuring Trojan on the Rise.