// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- // vim: ts=8 sw=2 smarttab #pragma once #include #include "crimson/common/gated.h" #include "crimson/net/Dispatcher.h" #include "crimson/net/Fwd.h" #include "mon/MgrMap.h" template using Ref = boost::intrusive_ptr; namespace crimson::net { class Messenger; } class MMgrMap; class MMgrConfigure; namespace crimson::mgr { // implement WithStats if you want to report stats to mgr periodically class WithStats { public: virtual seastar::future get_stats() const = 0; virtual ~WithStats() {} }; class Client : public crimson::net::Dispatcher { public: Client(crimson::net::Messenger& msgr, WithStats& with_stats); seastar::future<> start(); seastar::future<> stop(); void report(); private: std::optional> ms_dispatch( crimson::net::ConnectionRef conn, Ref m) override; void ms_handle_reset(crimson::net::ConnectionRef conn, bool is_replace) final; void ms_handle_connect(crimson::net::ConnectionRef conn, seastar::shard_id) final; seastar::future<> handle_mgr_map(crimson::net::ConnectionRef conn, Ref m); seastar::future<> handle_mgr_conf(crimson::net::ConnectionRef conn, Ref m); seastar::future<> reconnect(); void print(std::ostream&) const; friend std::ostream& operator<<(std::ostream& out, const Client& client); private: MgrMap mgrmap; crimson::net::Messenger& msgr; WithStats& with_stats; crimson::net::ConnectionRef conn; seastar::timer report_timer; crimson::common::Gated gate; uint64_t last_config_bl_version = 0; }; inline std::ostream& operator<<(std::ostream& out, const Client& client) { client.print(out); return out; } } #if FMT_VERSION >= 90000 template <> struct fmt::formatter : fmt::ostream_formatter {}; #endif