mirror of
https://github.com/GravitLauncher/Launcher
synced 2025-01-09 00:59:44 +03:00
[FIX] LauncherAgent.
This commit is contained in:
parent
d7a58ef42e
commit
f3a19701a2
7 changed files with 31 additions and 37 deletions
|
@ -6,6 +6,8 @@
|
|||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.lang.instrument.Instrumentation;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.jar.JarFile;
|
||||
|
||||
import org.objectweb.asm.ClassReader;
|
||||
|
@ -43,41 +45,40 @@ public static void premain(String agentArgument, Instrumentation instrumentation
|
|||
if (trimmedArg.contains("r")) rt = false;
|
||||
}
|
||||
}
|
||||
//if (rt || pb) replaceClasses(pb, rt);
|
||||
/*if (rt || pb)*/
|
||||
replaceClasses(pb, rt);
|
||||
}
|
||||
|
||||
public static boolean isStarted() {
|
||||
return isAgentStarted;
|
||||
}
|
||||
|
||||
/**
|
||||
* @author https://github.com/Konloch/JVM-Sandbox
|
||||
* Replaces the Runtime class via instrumentation, transforms the class via ASM
|
||||
*/
|
||||
private static void replaceClasses(boolean pb, boolean rt) {
|
||||
java.awt.Robot.class.getName();
|
||||
for(Class<?> c : inst.getAllLoadedClasses()) {
|
||||
if(rt && c.getName().equals("java.lang.Runtime")) {
|
||||
List<java.lang.instrument.ClassDefinition> defs = new ArrayList<>();
|
||||
if(rt) {
|
||||
try {
|
||||
inst.redefineClasses(new java.lang.instrument.ClassDefinition(java.lang.Runtime.class, transformClass(c.getName(), getClassFile(c))));
|
||||
defs.add(new java.lang.instrument.ClassDefinition(java.lang.Runtime.class, transformClass(java.lang.Runtime.class.getName(), getClassFile(java.lang.Runtime.class))));
|
||||
} catch(Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
if(pb && c.getName().equals("java.lang.ProcessBuilder")) {
|
||||
if(pb) {
|
||||
try {
|
||||
inst.redefineClasses(new java.lang.instrument.ClassDefinition(java.lang.ProcessBuilder.class, transformClass(c.getName(), getClassFile(c))));
|
||||
defs.add(new java.lang.instrument.ClassDefinition(java.lang.ProcessBuilder.class, transformClass(java.lang.ProcessBuilder.class.getName(), getClassFile(java.lang.ProcessBuilder.class))));
|
||||
} catch(Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
if(c.getName().equals("java.awt.Robot")) {
|
||||
try {
|
||||
inst.redefineClasses(new java.lang.instrument.ClassDefinition(java.lang.ProcessBuilder.class, transformClass(c.getName(), getClassFile(c))));
|
||||
defs.add(new java.lang.instrument.ClassDefinition(java.awt.Robot.class, transformClass(java.awt.Robot.class.getName(), getClassFile(java.awt.Robot.class))));
|
||||
} catch(Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
try {
|
||||
inst.redefineClasses(defs.toArray(new java.lang.instrument.ClassDefinition[0]));
|
||||
} catch(Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -2,7 +2,6 @@
|
|||
|
||||
import ru.gravit.launcher.Launcher;
|
||||
import ru.gravit.launcher.LauncherConfig;
|
||||
import ru.gravit.launcher.client.ClientLauncher;
|
||||
|
||||
import java.nio.file.Path;
|
||||
|
||||
|
|
2
Radon
2
Radon
|
@ -1 +1 @@
|
|||
Subproject commit e6974532efc7228a8b826a8cd9e1f1f7b609659f
|
||||
Subproject commit 07581407e7b214b7dff8a256247dde62bba1697d
|
|
@ -2,11 +2,9 @@
|
|||
|
||||
import ru.gravit.utils.helper.CommonHelper;
|
||||
import ru.gravit.utils.helper.LogHelper;
|
||||
import ru.gravit.utils.helper.VerifyHelper;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.*;
|
||||
import java.util.concurrent.ConcurrentHashMap;
|
||||
|
||||
public abstract class CommandHandler implements Runnable {
|
||||
private final List<Category> categories = new ArrayList<>();
|
||||
|
|
|
@ -6,7 +6,6 @@
|
|||
import ru.gravit.utils.command.CommandHandler;
|
||||
import ru.gravit.utils.helper.LogHelper;
|
||||
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
|
||||
public final class HelpCommand extends Command {
|
||||
|
|
|
@ -578,16 +578,13 @@ public static Path resolveJavaBin(Path javaDir) {
|
|||
@LauncherAPI
|
||||
public static void setSocketFlags(Socket socket) throws SocketException {
|
||||
// Set socket flags
|
||||
socket.setKeepAlive(false); // TODO To socket channels
|
||||
socket.setKeepAlive(false);
|
||||
socket.setTcpNoDelay(false);
|
||||
socket.setReuseAddress(true);
|
||||
|
||||
// Set socket options
|
||||
socket.setSoTimeout(SOCKET_TIMEOUT);
|
||||
socket.setTrafficClass(0b11100);
|
||||
// Allow OS to adjust buffer sizes
|
||||
// socket.setSendBufferSize(0x100000);
|
||||
// socket.setReceiveBufferSize(0x100000);
|
||||
socket.setPerformancePreferences(1, 0, 2);
|
||||
}
|
||||
|
||||
|
|
|
@ -70,12 +70,12 @@ public static void jarMap(Path file, Map<String, String> map, boolean overwrite)
|
|||
jarMap(inputStream, map,overwrite);
|
||||
}
|
||||
}
|
||||
public static Map<String, String> jarMap(Class clazz, boolean overwrite) throws IOException
|
||||
public static Map<String, String> jarMap(Class<?> clazz, boolean overwrite) throws IOException
|
||||
{
|
||||
Path file = IOHelper.getCodeSource(clazz);
|
||||
return jarMap(file, overwrite);
|
||||
}
|
||||
public static void jarMap(Class clazz, Map<String, String> map, boolean overwrite) throws IOException
|
||||
public static void jarMap(Class<?> clazz, Map<String, String> map, boolean overwrite) throws IOException
|
||||
{
|
||||
Path file = IOHelper.getCodeSource(clazz);
|
||||
jarMap(file, map, overwrite);
|
||||
|
|
Loading…
Reference in a new issue