| vuser documentation | Contained in the vuser distribution. |
VUser::Log::File - File log module
Log to a file. VUser::Log::File allows the file to be moved or rotated without stopping while vuser is running. (This is especially important if you are using vsoapd.) The missing file will be recreated as needed.
[Log File] log file = /var/log/vuser.log # Include timestamps in the output show timestamp = yes
Randy Smith <perlstalker@vuser.org>
This file is part of vuser. vuser is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. vuser is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with vuser; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
| vuser documentation | Contained in the vuser distribution. |
package VUser::Log::File; use warnings; use strict; # Copyright 2005 Randy Smith <perlstalker@vuser.org> # $Id: File.pm,v 1.5 2007-07-02 20:00:14 perlstalker Exp $ our $VERSION = "0.3.0"; use VUser::ExtLib qw(:config); use VUser::Log qw(:levels); our @ISA = qw(VUser::Log); use IO::File; my $c_sec = 'Log File'; my @levels = ('', 'DEBUG', 'INFO', 'NOTICE', 'WARN', 'ERROR', 'CRIT', 'ALERT', 'EMERG'); sub init { my $self = shift; my $cfg = shift; my $log_file = strip_ws($cfg->{$c_sec}{'log file'}); $self->add_member('log_file', $log_file); my $use_timestamp = check_bool($cfg->{$c_sec}{'use timestamp'}); $self->add_member('use_timestamp', $use_timestamp); my $fh = new IO::File; if ($fh->open(">> ".$self->log_file)) { $fh->autoflush(1); $self->add_member('fh', $fh); } else { die "Unable to open log file ".$self->log_file.": $!\n"; } } sub write_msg { my $self = shift; my ($level, $msg) = @_; if (not defined $level) { $level = VUser::Log::LOG_ERR(); } my $out = ''; if ($self->use_timestamp) { my @now = localtime; $out .= sprintf('%04d-%02d-%02d %02d:%02d:%02d ', $now[5]+1900, $now[4]+1, $now[3], $now[2], $now[1], $now[0]); } $out .= sprintf ('%s: %s ', $self->ident, $levels[$level]); $out .= "$msg\n"; eval { $self->fh->print($out); #print STDERR "Print: $out"; }; if ($@) { #warn "Unable to write to logs. Retrying: $@\n"; # There was a problem printing. Try reopening the file and try again. $self->fh->close(); $self->{'fh'} = IO::File->new(); $self->fh->autoflush(1); if ($self->{'fh'}->open('>>'.$self->log_file)) { eval { $self->fh->print($out); }; if ($@) { # We cannot log any more die "Unable to write logs: $@\n"; } } else { die "Unable to write logs. Reopen failed: $@\n"; } } } 1; __END__