From db6e60a196ec3a635a2de4d0fe3923b01dc6f0f7 Mon Sep 17 00:00:00 2001 From: ZXMushroom63 Date: Sat, 24 Aug 2024 23:07:32 +0800 Subject: [PATCH] Add support for static properties --- examplemods/minecraft_on_2x_speed.js | 5 + injector.html | 138 ++++++++++++++++++++++----- postinit.js | 68 +++++++++---- 3 files changed, 172 insertions(+), 39 deletions(-) create mode 100644 examplemods/minecraft_on_2x_speed.js diff --git a/examplemods/minecraft_on_2x_speed.js b/examplemods/minecraft_on_2x_speed.js new file mode 100644 index 0000000..131b29e --- /dev/null +++ b/examplemods/minecraft_on_2x_speed.js @@ -0,0 +1,5 @@ +//Very much WIP, still firguring out how to poke the dedicated server. +(()=>{ + //PluginAPI.javaClient.$timer.$timerSpeed = 4; + ModAPI.dedicatedServer.appendCode(`console.log(ModAPI.hooks._rippedStaticProperties[ModAPI.util.getCompiledNameFromPackage("net.lax1dude.eaglercraft.v1_8.sp.server.EaglerIntegratedServerWorker")].currentProcess)`); +})(); \ No newline at end of file diff --git a/injector.html b/injector.html index 8d5aeaa..1ebca7d 100644 --- a/injector.html +++ b/injector.html @@ -26,7 +26,7 @@

EaglerForge Injector

Adds ModAPI with more functionality (adds hooking into functions, exposes - all classes, etc) to unminified unobfuscated EaglercraftX and Eaglercraft + all classes, etc) to unminified unobfuscated EaglercraftX builds.


@@ -203,6 +203,8 @@

ModAPI.hooks.methods ||= {}; ModAPI.hooks._rippedMethodTypeMap ||= {}; ModAPI.hooks._postInit ||= ()=>{}; +ModAPI.hooks._rippedStaticProperties ||= {}; +ModAPI.hooks._rippedStaticIndexer ||= {}; `; document.querySelector("#giveme").addEventListener("click", () => { if ( @@ -245,7 +247,9 @@

patchedFile = patchedFile.replace( ` id="game_frame">`, - ` id="game_frame">\ + + + + diff --git a/postinit.js b/postinit.js index 931233f..e8fd3b7 100644 --- a/postinit.js +++ b/postinit.js @@ -1,9 +1,41 @@ (() => { //EaglerForge post initialization code. + //This script cannot contain backticks, escape characters, or backslashes in order to inject into the dedicated server code. ModAPI.hooks._classMap = {}; globalThis.PluginAPI ||= ModAPI; ModAPI.mcinstance ||= {}; ModAPI.javaClient ||= {}; + ModAPI.dedicatedServer ||= {}; + ModAPI.dedicatedServer._data ||= []; + ModAPI.dedicatedServer.appendCode = function (code) { + ModAPI.dedicatedServer._data.push(code); + } + ModAPI.util ||= {}; + ModAPI.util.getMethodFromPackage = function (classId, methodName) { + var name = ""; + var classStuff = classId.split("."); + classStuff.forEach((component, i) => { + if (i === classStuff.length - 1) { + name += "_" + component; + } else { + name += component[0].toLowerCase(); + } + }); + name += "_" + methodName; + return name; + } + ModAPI.util.getCompiledNameFromPackage = function (classId) { + var name = ""; + var classStuff = classId.split("."); + classStuff.forEach((component, i) => { + if (i === classStuff.length - 1) { + name += "_" + component; + } else { + name += component[0].toLowerCase(); + } + }); + return name; + } ModAPI.version = "v2.0"; ModAPI.flavour = "injector"; ModAPI.credits = ["ZXMushroom63", "radmanplays", "OtterCodes101", "TheIdiotPlays"]; @@ -12,11 +44,14 @@ ModAPI.hooks._rippedData.forEach(block => { block.forEach(item => { if (typeof item === "function") { - var compiledName = item.name; if (!item.$meta || typeof item.$meta.name !== "string") { return; } + var classId = item.$meta.name; + var compiledName = ModAPI.util.getCompiledNameFromPackage(classId); + + if (!ModAPI.hooks._classMap[classId]) { ModAPI.hooks._classMap[classId] = { "name": classId.split(".")[classId.split(".").length - 1], @@ -25,6 +60,8 @@ "constructors": [], "methods": {}, "staticMethods": {}, + "staticVariables": {}, + "staticVariableNames": [], "class": item, "compiledName": compiledName } @@ -32,6 +69,8 @@ if (typeof item.$meta.superclass === "function" && item.$meta.superclass.$meta) { ModAPI.hooks._classMap[classId].superclass = item.$meta.superclass.$meta.name; } + ModAPI.hooks._classMap[classId].staticVariableNames = ModAPI.hooks._rippedStaticIndexer[compiledName]; + ModAPI.hooks._classMap[classId].staticVariables = ModAPI.hooks._rippedStaticProperties[compiledName]; if (item["$$constructor$$"]) { //Class does not have any hand written constructors //Eg: class MyClass {} @@ -137,6 +176,9 @@ return true; }, }; + ModAPI.util.TeaVM_to_BaseData_ProxyConf = TeaVM_to_BaseData_ProxyConf; + ModAPI.util.TeaVMArray_To_Recursive_BaseData_ProxyConf = TeaVMArray_To_Recursive_BaseData_ProxyConf; + ModAPI.util.TeaVM_to_Recursive_BaseData_ProxyConf = TeaVM_to_Recursive_BaseData_ProxyConf; ModAPI.required = new Set(); ModAPI.events = {}; ModAPI.events.types = ["event"]; @@ -211,21 +253,6 @@ }); }; ModAPI.events.newEvent("update"); - ModAPI.util ||= {}; - ModAPI.util.TeaVM_to_BaseData_ProxyConf = TeaVM_to_BaseData_ProxyConf; - ModAPI.util.getMethodFromPackage = function (classId, methodName) { - var name = ""; - var classStuff = classId.split("."); - classStuff.forEach((component, i) => { - if (i === classStuff.length - 1) { - name += "_" + component; - } else { - name += component[0].toLowerCase(); - } - }); - name += "_" + methodName; - return name; - } ModAPI.require = function (module) { ModAPI.required.add(module); }; @@ -282,4 +309,13 @@ ModAPI.settings = new Proxy(ModAPI.mcinstance.$gameSettings, TeaVM_to_Recursive_BaseData_ProxyConf); return x; }; + + var integratedServerStartup = ModAPI.util.getMethodFromPackage("net.lax1dude.eaglercraft.v1_8.sp.internal.ClientPlatformSingleplayer", "loadIntegratedServerSourceInline"); + //Integrated server setup has a randomised suffix on the end + integratedServerStartup = ModAPI.hooks._rippedMethodKeys.filter(key => {return key.startsWith(integratedServerStartup); })[0]; + const integratedServerStartupMethod = ModAPI.hooks.methods[integratedServerStartup]; + ModAPI.hooks.methods[integratedServerStartup] = function (worker, bootstrap) { + var x = integratedServerStartupMethod.apply(this, [worker, bootstrap + ";" + globalThis.modapi_postinit + ";" + ModAPI.dedicatedServer._data.join(";")]); + return x; + }; })(); \ No newline at end of file