Provided by: dnssec-tools_2.0-1_all bug

NAME

       Net::DNS::SEC::Tools::rolllog - DNSSEC-Tools rollover logging interfaces.

SYNOPSIS

         use Net::DNS::SEC::Tools::rolllog;

         @levels = rolllog_levels();

         $curlevel = rolllog_level();
         $oldlevel = rolllog_level("info");
         $oldlevel = rolllog_level(LOG_ERR,1);

         $curlogfile = rolllog_file();
         $oldlogfile = rolllog_file("-");
         $oldlogfile = rolllog_file("/var/log/roll.log",1);

         $loglevelstr = rolllog_str(8)
         $loglevelstr = rolllog_str("info")

         $ret = rolllog_num("info");

         $bool = rolllog_validlevel($newlevel);
         $bool = rolllog_validlevel(8);

         $curtz = rolllog_gettz();
         $oldtz = rolllog_settz('local');

         rolllog_log(LOG_INFO,"example.com","zone is valid");

DESCRIPTION

       The Net::DNS::SEC::Tools::rolllog module provides logging interfaces for the rollover
       programs.  The logging interfaces allow log messages to be recorded.  rollerd must be
       running, as it is responsible for updating the log file.

       Each log message is assigned a particular logging level.  The valid logging levels are:

           text       numeric  meaning
           ----       -------  -------
           tmi           1     The highest level -- all log messages
                               are saved.
           expire        3     A verbose countdown of zone expiration
                               is given.
           info          4     Many informational messages are recorded.
           phase         6     Each zone's current rollover phase
                               is given.
           err           8     Errors are recorded.
           fatal         9     Fatal errors are saved.

       The levels include all numerically higher levels.  For example, if the log level is set to
       phase, then err and fatal messages will also be recorded.

LOGGING INTERFACES

       rolllog_file(newfile,useflag)
           This routine sets and retrieves the log file for rollerd.  The newfile argument
           specifies the new log file to be set.  If newfile exists, it must be a regular file.

           The useflag argument is a boolean that indicates whether or not to give a descriptive
           message if an invalid log file is given.  If useflag is true, the message is given and
           the process exits; if false, no message is given.  For any error condition, an empty
           string is returned.

       rolllog_gettz()
           This routine returns the timezone selector currently in use.  This value may be either
           'gmt' (for Greenwich Mean Time) or 'local' (for the host's local time.)

       rolllog_level(newlevel,useflag)
           This routine sets and retrieves the logging level for rollerd.  The newlevel argument
           specifies the new logging level to be set.  newlevel may be given in either text or
           numeric form.

           The useflag argument is a boolean that indicates whether or not to give a descriptive
           message and exit if an invalid logging level is given.  If useflag is true, the
           message is given and the process exits; if false, -1 is returned.

           If given with no arguments, the current logging level is returned.  In fact, the
           current level is always returned unless an error is found.  -1 is returned on error.

       rolllog_levels()
           This routine returns an array holding the text forms of the user-settable logging
           levels.  The levels are returned in order, from most verbose to least.

       rolllog_log(level,group,message)
           The rolllog_log() interface writes a message to the log file.  Log messages have this
           format:

                   timestamp: group: message

           The level argument is the message's logging level.  It will only be written to the log
           file if the current log level is numerically equal to or less than level.

           group allows messages to be associated together.  It is currently used by rollerd to
           group messages by the zone to which the message applies.

           The message argument is the log message itself.  Trailing newlines are removed.

       rolllog_num(loglevel)
           This routine translates a text log level (given in loglevel) into the associated
           numeric log level.  The numeric log level is returned to the caller.

           If loglevel is an invalid log level, -1 is returned.

       rolllog_settz(tzsel)
           This routine sets the timezone to be used for timestamps in messages written to the
           log.  This tzsel value may be either 'gmt' (Greenwich Mean Time) or 'local' (for the
           host's local time.)  tzsel may be uppercase or lowercase; the value will be converted
           to lowercase.  If no value is passed, then the default will be used.

           The current timezone selector is returned.  If an invalid selector is given, then an
           undefined value is returned.

       rolllog_str(loglevel)
           This routine translates a log level (given in loglevel) into the associated text log
           level.  The text log level is returned to the caller.

           If loglevel is a text string, it is checked to ensure it is a valid log level.  Case
           is irrelevant when checking loglevel.

           If loglevel is numeric, it is must be in the valid range of log levels.  undef is
           returned if loglevel is invalid.

       rolllog_validlevel(level)
           This interface returns a boolean value indicating if the given logging level is valid.

           The level argument is the logging level to be validated.  It may be a numeric or
           textual value.

COPYRIGHT

       Copyright 2005-2013 SPARTA, Inc.  All rights reserved.  See the COPYING file included with
       the DNSSEC-Tools package for details.

AUTHOR

       Wayne Morrison, tewok@tislabs.com

SEE ALSO

       rollctl(1)

       rollerd(8)

       Net::DNS::SEC::Tools::rollmgr.pm(3)