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

io.sentry.ITransaction Maven / Gradle / Ivy

package io.sentry;

import io.sentry.protocol.SentryId;
import io.sentry.protocol.TransactionNameSource;
import java.util.List;
import org.jetbrains.annotations.ApiStatus;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.jetbrains.annotations.TestOnly;

public interface ITransaction extends ISpan {

  /**
   * Sets transaction name.
   *
   * @param name - transaction name
   */
  void setName(@NotNull String name);

  @ApiStatus.Internal
  void setName(@NotNull String name, @NotNull TransactionNameSource transactionNameSource);

  /**
   * Returns transaction name.
   *
   * @return transaction name
   */
  @NotNull
  String getName();

  /**
   * Returns the source of the transaction name.
   *
   * @return transaction name source
   */
  @NotNull
  TransactionNameSource getTransactionNameSource();

  @NotNull
  @TestOnly
  List getSpans();

  /**
   * Starts a child Span.
   *
   * @param operation - new span operation name
   * @param description - the span description
   * @param timestamp - the start timestamp of the span
   * @return a new transaction span
   */
  @NotNull
  ISpan startChild(
      @NotNull String operation, @Nullable String description, @Nullable SentryDate timestamp);

  /**
   * Returns if the profile of a transaction is sampled.
   *
   * @return profile is sampled
   */
  @Nullable
  Boolean isProfileSampled();

  /**
   * Returns the latest span that is not finished.
   *
   * @return span or null if not found.
   */
  @Nullable
  ISpan getLatestActiveSpan();

  /** Schedules when transaction should be automatically finished. */
  void scheduleFinish();

  /**
   * Force finishes the transaction and it's child spans with the specified status. If the
   * transaction is already finished this is a no-op.
   *
   * @param status The status to set the unfinished child spans / transaction to.
   * @param dropIfNoChildren true, if the transaction should be dropped when it e.g. contains no
   *     child spans. Usually true, but can be set to falseS for situations were the transaction and
   *     profile provide crucial context (e.g. ANRs)
   * @param hint An optional hint to pass down to the client/transport layer
   */
  @ApiStatus.Internal
  void forceFinish(@NotNull final SpanStatus status, boolean dropIfNoChildren, @Nullable Hint hint);

  @ApiStatus.Internal
  void finish(
      @Nullable SpanStatus status,
      @Nullable SentryDate timestamp,
      boolean dropIfNoChildren,
      @Nullable Hint hint);

  @NotNull
  SentryId getEventId();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy