com.azure.core.util.TracingOptions Maven / Gradle / Ivy
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.core.util;
import com.azure.core.util.tracing.Tracer;
import com.azure.core.util.tracing.TracerProvider;
import java.util.Set;
import static com.azure.core.implementation.ImplUtils.getClassByName;
/**
* Tracing configuration options for clients.
*/
public class TracingOptions {
private static final ConfigurationProperty IS_DISABLED_PROPERTY
= ConfigurationPropertyBuilder.ofBoolean("tracing.disabled")
.environmentVariableName(Configuration.PROPERTY_AZURE_TRACING_DISABLED)
.shared(true)
.defaultValue(false)
.build();
private static final ConfigurationProperty PROVIDER_NAME_PROPERTY
= ConfigurationPropertyBuilder.ofString("tracing.provider.implementation")
.environmentVariableName(Configuration.PROPERTY_AZURE_TRACING_IMPLEMENTATION)
.shared(true)
.build();
private static final Configuration GLOBAL_CONFIG = Configuration.getGlobalConfiguration();
private final Class extends TracerProvider> tracerProvider;
private Set allowedQueryParamNames;
private boolean isEnabled;
/**
* Creates new instance of {@link TracingOptions}
*/
public TracingOptions() {
this(GLOBAL_CONFIG);
}
/**
* Creates new instance of {@link TracingOptions}
*
* @param tracerProvider The type of the {@link TracerProvider} implementation that should be used to construct an instance of
* {@link Tracer}.
*
* If the value is not set (or {@code null}), then the first {@link TracerProvider} resolved by {@link java.util.ServiceLoader} will
* be used to create an instance of {@link Tracer}. If the value is set and doesn't match any
* {@link TracerProvider} resolved by {@link java.util.ServiceLoader} an {@link IllegalStateException} will be thrown when
* attempting to create an instance of {@link Tracer}.
*/
protected TracingOptions(Class extends TracerProvider> tracerProvider) {
this.tracerProvider = tracerProvider;
this.isEnabled = !GLOBAL_CONFIG.get(IS_DISABLED_PROPERTY);
}
private TracingOptions(Configuration configuration) {
isEnabled = !configuration.get(IS_DISABLED_PROPERTY);
String className = configuration.get(PROVIDER_NAME_PROPERTY);
tracerProvider = className != null ? getClassByName(className) : null;
}
/**
* Loads tracing options from the configuration.
*
* @param configuration The {@link Configuration} instance containing tracing options. If
* {@code null} is passed then {@link Configuration#getGlobalConfiguration()} will be used.
* @return A {@link TracingOptions} reflecting updated tracing options loaded from the configuration,
* if no tracing options are found, default (enabled) tracing options will be returned.
*/
public static TracingOptions fromConfiguration(Configuration configuration) {
return new TracingOptions(configuration);
}
/**
* Flag indicating if distributed tracing should be enabled.
* @return {@code true} if tracing is enabled, {@code false} otherwise.
*/
public boolean isEnabled() {
return this.isEnabled;
}
/**
* Enables or disables distributed tracing. By default, tracing is enabled if and only if tracing implementation is detected.
*
* @param enabled pass {@code true} to enable tracing.
* @return the updated {@code TracingOptions} object.
*/
public TracingOptions setEnabled(boolean enabled) {
this.isEnabled = enabled;
return this;
}
/**
* Gets name of the {@link TracerProvider} implementation that should be used to construct an instance of
* {@link Tracer}.
*
* @return The {@link TracerProvider} implementation used to create an instance of {@link Tracer}.
*/
public Class extends TracerProvider> getTracerProvider() {
return tracerProvider;
}
/**
* Gets the set of query parameter names that are allowed to be recorded in the URL.
* @return The set of query parameter names that are allowed to be recorded in the URL.
*/
public Set getAllowedTracingQueryParamNames() {
return allowedQueryParamNames;
}
/**
* Sets the set of query parameter names that are allowed to be recorded in the URL.
* @param allowedQueryParamNames The set of query parameter names that are allowed to be recorded in the URL.
* @return The updated {@link TracingOptions} object.
*/
public TracingOptions setAllowedTracingQueryParamNames(final Set allowedQueryParamNames) {
this.allowedQueryParamNames = allowedQueryParamNames;
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy