All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.sentry.opentelemetry.OpenTelemetryLinkErrorEventProcessor Maven / Gradle / Ivy

package io.sentry.opentelemetry;

import io.opentelemetry.api.trace.Span;
import io.opentelemetry.api.trace.SpanId;
import io.opentelemetry.api.trace.TraceId;
import io.sentry.EventProcessor;
import io.sentry.Hint;
import io.sentry.IScopes;
import io.sentry.ISpan;
import io.sentry.Instrumenter;
import io.sentry.ScopesAdapter;
import io.sentry.SentryEvent;
import io.sentry.SentryLevel;
import io.sentry.SpanContext;
import io.sentry.protocol.SentryId;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.jetbrains.annotations.TestOnly;

/**
 * @deprecated this is no longer needed for the latest version of our OpenTelemetry integration.
 */
@Deprecated
public final class OpenTelemetryLinkErrorEventProcessor implements EventProcessor {

  private final @NotNull IScopes scopes;

  @SuppressWarnings("deprecation")
  private final @NotNull io.sentry.SentrySpanStorage spanStorage =
      io.sentry.SentrySpanStorage.getInstance();

  public OpenTelemetryLinkErrorEventProcessor() {
    this(ScopesAdapter.getInstance());
  }

  @TestOnly
  OpenTelemetryLinkErrorEventProcessor(final @NotNull IScopes scopes) {
    this.scopes = scopes;
  }

  @Override
  public @Nullable SentryEvent process(final @NotNull SentryEvent event, final @NotNull Hint hint) {
    final @NotNull Instrumenter instrumenter = scopes.getOptions().getInstrumenter();
    if (Instrumenter.OTEL.equals(instrumenter)) {
      @NotNull final Span otelSpan = Span.current();
      @NotNull final String traceId = otelSpan.getSpanContext().getTraceId();
      @NotNull final String spanId = otelSpan.getSpanContext().getSpanId();

      if (TraceId.isValid(traceId) && SpanId.isValid(spanId)) {
        final @Nullable ISpan sentrySpan = spanStorage.get(spanId);
        if (sentrySpan != null) {
          final @NotNull SpanContext sentrySpanSpanContext = sentrySpan.getSpanContext();
          final @NotNull String operation = sentrySpanSpanContext.getOperation();
          final @Nullable io.sentry.SpanId parentSpanId = sentrySpanSpanContext.getParentSpanId();
          final @NotNull SpanContext spanContext =
              new SpanContext(
                  new SentryId(traceId),
                  new io.sentry.SpanId(spanId),
                  operation,
                  parentSpanId,
                  null);

          event.getContexts().setTrace(spanContext);
          scopes
              .getOptions()
              .getLogger()
              .log(
                  SentryLevel.DEBUG,
                  "Linking Sentry event %s to span %s created via OpenTelemetry (trace %s).",
                  event.getEventId(),
                  spanId,
                  traceId);
        } else {
          scopes
              .getOptions()
              .getLogger()
              .log(
                  SentryLevel.DEBUG,
                  "Not linking Sentry event %s to any transaction created via OpenTelemetry as none has been found for span %s (trace %s).",
                  event.getEventId(),
                  spanId,
                  traceId);
        }
      } else {
        scopes
            .getOptions()
            .getLogger()
            .log(
                SentryLevel.DEBUG,
                "Not linking Sentry event %s to any transaction created via OpenTelemetry as traceId %s or spanId %s are invalid.",
                event.getEventId(),
                traceId,
                spanId);
      }
    } else {
      scopes
          .getOptions()
          .getLogger()
          .log(
              SentryLevel.DEBUG,
              "Not linking Sentry event %s to any transaction created via OpenTelemetry as instrumenter is set to %s.",
              event.getEventId(),
              instrumenter);
    }

    return event;
  }

  @Override
  public @Nullable Long getOrder() {
    return 6000L;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy