From b909af6940dee45f1376ae356b77687814921cba Mon Sep 17 00:00:00 2001 From: Zachary Sistrunk Date: Tue, 11 Jul 2023 09:48:39 -0500 Subject: [PATCH] Enable instrumentation of Spring EJB clients --- .../v4_0/SpringRmiIgnoredTypesConfigurer.java | 22 +++++++++++++++++++ .../v4_0/client/ClientInstrumentation.java | 4 +++- 2 files changed, 25 insertions(+), 1 deletion(-) create mode 100644 instrumentation/spring/spring-rmi-4.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/spring/rmi/v4_0/SpringRmiIgnoredTypesConfigurer.java diff --git a/instrumentation/spring/spring-rmi-4.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/spring/rmi/v4_0/SpringRmiIgnoredTypesConfigurer.java b/instrumentation/spring/spring-rmi-4.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/spring/rmi/v4_0/SpringRmiIgnoredTypesConfigurer.java new file mode 100644 index 000000000000..c12ab641a0a4 --- /dev/null +++ b/instrumentation/spring/spring-rmi-4.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/spring/rmi/v4_0/SpringRmiIgnoredTypesConfigurer.java @@ -0,0 +1,22 @@ +/* + * Copyright The OpenTelemetry Authors + * SPDX-License-Identifier: Apache-2.0 + */ + +package io.opentelemetry.javaagent.instrumentation.spring.rmi.v4_0; + +import com.google.auto.service.AutoService; +import io.opentelemetry.javaagent.extension.ignore.IgnoredTypesBuilder; +import io.opentelemetry.javaagent.extension.ignore.IgnoredTypesConfigurer; +import io.opentelemetry.sdk.autoconfigure.spi.ConfigProperties; + +@AutoService(IgnoredTypesConfigurer.class) +public class SpringRmiIgnoredTypesConfigurer implements IgnoredTypesConfigurer { + + @Override + public void configure(IgnoredTypesBuilder builder, ConfigProperties config) { + // The Spring EJB classes are ignored in the AdditionalLibraryIgnoredTypesConfigurer, but + // are required when utilizing Spring's local-slsb and remote-slsb to access EJBs through RMI. + builder.allowClass("org.springframework.ejb.access."); + } +} diff --git a/instrumentation/spring/spring-rmi-4.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/spring/rmi/v4_0/client/ClientInstrumentation.java b/instrumentation/spring/spring-rmi-4.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/spring/rmi/v4_0/client/ClientInstrumentation.java index 622e453f5ebf..b04daf155bd3 100644 --- a/instrumentation/spring/spring-rmi-4.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/spring/rmi/v4_0/client/ClientInstrumentation.java +++ b/instrumentation/spring/spring-rmi-4.0/javaagent/src/main/java/io/opentelemetry/javaagent/instrumentation/spring/rmi/v4_0/client/ClientInstrumentation.java @@ -5,6 +5,7 @@ package io.opentelemetry.javaagent.instrumentation.spring.rmi.v4_0.client; +import static io.opentelemetry.javaagent.extension.matcher.AgentElementMatchers.extendsClass; import static io.opentelemetry.javaagent.instrumentation.spring.rmi.v4_0.SpringRmiSingletons.clientInstrumenter; import static net.bytebuddy.matcher.ElementMatchers.isMethod; import static net.bytebuddy.matcher.ElementMatchers.named; @@ -25,7 +26,8 @@ public class ClientInstrumentation implements TypeInstrumentation { @Override public ElementMatcher typeMatcher() { - return named("org.springframework.remoting.rmi.RmiClientInterceptor"); + return named("org.springframework.remoting.rmi.RmiClientInterceptor") + .or(extendsClass(named("org.springframework.ejb.access.AbstractSlsbInvokerInterceptor"))); } @Override