#pragma once #include // Y_IGNORE #include #include namespace DB { class LoggerWrapper : public nuraft::logger { private: static inline const std::unordered_map LEVELS = { {LogsLevel::trace, Poco::Message::Priority::PRIO_TRACE}, {LogsLevel::debug, Poco::Message::Priority::PRIO_DEBUG}, {LogsLevel::information, Poco::Message::PRIO_INFORMATION}, {LogsLevel::warning, Poco::Message::PRIO_WARNING}, {LogsLevel::error, Poco::Message::PRIO_ERROR}, {LogsLevel::fatal, Poco::Message::PRIO_FATAL} }; static inline const int LEVEL_MAX = static_cast(LogsLevel::trace); static inline const int LEVEL_MIN = static_cast(LogsLevel::none); public: LoggerWrapper(const std::string & name, LogsLevel level_) : log(&Poco::Logger::get(name)) , level(level_) { log->setLevel(static_cast(LEVELS.at(level))); } void put_details( int level_, const char * /* source_file */, const char * /* func_name */, size_t /* line_number */, const std::string & msg) override { LogsLevel db_level = static_cast(level_); LOG_IMPL(log, db_level, LEVELS.at(db_level), msg); } void set_level(int level_) override { level_ = std::min(LEVEL_MAX, std::max(LEVEL_MIN, level_)); level = static_cast(level_); log->setLevel(static_cast(LEVELS.at(level))); } int get_level() override { LogsLevel lvl = level; return static_cast(lvl); } private: Poco::Logger * log; std::atomic level; }; }