This file is indexed.

/usr/share/doc/mgetty/contrib/watchit.pl is in mgetty-docs 1.1.36-1.6.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/usr/bin/perl
#
# watchit.pl
#
# watch mgetty log file (the "auth.log" syslog file) for repeated failure
# messages, alarming system administrator after repeated failures
#
# RCS: $Id: watchit.pl,v 1.2 1998/10/07 13:54:06 gert Exp $
#
# $Log: watchit.pl,v $
# Revision 1.2  1998/10/07 13:54:06  gert
# add RCS keywords
#
#
require 'getopts.pl';

# configuration section
#
# which file to monitor
$logfile="/var/log/auth.log";

# send mail after <n> "failed" mgetty startups
$max_fail=3;

# who you gonna call? This user gets the mail
$faxadmin="knarf";

# mail program
$mailprg="/usr/sbin/sendmail";


# options
#
# -d: debug = show what's going on (silent operation otherwise)

$opt_d = 0;
&Getopts('d') || do { print STDERR "$0: usage: watchit [-d]\n"; die; };


$cmd="tail -f $logfile |";
$skipped=0;

open( TAILF, $cmd ) ||
	die "Can't fork command '$cmd': $!\n";

while( <TAILF> )
{
# skip "old junk"
    $skipped++;
    next if ( $skipped<10 );

    chomp;

# skip non-mgetty messages
    next unless /mgetty/;

    print "DBUG: $_\n" if $opt_d;

# skip lines with no device name given
    next unless / dev=([^\s,]+)[, ]/;

    $dev=$1;

# set up status
    if ( /failed/ )
    {
	if ( $status{$dev} ne "FAIL" )
	    { $status{$dev}="FAIL"; $failures{$dev}=1; $failmsg{$dev}=$_; }
	else
	    { $failures{$dev}++;
	      $failmsg{$dev} .= "\n" . $_;
	      if ( $failures{$dev} >= $max_fail ) { &make_noise; };
	    }
    }
    else
    { $status{$dev}="GOOD" };

    print "DBUG: status\{$dev\} now ". $status{$dev}. 
			"(" . $failures{$dev} . ")\n" if $opt_d;
}

close TAILF;

sub make_noise
{
    open( PIPE, "|$mailprg $faxadmin" ) ||
		    die "can't open pipe to mail program: $!\n";

    print PIPE <<PEOF;
To: $faxadmin
From: root (Modem Watching Servant)
Subject: sick modem on $dev
Priority: urgent

Hello $faxadmin,

one of your modems ($dev) created $max_fail failure messages
in the logfile '$logfile'. You might want to investigate!!!

The offending lines in the log file are:

----------------- snip - snap - ouch --------------------------
PEOF
    print PIPE $failmsg{$dev};

    print PIPE <<PEOF2;

----------------- snip - snap - ouch --------------------------

Kind regards,

your ever happily watching modem servant.

PEOF2

    close PIPE;

    print "sent mail to $faxadmin\n" if $opt_d;

    $failures{$dev}=-57;	# complain again in 60 mgetty cycles
}