#pragma once #include #include #include #include #include "ExtendedLogChannel.h" #include 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); void addTextLog(std::shared_ptr log, int max_priority); private: void logSplit(const Poco::Message & msg); using ChannelPtr = Poco::AutoPtr; /// Handler and its pointer casted to extended interface using ExtendedChannelPtrPair = std::pair; std::vector channels; std::mutex text_log_mutex; std::weak_ptr text_log; int text_log_max_priority = -1; }; }