This commit is contained in:
Timur A. Fatkhullin 2024-06-09 23:41:44 +03:00
parent 8c1410ec90
commit 02811a92b5

View File

@ -20,15 +20,18 @@ namespace adc
{ {
template <traits::adc_netserver_session_c SessionT> template <traits::adc_netserver_session_c SessionT>
class AdcNetServerSessionSpdlogDecorator : public SessionT class AdcNetServerSessionSpdlogDecorator : public AdcSpdlogGenericMarkDecorator<SessionT>
{ {
protected: protected:
std::shared_ptr<spdlog::logger> _logger; using base_t = AdcSpdlogGenericMarkDecorator<SessionT>;
void* _thisAddress;
std::string _sessionID; std::string _sessionID;
public: public:
using base_t::logDebug;
using base_t::logInfo;
using base_t::logMethodCalling;
// using SessionT::sessionIdent; // using SessionT::sessionIdent;
using typename SessionT::session_ident_t; using typename SessionT::session_ident_t;
@ -36,63 +39,62 @@ public:
template <typename... ImplCtorArgTs> template <typename... ImplCtorArgTs>
AdcNetServerSessionSpdlogDecorator(std::shared_ptr<spdlog::logger> logger, ImplCtorArgTs&&... ctor_args) AdcNetServerSessionSpdlogDecorator(std::shared_ptr<spdlog::logger> logger, ImplCtorArgTs&&... ctor_args)
: SessionT(std::forward<ImplCtorArgTs>(ctor_args)...), : base_t("ADC NETSERVER SESSION", logger, std::forward<ImplCtorArgTs>(ctor_args)...)
_logger(logger),
_thisAddress((void*)std::addressof(this))
{ {
logMethodCalling(__PRETTY_FUNCTION__);
fmt::format_to(std::back_inserter(_sessionID), "{}", SessionT::sessionIdent()); fmt::format_to(std::back_inserter(_sessionID), "{}", SessionT::sessionIdent());
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::AdcNetServerSessionSpdlogDecorator (this: {})", this->setPattern(base_t::constructPattern(_sessionID));
_thisAddress);
_logger->debug("Creating network server session with ID = [{}] (ADDR = {})", _sessionID, _thisAddress); logDebug("Creating network server session with ID = [{}] (ADDR = {})", _sessionID, this->_thisAddress);
_logger->debug("use logger with name [{}] and level [{}]", _logger->name(), logDebug("Use logger with ", this->loggerInfo());
spdlog::level::to_string_view(_logger->level()));
} }
virtual ~AdcNetServerSessionSpdlogDecorator() virtual ~AdcNetServerSessionSpdlogDecorator()
{ {
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::~AdcNetServerSessionSpdlogDecorator (this: {})", logMethodCalling(__PRETTY_FUNCTION__);
_thisAddress);
_logger->debug("Deleting network server session with ID = [{}] (ADDR = {})", _sessionID, _thisAddress); logDebug("Deleting network server session with ID = [{}] (ADDR = {})", _sessionID, this->_thisAddress);
_logger->flush();
}; };
virtual session_ident_t sessionIdent() const override virtual session_ident_t sessionIdent() const override
{ {
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::sessionIdent (this: {})", _thisAddress); logMethodCalling(__PRETTY_FUNCTION__);
return SessionT::sessionIdent(); return SessionT::sessionIdent();
}; };
virtual void start() override virtual void start() override
{ {
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::start (this: {})", _thisAddress); logMethodCalling(__PRETTY_FUNCTION__);
_logger->info("Starting network server session with ID = [{}] (ADDR = {})", _sessionID, _thisAddress); logInfo("Starting network server session with ID = [{}]", _sessionID);
SessionT::start(); SessionT::start();
logInfo("Network server session [{}] is started", _sessionID);
}; };
virtual void stop() override virtual void stop() override
{ {
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::stop (this: {})", _thisAddress); logMethodCalling(__PRETTY_FUNCTION__);
_logger->info("Stopping network server session with ID = [{}] (ADDR = {})", _sessionID, _thisAddress); logInfo("Stopping network server session with ID = [{}]", _sessionID);
SessionT::stop(); SessionT::stop();
logInfo("Network server session [{}] is stopped", _sessionID);
}; };
}; };
template <traits::adc_netserver_c ServerT> template <traits::adc_netserver_c ServerT>
class AdcNetServerSpdlogDecorator : public AdcSpdlogGenericDecorator<ServerT> class AdcNetServerSpdlogDecorator : public AdcSpdlogGenericMarkDecorator<ServerT>
{ {
protected: protected:
using base_t = AdcSpdlogGenericDecorator<ServerT>; using base_t = AdcSpdlogGenericMarkDecorator<ServerT>;
std::string _serverID; std::string _serverID;
@ -106,19 +108,26 @@ public:
using typename ServerT::server_ident_t; using typename ServerT::server_ident_t;
static_assert(traits::formattable<server_ident_t>, "NETWORK SERVER IDENT TYPE MUST BE A FORMATTABLE ONE!!!");
template <typename... ImplCtorArgTs> template <typename... ImplCtorArgTs>
AdcNetServerSpdlogDecorator(std::shared_ptr<spdlog::logger> logger, ImplCtorArgTs&&... ctor_args) AdcNetServerSpdlogDecorator(std::shared_ptr<spdlog::logger> logger, ImplCtorArgTs&&... ctor_args)
: base_t(logger, std::forward<ImplCtorArgTs>(ctor_args)...) : base_t("ADC NETSERVER", logger, std::forward<ImplCtorArgTs>(ctor_args)...)
{ {
this->logMethodCalling(__PRETTY_FUNCTION__);
fmt::format_to(std::back_inserter(_serverID), "{}", ServerT::serverIdent()); fmt::format_to(std::back_inserter(_serverID), "{}", ServerT::serverIdent());
this->setPattern(base_t::constructPattern(_serverID));
logDebug("Creating network server with ID = [{}] (ADDR = {})", _serverID, this->_thisAddress); logDebug("Creating network server with ID = [{}] (ADDR = {})", _serverID, this->_thisAddress);
logDebug("Use logger with ", this->loggerInfo());
} }
virtual ~AdcNetServerSpdlogDecorator() virtual ~AdcNetServerSpdlogDecorator()
{ {
this->logMethodCalling(); this->logMethodCalling(__PRETTY_FUNCTION__);
logDebug("Deleting network server with ID = [{}] (ADDR = {})", _serverID, this->_thisAddress); logDebug("Deleting network server with ID = [{}] (ADDR = {})", _serverID, this->_thisAddress);
} }
@ -126,26 +135,31 @@ public:
virtual server_ident_t serverIdent() const virtual server_ident_t serverIdent() const
{ {
// this->logMethodCalling(__PRETTY_FUNCTION__);
return ServerT::serverIdent(); return ServerT::serverIdent();
} }
virtual void start() virtual void start()
{ {
this->logMethodCalling(); this->logMethodCalling(__PRETTY_FUNCTION__);
logInfo("Starting network server"); logInfo("Starting network server");
ServerT::start(); ServerT::start();
logInfo("Network server is started");
}; };
virtual void stop() virtual void stop()
{ {
this->logMethodCalling(); this->logMethodCalling(__PRETTY_FUNCTION__);
logInfo("Stopping network server"); logInfo("Stopping network server ...");
ServerT::stop(); ServerT::stop();
logInfo("Network server is stopped");
}; };
}; };