From b4d6df902253637f24647d3db2bc3781d69eec1c Mon Sep 17 00:00:00 2001 From: Joel Klinghed Date: Thu, 20 Feb 2025 22:54:56 +0100 Subject: Initial commit --- src/logger_syslog.cc | 49 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 src/logger_syslog.cc (limited to 'src/logger_syslog.cc') diff --git a/src/logger_syslog.cc b/src/logger_syslog.cc new file mode 100644 index 0000000..54cdaf3 --- /dev/null +++ b/src/logger_syslog.cc @@ -0,0 +1,49 @@ +#include "logger_syslog.hh" + +#include +#include + +#include "logger_base.hh" + +namespace { + +class LoggerSyslogImpl : public LoggerBase { +public: + explicit LoggerSyslogImpl(std::string const& prgname) + : ident_(prgname) { + openlog(ident_.c_str(), LOG_PID, LOG_DAEMON); + } + + ~LoggerSyslogImpl() override { + closelog(); + } + +protected: + void msg(Level lvl, std::string_view msg) override { + int prio; + switch (lvl) { + case Level::ERR: + prio = LOG_ERR; + break; + case Level::WARN: + prio = LOG_WARNING; + break; + case Level::INFO: + prio = LOG_INFO; + break; + case Level::DBG: + prio = LOG_DEBUG; + break; + } + syslog(prio, "%.*s", static_cast(msg.length()), msg.data()); + } + +private: + std::string const ident_; +}; + +} // namespace + +std::unique_ptr LoggerSyslog::create(std::string const& prgname) { + return std::make_unique(prgname); +} -- cgit v1.2.3-70-g09d2