| 1 | #!/usr/bin/perl -w |
|---|
| 2 | |
|---|
| 3 | # Originally by Emmanuel BUU <emmanuel.buu@ives.fr> (c) IVèS 2008 |
|---|
| 4 | # Adapted for scripts.mit.edu by Mitchell Berger <mitchb@mit.edu> |
|---|
| 5 | |
|---|
| 6 | use Net::LDAP; |
|---|
| 7 | use strict; |
|---|
| 8 | |
|---|
| 9 | # Nagios codes |
|---|
| 10 | my %ERRORS=('OK'=>0, 'WARNING'=>1, 'CRITICAL'=>2, 'UNKNOWN'=>3, 'DEPENDENT'=>4); |
|---|
| 11 | |
|---|
| 12 | my $ldapserver = 'localhost'; |
|---|
| 13 | my $user = 'cn=Directory Manager'; |
|---|
| 14 | my $passwdfile = '/etc/signup-ldap-pw'; |
|---|
| 15 | my $base = "cn=config"; |
|---|
| 16 | my $server="nsDS5ReplicaHost"; |
|---|
| 17 | my $status="nsds5replicaLastUpdateStatus"; |
|---|
| 18 | my $laststart="nsds5replicaLastUpdateStart"; |
|---|
| 19 | my $lastend="nsds5replicaLastUpdateEnd"; |
|---|
| 20 | |
|---|
| 21 | my $ldap=ConnectLdap(); |
|---|
| 22 | my $result=LDAPSearch($ldap,"objectClass=nsDS5ReplicationAgreement","",$base); |
|---|
| 23 | my @entries = $result->entries; |
|---|
| 24 | my $errors = 0; |
|---|
| 25 | my $errorstring = "Replication error(s): "; |
|---|
| 26 | foreach my $entr ( @entries ) { |
|---|
| 27 | my $servername=$entr->get_value($server); |
|---|
| 28 | my $serverstatus=$entr->get_value($status); |
|---|
| 29 | my $serverlaststart=$entr->get_value($laststart); |
|---|
| 30 | my $serverlastend=$entr->get_value($lastend); |
|---|
| 31 | my $statuscode = $serverstatus; |
|---|
| 32 | $statuscode =~ s/(^[-0123456789]+) (.*$)/$1/; |
|---|
| 33 | $serverlaststart =~ s/(....)(..)(..)(..)(..)(..)./$1-$2-$3\ $4:$5:$6/; |
|---|
| 34 | $serverlastend =~ s/(....)(..)(..)(..)(..)(..)./$1-$2-$3\ $4:$5:$6/; |
|---|
| 35 | print "Replication to $servername last operation $serverlaststart "; |
|---|
| 36 | print "Status: $serverstatus. "; |
|---|
| 37 | if ($statuscode) { |
|---|
| 38 | $errors++; |
|---|
| 39 | $errorstring = $errorstring . $serverstatus . ", "; |
|---|
| 40 | } |
|---|
| 41 | } |
|---|
| 42 | if ($errors > 0) { |
|---|
| 43 | &nagios_return("WARNING", $errorstring); |
|---|
| 44 | } else { |
|---|
| 45 | &nagios_return("OK", "All replicas are OK"); |
|---|
| 46 | } |
|---|
| 47 | |
|---|
| 48 | sub ConnectLdap { |
|---|
| 49 | my $ldap = Net::LDAP->new ( $ldapserver ) or die "$@"; |
|---|
| 50 | open (PASSWD, $passwdfile) || &nagios_return("CRITICAL", "Could not read credentials"); |
|---|
| 51 | my $passwd = <PASSWD>; |
|---|
| 52 | close (PASSWD); |
|---|
| 53 | my $mesg = $ldap->bind ( "$user", password => "$passwd" , version => 3 ); |
|---|
| 54 | if ($mesg->code) { |
|---|
| 55 | &nagios_return("CRITICAL", "Failed to bind to LDAP: " . $mesg->error); |
|---|
| 56 | } |
|---|
| 57 | return $ldap; |
|---|
| 58 | } |
|---|
| 59 | |
|---|
| 60 | sub LDAPSearch { |
|---|
| 61 | my ($ldap,$searchString,$attrs,$base) = @_; |
|---|
| 62 | my $result = $ldap->search ( base => "$base", |
|---|
| 63 | scope => "sub", |
|---|
| 64 | filter => "$searchString", |
|---|
| 65 | attrs => $attrs |
|---|
| 66 | ); |
|---|
| 67 | } |
|---|
| 68 | |
|---|
| 69 | sub nagios_return($$) { |
|---|
| 70 | my ($ret, $message) = @_; |
|---|
| 71 | my ($retval, $retstr); |
|---|
| 72 | if (defined($ERRORS{$ret})) { |
|---|
| 73 | $retval = $ERRORS{$ret}; |
|---|
| 74 | $retstr = $ret; |
|---|
| 75 | } else { |
|---|
| 76 | $retstr = 'UNKNOWN'; |
|---|
| 77 | $retval = $ERRORS{$retstr}; |
|---|
| 78 | } |
|---|
| 79 | $message = "$retstr - $message\n"; |
|---|
| 80 | print $message; |
|---|
| 81 | exit $retval; |
|---|
| 82 | } |
|---|
| 83 | |
|---|