io.opentelemetry.sdk.autoconfigure.spi.metrics.ConfigurableMetricExporterProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of opentelemetry-sdk-extension-autoconfigure-spi Show documentation
Show all versions of opentelemetry-sdk-extension-autoconfigure-spi Show documentation
OpenTelemetry SDK Auto-configuration SPI
/*
* Copyright The OpenTelemetry Authors
* SPDX-License-Identifier: Apache-2.0
*/
package io.opentelemetry.sdk.autoconfigure.spi.metrics;
import io.opentelemetry.sdk.autoconfigure.spi.ConfigProperties;
import io.opentelemetry.sdk.metrics.export.MetricExporter;
/**
* A service provider interface (SPI) for providing additional exporters that can be used with the
* autoconfigured SDK. If the {@code otel.metrics.exporter} property contains a value equal to what
* is returned by {@link #getName()}, the exporter returned by {@link
* #createExporter(ConfigProperties)} will be enabled and added to the SDK.
*
* @since 1.15.0
*/
public interface ConfigurableMetricExporterProvider {
/**
* Returns a {@link MetricExporter} that can be registered to OpenTelemetry by providing the
* property value specified by {@link #getName()}.
*/
MetricExporter createExporter(ConfigProperties config);
/**
* Returns the name of this exporter, which can be specified with the {@code
* otel.metrics.exporter} property to enable it. The name returned should NOT be the same as any
* other exporter name. If the name does conflict with another exporter name, the resulting
* behavior is undefined and it is explicitly unspecified which exporter will actually be used.
*/
String getName();
}