summaryrefslogtreecommitdiffstats
path: root/src/jaegertracing/opentelemetry-cpp/sdk/include/opentelemetry/sdk/trace/tracer_provider.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/jaegertracing/opentelemetry-cpp/sdk/include/opentelemetry/sdk/trace/tracer_provider.h')
-rw-r--r--src/jaegertracing/opentelemetry-cpp/sdk/include/opentelemetry/sdk/trace/tracer_provider.h103
1 files changed, 103 insertions, 0 deletions
diff --git a/src/jaegertracing/opentelemetry-cpp/sdk/include/opentelemetry/sdk/trace/tracer_provider.h b/src/jaegertracing/opentelemetry-cpp/sdk/include/opentelemetry/sdk/trace/tracer_provider.h
new file mode 100644
index 000000000..aa0f69a2b
--- /dev/null
+++ b/src/jaegertracing/opentelemetry-cpp/sdk/include/opentelemetry/sdk/trace/tracer_provider.h
@@ -0,0 +1,103 @@
+// Copyright The OpenTelemetry Authors
+// SPDX-License-Identifier: Apache-2.0
+
+#pragma once
+
+#include <map>
+#include <memory>
+#include <mutex>
+#include <string>
+#include <vector>
+
+#include "opentelemetry/nostd/shared_ptr.h"
+#include "opentelemetry/sdk/resource/resource.h"
+#include "opentelemetry/sdk/trace/processor.h"
+#include "opentelemetry/sdk/trace/samplers/always_on.h"
+#include "opentelemetry/sdk/trace/tracer.h"
+#include "opentelemetry/sdk/trace/tracer_context.h"
+#include "opentelemetry/trace/tracer_provider.h"
+
+OPENTELEMETRY_BEGIN_NAMESPACE
+namespace sdk
+{
+namespace trace
+{
+class TracerProvider final : public opentelemetry::trace::TracerProvider
+{
+public:
+ /**
+ * Initialize a new tracer provider with a specified sampler
+ * @param processor The span processor for this tracer provider. This must
+ * not be a nullptr.
+ * @param resource The resources for this tracer provider.
+ * @param sampler The sampler for this tracer provider. This must
+ * not be a nullptr.
+ * @param id_generator The custom id generator for this tracer provider. This must
+ * not be a nullptr
+ */
+ explicit TracerProvider(
+ std::unique_ptr<SpanProcessor> processor,
+ opentelemetry::sdk::resource::Resource resource =
+ opentelemetry::sdk::resource::Resource::Create({}),
+ std::unique_ptr<Sampler> sampler = std::unique_ptr<AlwaysOnSampler>(new AlwaysOnSampler),
+ std::unique_ptr<opentelemetry::sdk::trace::IdGenerator> id_generator =
+ std::unique_ptr<opentelemetry::sdk::trace::IdGenerator>(
+ new RandomIdGenerator())) noexcept;
+
+ explicit TracerProvider(
+ std::vector<std::unique_ptr<SpanProcessor>> &&processors,
+ opentelemetry::sdk::resource::Resource resource =
+ opentelemetry::sdk::resource::Resource::Create({}),
+ std::unique_ptr<Sampler> sampler = std::unique_ptr<AlwaysOnSampler>(new AlwaysOnSampler),
+ std::unique_ptr<opentelemetry::sdk::trace::IdGenerator> id_generator =
+ std::unique_ptr<opentelemetry::sdk::trace::IdGenerator>(
+ new RandomIdGenerator())) noexcept;
+
+ /**
+ * Initialize a new tracer provider with a specified context
+ * @param context The shared tracer configuration/pipeline for this provider.
+ */
+ explicit TracerProvider(std::shared_ptr<sdk::trace::TracerContext> context) noexcept;
+
+ ~TracerProvider();
+
+ opentelemetry::nostd::shared_ptr<opentelemetry::trace::Tracer> GetTracer(
+ nostd::string_view library_name,
+ nostd::string_view library_version = "",
+ nostd::string_view schema_url = "") noexcept override;
+
+ /**
+ * Attaches a span processor to list of configured processors for this tracer provider.
+ * @param processor The new span processor for this tracer provider. This
+ * must not be a nullptr.
+ *
+ * Note: This process may not receive any in-flight spans, but will get newly created spans.
+ * Note: This method is not thread safe, and should ideally be called from main thread.
+ */
+ void AddProcessor(std::unique_ptr<SpanProcessor> processor) noexcept;
+
+ /**
+ * Obtain the resource associated with this tracer provider.
+ * @return The resource for this tracer provider.
+ */
+ const opentelemetry::sdk::resource::Resource &GetResource() const noexcept;
+
+ /**
+ * Shutdown the span processor associated with this tracer provider.
+ */
+ bool Shutdown() noexcept;
+
+ /**
+ * Force flush the span processor associated with this tracer provider.
+ */
+ bool ForceFlush(std::chrono::microseconds timeout = (std::chrono::microseconds::max)()) noexcept;
+
+private:
+ // order of declaration is important here - tracers should destroy only after context.
+ std::vector<std::shared_ptr<opentelemetry::sdk::trace::Tracer>> tracers_;
+ std::shared_ptr<sdk::trace::TracerContext> context_;
+ std::mutex lock_;
+};
+} // namespace trace
+} // namespace sdk
+OPENTELEMETRY_END_NAMESPACE