%PDF- %PDF-
| Direktori : /proc/thread-self/root/backups/router/usr/local/include/log4cplus/ |
| Current File : //proc/thread-self/root/backups/router/usr/local/include/log4cplus/syslogappender.h |
// -*- C++ -*-
// Module: Log4CPLUS
// File: syslogappender.h
// Created: 6/2001
// Author: Tad E. Smith
//
//
// Copyright 2001-2017 Tad E. Smith
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/** @file */
#ifndef LOG4CPLUS_SYSLOG_APPENDER_HEADER_
#define LOG4CPLUS_SYSLOG_APPENDER_HEADER_
#include <log4cplus/config.hxx>
#if defined (LOG4CPLUS_HAVE_PRAGMA_ONCE)
#pragma once
#endif
#include <log4cplus/appender.h>
#include <log4cplus/helpers/socket.h>
#include <log4cplus/helpers/connectorthread.h>
namespace log4cplus
{
/**
* Appends log events to a file.
*
* <h3>Properties</h3>
* <dl>
* <dt><tt>ident</tt></dt>
* <dd>First argument to <code>openlog()</code>, a string that
* will be prepended to every message.</dd>
*
* <dt><tt>facility</tt></dt>
* <dd>Facility is used in combination with syslog level in first
* argument to syslog(). It can be one of the supported facility
* names (case insensitive), e.g. auth, cron, kern, mail, news
* etc.</dd>
*
* <dt><tt>host</tt></dt>
* <dd>Destination syslog host. When this property is specified,
* messages are sent using UDP to destination host, otherwise
* messages are logged to local syslog.</dd>
*
* <dt><tt>port</tt></dt>
* <dd>Destination port of syslog service on host specified by the
* <tt>host</tt> property. The default value is port 514.</dd>
*
* <dt><tt>udp</tt></dt> <dd>When the syslog is remote, this
* property picks the IP protocol. When the value is true, UDP is
* used. When the value is false, TCP is used. The default value
* is true.</dd>
*
* <dt><tt>IPv6</tt></dt>
* <dd>Boolean value specifying whether to use IPv6 (true) or IPv4
* (false). Default value is false.</dd>
*
* <dt><tt>fqdn</tt></dt>
* <dd>Boolean value specifying whether to use FQDN for hostname field.
* Default value is true.</dd>
*
* </dl>
*
* \note Messages sent to remote syslog using UDP are conforming
* to RFC5424. Messages sent to remote syslog using TCP are
* using octet counting as described in RFC6587.
*/
class LOG4CPLUS_EXPORT SysLogAppender
: public Appender
#if ! defined (LOG4CPLUS_SINGLE_THREADED)
, protected virtual helpers::IConnectorThreadClient
#endif
{
public:
//! Remote syslog IP protocol type.
enum RemoteSyslogType
{
RSTUdp,
RSTTcp
};
// Ctors
#if defined (LOG4CPLUS_HAVE_SYSLOG_H)
SysLogAppender(const tstring& ident);
#endif
SysLogAppender(const tstring& ident, const tstring & host,
int port = 514, const tstring & facility = tstring (),
RemoteSyslogType remoteSyslogType = RSTUdp, bool ipv6 = false);
SysLogAppender(const tstring& ident, const tstring & host,
int port, const tstring & facility,
RemoteSyslogType remoteSyslogType, bool ipv6, bool fqdn);
SysLogAppender(const log4cplus::helpers::Properties & properties);
// Dtor
virtual ~SysLogAppender();
// Methods
virtual void close();
protected:
virtual int getSysLogLevel(const LogLevel& ll) const;
virtual void append(const spi::InternalLoggingEvent& event);
#if defined (LOG4CPLUS_HAVE_SYSLOG_H)
//! Local syslog (served by `syslog()`) worker function.
void appendLocal(const spi::InternalLoggingEvent& event);
#endif
//! Remote syslog worker function.
void appendRemote(const spi::InternalLoggingEvent& event);
// Data
tstring ident;
int facility;
typedef void (SysLogAppender:: * AppendFuncType) (
const spi::InternalLoggingEvent&);
AppendFuncType appendFunc;
tstring host;
int port;
RemoteSyslogType remoteSyslogType;
helpers::Socket syslogSocket;
bool connected;
bool ipv6 = false;
static tstring const remoteTimeFormat;
void initConnector ();
void openSocket ();
#if ! defined (LOG4CPLUS_SINGLE_THREADED)
virtual thread::Mutex const & ctcGetAccessMutex () const;
virtual helpers::Socket & ctcGetSocket ();
virtual helpers::Socket ctcConnect ();
virtual void ctcSetConnected ();
helpers::SharedObjectPtr<helpers::ConnectorThread> connector;
#endif
private:
// Disallow copying of instances of this class
SysLogAppender(const SysLogAppender&);
SysLogAppender& operator=(const SysLogAppender&);
std::string identStr;
tstring hostname;
};
} // end namespace log4cplus
#endif // LOG4CPLUS_SYSLOG_APPENDER_HEADER_