In the course of our routine investigation, we discovered a DLL file, identified as hrserv.dll, which is a previously unknown web shell exhibiting sophisticated features such as custom encoding methods for client communication and in-memory execution. Our analysis of the sample led to the discovery of related variants compiled in 2021, indicating a potential correlation between these separate occurrences of malicious activity.
According to our telemetry data, the PAExec.exe process initiates the creation of a scheduled task on the system named MicrosoftsUpdate (sic), which in turn is designed to execute a .BAT file.
"schtasks" /create /sc DAILY /tn MicrosoftsUpdate /tr "$system32\cmd.exe /c $public\JKNLA.bat $public\hrserv.dll" /ru system /f |
The .BAT file accepts the path of a DLL file as an argument. In this instance, the script is provided with the file $public\hrserv.dll, which is then copied to the System32 directory. After this operation, the script configures a service via the system registry and the sc utility. It then activates the newly created service.
MD5 | 418657bf50ee32acc633b95bac4943c6 |
SHA1 | cb257e00a1082fc79debf9d1cb469bd250d8e026 |
SHA256 | 8043e6c6b5e9e316950ddb7060883de119e54f226ab7a320b743be99b9c10ec5 |
Link time | 2023-Aug-30 08:28:15 |
File type | PE32+ executable (DLL) (console) x86-64, for MS Windows |
Compiler | Microsoft Visual C/C++(2015 v.14.0) |
The sequence of operations starts with the registration of a service handler. HrServ then initiates an HTTP server utilizing the HTTP server API for its functionality. It calls the HttpAddUrlToGroup function to register the following URL so that matching requests are routed to the request queue.
http://+:80/FC4B97EB-2965-4A3B-8BAD-B8172DE25520/ |
Client-server communication uses custom encoding techniques that include Base64 encoding and FNV1A64 hashing algorithms.
Based on the type and information within an HTTP request, specific functions are activated. These functions are distinguished by the GET parameter named cp. In addition, the DLL file utilizes the value of the NID cookie for various purposes. The use of the GET parameter pattern and the cookie value is consistent with practices employed by Google. We suspect that this intentional similarity in naming conventions is intended to disguise these requests in network traffic, making it more challenging to detect such malicious activity.
An example of such a request would be:
&cp=1&client=desktop-gws-wiz-on-focus-serp&xssi=t&hl=en-TW&authuser=0&pq= |
Request type | cp value | Description |
GET | 0 | Call VirtualAlloc and copy a custom decoded NID cookie value, then create a new thread. |
POST | 1 | Create a file using the custom decoded NID cookie value and write the custom decoded POST data to that file. |
GET | 2 | Read a file using the custom decoded NID cookie value and return it as a response by appending it to the end of the “data:image/png;base64” string; If an error occurs while reading the file, HrServ responds with the string: data:image/png;base64,c3Dlc+DheRzlKBV2Yh92KS//; |
GET | 4 | Return Outlook Web App HTML data. |
POST | 6 | Call VirtualAlloc and copy the custom decoded POST data, then create a new thread. |
GET | 7 | Return Outlook Web App HTML data [Duplicate]. |
If the cp value in the request is 6, this indicates a code execution process.
In a particular observed scenario, the cp value is unknown. A multifunctional implant is activated in the system memory. The implant creates a file in the directory “%temp%”, retrieves information from the registry, performs some actions based on this information, and records the output of these actions in the created file. As a result, the registry and the temporary file are used as a communication channel between the implant and HrServ.
Based on our telemetry data, after successfully establishing a foothold and placing the memory implant in the system memory, the next actions are to erase the previously existing traces by deleting the scheduled “MicrosoftsUpdate” job and both the initial DLL and batch files:
schtasks /delete /tn MicrosoftsUpdate /f cmd /c "del /f/s/q $public\hrserv.dll & del /f/s/q $public\JKNLA.bat" |
We have also discovered earlier, differently named variants of HrServ. These DLL files date back to early 2021. They also use the custom encoding algorithm and behave the same way after a file read error. However, there are subtle differences.
https://+:443/owa/MSExchangeService.svc |
The only known victim according to our telemetry is a government entity in Afghanistan.
The TTPs analyzed in this investigation are not associated with any known threat actors we are tracking, but there are a few things that we observed:
&cp=1&client=desktop-gws-wiz-on-focus-serp&xssi=t&hl=en-TW&authuser=0&pq= |
The analyzed sample represents a capable web shell. Based on the compile timestamps, its origins date back to at least 2021. This sophisticated malware variant exhibits the ability to initiate in-memory executions. In the observed scenario, communication is established through registry manipulations and temporary files.
Notably, the web shell and memory implant use different strings for specific conditions. In addition, the memory implant features a meticulously crafted help message. Considering these factors, the malware’s characteristics are more consistent with financially motivated malicious activity. However, its operational methodology exhibits similarities with APT behavior. Despite the malware’s prolonged activity over several years, multiple instances involving these samples have not been documented. Our efforts are ongoing as we continue to monitor related activity, with the goal of unraveling the mystery in future investigations.
b9b7f16ed28140c5fcfab026078f4e2e
418657bf50ee32acc633b95bac4943c6
d0fe27865ab271963e27973e81b77bae
890fe3f9c7009c23329f9a284ec2a61b