Sunday, January 21, 2024

EXOCET - AV-evading, Undetectable, Payload Delivery Tool


EXOCET is superior to Metasploit's "Evasive Payloads" modules as EXOCET uses AES-256 in GCM Mode (Galois/Counter Mode). Metasploit's Evasion Payloads uses a easy to detect RC4 encryption. While RC4 can decrypt faster, AES-256 is much more difficult to ascertain the intent of the malware.



However, it is possible to use Metasploit to build a Evasive Payload, and then chain that with EXOCET. So EXOCET will decrypt via AES-256, and then the Metasploit Evasive Payload then decrypts itself from RC4.

Much like my previous project, DarkLordObama, this toolkit is designed to be a delivery/launch vehicle, much like Veil-Evasion does.

Dark Lord Obama Project

However, EXOCET is not limited to a single codebase or platforms that are running Python. EXOCET works on ALL supported platforms and architectures that Go supports.


Exocet Overview

EXOCET, is effectively a crypter-type malware dropper that can recycle easily detectable payloads like WannaCry, encrypt them using AES-GCM (Galois/Counter Mode), which is more secure than AES-CBC, and then create a dropper file for a majority of architectures and platforms out there.

Basically...

  1. It ingests dangerous malware that are now detectable by antivirus engines
  2. It then encrypts them and produces it's own Go file
  3. Then that Go file can be cross-compiled to 99% of known architectures
  4. Upon execution, the encrypted payload is written to the disk and immediately executed on the command line
  5. Alternatively, instead of a file-drop, it will execute the reconstitute shellcode in memory using amenzhinsky's go-memexec module github.com/amenzhinsky/go-memexec
  6. A custom shellcode executor is in the works, it takes ordinary C shellcode and after num-transform, it will run it by creating a new process after allocating the correct virtual address space and granting it RWX permissions on Windows

That means 32-bit, and 64-bit architectures, and it works on Linux, Windows, Macs, Unix, Android, iPhone, etc. You take, anything, and I mean ANYTHING, like the 1988 Morris Worm that nearly brought down the internet (which exploited a flaw in the fingerd listener daemon on UNIX), and make it a viable cyberweapon again.

EXOCET is designed to be used with the DSX Program, or the "Cyber Metal Gear" as I envisioned it. Being able to launch and proliferate dangerous malware without a traceable launch trail.

EXOCET is written entirely in Go.


How to use

EXOCET, regardless of which binary you use to run it, requires Golang to work. By default, it generates a crypter .go file.

  1. Windows users: Install Go Here
  2. Linux users: run sudo apt-get update && sudo apt-get install -y golang
  3. You must install the EXOCET source files in golang go get github.com/tanc7/EXOCET-AV-Evasion
  4. Sub-requirements will also be downloaded and installed
  5. For Windows and Mac x64 Users, pre-compiled binaries are in the /bin folder

To run it

go run EXOCET.go detectablemalware.exe outputmalware.go

A key is automatically generated for you. The key is 64-characters long and is entirely composed of bash and cmd.exe shell pipe redirectors to confuse and disrupt brute-forcing attempts against the key by causing unpredictable, destructive behavior on the forensic analyst's device.

For 64-bit Windows Targets...

env GOOS=windows GOARCH=amd64 go build -ldflags "-s -w" -o outputMalware.exe outputmalware.go

And out comes a outputmalware.exe file

For 64-bit MacOS Targets

env GOOS=darwin GOARCH=amd64 go build -ldflags "-s -w" -o outputMalware.macho outputmalware.go

For 64-bit Linux Targets

env GOOS=linux GOARCH=amd64 go build -ldflags "-s -w" -o outputMalware.elf outputmalware.go

See this reference on github for your parameters for other operating systems like Android Reference for Go Cross Compilation

Note that the key can still be found with the strings command, please use the upx-ucl command to pack binary to conceal the key.

Furthermore, there are prebuilt binaries that I have made, meaning you just have to run ./EXOCET or EXOCET-Windows.exe


Legal Information

