From f62d058a7967618ea5f6b6b4db05a0f0d968b4c0 Mon Sep 17 00:00:00 2001
From: ChaoWang <66939405+wangchao316@users.noreply.github.com>
Date: Sun, 15 Dec 2024 11:10:08 +0800
Subject: [PATCH] [IOTDB-6353] replace cglib to byte-buddy (#14426)
* [IOTDB-6353] replace cglib to byte-buddy
* [IOTDB-6353] replace cglib to byte-buddy
---
dependencies.json | 2 +-
iotdb-core/node-commons/pom.xml | 4 +-
.../client/sync/ByteBuddyEnhancer.java | 75 +++++++++++++++++++
.../SyncThriftClientWithErrorHandler.java | 30 +-------
pom.xml | 8 +-
5 files changed, 85 insertions(+), 34 deletions(-)
create mode 100644 iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/client/sync/ByteBuddyEnhancer.java
diff --git a/dependencies.json b/dependencies.json
index 0c8ff00acdd6..dfcaa6a317bc 100644
--- a/dependencies.json
+++ b/dependencies.json
@@ -1,6 +1,6 @@
{
"dependencies": [
- "cglib:cglib",
+ "net.bytebuddy:byte-buddy",
"ch.qos.logback:logback-classic",
"ch.qos.logback:logback-core",
"ch.qos.reload4j:reload4j",
diff --git a/iotdb-core/node-commons/pom.xml b/iotdb-core/node-commons/pom.xml
index 2243f340bfcf..a9d45250027b 100644
--- a/iotdb-core/node-commons/pom.xml
+++ b/iotdb-core/node-commons/pom.xml
@@ -140,8 +140,8 @@
nimbus-jose-jwt
- cglib
- cglib
+ net.bytebuddy
+ byte-buddy
io.jsonwebtoken
diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/client/sync/ByteBuddyEnhancer.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/client/sync/ByteBuddyEnhancer.java
new file mode 100644
index 000000000000..db72b444c858
--- /dev/null
+++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/client/sync/ByteBuddyEnhancer.java
@@ -0,0 +1,75 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.iotdb.commons.client.sync;
+
+import org.apache.iotdb.commons.client.ThriftClient;
+
+import net.bytebuddy.ByteBuddy;
+import net.bytebuddy.description.method.MethodDescription;
+import net.bytebuddy.dynamic.loading.ClassLoadingStrategy;
+import net.bytebuddy.implementation.MethodDelegation;
+import net.bytebuddy.implementation.bind.annotation.Origin;
+import net.bytebuddy.implementation.bind.annotation.RuntimeType;
+import net.bytebuddy.implementation.bind.annotation.SuperCall;
+import net.bytebuddy.implementation.bind.annotation.This;
+import net.bytebuddy.matcher.ElementMatcher;
+import net.bytebuddy.matcher.ElementMatchers;
+import org.apache.thrift.TException;
+
+import java.lang.reflect.Constructor;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+import java.util.concurrent.Callable;
+
+public class ByteBuddyEnhancer {
+ public static V createProxy(Class targetClass, Constructor constructor, Object[] args)
+ throws NoSuchMethodException,
+ IllegalAccessException,
+ InvocationTargetException,
+ InstantiationException {
+ ElementMatcher.Junction matcher =
+ ElementMatchers.noneOf(Object.class.getDeclaredMethods());
+
+ return new ByteBuddy()
+ .subclass(targetClass)
+ .method(matcher)
+ .intercept(MethodDelegation.to(SyncThriftClientWithErrorHandler.class))
+ .make()
+ .load(targetClass.getClassLoader(), ClassLoadingStrategy.Default.CHILD_FIRST)
+ .getLoaded()
+ .getDeclaredConstructor(constructor.getParameterTypes())
+ .newInstance(args);
+ }
+
+ public static class SyncThriftClientWithErrorHandler {
+ @RuntimeType
+ public static Object intercept(
+ @This Object targetObject, @SuperCall Callable> callable, @Origin Method method)
+ throws TException {
+ try {
+ Object result = callable.call();
+ return result;
+ } catch (Throwable t) {
+ ThriftClient.resolveException(t, (ThriftClient) targetObject);
+ throw new TException(
+ "Error in calling method " + method.getName() + ", because: " + t.getMessage(), t);
+ }
+ }
+ }
+}
diff --git a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/client/sync/SyncThriftClientWithErrorHandler.java b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/client/sync/SyncThriftClientWithErrorHandler.java
index 06097c9c8217..9047fb9f3dfd 100644
--- a/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/client/sync/SyncThriftClientWithErrorHandler.java
+++ b/iotdb-core/node-commons/src/main/java/org/apache/iotdb/commons/client/sync/SyncThriftClientWithErrorHandler.java
@@ -21,15 +21,9 @@
import org.apache.iotdb.commons.client.ThriftClient;
-import net.sf.cglib.proxy.Enhancer;
-import net.sf.cglib.proxy.MethodInterceptor;
-import net.sf.cglib.proxy.MethodProxy;
-import org.apache.thrift.TException;
-
import java.lang.reflect.Constructor;
-import java.lang.reflect.Method;
-public class SyncThriftClientWithErrorHandler implements MethodInterceptor {
+public class SyncThriftClientWithErrorHandler {
/**
* Note: The caller needs to ensure that the constructor corresponds to the class, or the cast
@@ -37,25 +31,7 @@ public class SyncThriftClientWithErrorHandler implements MethodInterceptor {
*/
@SuppressWarnings("unchecked")
public static V newErrorHandler(
- Class targetClass, Constructor constructor, Object... args) {
- Enhancer enhancer = new Enhancer();
- enhancer.setSuperclass(targetClass);
- enhancer.setCallback(new SyncThriftClientWithErrorHandler());
- if (constructor == null) {
- return (V) enhancer.create();
- }
- return (V) enhancer.create(constructor.getParameterTypes(), args);
- }
-
- @Override
- public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy)
- throws Throwable {
- try {
- return methodProxy.invokeSuper(o, objects);
- } catch (Throwable t) {
- ThriftClient.resolveException(t, (ThriftClient) o);
- throw new TException(
- "Error in calling method " + method.getName() + ", because: " + t.getMessage(), t);
- }
+ Class targetClass, Constructor constructor, Object... args) throws Exception {
+ return ByteBuddyEnhancer.createProxy(targetClass, constructor, args);
}
}
diff --git a/pom.xml b/pom.xml
index da51a20417d0..6dc3be76131c 100644
--- a/pom.xml
+++ b/pom.xml
@@ -55,7 +55,7 @@
2.9.3
- 3.3.0
+ 1.14.19
3.38.0
Release
1.5.0
@@ -475,9 +475,9 @@
${nimbus-jose-jwt.version}
- cglib
- cglib
- ${cglib.version}
+ net.bytebuddy
+ byte-buddy
+ ${bytebuddy.version}
org.apache.commons