Skip to content

Commit

Permalink
\elastic#3030: Reduce dependency on elastic APM tracer in plugins but…
Browse files Browse the repository at this point in the history
… rather depend on a more general API.
  • Loading branch information
raphw committed Feb 20, 2023
1 parent 435e1d3 commit fe6a9bb
Show file tree
Hide file tree
Showing 129 changed files with 1,169 additions and 796 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,7 @@
import co.elastic.apm.agent.common.ThreadUtils;
import co.elastic.apm.agent.common.util.SystemStandardOutputLogger;
import co.elastic.apm.agent.configuration.CoreConfiguration;
import co.elastic.apm.agent.impl.ElasticApmTracer;
import co.elastic.apm.agent.impl.ElasticApmTracerBuilder;
import co.elastic.apm.agent.impl.GlobalTracer;
import co.elastic.apm.agent.impl.*;
import co.elastic.apm.agent.logging.ApmServerLogAppender;
import co.elastic.apm.agent.matcher.MethodMatcher;
import co.elastic.apm.agent.sdk.ElasticApmInstrumentation;
Expand Down Expand Up @@ -83,14 +81,7 @@
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.security.ProtectionDomain;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.Future;
Expand Down Expand Up @@ -877,10 +868,43 @@ private static boolean matches(Class<?> classToInstrument, ElementMatcher<? supe
}

private static ElasticApmInstrumentation instantiate(Class<? extends ElasticApmInstrumentation> instrumentation) {
List<Constructor<?>> candidates = new ArrayList<>();
for (Constructor<?> constructor : instrumentation.getConstructors()) {
Class<?>[] types = constructor.getParameterTypes();
if (types.length == 0 || types.length == 1 && types[0].isAssignableFrom(Tracer.class)) {
candidates.add(constructor);
}
}

ElasticApmInstrumentation instance = tryInstantiate(instrumentation, false);
if (instance == null) {
instance = tryInstantiate(instrumentation, true);
Collections.sort(candidates, new Comparator<Constructor<?>>() {
@Override
public int compare(Constructor<?> left, Constructor<?> right) {
if (left == right) {
return 0;
}
Class<?>[] leftTypes = left.getParameterTypes(), rightTypes = right.getParameterTypes();
int difference = rightTypes.length - leftTypes.length;
if (difference == 0) {
return rightTypes[0].isAssignableFrom(leftTypes[0]) ? -1 : 1;
} else {
return difference;
}
}
});

ElasticApmTracer tracer = GlobalTracer.requireTracerImpl();
ElasticApmInstrumentation instance = null;
for (Constructor<?> candidate : candidates) {
try {
if (candidate.getParameterTypes().length == 0) {
instance = (ElasticApmInstrumentation) candidate.newInstance();
} else {
instance = (ElasticApmInstrumentation) candidate.newInstance(tracer);
}
break;
} catch (ReflectiveOperationException e) {
// silently ignored
}
}

if (instance == null) {
Expand All @@ -890,34 +914,18 @@ private static ElasticApmInstrumentation instantiate(Class<? extends ElasticApmI
return instance;
}

@Nullable
private static ElasticApmInstrumentation tryInstantiate(Class<? extends ElasticApmInstrumentation> instrumentation, boolean withTracer) {
public static class X {

Constructor<? extends ElasticApmInstrumentation> constructor = null;
try {
if (withTracer) {
constructor = instrumentation.getConstructor(ElasticApmTracer.class);
} else {
constructor = instrumentation.getConstructor();
}
} catch (NoSuchMethodException e) {
// silently ignored
public X() {
}

ElasticApmInstrumentation instance = null;
if (constructor != null) {
try {
if (withTracer) {
instance = constructor.newInstance(GlobalTracer.requireTracerImpl());
} else {
instance = constructor.newInstance();
}
} catch (ReflectiveOperationException e) {
// silently ignored
}
public X(Tracer tracer) {

}

return instance;
public X(ElasticApmTracer tracer) {

}
}

public static ClassLoader getAgentClassLoader() {
Expand Down
Loading

0 comments on commit fe6a9bb

Please sign in to comment.