diff --git a/otlp/src/otlp/logs/logger.cpp b/otlp/src/otlp/logs/logger.cpp index ab8ca98b27f0..b505385b769c 100644 --- a/otlp/src/otlp/logs/logger.cpp +++ b/otlp/src/otlp/logs/logger.cpp @@ -230,10 +230,10 @@ void Logger::SendingLoop(Queue::Consumer& consumer, LogClient& log_client, Trace ); } while (consumer.Pop(action, deadline)); - if (config_.logs_sink == SinkType::kBoth || config_.logs_sink == SinkType::kOtlp) { + if (static_cast(config_.logs_sink) & static_cast(SinkType::kOtlp)) { DoLog(log_request, log_client); } - if (config_.tracing_sink == SinkType::kBoth || config_.tracing_sink == SinkType::kOtlp) { + if (static_cast(config_.tracing_sink) & static_cast(SinkType::kOtlp)) { DoTrace(trace_request, trace_client); } } diff --git a/otlp/src/otlp/logs/logger.hpp b/otlp/src/otlp/logs/logger.hpp index 2c0040ac8481..22df4b0adebc 100644 --- a/otlp/src/otlp/logs/logger.hpp +++ b/otlp/src/otlp/logs/logger.hpp @@ -17,7 +17,11 @@ USERVER_NAMESPACE_BEGIN namespace otlp { -enum class SinkType { kBoth, kDefault, kOtlp }; +enum class SinkType : uint8_t { + kDefault = 0x1, + kOtlp = 0x2, + kBoth = kDefault | kOtlp, +}; SinkType Parse(const yaml_config::YamlConfig& value, formats::parse::To);