#pragma once #include #include #include #include #include #include namespace DB { struct ZooKeeperLogElement { enum Type { UNKNOWN = 0, REQUEST = 1, RESPONSE = 2, FINALIZE = 3 }; Type type = UNKNOWN; Decimal64 event_time = 0; UInt64 thread_id = 0; String query_id; Poco::Net::SocketAddress address; Int64 session_id = 0; UInt64 duration_microseconds = 0; /// Common request info Int64 xid = 0; bool has_watch = false; Int32 op_num = 0; String path; /// create, set String data; /// create bool is_ephemeral = false; bool is_sequential = false; /// remove, check, set std::optional version; /// multi UInt32 requests_size = 0; UInt32 request_idx = 0; /// Common response info Int64 zxid = 0; std::optional error; /// watch std::optional watch_type; std::optional watch_state; /// create String path_created; /// exists, get, set, list Coordination::Stat stat = {}; /// list Strings children; static std::string name() { return "ZooKeeperLog"; } static ColumnsDescription getColumnsDescription(); static NamesAndAliases getNamesAndAliases() { return {}; } void appendToBlock(MutableColumns & columns) const; }; class ZooKeeperLog : public SystemLog { using SystemLog::SystemLog; }; DataTypePtr getCoordinationErrorCodesEnumType(); }