| 1 | // |
| 2 | // SyslogChannel.cpp |
| 3 | // |
| 4 | // Library: Foundation |
| 5 | // Package: Logging |
| 6 | // Module: SyslogChannel |
| 7 | // |
| 8 | // Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH. |
| 9 | // and Contributors. |
| 10 | // |
| 11 | // SPDX-License-Identifier: BSL-1.0 |
| 12 | // |
| 13 | |
| 14 | |
| 15 | #include "Poco/SyslogChannel.h" |
| 16 | #include "Poco/Message.h" |
| 17 | #include "Poco/StringTokenizer.h" |
| 18 | #include <syslog.h> |
| 19 | |
| 20 | |
| 21 | namespace Poco { |
| 22 | |
| 23 | |
| 24 | const std::string SyslogChannel::PROP_NAME = "name" ; |
| 25 | const std::string SyslogChannel::PROP_FACILITY = "facility" ; |
| 26 | const std::string SyslogChannel::PROP_OPTIONS = "options" ; |
| 27 | |
| 28 | |
| 29 | SyslogChannel::SyslogChannel(): |
| 30 | _options(SYSLOG_CONS), |
| 31 | _facility(SYSLOG_USER), |
| 32 | _open(false) |
| 33 | { |
| 34 | } |
| 35 | |
| 36 | |
| 37 | SyslogChannel::SyslogChannel(const std::string& name, int options, int facility): |
| 38 | _name(name), |
| 39 | _options(options), |
| 40 | _facility(facility), |
| 41 | _open(false) |
| 42 | { |
| 43 | } |
| 44 | |
| 45 | |
| 46 | SyslogChannel::~SyslogChannel() |
| 47 | { |
| 48 | close(); |
| 49 | } |
| 50 | |
| 51 | |
| 52 | void SyslogChannel::open() |
| 53 | { |
| 54 | openlog(_name.c_str(), _options, _facility); |
| 55 | _open = true; |
| 56 | } |
| 57 | |
| 58 | |
| 59 | void SyslogChannel::close() |
| 60 | { |
| 61 | if (_open) |
| 62 | { |
| 63 | closelog(); |
| 64 | _open = false; |
| 65 | } |
| 66 | } |
| 67 | |
| 68 | |
| 69 | void SyslogChannel::log(const Message& msg) |
| 70 | { |
| 71 | if (!_open) open(); |
| 72 | syslog(getPrio(msg), "%s" , msg.getText().c_str()); |
| 73 | } |
| 74 | |
| 75 | |
| 76 | void SyslogChannel::setProperty(const std::string& name, const std::string& value) |
| 77 | { |
| 78 | if (name == PROP_NAME) |
| 79 | { |
| 80 | _name = value; |
| 81 | } |
| 82 | else if (name == PROP_FACILITY) |
| 83 | { |
| 84 | if (value == "LOG_KERN" ) |
| 85 | _facility = SYSLOG_KERN; |
| 86 | else if (value == "LOG_USER" ) |
| 87 | _facility = SYSLOG_USER; |
| 88 | else if (value == "LOG_MAIL" ) |
| 89 | _facility = SYSLOG_MAIL; |
| 90 | else if (value == "LOG_DAEMON" ) |
| 91 | _facility = SYSLOG_DAEMON; |
| 92 | else if (value == "LOG_AUTH" ) |
| 93 | _facility = SYSLOG_AUTH; |
| 94 | else if (value == "LOG_AUTHPRIV" ) |
| 95 | _facility = SYSLOG_AUTHPRIV; |
| 96 | else if (value == "LOG_SYSLOG" ) |
| 97 | _facility = SYSLOG_SYSLOG; |
| 98 | else if (value == "LOG_LPR" ) |
| 99 | _facility = SYSLOG_LPR; |
| 100 | else if (value == "LOG_NEWS" ) |
| 101 | _facility = SYSLOG_NEWS; |
| 102 | else if (value == "LOG_UUCP" ) |
| 103 | _facility = SYSLOG_UUCP; |
| 104 | else if (value == "LOG_CRON" ) |
| 105 | _facility = SYSLOG_CRON; |
| 106 | else if (value == "LOG_FTP" ) |
| 107 | _facility = SYSLOG_FTP; |
| 108 | else if (value == "LOG_LOCAL0" ) |
| 109 | _facility = SYSLOG_LOCAL0; |
| 110 | else if (value == "LOG_LOCAL1" ) |
| 111 | _facility = SYSLOG_LOCAL1; |
| 112 | else if (value == "LOG_LOCAL2" ) |
| 113 | _facility = SYSLOG_LOCAL2; |
| 114 | else if (value == "LOG_LOCAL3" ) |
| 115 | _facility = SYSLOG_LOCAL3; |
| 116 | else if (value == "LOG_LOCAL4" ) |
| 117 | _facility = SYSLOG_LOCAL4; |
| 118 | else if (value == "LOG_LOCAL5" ) |
| 119 | _facility = SYSLOG_LOCAL5; |
| 120 | else if (value == "LOG_LOCAL6" ) |
| 121 | _facility = SYSLOG_LOCAL6; |
| 122 | else if (value == "LOG_LOCAL7" ) |
| 123 | _facility = SYSLOG_LOCAL7; |
| 124 | } |
| 125 | else if (name == PROP_OPTIONS) |
| 126 | { |
| 127 | _options = 0; |
| 128 | StringTokenizer tokenizer(value, "|+:;," , StringTokenizer::TOK_IGNORE_EMPTY | StringTokenizer::TOK_TRIM); |
| 129 | for (StringTokenizer::Iterator it = tokenizer.begin(); it != tokenizer.end(); ++it) |
| 130 | { |
| 131 | if (*it == "LOG_CONS" ) |
| 132 | _options |= SYSLOG_CONS; |
| 133 | else if (*it == "LOG_NDELAY" ) |
| 134 | _options |= SYSLOG_NDELAY; |
| 135 | else if (*it == "LOG_PERROR" ) |
| 136 | _options |= SYSLOG_PERROR; |
| 137 | else if (*it == "LOG_PID" ) |
| 138 | _options |= SYSLOG_PID; |
| 139 | } |
| 140 | } |
| 141 | else |
| 142 | { |
| 143 | Channel::setProperty(name, value); |
| 144 | } |
| 145 | } |
| 146 | |
| 147 | |
| 148 | std::string SyslogChannel::getProperty(const std::string& name) const |
| 149 | { |
| 150 | if (name == PROP_NAME) |
| 151 | { |
| 152 | return _name; |
| 153 | } |
| 154 | else if (name == PROP_FACILITY) |
| 155 | { |
| 156 | if (_facility == SYSLOG_KERN) |
| 157 | return "LOG_KERN" ; |
| 158 | else if (_facility == SYSLOG_USER) |
| 159 | return "LOG_USER" ; |
| 160 | else if (_facility == SYSLOG_MAIL) |
| 161 | return "LOG_MAIL" ; |
| 162 | else if (_facility == SYSLOG_DAEMON) |
| 163 | return "LOG_DAEMON" ; |
| 164 | else if (_facility == SYSLOG_AUTH) |
| 165 | return "LOG_AUTH" ; |
| 166 | else if (_facility == SYSLOG_AUTHPRIV) |
| 167 | return "LOG_AUTHPRIV" ; |
| 168 | else if (_facility == SYSLOG_SYSLOG) |
| 169 | return "LOG_SYSLOG" ; |
| 170 | else if (_facility == SYSLOG_LPR) |
| 171 | return "LOG_LPR" ; |
| 172 | else if (_facility == SYSLOG_NEWS) |
| 173 | return "LOG_NEWS" ; |
| 174 | else if (_facility == SYSLOG_UUCP) |
| 175 | return "LOG_UUCP" ; |
| 176 | else if (_facility == SYSLOG_CRON) |
| 177 | return "LOG_CRON" ; |
| 178 | else if (_facility == SYSLOG_FTP) |
| 179 | return "LOG_FTP" ; |
| 180 | else if (_facility == SYSLOG_LOCAL0) |
| 181 | return "LOG_LOCAL0" ; |
| 182 | else if (_facility == SYSLOG_LOCAL1) |
| 183 | return "LOG_LOCAL1" ; |
| 184 | else if (_facility == SYSLOG_LOCAL2) |
| 185 | return "LOG_LOCAL2" ; |
| 186 | else if (_facility == SYSLOG_LOCAL3) |
| 187 | return "LOG_LOCAL3" ; |
| 188 | else if (_facility == SYSLOG_LOCAL4) |
| 189 | return "LOG_LOCAL4" ; |
| 190 | else if (_facility == SYSLOG_LOCAL5) |
| 191 | return "LOG_LOCAL5" ; |
| 192 | else if (_facility == SYSLOG_LOCAL6) |
| 193 | return "LOG_LOCAL6" ; |
| 194 | else if (_facility == SYSLOG_LOCAL7) |
| 195 | return "LOG_LOCAL7" ; |
| 196 | else |
| 197 | return "" ; |
| 198 | } |
| 199 | else if (name == PROP_OPTIONS) |
| 200 | { |
| 201 | std::string result; |
| 202 | if (_options & SYSLOG_CONS) |
| 203 | { |
| 204 | if (!result.empty()) result.append("|" ); |
| 205 | result.append("LOG_CONS" ); |
| 206 | } |
| 207 | if (_options & SYSLOG_NDELAY) |
| 208 | { |
| 209 | if (!result.empty()) result.append("|" ); |
| 210 | result.append("LOG_NDELAY" ); |
| 211 | } |
| 212 | if (_options & SYSLOG_PERROR) |
| 213 | { |
| 214 | if (!result.empty()) result.append("|" ); |
| 215 | result.append("LOG_PERROR" ); |
| 216 | } |
| 217 | if (_options & SYSLOG_PID) |
| 218 | { |
| 219 | if (!result.empty()) result.append("|" ); |
| 220 | result.append("LOG_PID" ); |
| 221 | } |
| 222 | return result; |
| 223 | } |
| 224 | else |
| 225 | { |
| 226 | return Channel::getProperty(name); |
| 227 | } |
| 228 | } |
| 229 | |
| 230 | |
| 231 | int SyslogChannel::getPrio(const Message& msg) |
| 232 | { |
| 233 | switch (msg.getPriority()) |
| 234 | { |
| 235 | case Message::PRIO_TRACE: |
| 236 | case Message::PRIO_DEBUG: |
| 237 | return LOG_DEBUG; |
| 238 | case Message::PRIO_INFORMATION: |
| 239 | return LOG_INFO; |
| 240 | case Message::PRIO_NOTICE: |
| 241 | return LOG_NOTICE; |
| 242 | case Message::PRIO_WARNING: |
| 243 | return LOG_WARNING; |
| 244 | case Message::PRIO_ERROR: |
| 245 | return LOG_ERR; |
| 246 | case Message::PRIO_CRITICAL: |
| 247 | return LOG_CRIT; |
| 248 | case Message::PRIO_FATAL: |
| 249 | return LOG_ALERT; |
| 250 | default: |
| 251 | return 0; |
| 252 | } |
| 253 | } |
| 254 | |
| 255 | |
| 256 | } // namespace Poco |
| 257 | |