Zscaler Blog

Get the latest Zscaler blog updates in your inbox

Subscribe
Security Research

No Honor Among Thieves - Prynt Stealer’s Backdoor Exposed

ATINDERPAL SINGH, BRETT STONE-GROSS
September 01, 2022 - 12 min read

Stealing information is fundamental to cybercriminals today to scope and gain access to systems, profile organizations, and execute bigger payday schemes like ransomware. Information stealer malware families including Prynt Stealer are often configured through a builder to facilitate the process for less sophisticated threat actors. However, Zscaler ThreatLabz researchers have uncovered the Prynt Stealer builder, also attributed with WorldWind, and DarkEye, has a secret backdoor in the code that ends up in every derivative copy and variant of these malware families. The backdoor sends copies of victims' exfiltrated data gathered by other threat actors to a private Telegram chat monitored by the builder’s developers. While this untrustworthy behavior is nothing new in the world of cybercrime, the victims' data end up in the hands of multiple threat actors, increasing the risks of one or more large scale attacks to follow.
 

Key Points

  • Prynt Stealer is an information stealer that has the ability to capture credentials that are stored on a compromised system including web browsers, VPN/FTP clients, as well as messaging and gaming applications
  • The Prynt Stealer developer based the malware code on open source projects including AsyncRAT and StormKitty
  • Prynt Stealer uses Telegram to exfiltrate data that is stolen from victims
  • The Prynt Stealer malware author added a backdoor Telegram channel to collect the information stolen by other criminals
  • The informational stealer malware families known as DarkEye and WorldWind are near identical to Prynt Stealer

Prynt Stealer is a relatively new information stealer malware family that is written in .NET. The malware has previously been analyzed in-depth including the data harvesting capabilities and the targeted applications. Zscaler ThreatLabz has since uncovered additional details about the malware including the codebase being derived from at least two other open source malware families: AsyncRAT and StormKitty. This blog will focus on these shared codebases, the modifications introduced by the Prynt Stealer author (including a backdoor), and the very close relationship with WorldWind and DarkEye.

 

Prynt Stealer Origins

Prynt Stealer is not just inspired from open source malware families, but shares code that appears to have been directly copy and pasted from these repositories. Many parts of the Prynt Stealer code that have been borrowed from other malware families are not used, but are still present in the binary as dead unreachable code. The Prynt Stealer code is primarily derived from AsyncRAT (a versatile RAT) and StormKitty (an information stealer). The AsyncRAT code is used as the main module with a modified entry point that calls the StormKitty stealer method. Prynt Stealer executables are configured using a builder that has no options to modify the embedded AsyncRAT components, which are pre-configured primarily just to run the StormKitty stealer module. Most of AsyncRAT’s functionality in Prynt Stealer is disabled and the command-and-control (C&C) URLs are configured to 127.0.0.1. While the AsyncRAT’s network component of Prynt Stealer is disabled, the malware contains the following embedded certificate shown below:

         "issuer": "CN=WorldWind Stealer",
         "subject": "CN=WorldWind Stealer",
         "to_date": "9999-12-31T23:59:59",
         "version": "v3",
         "from_date": "2021-07-13T04:51:06",
         "serial_number": 852016614067188563094399707801818649

Note that the common name for this certificate is WorldWind Stealer, which is also sold by the Prynt Stealer malware author.

 

AsyncRAT/StormKitty Code Comparison

The Prynt Stealer author added two new fields (highlighted in Figure 1) to the AsyncRAT configuration codebase for data exfiltration via Telegram.

Prynt Stealer configuration vs AsyncRAT configuration

Figure 1: Side-by-side comparison of a Prynt Stealer configuration (left) with an original AsyncRAT configuration (right)

The main code responsible for sending information to Telegram is copied from StormKitty with a few minor changes in text as shown in Figure 2.

Side-by-side comparison of Prynt Stealer’s UploadFile with StormKitty’s SendSystemInfo function

Figure 2: Side-by-side comparison of Prynt Stealer’s UploadFile with StormKitty’s SendSystemInfo function

The main difference is the field names and order have changed, and a field related to detecting porn websites is missing from Prynt.

 

A Detailed look at Prynt Stealer Modifications

Anti-Detection Techniques

Prynt Stealer does not use the anti-analysis code from either AsyncRAT or StormKitty with one exception: the malware creates a thread that invokes the function named processChecker (shown in Figure 3) in AsyncRAT’s static constructor. The thread execution is started at the end of the main function after stolen logs are sent.

Prynt Stealer process checker thread

Figure 3: Prynt Stealer process checker thread's code

Prynt Stealer uses this thread to continuously monitor the victim’s process list. If any of the following processes are detected, the malware will block the Telegram C&C communication channels:

  • taskmgr
  • processhacker
  • netstat
  • netmon
  • tcpview
  • wireshark
  • filemon
  • regmon
  • cain

Telegram Command Thread

Prynt Stealer creates a thread that will poll for a file to download using the Telegram getUpdates API as shown in Figure 4. Of note, this download command only saves the file on the target system and does not take any further actions that might be expected like executing a second-stage payload or updating the malware.

Prynt Stealer Telegram download command

Figure 4: Prynt Stealer Telegram download command

 

Crowdsourcing Stolen Logs

Prynt Stealer steals data from a wide array of applications, and the information is sent to a Telegram channel that is configured using the builder shown in Figure 5.

Prynt Stealer builder

Figure 5: Prynt Stealer builder

The Prynt Stealer logs are sent to the operator’s Telegram. However, there is a catch: a copy of the log files is also sent to a Telegram chat presumably embedded by the Prynt Stealer author as shown below in Figure 6. 

Prynt Stealer backdoor sending log files to two different Telegram chats

Figure 6: Prynt Stealer backdoor sending log files to two different Telegram chats

ThreatLabz has observed similar tactics employed by malware authors in the past as well, where the malware has been given away for free. This enables a malware author to benefit from unsuspecting cybercriminal clients who perform the heavy lifting of infecting victims. The fact that all Prynt Stealer samples encountered by ThreatLabz had the same embedded telegram channel implies that this backdoor channel was deliberately planted by the author. Interestingly, the Prynt Stealer author is not only charging some clients for the malware, but also receiving all of the data that is stolen. Note that there are cracked/leaked copies of Prynt Stealer with the same backdoor, which in turn will benefit the malware author even without direct compensation.

 

Prynt Stealer / WorldWind / DarkEye: Multiple Faces of the Same Malware

ThreatLabz has identified at least two more Prynt Stealer variants dubbed WorldWind and DarkEye that appear to be written by the same author. All three strains are nearly identical with a few minor differences. Prynt Stealer is the most popular brand name for selling the malware, while WorldWind payloads are the most commonly observed in-the-wild. DarkEye is not sold or mentioned publicly, however, it is bundled as a backdoor with a “free” Prynt Stealer builder. Figure 7 shows a pie chart of the percentage of samples by name observed by ThreatLabz over the last year.

Distribution of Prynt Stealer, WorldWind and DarkEye payloads in-the-wild over the last year

Figure 7: Distribution of Prynt Stealer, WorldWind and DarkEye payloads in-the-wild over the last year

Both Prynt and WorldWind have been sold by the same author on the following websites:

 

Market Website

Malware name

Status

http://shop.prynt[.]market

WorldWind

Inactive

http://market.prynt[.]market

Prynt Stealer

Inactive
http://venoxxxx[.]xxxPrynt StealerActive


Screenshots of these websites (offline at the time of publication) are shown in Figure 8.

market.prynt[.]market selling Prynt Stealer and shop.prynt[.]market selling WorldWind side-by-side

Figure 8: market.prynt[.]market selling Prynt Stealer and shop.prynt[.]market selling WorldWind side-by-side

Various websites and criminal forums have offered cracked versions of Prynt Stealer and the code has been uploaded on GitHub for free under different names. Prynt (with the same Telegram backdoor) has also been offered for free on Telegram channels used by cybercriminals as shown in Figure 9. 

PryntStealer offered for free on a cybercriminal Telegram channel

Figure 9: Prynt Stealer offered for free on a cybercriminal Telegram channel

The distributed builder is backdoored with DarkEye Stealer and Loda RAT. This may be a deliberate leak by the Prynt Stealer threat actor since they will benefit from the data stolen from victims. 

 

Feature/Code Comparison

Table 1 shows a feature parity between Prynt, WorldWind and DarkEye. Overall, there are few very minor differences such as the text in the log report, code and settings placement. However, functionality-wise all three are almost identical.

 


 

Prynt

WorldWind

DarkEye

AsyncRAT

Present (Not Used)

Present (Not Used)

Used

Clipper

Present (Not Used)

Present (Not Used)

Used

Keylogger

Present (Not Used)

Present (Not Used)

Used

ProcessChecker Anti-Analysis

Used

Not Present

Not Present

StomKitty Stealing 

Used

Used

Used

HideConsoleWindow

Used

Not Present

Not Present

Elevate privileges by running as admin

Used

Not Present

Not Present

Copy itself to a specified path

Used

Not Present

Not Present

Persist using task creation (e.g., “Chrome Update”)

Used

Not Present

Not Present

Self delete using a .bat file

Used

Not Present

Not Present

Check for an Internet connection

Used

Not Present

Not Present

Protect the process using RtlSetProcessIsCritical

Used

Not Present

Not Present

Prevent sleep by setting SetThreadExecutionState to 0x80000003 (ES_CONTINUOUS | ES_DISPLAY_REQUIRED | ES_SYSTEM_REQUIRED)

Used

Not Present

Not Present

Table 1. Some notable similarities and differences in functionality between Prynt Stealer, WorldWind and DarkEye

 

Table 2 compares the field names between StormKitty, Prynt Stealer, WorldWind and DarkEye.

 

StormKitty

Prynt

WorldWind

DarkEye

😹 *StormKitty - Report:*

\ud83d\udc63 *Prynt Stealer New Results:*

\ud83c\udf2a *WorldWind Pro - Results:*

\ud83d\ude39 *DARK-EYE - Report:*

🏦 *Banking services*

\ud83c\udfe6 *Banks*

\ud83c\udfe6 *Bank Logs*

\ud83c\udfe6 *Banking services*

💰 *Cryptocurrency services*

\ud83d\udcb0 *Crypto*

\ud83d\udcb0 *Crypto Logs*

\ud83d\udcb0 *Cryptocurrency services*

🍓 *Porn websites*

N/A

\ud83c\udf53 *Freaky Logs*

\ud83c\udf53 *Porn websites*

🌐 *Browsers:*

\ud83d\udcb5 *Stealer Data:*

\ud83c\udf10 *Logs:*

\ud83c\udf10 *Browsers:*

🗃 *Software:*

\ud83d\udc63 *Installed Software:*

\ud83d\uddc3 *Software:*

\ud83d\uddc3 *Software:*

🧭 *Device:*

\ud83d\udc63 *Local Device:*

\ud83e\udded *Device:*

\ud83e\udded *Device:*

📄 *File Grabber:*

\ud83d\udc63 *Files:*

\ud83d\udcc4 *File Grabber:*

\ud83d\udcc4 *File Grabber:*

N/A

\ud83d\udc63 Solen Useing Prynt Stealer\n\n  \ud83d\udc63 Developed By @FlatLineStealerUpdated\n\n  \ud83d\udc63 Or Join The Channel @pryntdotmarket

Telegram Channel: @x0splinter

N/A

Table 2. Comparison of field names between StormKitty, Prynt Stealer, WorldWind and DarkEye

 

Leaked Prynt Stealer Builder

Threatlabz has acquired a copy of the Prynt Stealer builder that is backdoored with DarkEye being circulated in-the-wild. Figure 10 illustrates the “free” Prynt Stealer builder’s backdoor execution process.

Prynt Stealer builder backdoor execution and infection flow

Figure 10: Prynt Stealer builder backdoor execution and infection flow

The Prynt Stealer builder package includes the following files:

  • Stub.exe - Prynt stub used by the builder
  • Prynt Stealer.exe - Builder executable
  • Prynt Stealer sub.exe - Unmanaged PE
  • Prynt.exe - Backdoor that downloads and executes DarkEye Stealer

 

Stub.exe - The Prynt Stealer Stub

This is the actual Prynt Stealer stub that is used by the builder to build payloads based on the configuration. The stub simply enumerates the resources in the file Prynt Stealer sub.exe and performs actions based on the settings in the RCData resource section, as shown in Figure 11.

Celesity Binder resource enumeration method

Figure 11. Celesity Binder resource enumeration method

The Prynt Stealer sub.exe is generated using Celesty Binder as indicated by the presence of the string C:\Users\DarkCoderSc\Desktop\Celesty Binder\Stub\STATIC\Stub.pdb. This binary stores embedded payloads under the “RBIND” resource in plaintext. This sample was configured to drop and execute the payloads in the %TEMP% folder as shown in Figure 12.

Celesity Binder stub settings in resources

Figure 12. Celesity Binder stub settings in resources

Other valid options for the “DROPIN” value include the following:

  • %APPDATA%
  • %PROGFILES%
  • %DEFDRIVE%
  • %STARTUPDIR%
  • %LAPPDATA%
  • %USERDIR%

The Prynt Stealer builder stub contains two payloads:

  • “PRYNT STEALER.EXE” - The builder binary explained below
  • “SVCHOST.EXE” - LodaRAT backdoor

 

Prynt Stealer.exe - The Builder

The Prynt Stealer builder is a modified version of the AsyncRAT builder with modified forms to change the UI and an additional line was added in the main method to run the loader mentioned above from {Builder Path}/Stub/Prynt.exe.

 

Prynt.exe - The Loader 

This is a very basic loader written in .NET, which simply downloads the payload from a hardcoded URL and runs the payload as shown in Figure 13.

Loader obfuscated vs deobfuscated

Figure 13. Loader obfuscated vs deobfuscated

The downloaded payload is DarkEye Stealer, a variant of Prynt Stealer. Based on a hardcoded Telegram token shared by DarkEye, Prynt and WorldWind stealer, they are all likely from the same author(s). 

 

DarkEye Stealer

This malware is essentially Prynt Stealer with some minor differences in code placement. Most settings related to the clipper, keylogger, etc are moved under the AsyncRAT constructor as shown in Figure 14.

Example AsyncRAT settings configured by DarkEye Stealer

Figure 14. Example AsyncRAT settings configured by DarkEye Stealer

The main factor differentiating DarkEye from Prynt and Worldwind is that the AsyncRAT part of the code is weaponized by configuring the related settings. Note that there were some earlier versions of DarkEye stealer in-the-wild without the AsyncRAT components. 

 

Loda RAT 

Loda RAT is an Autoit based RAT first documented in 2017 that has been active since and has evolved over the years. This is a fairly capable malware that can steal a variety of information, remotely control an infected system and deploy additional payloads.

 

Conclusion

The free availability of source code for numerous malware families has made development easier than ever for less sophisticated threat actors. As a result, there have been many new malware families created over the years that are based on popular open source malware projects like NjRat, AsyncRAT and QuasarRAT. The Prynt Stealer author went a step further and added a backdoor to steal from their customers by hardcoding a Telegram token and chat ID into the malware. This tactic is not new by any means; there have been several similar instances, including CobianRAT. As the saying goes, there is no honor among thieves.

 

Cloud Sandbox Detection

 Zscaler Cloud Sandbox Report

Figure 15: Zscaler Cloud Sandbox Report

In addition to sandbox detections, Zscaler’s multilayered cloud security platform detects indicators related to the campaign at various levels with the following threat names:

Win32.Backdoor.PryntStealer

Win32.Backdoor.WorldWind

Win32.Backdoor.DarkEyeStealer

Win32.Backdoor.LodaRat

 

Indicators of Compromise (IOCs)

Prynt Stealer IOCs are available in our GitHub repository.

 

SHA256

Malware

d8469e32afc3499a04f9bcb0ca34fde63140c3b872c41e898f4e31f2a7c1f61f

Prynt Stealer

f15e92c34dd8adfcd471d726e88292d6698217f05f1d2bcce8193eb2536f817c

Prynt Stealer

3b948a0eb0e9bbca72fc363b63ffd3a5983e23c47f14f8296e8559fd98c25094

WorldWind Stealer

bb96db7406566ec0e9305acde9205763d4e9d7a65f257f3d5c47c15f393628ec

DarkEye Stealer

e48179c4629b5ab9e53ccb785ab3ee5eeb2e246e1897154a15fec8fd9237f44b

DarkEye Stealer (old version without AsyncRAT)

9678ca06068b705da310aa2f76713d2d59905b12b67097364160857cd1f90c58

Celesty Binder payload

654f080d5790054f0cd1a0f9b31cd7a82a4722ff3ce5093acdc31ff154f1ae24

Builder

cb132691793e93ad8065f857b4b1baba92e937cfc3d3a8042ce9109e12d32b4c

LodaRAT

d37d0ae4c5ced373fe1960af5ea494a6131717d1c400da877d9daa13f55439bb

Prynt Stealer Stub

c79aed9551260daf74a2af2ec5b239332f3b89764ede670106389c3078e74d1a

Loader

 

Telegram Token

Chat ID

Comment

1119746739:AAGMhvpUjXI4CzIfizRC--VXilxnkJlhaf8

1096425866

WorldWind (hardcoded)

1784055443:AAG-bXLYtnFpjJ_L3ogxA3bq6Mx09cqh8ug

1937717367

Prynt Stealer (hardcoded)

5292408150:AAHAPbTr2Jc9L4hgsfkDkvfw_hISg6lPMMI

5038570348

Prynt Stealer

5292408150:AAHAPbTr2Jc9L4hgsfkDkvfw_hISg6lPMMI

1856525476

Prynt Stealer

1916193181:AAHhdcx3k6mHbnJ6JLfyWtJBMChny-la8Xs

849561191

Prynt Stealer

 

URL

Description

https://cdn.discordapp[.]com/attachments/523238636561629190/890007970207907871/vltn.exe 

DarkEye Stealer Hosting

bigdaddy-service[.]biz:6606

DarkEye Stealer C&C 

bigdaddy-service[.]biz:7707

DarkEye Stealer C&C 

bigdaddy-service[.]biz:8808

DarkEye Stealer C&C 

daddy.linkpc[.]net:1199

LodaRAT C&C

 

 

form submtited
Thank you for reading

Was this post useful?

Get the latest Zscaler blog updates in your inbox

By submitting the form, you are agreeing to our privacy policy.