source: server/fedora/config/etc/syslog-ng/d_zroot.pl @ 883

Last change on this file since 883 was 883, checked in by geofft, 16 years ago
Re r882, make the resulting log zephyr public. (Thanks to price for catching this.)
  • Property svn:executable set to *
File size: 3.8 KB
Line 
1#!/usr/bin/perl
2
3use strict;
4use warnings;
5use Sys::Hostname;
6use Time::HiRes qw(ualarm);
7use File::Temp;
8
9our $ZCLASS = "scripts-auto";
10our @USERS = qw/root logview/;
11my $k5login;
12open $k5login, '/root/.k5login';
13our @RECIPIENTS = map {chomp; m|([^/@]*)| && $1} <$k5login>;
14close $k5login;
15
16our %USERS;
17@USERS{@USERS} = undef;
18
19sub zwrite($;$$@) {
20    my ($message, $class, $instance, @recipients) = @_;
21    $class ||= $ZCLASS;
22    $instance ||= 'root.'.hostname;
23    open(ZWRITE, "|-", qw|/usr/bin/zwrite -d -n -O log -c|, $class, '-i', $instance, '-s', hostname, @recipients) or die "Couldn't open zwrite";
24    print ZWRITE $message;
25    close(ZWRITE);
26}
27
28my %toclass;
29
30my %sshkeys;
31
32sub buildKeyMap($) {
33    my ($file) = @_;
34    open (KEYS, $file) or warn "Couldn't open $file: $!";
35    while (<KEYS>) {
36        chomp;
37        my ($fingerprint, $comment) = parseKey($_);
38        $sshkeys{$fingerprint} = $comment;
39    }
40    close(KEYS);
41}
42
43sub parseKey($) {
44    my ($key) = @_;
45    my $tmp = new File::Temp;
46    print $tmp $key;
47    close $tmp;
48    open (KEYGEN, "-|", qw(/usr/bin/ssh-keygen -l -f), $tmp) or die "Couldn't call ssh-keygen: $!";
49    my ($line) = <KEYGEN>;
50    close(KEYGEN);
51    my (undef, $fingerprint, undef) = split(' ', $line, 3);
52    my (undef, undef, $comment) = split(' ', $key, 3);
53    #print "$fingerprint $comment";
54    return ($fingerprint, $comment);
55}
56
57buildKeyMap("/root/.ssh/authorized_keys2");
58
59while (1) {
60    my @message = scalar(<>);
61    eval {
62        local $SIG{ALRM} = sub { die "alarm\n" }; # NB: \n required
63        ualarm(500*1000);
64        while (<>) { push @message, $_; }
65    };
66    chomp @message;
67    map { s/^(.*?): // } @message;
68    %toclass = ();
69    foreach my $message (@message) {
70        sub sendmsg ($;$) {
71            my ($message, $class) = @_;
72            $class ||= $ZCLASS;
73            $toclass{$class} .= $message."\n";
74        }
75        if ($message =~ m|Accepted (\S+) for (\S+)|) {
76            sendmsg($message) if exists $USERS{$2}
77        } elsif ($message =~ m|Authorized to (\S+),|) {
78            sendmsg($message) if exists $USERS{$1};
79        } elsif ($message =~ m|Root (\S+) shell|) {
80            sendmsg($message);
81        } elsif ($message =~ m|session \S+ for user (\S+)|) {
82            sendmsg($message) if exists $USERS{$1};
83        } elsif ($message =~ m|^Found matching (\w+) key: (\S+)|) {
84            if ($sshkeys{$2}) {
85                sendmsg($message." (".$sshkeys{$2}.")");
86            } else {
87                sendmsg($message." (UNKNOWN KEY)");
88            }
89        } elsif ($message =~ m|^Out of memory:|) {
90            sendmsg($message);
91        } elsif ($message =~ m|^giving \S+ admin rights|) {
92            sendmsg($message);
93        } elsif ($message =~ m|^Connection closed|) {
94            # Do nothing
95        } elsif ($message =~ m|^Closing connection to |) {
96        } elsif ($message =~ m|^Connection from (\S+) port (\S+)|) {
97        } elsif ($message =~ m|^Invalid user|) {
98        } elsif ($message =~ m|^input_userauth_request: invalid user|) {
99        } elsif ($message =~ m|^Received disconnect from|) {
100        } elsif ($message =~ m|^fatal: Read from socket failed: Connection reset by peer$|) {
101        } elsif ($message =~ m|^reverse mapping checking getaddrinfo|) {
102        } elsif ($message =~ m|^pam_succeed_if\(sshd\:auth\)\:|) {
103        } elsif ($message =~ m|^error: PAM: Authentication failure|) {
104        } elsif ($message =~ m|^pam_unix\(sshd:auth\): authentication failure|) {
105        } elsif ($message =~ m|^Postponed keyboard-interactive for invalid user |) {
106        } elsif ($message =~ m|^Failed keyboard-interactive/pam for invalid user |) {
107        } elsif ($message =~ m|^Postponed gssapi-with-mic for |) {
108        } elsif ($message =~ m|^Address \S+ maps to \S+, but this does not map back to the address|) {
109        } elsif ($message =~ m|^User child is on pid \d+$|) {
110        } elsif ($message =~ m|^Transferred: sent \d+, received \d+ bytes$|) {
111        } else {
112            sendmsg($message, "scripts-spew");
113        }
114    }
115
116    foreach my $class (keys %toclass) {
117        if ($class eq "scripts-auto") {
118            zwrite($toclass{$class}, $class);
119        } else {
120            zwrite($toclass{$class}, $class, undef, @RECIPIENTS);
121        }
122    }
123}
Note: See TracBrowser for help on using the repository browser.