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

org.springframework.cloud.sleuth.TraceContext Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2013-2021 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.cloud.sleuth;

import org.springframework.lang.Nullable;

/**
 * Contains trace and span data.
 *
 * @author Marcin Grzejszczak
 * @since 3.0.0
 */
public interface TraceContext {

	/**
	 * Trace id.
	 * @return trace id of a span
	 */
	String traceId();

	/**
	 * Parent span id.
	 * @return parent span id or {@code null} if one is not set
	 */
	@Nullable
	String parentId();

	/**
	 * Span id.
	 * @return span id
	 */
	String spanId();

	/**
	 * @return {@code true} when sampled, {@code false} when not sampled and {@code null}
	 * when sampling decision should be deferred
	 */
	Boolean sampled();

	/**
	 * Builder for {@link TraceContext}.
	 *
	 * @since 3.1.0
	 */
	interface Builder {

		/**
		 * Sets trace id on the trace context.
		 * @param traceId trace id
		 * @return this
		 */
		TraceContext.Builder traceId(String traceId);

		/**
		 * Sets parent id on the trace context.
		 * @param parentId parent trace id
		 * @return this
		 */
		TraceContext.Builder parentId(String parentId);

		/**
		 * Sets span id on the trace context.
		 * @param spanId span id
		 * @return this
		 */
		TraceContext.Builder spanId(String spanId);

		/**
		 * Sets sampled on the trace context.
		 * @param sampled if span is sampled
		 * @return this
		 */
		TraceContext.Builder sampled(Boolean sampled);

		/**
		 * Builds the trace context.
		 * @return trace context
		 */
		TraceContext build();

	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy