#pragma once #include #include #include #include #include #include #include "ExtendedLogChannel.h" #ifdef WITH_TEXT_LOG namespace DB { class TextLog; } #endif namespace DB { /// Works as Poco::SplitterChannel, but performs additional work: /// passes logs to Client via TCP interface /// tries to use extended logging interface of child for more comprehensive logging class OwnSplitChannel : public Poco::Channel { public: /// Makes an extended message from msg and passes it to the client logs queue and child (if possible) void log(const Poco::Message & msg) override; /// Adds a child channel void addChannel(Poco::AutoPtr channel, const std::string & name); #ifdef WITH_TEXT_LOG void addTextLog(std::shared_ptr log, int max_priority); #endif void setLevel(const std::string & name, int level); private: void logSplit(const Poco::Message & msg); void tryLogSplit(const Poco::Message & msg); using ChannelPtr = Poco::AutoPtr; /// Handler and its pointer casted to extended interface using ExtendedChannelPtrPair = std::pair; std::map channels; std::mutex text_log_mutex; #ifdef WITH_TEXT_LOG std::weak_ptr text_log; std::atomic text_log_max_priority = -1; #endif }; }