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

io.opentelemetry.sdk.trace.data.LinkData Maven / Gradle / Ivy

/*
 * Copyright The OpenTelemetry Authors
 * SPDX-License-Identifier: Apache-2.0
 */

package io.opentelemetry.sdk.trace.data;

import io.opentelemetry.api.common.Attributes;
import io.opentelemetry.api.trace.SpanContext;
import io.opentelemetry.sdk.trace.SpanLimits;
import javax.annotation.concurrent.Immutable;

/**
 * Data representation of a link.
 *
 * 

Used (for example) in batching operations, where a single batch handler processes multiple * requests from different traces. Link can be also used to reference spans from the same trace. */ @Immutable public interface LinkData { /** * Returns a new immutable {@link LinkData}. * * @param spanContext the {@link SpanContext} of this {@link LinkData}. * @return a new immutable {@link LinkData} */ static LinkData create(SpanContext spanContext) { return ImmutableLinkData.create(spanContext); } /** * Returns a new immutable {@link LinkData}. * * @param spanContext the {@link SpanContext} of this {@link LinkData}. * @param attributes the attributes of this {@link LinkData}. * @return a new immutable {@link LinkData} */ static LinkData create(SpanContext spanContext, Attributes attributes) { return ImmutableLinkData.create(spanContext, attributes); } /** * Returns a new immutable {@link LinkData}. * * @param spanContext the {@link SpanContext} of this {@link LinkData}. * @param attributes the attributes of this {@link LinkData}. * @param totalAttributeCount the total number of attributed for this {@link LinkData}. * @return a new immutable {@link LinkData} */ static LinkData create(SpanContext spanContext, Attributes attributes, int totalAttributeCount) { return ImmutableLinkData.create(spanContext, attributes, totalAttributeCount); } /** Returns the {@link SpanContext} of the span this {@link LinkData} refers to. */ SpanContext getSpanContext(); /** * Returns the set of attributes. * * @return the set of attributes. */ Attributes getAttributes(); /** * The total number of attributes that were recorded on this Link. This number may be larger than * the number of attributes that are attached to this span, if the total number recorded was * greater than the configured maximum value. See: {@link * SpanLimits#getMaxNumberOfAttributesPerLink()} * * @return The number of attributes on this link. */ int getTotalAttributeCount(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy