// Copyright The OpenTelemetry Authors // SPDX-License-Identifier: Apache-2.0 #pragma once #include "opentelemetry/context/propagation/global_propagator.h" #include "opentelemetry/context/propagation/text_map_propagator.h" #include "opentelemetry/exporters/ostream/span_exporter_factory.h" #include "opentelemetry/nostd/shared_ptr.h" #include "opentelemetry/sdk/trace/exporter.h" #include "opentelemetry/sdk/trace/processor.h" #include "opentelemetry/sdk/trace/provider.h" #include "opentelemetry/sdk/trace/simple_processor_factory.h" #include "opentelemetry/sdk/trace/tracer_context.h" #include "opentelemetry/sdk/trace/tracer_context_factory.h" #include "opentelemetry/sdk/trace/tracer_provider_factory.h" #include "opentelemetry/trace/propagation/http_trace_context.h" #include "opentelemetry/trace/provider.h" #include #include #include #include using grpc::ClientContext; using grpc::ServerContext; namespace { class GrpcClientCarrier : public opentelemetry::context::propagation::TextMapCarrier { public: GrpcClientCarrier(ClientContext *context) : context_(context) {} GrpcClientCarrier() = default; virtual opentelemetry::nostd::string_view Get( opentelemetry::nostd::string_view /* key */) const noexcept override { return ""; } virtual void Set(opentelemetry::nostd::string_view key, opentelemetry::nostd::string_view value) noexcept override { std::cout << " Client ::: Adding " << key << " " << value << "\n"; context_->AddMetadata(std::string(key), std::string(value)); } ClientContext *context_ = nullptr; }; class GrpcServerCarrier : public opentelemetry::context::propagation::TextMapCarrier { public: GrpcServerCarrier(ServerContext *context) : context_(context) {} GrpcServerCarrier() = default; virtual opentelemetry::nostd::string_view Get( opentelemetry::nostd::string_view key) const noexcept override { auto it = context_->client_metadata().find({key.data(), key.size()}); if (it != context_->client_metadata().end()) { return opentelemetry::nostd::string_view(it->second.data(), it->second.size()); } return ""; } virtual void Set(opentelemetry::nostd::string_view /* key */, opentelemetry::nostd::string_view /* value */) noexcept override { // Not required for server } ServerContext *context_ = nullptr; }; void InitTracer() { auto exporter = opentelemetry::exporter::trace::OStreamSpanExporterFactory::Create(); auto processor = opentelemetry::sdk::trace::SimpleSpanProcessorFactory::Create(std::move(exporter)); std::vector> processors; processors.push_back(std::move(processor)); // Default is an always-on sampler. std::unique_ptr context = opentelemetry::sdk::trace::TracerContextFactory::Create(std::move(processors)); std::shared_ptr provider = opentelemetry::sdk::trace::TracerProviderFactory::Create(std::move(context)); // Set the global trace provider opentelemetry::sdk::trace::Provider::SetTracerProvider(provider); // set global propagator opentelemetry::context::propagation::GlobalTextMapPropagator::SetGlobalPropagator( opentelemetry::nostd::shared_ptr( new opentelemetry::trace::propagation::HttpTraceContext())); } void CleanupTracer() { std::shared_ptr none; opentelemetry::sdk::trace::Provider::SetTracerProvider(none); } opentelemetry::nostd::shared_ptr get_tracer(std::string tracer_name) { auto provider = opentelemetry::trace::Provider::GetTracerProvider(); return provider->GetTracer(tracer_name); } } // namespace