summaryrefslogtreecommitdiff
path: root/src/logger_syslog.cc
diff options
context:
space:
mode:
authorJoel Klinghed <the_jk@spawned.biz>2021-11-17 22:34:57 +0100
committerJoel Klinghed <the_jk@spawned.biz>2021-11-17 22:34:57 +0100
commit6232d13f5321b87ddf12a1aa36b4545da45f173d (patch)
tree23f3316470a14136debd9d02f9e920ca2b06f4cc /src/logger_syslog.cc
Travel3: Simple image and video display site
Reads the images and videos from filesystem and builds a site in memroy.
Diffstat (limited to 'src/logger_syslog.cc')
-rw-r--r--src/logger_syslog.cc45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/logger_syslog.cc b/src/logger_syslog.cc
new file mode 100644
index 0000000..684405c
--- /dev/null
+++ b/src/logger_syslog.cc
@@ -0,0 +1,45 @@
+#include "common.hh"
+
+#include "logger_base.hh"
+
+#include <string>
+#include <syslog.h>
+
+namespace {
+
+class LoggerSyslog : public LoggerBase {
+public:
+ explicit LoggerSyslog(std::string const& prgname) {
+ openlog(prgname.c_str(), LOG_PID, LOG_DAEMON);
+ }
+
+ ~LoggerSyslog() 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<int>(msg.length()), msg.data());
+ }
+};
+
+} // namespace
+
+std::unique_ptr<Logger> Logger::create_syslog(std::string const& prgname) {
+ return std::make_unique<LoggerSyslog>(prgname);
+}