diff --git a/pom.xml b/pom.xml
index bdf539c..abc2782 100644
--- a/pom.xml
+++ b/pom.xml
@@ -12,7 +12,6 @@
1.7
-
org.apache.maven.plugins
diff --git a/src/main/java/net/x3f200c/pala4linux/launcherpatch/LauncherPatch.java b/src/main/java/net/x3f200c/pala4linux/launcherpatch/LauncherPatch.java
index 08ee9f4..6e8ed0e 100644
--- a/src/main/java/net/x3f200c/pala4linux/launcherpatch/LauncherPatch.java
+++ b/src/main/java/net/x3f200c/pala4linux/launcherpatch/LauncherPatch.java
@@ -4,27 +4,45 @@ import java.lang.instrument.Instrumentation;
import java.lang.instrument.UnmodifiableClassException;
import java.lang.Class;
import java.lang.String;
+import java.lang.Exception;
+import java.net.URL;
+import javax.net.ssl.HttpsURLConnection;
import net.x3f200c.pala4linux.launcherpatch.LauncherPatcher;
public class LauncherPatch {
public static void premain(String agentArgs, Instrumentation inst) {
+ try {
+ prepareCertificates();
+ } catch (Exception e) {
+ System.out.println("[PalaLauncher4Linux] Failed to prepare certificates. ");
+ }
patch(inst);
}
public static void agentmain(String agentArgs, Instrumentation inst) {
+ try {
+ prepareCertificates();
+ } catch (Exception e) {
+ System.out.println("[PalaLauncher4Linux] Failed to prepare certificates. ");
+ }
patch(inst);
}
+ public static void prepareCertificates() throws Exception {
+ URL apacheMavenRepository = new URL("https://repo.maven.apache.org");
+
+ HttpsURLConnection connection = (HttpsURLConnection) apacheMavenRepository.openConnection();
+ connection.connect();
+ connection.disconnect();
+ }
public static void patch(Instrumentation inst) {
Class> routeHandlerClass = null;
- ClassLoader routeHandlerClassLoader = null;
try {
routeHandlerClass = Class.forName("fr.paladium.router.route.common.CommonRoute");
- routeHandlerClassLoader = routeHandlerClass.getClassLoader();
} catch(ClassNotFoundException e) {
}
- LauncherPatcher dt = new LauncherPatcher(routeHandlerClass.getName(), routeHandlerClassLoader);
+ LauncherPatcher dt = new LauncherPatcher(routeHandlerClass.getName());
inst.addTransformer(dt, true);
diff --git a/src/main/java/net/x3f200c/pala4linux/launcherpatch/LauncherPatcher.java b/src/main/java/net/x3f200c/pala4linux/launcherpatch/LauncherPatcher.java
index 1c025c7..cf13d3c 100644
--- a/src/main/java/net/x3f200c/pala4linux/launcherpatch/LauncherPatcher.java
+++ b/src/main/java/net/x3f200c/pala4linux/launcherpatch/LauncherPatcher.java
@@ -10,24 +10,22 @@ import javassist.NotFoundException;
import javassist.CannotCompileException;
class LauncherPatcher implements ClassFileTransformer {
- private final String targetClassName;
+ private final String routeTargetClassName;
- public LauncherPatcher(String className, ClassLoader classLoader) {
- this.targetClassName = className;
+ public LauncherPatcher(String routerClassName) {
+ this.routeTargetClassName = routerClassName;
}
@Override
public byte[] transform(ClassLoader loader, String className, Class> redefinedClass, ProtectionDomain protectionDomain, byte[] classBuffer) {
byte[] bytecode = classBuffer;
- String finalTargetClassName = this.targetClassName.replaceAll("\\.", "/");
- if (!className.equals(finalTargetClassName)) {
- return bytecode;
- }
+ ClassPool cp = ClassPool.getDefault();
- if (className.equals(finalTargetClassName)) {
+ String finalRouterClassName = this.routeTargetClassName.replaceAll("\\.", "/");
+
+ if (className.equals(finalRouterClassName)) {
try {
- ClassPool cp = ClassPool.getDefault();
CtClass crClass = cp.get("fr.paladium.router.route.common.CommonRoute");
CtMethod osGetterMethod = crClass.getDeclaredMethod("handleGetOS");