Skip to content

Latest commit

 

History

History
61 lines (44 loc) · 3.78 KB

README.md

File metadata and controls

61 lines (44 loc) · 3.78 KB

Danghui-LVM

Danghui is a Roblox CLVM that uses a relatively brand new script execution method to execute arbitrary code on Roblox's own main lua_State. Since 2017, this project has been depreciated.

The CLVM's objective is to achieve script execution through a custom virtual machine that operates on a foreign, untranslated and incompatable lua state. It copies the Lua C functions from Roblox to a seperate DLL, and does everything WITHOUT BYPASSING ANY MAJOR CHECKS. (memcheck, retcheck, hookcheck, etc). This is an amazing solution to executing code compared to proto conversion/bytecode conversion, as it rarely touches anything in Roblox's memory, and rarely calls any Roblox functions externally, while outsourcing all of the execution work to the local lua_state.

The CLVM achieves all of the above by only compiling all of the lua code on it's own external lua state. The operations are then saved, wrapped into Roblox's implementation of every opcode, and executed in order. Addressed below in the "Issues" row, a few opcodes cannot follow this procedure due to their own complications, they must be manually mapped. The code execution mainly happens in the simplified code below. The instructions are recieved, and for each instruction, an action is assigned and executed, then the cycle repeats for each instruction following until the script has been completed.

Instruction *i = f->code; 
for (;;)
 i++;
 switch (get_opcode(*i))
 case OP_SETGLOBAL:
  // execute Roblox's modified OP_SETGLOBAL
 case OP_ADD:
  // execute Roblox's modified OP_ADD
 case OP_CALL:
  // execute Roblox's modified OP_CALL

Thank you: 3dsboy, sloppey, Austin, Slappy, Autumn, Jordan (RC7)

  • Able to index every class
  • Able to set any property
  • Calling all Roblox functions
  • Roblox API functions all work, including require, RbxUtility, and LoadLibrary, with no manual modifications!
  • Accessing all Roblox global tables
  • Context level 7, acecess to CoreGUI, ScriptContext, etc.
  • YieldFunction's have native support, isn't that just great?
  • NO YIELDING, NO HTTP/LOADSTRING SUPPORT.

Danghui is the newer backend of the exploit Abstract, ever since it has switched from an extremely incompetent script execution method classified by the community as "Bytecode Execution". The previous method, created through an illegal copy of Roblox's source code, was impossible to maintain by nature. The bytecode execution backend version of Abstract was released for free and NEVER sold.

Here's the last working version of Danghui if anyone still cares, along with a review NateVang has made about my exploit.

https://www.youtube.com/watch?v=AF80kcpa2AM&ab_channel=AzulScript

https://www.youtube.com/watch?v=nevULP0USlM

Issues:

  • Lua functions like lua_resume and lua_yield will not work as expected, as the VM is tasked with handling the yield. Since we execute code locally on the CLVM, yields act differently.
  • Checks such as the simple "hackflag" check in lua C functions need to be bypassed manually, then quickly reverted in a short period of time in order to prevent the memory checker from flagging any modifications in memory.
  • OP_CALL, OP_CLOSURE, OP_RETURN, OP_TAILCALL are notoriously difficult, as you cannot copy Roblox's implementation. "Temporary" fixes have been employed.

Rest in peace, Danghui.

Devlogs I found on Gyazo (2015-2017):