in agent/agent-tooling/src/main/java/com/microsoft/applicationinsights/agent/internal/legacysdk/TelemetryClientClassFileTransformer.java [672:812]
private void writeAgentTrackRemoteDependencyTelemetryMethod() {
MethodVisitor mv =
cw.visitMethod(
ACC_PRIVATE,
"agent$trackRemoteDependencyTelemetry",
"(L" + unshadedPrefix + "/telemetry/RemoteDependencyTelemetry;)V",
null,
null);
mv.visitCode();
Label label0 = new Label();
mv.visitLabel(label0);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getTimestamp",
"()Ljava/util/Date;",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getName",
"()Ljava/lang/String;",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getId",
"()Ljava/lang/String;",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getResultCode",
"()Ljava/lang/String;",
false);
mv.visitVarInsn(ALOAD, 0);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getDuration",
"()L" + unshadedPrefix + "/telemetry/Duration;",
false);
mv.visitMethodInsn(
INVOKESPECIAL,
unshadedPrefix + "/TelemetryClient",
"agent$toMillis",
"(L" + unshadedPrefix + "/telemetry/Duration;)Ljava/lang/Long;",
false);
mv.visitVarInsn(ALOAD, 1);
Label label1 = new Label();
mv.visitLabel(label1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getSuccess",
"()Z",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getCommandName",
"()Ljava/lang/String;",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getType",
"()Ljava/lang/String;",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getTarget",
"()Ljava/lang/String;",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getProperties",
"()Ljava/util/Map;",
false);
mv.visitVarInsn(ALOAD, 1);
Label label2 = new Label();
mv.visitLabel(label2);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getContext",
"()L" + unshadedPrefix + "/telemetry/TelemetryContext;",
false);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/TelemetryContext",
"getTags",
"()Ljava/util/concurrent/ConcurrentMap;",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getMetrics",
"()Ljava/util/Map;",
false);
mv.visitVarInsn(ALOAD, 1);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/RemoteDependencyTelemetry",
"getContext",
"()L" + unshadedPrefix + "/telemetry/TelemetryContext;",
false);
mv.visitMethodInsn(
INVOKEVIRTUAL,
unshadedPrefix + "/telemetry/TelemetryContext",
"getInstrumentationKey",
"()Ljava/lang/String;",
false);
Label label3 = new Label();
mv.visitLabel(label3);
mv.visitMethodInsn(
INVOKESTATIC,
BYTECODE_UTIL_INTERNAL_NAME,
"trackDependency",
"(Ljava/util/Date;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Long;ZLjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;Ljava/util/Map;Ljava/util/Map;Ljava/lang/String;)V",
false);
Label label4 = new Label();
mv.visitLabel(label4);
mv.visitInsn(RETURN);
Label label5 = new Label();
mv.visitLabel(label5);
mv.visitMaxs(13, 2);
mv.visitEnd();
}