blob: fc59776c670128c6088f802e2f0030561715ee35 [file] [log] [blame]
\section{\module{syslog} ---
\UNIX{} syslog library routines}
\declaremodule{builtin}{syslog}
\platform{Unix}
\modulesynopsis{An interface to the \UNIX\ syslog library routines.}
This module provides an interface to the \UNIX{} \code{syslog} library
routines. Refer to the \UNIX{} manual pages for a detailed description
of the \code{syslog} facility.
The module defines the following functions:
\begin{funcdesc}{syslog}{\optional{priority,} message}
Send the string \var{message} to the system logger. A trailing
newline is added if necessary. Each message is tagged with a priority
composed of a \var{facility} and a \var{level}. The optional
\var{priority} argument, which defaults to \constant{LOG_INFO},
determines the message priority. If the facility is not encoded in
\var{priority} using logical-or (\code{LOG_INFO | LOG_USER}), the
value given in the \function{openlog()} call is used.
\end{funcdesc}
\begin{funcdesc}{openlog}{ident\optional{, logopt\optional{, facility}}}
Logging options other than the defaults can be set by explicitly
opening the log file with \function{openlog()} prior to calling
\function{syslog()}. The defaults are (usually) \var{ident} =
\code{'syslog'}, \var{logopt} = \code{0}, \var{facility} =
\constant{LOG_USER}. The \var{ident} argument is a string which is
prepended to every message. The optional \var{logopt} argument is a
bit field - see below for possible values to combine. The optional
\var{facility} argument sets the default facility for messages which
do not have a facility explicitly encoded.
\end{funcdesc}
\begin{funcdesc}{closelog}{}
Close the log file.
\end{funcdesc}
\begin{funcdesc}{setlogmask}{maskpri}
Set the priority mask to \var{maskpri} and return the
previous mask value. Calls to \function{syslog()} with a priority
level not set in \var{maskpri} are ignored. The default is to log all
priorities. The function \code{LOG_MASK(\var{pri})} calculates the
mask for the individual priority \var{pri}. The function
\code{LOG_UPTO(\var{pri})} calculates the mask for all priorities up
to and including \var{pri}.
\end{funcdesc}
The module defines the following constants:
\begin{description}
\item[Priority levels (high to low):]
\constant{LOG_EMERG}, \constant{LOG_ALERT}, \constant{LOG_CRIT},
\constant{LOG_ERR}, \constant{LOG_WARNING}, \constant{LOG_NOTICE},
\constant{LOG_INFO}, \constant{LOG_DEBUG}.
\item[Facilities:]
\constant{LOG_KERN}, \constant{LOG_USER}, \constant{LOG_MAIL},
\constant{LOG_DAEMON}, \constant{LOG_AUTH}, \constant{LOG_LPR},
\constant{LOG_NEWS}, \constant{LOG_UUCP}, \constant{LOG_CRON} and
\constant{LOG_LOCAL0} to \constant{LOG_LOCAL7}.
\item[Log options:]
\constant{LOG_PID}, \constant{LOG_CONS}, \constant{LOG_NDELAY},
\constant{LOG_NOWAIT} and \constant{LOG_PERROR} if defined in
\code{<syslog.h>}.
\end{description}