Akka server indy support (#12243)

This commit is contained in:
César 2024-09-13 16:33:17 +02:00 committed by GitHub
parent 32fd44ebf2
commit 68e844e129
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 13 additions and 13 deletions

View File

@ -11,15 +11,22 @@ import static java.util.Arrays.asList;
import com.google.auto.service.AutoService; import com.google.auto.service.AutoService;
import io.opentelemetry.javaagent.extension.instrumentation.InstrumentationModule; import io.opentelemetry.javaagent.extension.instrumentation.InstrumentationModule;
import io.opentelemetry.javaagent.extension.instrumentation.TypeInstrumentation; import io.opentelemetry.javaagent.extension.instrumentation.TypeInstrumentation;
import io.opentelemetry.javaagent.extension.instrumentation.internal.ExperimentalInstrumentationModule;
import java.util.List; import java.util.List;
import net.bytebuddy.matcher.ElementMatcher; import net.bytebuddy.matcher.ElementMatcher;
@AutoService(InstrumentationModule.class) @AutoService(InstrumentationModule.class)
public class AkkaHttpServerInstrumentationModule extends InstrumentationModule { public class AkkaHttpServerInstrumentationModule extends InstrumentationModule
implements ExperimentalInstrumentationModule {
public AkkaHttpServerInstrumentationModule() { public AkkaHttpServerInstrumentationModule() {
super("akka-http", "akka-http-10.0", "akka-http-server"); super("akka-http", "akka-http-10.0", "akka-http-server");
} }
@Override
public String getModuleGroup() {
return "akka-http";
}
@Override @Override
public ElementMatcher.Junction<ClassLoader> classLoaderMatcher() { public ElementMatcher.Junction<ClassLoader> classLoaderMatcher() {
// in GraphInterpreterInstrumentation we instrument a class that belongs to akka-streams, make // in GraphInterpreterInstrumentation we instrument a class that belongs to akka-streams, make
@ -27,13 +34,6 @@ public class AkkaHttpServerInstrumentationModule extends InstrumentationModule {
return hasClassesNamed("akka.http.scaladsl.HttpExt"); return hasClassesNamed("akka.http.scaladsl.HttpExt");
} }
@Override
public boolean isIndyModule() {
// AkkaHttpServerInstrumentationModule and AkkaHttpServerRouteInstrumentationModule share
// AkkaRouteHolder class
return false;
}
@Override @Override
public List<TypeInstrumentation> typeInstrumentations() { public List<TypeInstrumentation> typeInstrumentations() {
return asList( return asList(

View File

@ -10,6 +10,7 @@ import static java.util.Arrays.asList;
import com.google.auto.service.AutoService; import com.google.auto.service.AutoService;
import io.opentelemetry.javaagent.extension.instrumentation.InstrumentationModule; import io.opentelemetry.javaagent.extension.instrumentation.InstrumentationModule;
import io.opentelemetry.javaagent.extension.instrumentation.TypeInstrumentation; import io.opentelemetry.javaagent.extension.instrumentation.TypeInstrumentation;
import io.opentelemetry.javaagent.extension.instrumentation.internal.ExperimentalInstrumentationModule;
import java.util.List; import java.util.List;
/** /**
@ -17,16 +18,15 @@ import java.util.List;
* AkkaHttpServerInstrumentationModule applies to classes in akka-http-core.jar * AkkaHttpServerInstrumentationModule applies to classes in akka-http-core.jar
*/ */
@AutoService(InstrumentationModule.class) @AutoService(InstrumentationModule.class)
public class AkkaHttpServerRouteInstrumentationModule extends InstrumentationModule { public class AkkaHttpServerRouteInstrumentationModule extends InstrumentationModule
implements ExperimentalInstrumentationModule {
public AkkaHttpServerRouteInstrumentationModule() { public AkkaHttpServerRouteInstrumentationModule() {
super("akka-http", "akka-http-10.0", "akka-http-server", "akka-http-server-route"); super("akka-http", "akka-http-10.0", "akka-http-server", "akka-http-server-route");
} }
@Override @Override
public boolean isIndyModule() { public String getModuleGroup() {
// AkkaHttpServerInstrumentationModule and AkkaHttpServerRouteInstrumentationModule share return "akka-http";
// AkkaRouteHolder class
return false;
} }
@Override @Override