Blame scripts/services/syslog-ng

Packit 57988d
###########################################################################
Packit Service 41b10a
# $Id: syslog-ng 280 2014-12-24 15:29:13Z stefjakobs $
Packit 57988d
###########################################################################
Packit 57988d
Packit 57988d
###########################################################################
Packit 57988d
# This was written and is maintained by:
Packit 57988d
#    Stefan Jakobs <logwatch at localside.net>
Packit 57988d
#
Packit 57988d
# Please send all comments, suggestions, bug reports,
Packit 57988d
#    etc, to logwatch at localside.net.
Packit 57988d
###########################################################################
Packit 57988d
# Copyright (c) 2008-2013 Stefan Jakobs
Packit 57988d
# Covered under the included MIT/X-Consortium License:
Packit 57988d
#    http://www.opensource.org/licenses/mit-license.php
Packit 57988d
# Permission is hereby granted, free of charge, to any person obtaining a
Packit 57988d
# copy of this software and associated documentation files (the "Software"),
Packit 57988d
# to deal in the Software without restriction, including without limitation
Packit 57988d
# the rights to use, copy, modify, merge, publish, distribute, sublicense,
Packit 57988d
# and/or sell copies of the Software, and to permit persons to whom the
Packit 57988d
# Software is furnished to do so, subject to the following conditions:
Packit 57988d
#
Packit 57988d
# The above copyright notice and this permission notice shall be included
Packit 57988d
# in all copies or substantial portions of the Software.
Packit 57988d
#
Packit 57988d
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
Packit 57988d
# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
Packit 57988d
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
Packit 57988d
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
Packit 57988d
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
Packit 57988d
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
Packit 57988d
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Packit 57988d
###########################################################################
Packit 57988d
Packit 57988d
#use warnings;
Packit 57988d
use strict;
Packit 57988d
Packit 57988d
my $Detail         = $ENV{'LOGWATCH_DETAIL_LEVEL'} || 0;
Packit 57988d
my $Version        = "1.4-20130219";
Packit 57988d
Packit 57988d
# initialize logwatch variables 
Packit 57988d
my $ThisLine        = "";
Packit 57988d
my %OtherList       = ();
Packit 57988d
Packit 57988d
# initialize variables which save the stats
Packit 57988d
my ($Starts,$Stops,$Reloads)       = ( 0, 0, 0);
Packit 57988d
my ($Perms,$FileOpenErrors)        = ( 0, 0);
Packit 57988d
my ($Drops, $WriteErrsSum)         = ( 0, 0);
Packit 57988d
my ($ExceedConns)                  = ( 0);
Packit 57988d
my (%PermFiles, %OpenFiles)        = ( (), ());
Packit 57988d
my (%WriteErrs, %Connections)      = ( (), ());
Packit 57988d
my (%Conns, %ConnsSum)             = ();
Packit 57988d
my (%Stats_center, %Stats_source, %Stats_dest)   = ( (), (), ());
Packit 57988d
my (%Stats_dropped, %Stats_supp, %Stats_global)  = ( (), (), ());
Packit 57988d
my (%Stats_program, %Stats_stored, %Stats_net)   = ( (), (), ());
Packit 57988d
my (%Stats_dropped_program, %Stats_supp_program) = ( (), ());
Packit 57988d
my (%Stats_dropped_net, %Stats_supp_net)         = ( (), ());
Packit 57988d
my (%Warnings, %IntErrors)                       = ( (), ());
Packit 57988d
Packit 57988d
### Parse the lines ###
Packit 57988d
Packit 57988d
while (defined($ThisLine = <STDIN>)) {
Packit 57988d
   chomp($ThisLine);
Packit 57988d
Packit 57988d
   #TD syslog-ng[2351]: New configuration initialized;
Packit 57988d
   if ( ($ThisLine =~ /^[Nn]ew configuration initialized/ ) ||
Packit 57988d
        ($ThisLine =~ /^EOF on control channel, closing connection;/ ) ||
Packit 57988d
        ($ThisLine =~ /^(?:POLLERR|EOF) occurred while idle;/ )
Packit 57988d
   ) {
Packit 57988d
      #ignore
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[9754]: Changing permissions on special file /dev/xconsole
Packit 57988d
   elsif ($ThisLine =~ /^Changing permissions on special file ((\/[a-zA-Z0-9_]*)*)$/) {
Packit 57988d
      %PermFiles = (%PermFiles, $1 => $PermFiles{$1}+1);
Packit 57988d
      $Perms++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[9754]: Cannot open file /tmp/.adir/afile for writing (No such file or directory)
Packit 57988d
   elsif ($ThisLine =~ /^Cannot open file ((\/[a-zA-Z0-9_.]*)*) .*/) {
Packit 57988d
      # $1 fq file name, $2 only filename
Packit 57988d
      %OpenFiles = (%OpenFiles, $1 => $OpenFiles{$1}+1);
Packit 57988d
      $FileOpenErrors++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[9754]: SIGHUP received, restarting syslog-ng
Packit 57988d
   #TD syslog-ng[4027]: Configuration reload request received, reloading configuration;
Packit 57988d
   elsif ($ThisLine =~ /^SIGHUP received, restarting syslog-ng$/ ||
Packit 57988d
      $ThisLine =~ /^Configuration reload request received, reloading configuration;/) {
Packit 57988d
      $Reloads++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[9754]: syslog-ng version 1.6.2 starting
Packit 57988d
   #TD syslog-ng[3956]: syslog-ng starting up; version='2.0.9'
Packit 57988d
   elsif ($ThisLine =~ /^syslog-ng version [\d.]+ starting$/ ||
Packit 57988d
      $ThisLine =~ /^syslog-ng starting up; version='[\d.]+'$/) {
Packit 57988d
      $Starts++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[9754]: syslog-ng version 1.6.2 going down
Packit 57988d
   #TD syslog-ng[20043]: syslog-ng shutting down; version='2.0.9'
Packit 57988d
   elsif ($ThisLine =~ /^syslog-ng version [\d.]+ going down$/ ||
Packit 57988d
      $ThisLine =~ /^syslog-ng shutting down; version='[\d.]+'$/) {
Packit 57988d
      $Stops++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[20043]: Termination requested via signal, terminating;
Packit 57988d
   elsif ($ThisLine =~ /^Termination requested via signal, terminating;/) {
Packit 57988d
      # happens with shutdown, but it's not for extra accounting
Packit 57988d
   }
Packit 57988d
Packit 57988d
   # syslog-ng v1.X
Packit 57988d
   #TD syslog-ng[4833]: STATS: dropped 0
Packit 57988d
   elsif ($ThisLine =~ /^STATS: dropped ([0-9]*)$/) {
Packit 57988d
      if ($1 != 0) { $Drops = $Drops + $1; }
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[4833]: Syslog connection closed; fd='45', client='AF_INET(192.168.1.1:40280)', local='AF_INET(192.168.1.10:625)'
Packit 57988d
   #TD syslog-ng[4833]: Syslog connection accepted; fd='52', client='AF_INET(192.168.1.1:40280)', local='AF_INET(192.168.1.10:625)'
Packit 57988d
   # syslog-ng v3.X
Packit 57988d
   #TD Syslog connection broken; fd='63', server='AF_INET(192.169.1.1:514)', time_reopen='60' : 44 Time(s)
Packit 57988d
   #TD Syslog connection established; fd='48', server='AF_INET(192.168.1.1:514)', local='AF_INET(0.0.0.0:0)' 
Packit 57988d
   elsif ($ThisLine =~ /^Syslog connection (\S+); fd='\d+', (server|client)='AF_INET\(([.\d]+):\d+\)', (?:local='AF_INET\(([.\d]+:\d+)\)'|time_reopen='\d+')?$/) {
Packit 57988d
      my $loc = defined($4) ? $4 : '0.0.0.0';
Packit 57988d
      $Connections{"$1 ($2)"}{$loc}{$3}++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[4833]: Connection broken to AF_INET(XXX.YYY.ZZZ.AAA:BBB), reopening in 60 seconds
Packit 57988d
   elsif ($ThisLine =~ /^Connection broken to [A-Z_]*\((([0-9]{1,3}\.){3}[0-9]{1,3}:[0-9]{1,5})\), reopening in [0-9]* seconds$/) {
Packit 57988d
      $Conns{'Connection broken'}{$1}++;
Packit 57988d
      $ConnsSum{'Connection broken'}++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   # syslog-ng v2.X
Packit 57988d
   #TD syslog-ng[4833]: Connection failed; error='Connection timed out (110)', time_reopen='60'
Packit 57988d
   #TD syslog-ng[4833]: Connection failed; error='Connection refused (111)', time_reopen='60'
Packit 57988d
   #TD syslog-ng[4833]: Connection broken; time_reopen='60' 
Packit 57988d
   elsif ($ThisLine =~ /^(Connection \w+); (?:error='([^\(']+) \(\d+\)', )?time_reopen='\d+'/ ) {
Packit 57988d
      $Conns{$1}{$2}++;
Packit 57988d
      $ConnsSum{$1}++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[4869]: io.c: do_write: write() failed (errno 111), Connection refused
Packit 57988d
   #TD syslog-ng[4869]: I/O error occurred while writing; fd='66', error='Connection refused (111)'
Packit 57988d
   elsif ( ($ThisLine =~ /^io\.c: do_write: write\(\) failed \(errno ([\d]+)\)/) or 
Packit 57988d
           ($ThisLine =~ /I\/O error occurred while writing; fd='\d+', error='[^'(]+ \((\d+)\)'/) 
Packit 57988d
   ) {
Packit 57988d
      $WriteErrs{$1}++;
Packit 57988d
      $WriteErrsSum++;
Packit 57988d
   } 
Packit 57988d
Packit 57988d
   # Log statistics from syslog-ng v2.X
Packit 57988d
   #TD syslog-ng[4883]: Log statistics; dropped='program(/path/to/p)=12', 
Packit 57988d
   #        processed='center(queued)=1717', processed='center(received)=916', ...
Packit 57988d
   #        suppressed='program(/path/to/p)=0'
Packit 57988d
   # Log statisctics from syslog-ng v3.X
Packit 57988d
   #TD syslog-ng[1625]: Log statistics; processed='destination(newsnotice)=0',
Packit 57988d
   #     processed='center(queued)=0', processed='src.internal(src#0)=7',
Packit 57988d
   #     stamp='src.internal(src#0)=1283808150', processed='global(msg_clones)=0', ...
Packit 57988d
   elsif ($ThisLine =~ /^Log statistics; /) {
Packit 57988d
      my @processed = 
Packit 57988d
         $ThisLine =~ /processed='([a-z.]*)\((\S*)\)=([0-9]*)'/g;
Packit 57988d
      for (my $i=0; $i<@processed; $i=$i+3)
Packit 57988d
      {
Packit 57988d
         if ($processed[$i] eq "center") { 
Packit 57988d
            $Stats_center{$processed[$i+1]} = 
Packit 57988d
               $Stats_center{$processed[$i+1]} + $processed[$i+2]; 
Packit 57988d
         } elsif ($processed[$i] eq "destination") {
Packit 57988d
            $Stats_dest{$processed[$i+1]} = 
Packit 57988d
               $Stats_dest{$processed[$i+1]} + $processed[$i+2];
Packit 57988d
         } elsif ($processed[$i] eq "source" || $processed[$i] eq "src.internal" ||
Packit Service 41b10a
                  $processed[$i] eq 'src.none' || $processed[$i] eq 'src.journald') {
Packit 57988d
            $Stats_source{$processed[$i+1]} = 
Packit 57988d
               $Stats_source{$processed[$i+1]} + $processed[$i+2];
Packit 57988d
         } elsif ($processed[$i] eq "global") {
Packit 57988d
            $Stats_global{$processed[$i+1]} =
Packit 57988d
               $Stats_global{$processed[$i+1]} + $processed[$i+2];
Packit 57988d
         } elsif ($processed[$i] eq "dst.program") {
Packit 57988d
            $Stats_program{$processed[$i+1]} =
Packit 57988d
               $Stats_program{$processed[$i+1]} + $processed[$i+2];
Packit 57988d
         } elsif ($processed[$i] =~ /(?:dst\.)?(?:udp|tcp)/) {
Packit 57988d
            $Stats_net{$processed[$i+1]} =
Packit 57988d
               $Stats_net{$processed[$i+1]} + $processed[$i+2];
Packit 57988d
         } else { chomp($ThisLine); $OtherList{$ThisLine}++; }
Packit 57988d
      }
Packit 57988d
      my @dropped =
Packit 57988d
              $ThisLine =~ /dropped='([a-z.]*)\((\S*)\)=([0-9]*)'/g;
Packit 57988d
      for (my $i=0; $i<@dropped; $i=$i+3)
Packit 57988d
      {
Packit 57988d
         if ($dropped[$i] eq "program" || $dropped[$i] eq "pipe") {
Packit 57988d
            if ($dropped[$i+2] > 0) {
Packit 57988d
               $Stats_dropped{$dropped[$i+1]} =
Packit 57988d
                  $Stats_dropped{$dropped[$i+1]} + $dropped[$i+2];
Packit 57988d
            }
Packit 57988d
         } elsif ($dropped[$i] =~ /(?:dst\.)?(?:tcp|udp)/) {
Packit 57988d
            if ($dropped[$i+2] > 0) {
Packit 57988d
               $Stats_dropped_net{$dropped[$i+1]} =
Packit 57988d
                  $Stats_dropped_net{$dropped[$i+1]} + $dropped[$i+2];
Packit 57988d
            }
Packit 57988d
         } elsif ($dropped[$i] eq "dst.program") {
Packit 57988d
            if ($dropped[$i+2] > 0) {
Packit 57988d
               $Stats_dropped_program{$dropped[$i+1]} =
Packit 57988d
                  $Stats_dropped_program{$dropped[$i+1]} + $dropped[$i+2];
Packit 57988d
            }
Packit 57988d
         } else { chomp($ThisLine); $OtherList{$ThisLine}++; }
Packit 57988d
      }   
Packit 57988d
      my @suppressed =
Packit 57988d
         $ThisLine =~ /suppressed='([a-z.]*)\((\S*)\)=([0-9]*)'/g;
Packit 57988d
      for (my $i=0; $i<@suppressed; $i=$i+3)
Packit 57988d
      {
Packit 57988d
         if ($suppressed[$i] eq "program" || $suppressed[$i] eq "pipe") {
Packit 57988d
            if ($suppressed[$i+2] > 0) {
Packit 57988d
               $Stats_supp{$suppressed[$i+1]} =
Packit 57988d
                  $Stats_supp{$suppressed[$i+1]} + $suppressed[$i+2];
Packit 57988d
            }
Packit 57988d
         } elsif ($suppressed[$i] =~ /(?:dst\.)?(?:tcp|udp)/) {
Packit 57988d
            if ($suppressed[$i+2] > 0) {
Packit 57988d
               $Stats_supp_net{$suppressed[$i+1]} =
Packit 57988d
                  $Stats_supp_net{$suppressed[$i+1]} + $suppressed[$i+2];
Packit 57988d
            }
Packit 57988d
         } elsif ($suppressed[$i] eq "dst.program") {
Packit 57988d
            if ($suppressed[$i+2] > 0) {
Packit 57988d
               $Stats_supp_program{$suppressed[$i+1]} =
Packit 57988d
                  $Stats_supp_program{$suppressed[$i+1]} + $suppressed[$i+2];
Packit 57988d
            }
Packit 57988d
         } else { chomp($ThisLine); $OtherList{$ThisLine}++; }
Packit 57988d
      }
Packit 57988d
      my @stored = 
Packit 57988d
          $ThisLine =~ /stored='([a-z.]*)\((\S*)\)=([0-9]*)'/g;
Packit 57988d
      for (my $i=0; $i<@stored; $i=$i+3)
Packit 57988d
      {
Packit 57988d
         if ($stored[$i] =~ "(?:dst\.)?(?:program|tcp|udp)" || $stored[$i] eq "pipe") {
Packit 57988d
            if ($stored[$i+2] > 0) {
Packit 57988d
               $Stats_stored{$stored[$i+1]} =
Packit 57988d
                  $Stats_stored{$stored[$i+1]} + $stored[$i+2];
Packit 57988d
            }
Packit 57988d
         } else { chomp($ThisLine); $OtherList{$ThisLine}++; }
Packit 57988d
      }
Packit 57988d
   }
Packit 57988d
Packit 57988d
   # syslog-ng v2.X
Packit 57988d
   #TD syslog-ng[1796]: Number of allowed concurrent connections exceeded; num='10', max='10'  
Packit 57988d
   elsif ($ThisLine =~ /^Number of allowed concurrent connections exceeded/) {
Packit 57988d
      $ExceedConns++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   # syslog-ng v3.X
Packit 57988d
   #TD syslog-ng[1601]: WARNING: global: the default value of chain_hostnames is changing to
Packit 57988d
   #     'no' in version 3.0, please update your configuration accordingly;
Packit 57988d
   #TD syslog-ng[1601]: WARNING: you are using the pipe driver, underlying file is not a
Packit 57988d
   #     FIFO, it should be used by file(); filename='/dev/tty10'
Packit 57988d
   elsif ($ThisLine =~ /^WARNING: (.*)$/) {
Packit 57988d
      $Warnings{$1}++;
Packit 57988d
   }
Packit 57988d
   # syslog-ng v3.X
Packit 57988d
   #TD syslog-ng[1601]: Configuration file has no version number, assuming ...
Packit 57988d
   elsif ($ThisLine =~ /(Configuration file has no version number)/) {
Packit 57988d
      $Warnings{$1}++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   # syslog-ng v2.X
Packit 57988d
   #TD syslog-ng[1602]: Error initializing new configuration, reverting to old config;
Packit 57988d
   elsif ($ThisLine =~ /^Error initializing new configuration, reverting to old config;/) {
Packit 57988d
      $IntErrors{"Error initializing new configuration"}{"reverting to old config"}++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   #TD syslog-ng[2550]: Internal error, duplicate configuration elements refer to
Packit 57988d
   #   the same persistent config; name='afsocket_sd_connections(dgram,AF_INET(0.0.0.0:514))'
Packit 57988d
   elsif ($ThisLine =~ /Internal error, ([^;]*); name='([^']*)'/) {
Packit 57988d
      $IntErrors{$1}{$2}++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   # syslog-ng v2.X
Packit 57988d
   #TD syslog-ng[20709]: Referenced filter rule not found; rule='f_dhcpd'
Packit 57988d
   elsif ($ThisLine =~ /(Referenced filter rule not found); (.+)/) {
Packit 57988d
      $IntErrors{$1}{$2}++
Packit 57988d
   }
Packit 57988d
Packit 57988d
   # syslog-ng v2.X
Packit 57988d
   #TD syslog-ng[2000]: Error in configuration, unresolved filter reference; filter='f_host_dhcp_dns0'
Packit 57988d
   elsif ($ThisLine =~ /^Error in configuration, ([^;]+); (.+)/) {
Packit 57988d
      $IntErrors{$1}{$2}++;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   else {
Packit 57988d
      # Report any unmatched entries...
Packit 57988d
      chomp($ThisLine);
Packit 57988d
      $OtherList{$ThisLine}++;
Packit 57988d
   }
Packit 57988d
}
Packit 57988d
Packit 57988d
### generate the output ###
Packit 57988d
Packit 57988d
if ($Starts) {
Packit 57988d
    printf "\n%-48s %5i Time(s)", "Syslog-ng started:", $Starts;
Packit 57988d
}
Packit 57988d
Packit 57988d
if ($Stops) {
Packit 57988d
    printf "\n%-48s %5i Time(s)", "Syslog-ng stopped:", $Stops;
Packit 57988d
}
Packit 57988d
Packit 57988d
if ($Reloads) {
Packit 57988d
    printf "\n%-48s %5i Time(s)", "Syslog-ng reloaded:", $Reloads;
Packit 57988d
}
Packit 57988d
if ($Starts || $Stops || $Reloads) { print "\n"; }
Packit 57988d
Packit 57988d
if ($Perms) {
Packit 57988d
    if ($Detail >= 5) {
Packit 57988d
        print "\nSyslog-ng changed the permission on the file(s):";
Packit 57988d
        foreach my $file (keys %PermFiles) {
Packit 57988d
             printf "\n\t%-41s %5i Time(s)", $file, $PermFiles{$file};
Packit 57988d
        }
Packit 57988d
        print "\n";
Packit 57988d
    } else {
Packit 57988d
        printf "\n$-48s %5i Time(s)\n", "Syslog-ng changed permission on file(s):", $Perms;
Packit 57988d
    }
Packit 57988d
}
Packit 57988d
Packit 57988d
if ($FileOpenErrors) {
Packit 57988d
    if ($Detail >= 5) {
Packit 57988d
        print "\nSyslog-ng could not open the file(s):";
Packit 57988d
        foreach my $file (keys %OpenFiles) {
Packit 57988d
            printf "\n\t%-41s %5i Time(s)", $file, $OpenFiles{$file};
Packit 57988d
        }
Packit 57988d
        print "\n";
Packit 57988d
    } else {
Packit 57988d
        printf "\n%-48s %5i Time(s)\n", "Syslog-ng could not open file:", $FileOpenErrors;
Packit 57988d
    }
Packit 57988d
}
Packit 57988d
Packit 57988d
if (keys %Conns) {
Packit 57988d
    foreach my $cat (keys %Conns) {
Packit 57988d
        if ($Detail >= 5) {
Packit 57988d
            print "\n$cat:";
Packit 57988d
            foreach my $IP (keys %{$Conns{$cat}}) {
Packit 57988d
                printf "\n\t%-41s %5i Time(s)", $IP, $Conns{$cat}{$IP}; 
Packit 57988d
            }
Packit 57988d
            print "\n";
Packit 57988d
        } else {
Packit 57988d
            printf "\n%-48s %5i Time(s)\n", "$cat:", $ConnsSum{$cat};
Packit 57988d
        }
Packit 57988d
    }
Packit 57988d
}
Packit 57988d
Packit 57988d
if (keys %WriteErrs) {
Packit 57988d
    if ($Detail >= 5) {
Packit 57988d
        print "\nWrite Error(s):";
Packit 57988d
        foreach my $err (keys %WriteErrs) {
Packit 57988d
            printf "\n\t%-41s %5i Time(s)", "Error Number $err:", $WriteErrs{$err};
Packit 57988d
        }
Packit 57988d
        print "\n";
Packit 57988d
    } else {
Packit 57988d
        printf "\n%-48s %5i Time(s)\n", "Write Error(s):", $WriteErrsSum;
Packit 57988d
    }
Packit 57988d
}
Packit 57988d
Packit 57988d
if ($ExceedConns && $Detail >= 5) {
Packit 57988d
    printf "\n%-48s %5i Time(s)\n", "Concurrent Connections Exceeded:", $ExceedConns;
Packit 57988d
}
Packit 57988d
Packit 57988d
if (keys %Stats_center || keys %Stats_dest || keys %Stats_source ||
Packit 57988d
    keys %Stats_dropped || keys %Stats_supp || keys %Stats_global ||
Packit 57988d
    keys %Stats_stored || keys %Stats_program || keys %Stats_net) {
Packit 57988d
   my ($lost_rcvd, $lost_dest) = ( 0, 0);
Packit 57988d
Packit 57988d
   if ($Stats_center{received} && %Stats_source) {
Packit 57988d
      $lost_rcvd = 0 - $Stats_center{received};
Packit 57988d
      map {
Packit 57988d
         # skip 'src#X' as this seams to be aggregated into 'src'
Packit Service 41b10a
         # skip 'journal' as this is not counted.
Packit Service 41b10a
         $lost_rcvd = $lost_rcvd + $Stats_source{$_} unless ($_ =~ /(?:src#\d+|journal)/);
Packit 57988d
      } keys %Stats_source;
Packit 57988d
   }
Packit 57988d
   if ($Stats_center{queued} && %Stats_dest) {
Packit 57988d
      $lost_dest = $Stats_center{queued};
Packit 57988d
      map { $lost_dest = $lost_dest - $Stats_dest{$_} } keys %Stats_dest;
Packit 57988d
   }
Packit 57988d
Packit 57988d
   if ($Detail >= 6) { print "\nLog Statistics:"; }
Packit 57988d
   if ($lost_rcvd != 0 || $lost_dest != 0) {
Packit 57988d
      if ($lost_rcvd != 0) { 
Packit 57988d
         if ($Detail >= 5) { 
Packit 57988d
            print "\n- Failed to receive $lost_rcvd message(s)!"; 
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if ($lost_dest != 0) {
Packit 57988d
         if ($Detail >= 5 ) {
Packit 57988d
            print "\n- Failed to save $lost_dest message(s) in logfile(s)!";
Packit 57988d
         } else { $Drops = $Drops +  $lost_dest; }
Packit 57988d
      }
Packit 57988d
      if ($Detail >= 5) { print "\n"; }
Packit 57988d
   }
Packit 57988d
Packit 57988d
   if ($Detail >= 6) {
Packit 57988d
      if (keys %Stats_center) {
Packit 57988d
         print "\nCenter:";
Packit 57988d
         foreach my $center (sort {$a cmp $b} keys %Stats_center) {
Packit 57988d
            printf "\n\t%-34s %12i", $center, $Stats_center{$center};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_dest) {
Packit 57988d
         print "\nDestination:";
Packit 57988d
         foreach my $dest (sort {$a cmp $b} keys %Stats_dest) {
Packit 57988d
            printf "\n\t%-34s %12i", $dest, $Stats_dest{$dest};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_source) {
Packit 57988d
         print "\nSource:";
Packit 57988d
         foreach my $source (sort {$a cmp $b} keys %Stats_source) {
Packit 57988d
            printf "\n\t%-34s %12i", $source, $Stats_source{$source};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_net) {
Packit 57988d
         print "\nNetwork:";
Packit 57988d
         foreach my $source (sort {$a cmp $b} keys %Stats_net) {
Packit 57988d
            (my $short_source) = ($source =~ /,?([^,]*)/); 
Packit 57988d
            printf "\n\t%-34s %12i", $short_source, $Stats_net{$source};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_program) {
Packit 57988d
         print "\nProgram:";
Packit 57988d
         foreach my $source (sort {$a cmp $b} keys %Stats_program) {
Packit 57988d
            (my $short_source) = ($source =~ /,?([^,]*)/); 
Packit 57988d
            printf "\n\t%-34s %12i", $short_source, $Stats_program{$source};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_supp) {
Packit 57988d
         print "\nSuppressed:";
Packit 57988d
         foreach my $source (sort {$a cmp $b} keys %Stats_supp) {
Packit 57988d
            printf "\n\t%-34s %12i", $source, $Stats_supp{$source};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_supp_net) {
Packit 57988d
         print "\nSuppressed(net):";
Packit 57988d
         foreach my $source (sort {$a cmp $b} keys %Stats_supp_net) {
Packit 57988d
            printf "\n\t%-34s %12i", $source, $Stats_supp_net{$source};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_supp_program) {
Packit 57988d
         print "\nSuppressed(program):";
Packit 57988d
         foreach my $source (sort {$a cmp $b} keys %Stats_supp_program) {
Packit 57988d
            printf "\n\t%-34s %12i", $source, $Stats_supp_program{$source};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_stored) {
Packit 57988d
         print "\nStored:";
Packit 57988d
         foreach my $source (sort {$a cmp $b} keys %Stats_stored) {
Packit 57988d
            (my $short_source) = ($source =~ /,?([^,]*)/); 
Packit 57988d
            printf "\n\t%-34s %12i", $short_source, $Stats_stored{$source};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
      if (keys %Stats_global) {
Packit 57988d
         print "\nGlobal:";
Packit 57988d
         foreach my $source (sort {$a cmp $b} keys %Stats_global) {
Packit 57988d
            printf "\n\t%-34s %12i", $source, $Stats_global{$source};
Packit 57988d
         }
Packit 57988d
      }
Packit 57988d
   }
Packit 57988d
   if (keys %Stats_dropped) {
Packit 57988d
      print "\nDropped:";
Packit 57988d
      foreach my $source (sort {$a cmp $b} keys %Stats_dropped) {
Packit 57988d
         printf "\n\t%-34s %12i", $source, $Stats_dropped{$source};
Packit 57988d
      }
Packit 57988d
   }
Packit 57988d
   if (keys %Stats_dropped_net) {
Packit 57988d
   print "\nDropped(net):";
Packit 57988d
   foreach my $source (sort {$a cmp $b} keys %Stats_dropped_net) {
Packit 57988d
         printf "\n\t%-34s %12i", $source, $Stats_dropped_net{$source};
Packit 57988d
      }
Packit 57988d
   }
Packit 57988d
   if (keys %Stats_dropped_program) {
Packit 57988d
   print "\nDropped(program):";
Packit 57988d
   foreach my $source (sort {$a cmp $b} keys %Stats_dropped_program) {
Packit 57988d
         printf "\n\t%-34s %12i", $source, $Stats_dropped_program{$source};
Packit 57988d
      }
Packit 57988d
   }
Packit 57988d
   if (keys %Stats_center or keys %Stats_dropped or keys %Stats_dropped_net or 
Packit 57988d
       keys %Stats_dropped_program) {
Packit 57988d
      print "\n";
Packit 57988d
   }
Packit 57988d
}
Packit 57988d
Packit 57988d
if (keys %Connections) {
Packit 57988d
   foreach my $state (sort {$a cmp $b} keys %Connections) {
Packit 57988d
      my $sum = 0;
Packit 57988d
      print "\nConnections $state: ";
Packit 57988d
      print "\n" if $Detail > 2;
Packit 57988d
      foreach my $localip (sort {$a cmp $b} keys %{$Connections{$state}}) {
Packit 57988d
         print "    $localip: " if $Detail > 2;
Packit 57988d
         print "\n" if $Detail > 5;
Packit 57988d
         my $sum_pro_ip = 0;
Packit 57988d
         foreach my $extip (sort {$a cmp $b} keys %{$Connections{$state}{$localip}}) {
Packit 57988d
            print "\t$extip : $Connections{$state}{$localip}{$extip} Time(s)\n" if $Detail > 5;
Packit 57988d
            $sum = $sum + $Connections{$state}{$localip}{$extip};
Packit 57988d
            $sum_pro_ip = $sum_pro_ip + $Connections{$state}{$localip}{$extip};
Packit 57988d
         }
Packit 57988d
         print "$sum_pro_ip\n" if $Detail > 2 and $Detail <= 5;
Packit 57988d
      }
Packit 57988d
      print "$sum\n" if $Detail <= 2;
Packit 57988d
   }
Packit 57988d
}
Packit 57988d
Packit 57988d
if ($Drops) {
Packit 57988d
    print "\nSyslog-ng dropped " . $Drops ." line(s)\n";
Packit 57988d
}
Packit 57988d
Packit 57988d
if (keys %IntErrors) {
Packit 57988d
   print "\nInternal Errors:";
Packit 57988d
   foreach my $class (sort {$a cmp $b} keys %IntErrors) {
Packit 57988d
      print "\n    $class";
Packit 57988d
      foreach my $error (sort {$a cmp $b} keys %{$IntErrors{$class}}) {
Packit 57988d
         printf "\n\t%-41s %5i Time(s)", "$error:", $IntErrors{$class}{$error};
Packit 57988d
      }
Packit 57988d
   }
Packit 57988d
   print "\n";
Packit 57988d
}
Packit 57988d
Packit 57988d
if (keys %Warnings) {
Packit 57988d
   print "\nWarnings:";
Packit 57988d
   foreach my $warning (keys %Warnings) {
Packit 57988d
      printf "\n\t%-41s %5i Time(s)", "$warning:", $Warnings{$warning};
Packit 57988d
   }
Packit 57988d
   print "\n";
Packit 57988d
}
Packit 57988d
Packit 57988d
if (keys %OtherList) {
Packit 57988d
   print "\n**** Unmatched entries ****\n";
Packit 57988d
   foreach my $Error (keys %OtherList) {
Packit 57988d
      print "    $Error : $OtherList{$Error} Time(s)\n";
Packit 57988d
   }
Packit 57988d
}
Packit 57988d
Packit 57988d
### return without a failure ###
Packit 57988d
exit(0);
Packit 57988d
Packit 57988d
# vi: shiftwidth=3 tabstop=3 syntax=perl et
Packit 57988d