// Copyright The OpenTelemetry Authors // SPDX-License-Identifier: Apache-2.0 #pragma once #include #include "opentelemetry/nostd/shared_ptr.h" #include "opentelemetry/nostd/span.h" #include "opentelemetry/nostd/string_view.h" #include "opentelemetry/nostd/unique_ptr.h" #include "opentelemetry/version.h" OPENTELEMETRY_BEGIN_NAMESPACE namespace metrics { template class Counter; template class Histogram; template class UpDownCounter; template class Gauge; class ObservableInstrument; class MultiObserverResult; using MultiObservableCallbackPtr = void (*)(MultiObserverResult &, void *); /** * Handles instrument creation and provides a facility for batch recording. * * This class provides methods to create new metric instruments, record a * batch of values to a specified set of instruments, and collect * measurements from all instruments. * */ class Meter { public: Meter() = default; Meter(const Meter &) = default; Meter(Meter &&) noexcept = default; Meter &operator=(const Meter &) = default; Meter &operator=(Meter &&) noexcept = default; virtual ~Meter() = default; /** * Creates a Counter with the passed characteristics and returns a unique_ptr to that Counter. * * @param name the name of the new Counter. * @param description a brief description of what the Counter is used for. * @param unit the unit of metric values following https://unitsofmeasure.org/ucum.html. * @return a shared pointer to the created Counter. */ virtual nostd::unique_ptr> CreateUInt64Counter( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; virtual nostd::unique_ptr> CreateDoubleCounter( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; /** * Creates a Asynchronous (Observable) counter with the passed characteristics and returns a * shared_ptr to that Observable Counter * * @param name the name of the new Observable Counter. * @param description a brief description of what the Observable Counter is used for. * @param unit the unit of metric values following https://unitsofmeasure.org/ucum.html. */ virtual nostd::shared_ptr CreateInt64ObservableCounter( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; virtual nostd::shared_ptr CreateDoubleObservableCounter( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; /** * Creates a Histogram with the passed characteristics and returns a unique_ptr to that Histogram. * * @param name the name of the new Histogram. * @param description a brief description of what the Histogram is used for. * @param unit the unit of metric values following https://unitsofmeasure.org/ucum.html. * @return a shared pointer to the created Histogram. */ virtual nostd::unique_ptr> CreateUInt64Histogram( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; virtual nostd::unique_ptr> CreateDoubleHistogram( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; #if OPENTELEMETRY_ABI_VERSION_NO >= 2 /** * Creates a Gauge with the passed characteristics and returns a unique_ptr to that Gauge. * * @param name the name of the new Gauge. * @param description a brief description of what the Gauge is used for. * @param unit the unit of metric values following https://unitsofmeasure.org/ucum.html. * @return a unique pointer to the created Gauge. */ virtual nostd::unique_ptr> CreateInt64Gauge( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; virtual nostd::unique_ptr> CreateDoubleGauge( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; #endif /** * Creates a Asynchronous (Observable) Gauge with the passed characteristics and returns a * shared_ptr to that Observable Gauge * * @param name the name of the new Observable Gauge. * @param description a brief description of what the Observable Gauge is used for. * @param unit the unit of metric values following https://unitsofmeasure.org/ucum.html. */ virtual nostd::shared_ptr CreateInt64ObservableGauge( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; virtual nostd::shared_ptr CreateDoubleObservableGauge( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; /** * Creates an UpDownCounter with the passed characteristics and returns a unique_ptr to that * UpDownCounter. * * @param name the name of the new UpDownCounter. * @param description a brief description of what the UpDownCounter is used for. * @param unit the unit of metric values following https://unitsofmeasure.org/ucum.html. * @return a shared pointer to the created UpDownCounter. */ virtual nostd::unique_ptr> CreateInt64UpDownCounter( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; virtual nostd::unique_ptr> CreateDoubleUpDownCounter( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; /** * Creates a Asynchronous (Observable) UpDownCounter with the passed characteristics and returns * a shared_ptr to that Observable UpDownCounter * * @param name the name of the new Observable UpDownCounter. * @param description a brief description of what the Observable UpDownCounter is used for. * @param unit the unit of metric values following https://unitsofmeasure.org/ucum.html. */ virtual nostd::shared_ptr CreateInt64ObservableUpDownCounter( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; virtual nostd::shared_ptr CreateDoubleObservableUpDownCounter( nostd::string_view name, nostd::string_view description = "", nostd::string_view unit = "") noexcept = 0; #if OPENTELEMETRY_ABI_VERSION_NO >= 2 /** * Registers a callback to be invoked when metrics are collected by this meter. The callback will * be passed a MultiObserverResult which it can use to make observations for any or all of the * instruments provided in this registration. Any measurements recorded for instruments _not_ in * the initial RegisterCallback call will be discarded. * * @param callback the callback to be invoked. * @param state the state to be passed to the callback. * @param instruments the instruments to be observed. * @return a unique identifier for the registered callback, which can be used to unregister the * callback in DeregisterCallback. */ virtual uintptr_t RegisterCallback(MultiObservableCallbackPtr callback, void *state, nostd::span instruments) noexcept = 0; /** * Unregisters a callback previously registered with RegisterCallback. * * @param callback_id the unique identifier returned by RegisterCallback. */ virtual void DeregisterCallback(uintptr_t callback_id) noexcept = 0; #endif }; } // namespace metrics OPENTELEMETRY_END_NAMESPACE