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

com.azure.core.util.MetricsOptions Maven / Gradle / Ivy

There is a newer version: 1.54.1
Show newest version
// 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 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 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 getMeterProvider() { return meterProvider; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy