1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69
|
# <@LICENSE>
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to you 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.
# </@LICENSE>
=head1 NAME
Mail::SpamAssassin::Logger::Stderr - log to standard error
=head1 SYNOPSIS
loadplugin Mail::SpamAssassin::Logger::Stderr
=head1 DESCRIPTION
=cut
package Mail::SpamAssassin::Logger::Stderr;
use strict;
use warnings;
use bytes;
use re 'taint';
use POSIX ();
use Time::HiRes ();
use vars qw(@ISA);
@ISA = ();
sub new {
my $class = shift;
$class = ref($class) || $class;
my $self = { };
bless ($self, $class);
return($self);
}
sub log_message {
my ($self, $level, $msg) = @_;
my $now = Time::HiRes::time;
my $timestamp = sprintf("%s:%06.3f",
POSIX::strftime("%b %d %H:%M",localtime($now)), $now-int($now/60)*60);
# Bug 6329: %e is not in a POSIX standard, use %d instead and edit
local $1; $timestamp =~ s/^(\S+\s+)0/$1 /;
printf STDERR ("%s [%d] %s: %s\n",
$timestamp, $$, $level, $msg) or warn "Error writing to log file: $!";
}
sub close_log {
my ($self) = @_;
}
1;
|