Poco::Net

class RemoteSyslogChannel

File Information

Library: Net
Package: Logging
Header: Poco/Net/RemoteSyslogChannel.h

Description

This Channel implements remote syslog logging over UDP according to RFC 5424 "The Syslog Protocol" and RFC 5426 "Transmission of syslog messages over UDP".

In addition, RemoteSyslogListener also supports the "old" BSD syslog protocol, as described in RFC 3164.

RFC 5425 structured data can be passed via the "structured-data" property of the log Message. The content of the "structured-data" property must be correct according to RFC 5425.

Example:

msg.set("structured-data", "[exampleSDID@32473 iut=\"3\" eventSource=\"Application\" eventID=\"1011\"]");

Inheritance

Direct Base Classes: Poco::Channel

All Base Classes: Poco::Channel, Poco::Configurable, Poco::RefCountedObject

Member Summary

Member Functions: close, getPrio, getProperty, log, open, registerChannel, setProperty

Inherited Functions: close, duplicate, getProperty, log, open, referenceCount, release, setProperty

Types Aliases

Ptr

using Ptr = Poco::AutoPtr < RemoteSyslogChannel >;

Enumerations

Anonymous

SYSLOG_PORT = 514

Facility

SYSLOG_KERN = (0 << 3)

kernel messages

SYSLOG_USER = (1 << 3)

random user-level messages

SYSLOG_MAIL = (2 << 3)

mail system

SYSLOG_DAEMON = (3 << 3)

system daemons

SYSLOG_AUTH = (4 << 3)

security/authorization messages

SYSLOG_SYSLOG = (5 << 3)

messages generated internally by syslogd

SYSLOG_LPR = (6 << 3)

line printer subsystem

SYSLOG_NEWS = (7 << 3)

network news subsystem

SYSLOG_UUCP = (8 << 3)

UUCP subsystem

SYSLOG_CRON = (9 << 3)

clock daemon

SYSLOG_AUTHPRIV = (10 << 3)

security/authorization messages (private)

SYSLOG_FTP = (11 << 3)

ftp daemon

SYSLOG_NTP = (12 << 3)

ntp subsystem

SYSLOG_LOGAUDIT = (13 << 3)

log audit

SYSLOG_LOGALERT = (14 << 3)

log alert

SYSLOG_CLOCK = (15 << 3)

clock daemon

SYSLOG_LOCAL0 = (16 << 3)

reserved for local use

SYSLOG_LOCAL1 = (17 << 3)

reserved for local use

SYSLOG_LOCAL2 = (18 << 3)

reserved for local use

SYSLOG_LOCAL3 = (19 << 3)

reserved for local use

SYSLOG_LOCAL4 = (20 << 3)

reserved for local use

SYSLOG_LOCAL5 = (21 << 3)

reserved for local use

SYSLOG_LOCAL6 = (22 << 3)

reserved for local use

SYSLOG_LOCAL7 = (23 << 3)

reserved for local use

Severity

SYSLOG_EMERGENCY = 0

Emergency: system is unusable

SYSLOG_ALERT = 1

Alert: action must be taken immediately

SYSLOG_CRITICAL = 2

Critical: critical conditions

SYSLOG_ERROR = 3

Error: error conditions

SYSLOG_WARNING = 4

Warning: warning conditions

SYSLOG_NOTICE = 5

Notice: normal but significant condition

SYSLOG_INFORMATIONAL = 6

Informational: informational messages

SYSLOG_DEBUG = 7

Debug: debug-level messages

Constructors

RemoteSyslogChannel

RemoteSyslogChannel();

Creates a RemoteSyslogChannel.

RemoteSyslogChannel

RemoteSyslogChannel(
    const std::string & address,
    const std::string & name,
    int facility = SYSLOG_USER,
    bool bsdFormat = false
);

Creates a RemoteSyslogChannel with the given target address, name, and facility. If bsdFormat is true, messages are formatted according to RFC 3164.

Destructor

~RemoteSyslogChannel protected virtual

~RemoteSyslogChannel();

Member Functions

close virtual

void close();

Closes the RemoteSyslogChannel.

getProperty virtual

std::string getProperty(
    const std::string & name
) const;

Returns the value of the property with the given name.

log virtual

void log(
    const Message & msg
);

Sends the message's text to the syslog service.

open virtual

void open();

Opens the RemoteSyslogChannel.

registerChannel static

static void registerChannel();

Registers the channel with the global LoggingFactory.

setProperty virtual

void setProperty(
    const std::string & name,
    const std::string & value
);

Sets the property with the given value.

The following properties are supported:

  • name: The name used to identify the source of log messages.
  • facility: The facility added to each log message. See the Facility enumeration for a list of supported values. The LOG_ prefix can be omitted and values are case insensitive (e.g. a facility value "mail" is recognized as SYSLOG_MAIL)
  • format: "bsd"/"rfc3164" (RFC 3164 format) or "new"/"rfc5424" (default)
  • loghost: The target IP address or host name where log messages are sent. Optionally, a port number (separated by a colon) can also be specified.
  • host: (optional) Host name included in syslog messages. If not specified, the host's real domain name or IP address will be used.
  • buffer: UDP socket send buffer size in bytes. If not specified, the system default is used.

getPrio protected static

static int getPrio(
    const Message & msg
);

Variables

BSD_TIMEFORMAT static

static const std::string BSD_TIMEFORMAT;

PROP_BUFFER static

static const std::string PROP_BUFFER;

PROP_FACILITY static

static const std::string PROP_FACILITY;

PROP_FORMAT static

static const std::string PROP_FORMAT;

PROP_HOST static

static const std::string PROP_HOST;

PROP_LOGHOST static

static const std::string PROP_LOGHOST;

PROP_NAME static

static const std::string PROP_NAME;

STRUCTURED_DATA static

static const std::string STRUCTURED_DATA;

SYSLOG_TIMEFORMAT static

static const std::string SYSLOG_TIMEFORMAT;

Securely control IoT edge devices from anywhere   Connect a Device