com.azure.core.util.MetricsOptions Maven / Gradle / Ivy
Show all versions of azure-core Show documentation
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.core.util;
import com.azure.core.util.metrics.Meter;
import com.azure.core.util.metrics.MeterProvider;
import static com.azure.core.implementation.ImplUtils.getClassByName;
/**
* Metrics configuration options for clients.
*/
public class MetricsOptions {
private static final ConfigurationProperty IS_DISABLED_PROPERTY = ConfigurationPropertyBuilder.ofBoolean("metrics.disabled")
.environmentVariableName(Configuration.PROPERTY_AZURE_METRICS_DISABLED)
.shared(true)
.defaultValue(false)
.build();
private static final ConfigurationProperty PROVIDER_NAME_PROPERTY = ConfigurationPropertyBuilder.ofString("metrics.provider.implementation")
.environmentVariableName(Configuration.PROPERTY_AZURE_METRICS_IMPLEMENTATION)
.shared(true)
.build();
private static final Configuration GLOBAL_CONFIG = Configuration.getGlobalConfiguration();
private final Class extends MeterProvider> meterProvider;
private boolean isEnabled;
/**
* Creates new instance of {@link MetricsOptions}
*/
public MetricsOptions() {
this(GLOBAL_CONFIG);
}
/**
* Creates new instance of {@link MetricsOptions}
*
* @param meterProvider type of the {@link MeterProvider} implementation that should be used to construct an instance of
* {@link Meter}.
* If the value isn't set or is an empty string the first {@link MeterProvider} resolved by {@link java.util.ServiceLoader} will
* be used to create an instance of {@link Meter}. If the value is set and doesn't match any
* {@link MeterProvider} resolved by {@link java.util.ServiceLoader} an {@link IllegalStateException} will be thrown when
* attempting to create an instance of {@link Meter}.
*/
protected MetricsOptions(Class extends MeterProvider> meterProvider) {
this.isEnabled = !GLOBAL_CONFIG.get(IS_DISABLED_PROPERTY);
this.meterProvider = meterProvider;
}
private MetricsOptions(Configuration configuration) {
isEnabled = !configuration.get(IS_DISABLED_PROPERTY);
String className = configuration.get(PROVIDER_NAME_PROPERTY);
meterProvider = className != null ? getClassByName(className) : null;
}
/**
* Attempts to load metrics options from the configuration.
*
* {@code null} will be returned if no metric options are found in the environment.
*
* @param configuration The {@link Configuration} that is used to load proxy configurations from the environment. If
* {@code null} is passed then {@link Configuration#getGlobalConfiguration()} will be used.
* @return A {@link MetricsOptions} reflecting a metrics loaded from configuration, if no options are found, default
* (enabled) options will be returned.
*/
public static MetricsOptions fromConfiguration(Configuration configuration) {
if (configuration.contains(IS_DISABLED_PROPERTY)) {
return new MetricsOptions().setEnabled(!configuration.get(IS_DISABLED_PROPERTY));
}
return new MetricsOptions();
}
/**
* Flag indicating if metrics should be enabled.
* @return {@code true} if metrics are enabled, {@code false} otherwise.
*/
public boolean isEnabled() {
return this.isEnabled;
}
/**
* Enables or disables metrics. By default, metrics are enabled if and only if metrics implementation is detected.
*
* @param enabled pass {@code true} to enable metrics.
* @return the updated {@code MetricsOptions} object.
*/
public MetricsOptions setEnabled(boolean enabled) {
this.isEnabled = enabled;
return this;
}
/**
* Gets configured {@link MeterProvider} implementation that should be used to construct an instance of
* {@link Meter}.
*
* @return The {@link MeterProvider} implementation used to create an instance of {@link Meter}.
*/
public Class extends MeterProvider> getMeterProvider() {
return meterProvider;
}
}