I, Chang Tan, and the creators of the main module and submodules of Exocet and the packages it incorporates are NOT responsible for the misuse of this tool. This is merely a penetration testing tool. You are strictly prohibited from deploying Exocet output binaries against unauthorized protected systems or unauthorized protected government systems.

I am aware that threat actors of APT41 and the NSO Group have used and/or adopted code from this tool, particularly the go-memexec method. If I were to be approached by Federal Investigators regarding the misuse of this tool, I am not claiming responsibility.

This is the same stuff that happened to the developers of Mimikatz and PowerShell Empire (who deprecated their own development upon realization of its use among threat actors). The successors have picked up development of Empire, and there are free alternatives such as Covenant C2.


EXOCET live demo
<iframe width="560" height="315" src="https://github.com/tanc7/EXOCET-AV-Evasion/blob/master/media/exocetdemo.mp4" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
Reason for the name

On May 4th, 1982, during the Falklands War, a squadron of Argentinan Super Eterdards launched a French made Exocet missile at the HMS Sheffield. Despite the Royal Navy's attempts to stop the missile, one struck, sinking the Sheffield. That incident literally put Argentina on the map as a show of force against a global colonial power.

News Article of the sinking of the HMS Sheffield

Very much like how Onel de Guzman's actions with the ILOVEYOU virus put the Philippines on the map as a cyber threat.

ILOVEYOU Virus on Wikipedia


Incoming update, notes and ambitions


 

So this month, and the next month is going to be a busy month for me, and there will be delays in implementing these methods. But I am excited to get started on implementing new AV evasion techniques such as...

  1. Inline hooking
  2. Obfuscation by emulating BlackRota and the gobfuscate module
  3. Process hollowing
  4. Reflective DLL injection
  5. Remote process injection
  6. ThreadLocalStorage Callbacks
  7. Registration of Top-Level Exception Handlers
  8. Custom UPX packing

I am a very busy man, I have the following priorities and I would like to request some help, some pull requests to aid in the project. Since I have the following things to do

  1. A court appearance in late October
  2. National Cyber League
  3. Accounting and Finance Classes, Computer Science was NEVER my college major and in the following weeks I will have exams back-to-back
  4. Federal Supervised Release Conditions and the FBI trying to implicate me in new unproven crimes. I have dash camera videos I uploaded to the cloud to prove it that I am sending to my lawyers. I have documented multiple attacks against me, vandalism of my car, my house, filed police reports and counter reports and will be building my case to file a Federal lawsuit. One of the perpetrators, who ripped out my front bumper of my car, has been arrested.
  5. A private project involving interaction with the CoinGeckoAPI
  6. Running the cryptoscopeinitiative.org, a to-be-filed 501c3 Non-Profit Organization
  7. Teaching three online classes on Exploit Development

Upcoming update! Direct encrypted shellcode execution! (Implemented in test versions, not released yet)

I need a bit of help, because I successfully implemented CGO to execute encrypted shellcode but it is throwing memory access violations exit status 0xc0000005. It shouldn't be anything related to DEP (Data Execution Prevention) because the file CGOTest/working-template-shellcode-executor.go did run.

Problem Discovered

As it turns out, VirtualAlloc must be called from kernel32.dll and ntdll.dll to properly make the memory page where the shellcode lands, readable, writable, and executable, in other word, set the PAGE_EXECUTE_READWRITE to ON. Read the Note on Memory Access Violation Problem below.


Once I figure this out, CGO was a pain in the ass to implement, we can now create crypters that execute INLINE-ASSEMBLY. Which was considered a impossibility until now.

Note this requires Golang and the MinGW toolchain to be installed on Windows with you running and generating the shellcode on Windows. The reason why, is because CGO cannot be cross-compiled like our other EXOCET modules. To install the toolchain you need to go to https://www.msys2.org/ and follow the guide. Then you must add gcc to your environment variables in Windows

Step 1: Generate shellcode, this could be from msfvenom Meterpreter payloads, Cobalt Strike Beacons, or your own custom shellcode in C compatible format


Step 2: Copy only the bytes of the shellcode, excluding the quotes into a text file like sc.txt


Step 3: Your shellcode file should look like this. Raw shellcode


Step 4: Now run the command go run exocet-shellcode-exec.go sc.txt shellcodetest.go KEY

Step 5: You can attempt to run it but you'll run into memory access violation errors for some reason, which I am still working on


Note on Memory Access Violation Problem

Apparently, aside from the major limitations of CGO that prohibit or dramatically frustrates cross-compilation, the issue is that the shellcode we want to execute is landing in a section of memory (analyzed in WinDBG x64) that is not RWX. In other words, unless we write C code that explicitly allows execution in memory of the shellcode, it will always throw access violation errors.

The other method, that I observed other developers of rudimentary Go modules https://gist.github.com/mgeeky/bb0fd5652b234fbd1c7630d7e5c8542d, is that they use Go's Windows API to interact with ntdll.dll and kernel32.dll to call VirtualAlloc and specify areas of RWX memory pages. This method works better, but it seems that the shellcode must be in num-transformed format only for it to work.

I am still working on this you guys. I may combine multiple programming languages together to write a proper shellcode execution module


Note on Apple M1 Chips for precompiled binaries

Unfortunately I am running into errors for making a pre-compiled binary for MacBooks running the new M1 CPUs. It may be a issue with my Golang installation

â"Ή"€Ã¢"€(rootðŸ'€kali)-[/opt/EXOCET-AV-Evasion]
â""â"€# GOOS=darwin GOARCH=arm64 go build exocet.go
# command-line-arguments
/usr/lib/go-1.15/pkg/tool/linux_amd64/link: running gcc failed: exit status 1
/tmp/go-link-477718799/go.o: file not recognized: file format not recognized
collect2: error: ld returned 1 exit status

Either way, you still require Golang to compile or cross-compile the malware to the platform you are targeting.



Related links


  1. Hacker
  2. Hacking Tools For Pc
  3. Hacker Tools Windows
  4. Pentest Tools For Mac
  5. Hacker Tools Github
  6. Hacker Tools Apk Download
  7. Hacker Tools 2020
  8. Pentest Automation Tools
  9. Hacking Tools Windows 10
  10. Hack Tools Pc
  11. Hacking Tools 2019
  12. Hak5 Tools
  13. Pentest Box Tools Download
  14. Kik Hack Tools
  15. New Hack Tools
  16. Pentest Tools Kali Linux
  17. Hacking Tools For Kali Linux
  18. Hacker Tools Linux
  19. Best Hacking Tools 2019
  20. What Is Hacking Tools
  21. Best Hacking Tools 2020
  22. Nsa Hacker Tools
  23. Nsa Hack Tools Download
  24. What Are Hacking Tools
  25. Usb Pentest Tools
  26. Tools 4 Hack
  27. Pentest Tools Nmap
  28. Hacker Tools For Ios
  29. Pentest Box Tools Download
  30. Pentest Box Tools Download
  31. Pentest Tools Download
  32. Pentest Tools For Ubuntu
  33. Hacking Tools For Windows
  34. Hacking Tools Hardware
  35. Hacking Tools Mac
  36. Pentest Tools Url Fuzzer
  37. Hacker Tools 2020
  38. Hackrf Tools
  39. Hacking Tools Mac
  40. Hack Tools
  41. Hacker Hardware Tools
  42. Pentest Tools For Android
  43. Pentest Tools Android
  44. Android Hack Tools Github
  45. Hacker Tools Github
  46. Hacker Tools 2019
  47. Hackrf Tools
  48. Hacking Tools For Pc
  49. Underground Hacker Sites
  50. Hack Tool Apk
  51. Hack Tools Online
  52. Hacker Tools Github
  53. Hacking Tools
  54. Hackers Toolbox
  55. Pentest Tools Website
  56. Physical Pentest Tools
  57. Hack Tools For Windows
  58. Tools 4 Hack
  59. Hack And Tools
  60. Best Hacking Tools 2020
  61. Hacking Tools For Beginners
  62. Pentest Tools Subdomain
  63. Hacker Tools Linux
  64. Hacking Tools For Kali Linux
  65. Hacker Tools For Mac
  66. Hack Tools Github
  67. Pentest Reporting Tools
  68. Hacking Tools Mac
  69. Best Hacking Tools 2019
  70. Hacking Tools For Windows Free Download
  71. Hacker Search Tools
  72. Pentest Tools Website
  73. Hacking Tools For Kali Linux
  74. Pentest Tools Review
  75. New Hacker Tools
  76. Black Hat Hacker Tools
  77. What Is Hacking Tools
  78. How To Make Hacking Tools
  79. Blackhat Hacker Tools
  80. Hackrf Tools
  81. How To Make Hacking Tools
  82. Hacking Tools For Kali Linux
  83. Tools 4 Hack
  84. Hacking Tools Hardware
  85. Best Hacking Tools 2020
  86. Hacker Tool Kit
  87. Hacker Tools Free
  88. Pentest Tools Website
  89. Hacking Tools For Pc
  90. Hacker Tools Linux
  91. Ethical Hacker Tools
  92. Pentest Tools For Windows
  93. Hack Tools
  94. Hak5 Tools
  95. Hacking Tools Download
  96. Termux Hacking Tools 2019
  97. Android Hack Tools Github
  98. Hacker Techniques Tools And Incident Handling
  99. Hacking Tools Github
  100. Hackrf Tools
  101. How To Make Hacking Tools
  102. Hacker Techniques Tools And Incident Handling
  103. Pentest Tools Github
  104. Growth Hacker Tools
  105. Hacker Tools Linux
  106. Hacker Tools Github
  107. Hack Tool Apk No Root
  108. Hacker Tools Github
  109. Hack App
  110. Hacking Tools Download
  111. Growth Hacker Tools
  112. Hacking Tools For Windows Free Download
  113. Hacking Tools Windows 10
  114. Hack Tools Github
  115. Hacker Tools
  116. Hackers Toolbox
  117. Hack Tools Download
  118. Hacker Tools Online
  119. Pentest Tools Framework
  120. How To Hack
  121. Hacking Tools For Games
  122. Pentest Tools For Ubuntu
  123. Pentest Tools Url Fuzzer
  124. Pentest Tools Find Subdomains
  125. Nsa Hack Tools
  126. Underground Hacker Sites
  127. Pentest Tools Website
  128. Tools For Hacker
  129. Termux Hacking Tools 2019
  130. Blackhat Hacker Tools
  131. Hacking Tools Pc
  132. Hacker Tools Hardware
  133. Hack Tools For Ubuntu
  134. Tools 4 Hack
  135. Hacking Tools For Beginners
  136. Pentest Reporting Tools
  137. Hacker Tools Software
  138. Hack Tool Apk
  139. Pentest Tools For Ubuntu
  140. Easy Hack Tools
  141. Hacker Tools Github
  142. Hacks And Tools
  143. Pentest Tools For Mac
  144. Tools Used For Hacking
  145. Pentest Tools Review
  146. Hacker Tools Free
  147. Pentest Tools Website
  148. Hacker Security Tools
  149. World No 1 Hacker Software
  150. Hack Tools For Windows
  151. Hacking Tools And Software
  152. Tools Used For Hacking
  153. Hacking Tools Windows
  154. Hack Rom Tools
  155. Hacker Tools Online
  156. Pentest Tools Port Scanner
  157. Pentest Tools Subdomain
  158. Pentest Tools Apk
  159. Hacker Tools For Ios
  160. Hacking Tools Usb
  161. How To Hack
  162. Hacking Tools For Windows
  163. Nsa Hacker Tools
  164. Kik Hack Tools
  165. New Hacker Tools
  166. Kik Hack Tools
  167. Hackers Toolbox
  168. How To Install Pentest Tools In Ubuntu
  169. What Are Hacking Tools
  170. Pentest Tools Find Subdomains
  171. Pentest Tools Port Scanner
  172. Hacker Techniques Tools And Incident Handling
  173. Pentest Tools Android
  174. Hacking Tools Usb
  175. Hacking Tools For Beginners
  176. Hacks And Tools
  177. Hack Apps

No comments:

Post a Comment