summaryrefslogtreecommitdiff
path: root/files
diff options
context:
space:
mode:
authormh <mh@immerda.ch>2011-02-07 01:41:12 +0100
committermh <mh@immerda.ch>2011-02-07 01:41:12 +0100
commitef76d11b5712e9c4cdc3a7454904ddbdecfdd868 (patch)
tree245d4f661aab7fae9582e09ac4de7f92003d6d67 /files
parent1c4844d696b7ab50b8e1337d6d294e75b73189b2 (diff)
make the client config aware
Diffstat (limited to 'files')
-rw-r--r--files/irc_bot/riseup-nagios-client.pl46
1 files changed, 39 insertions, 7 deletions
diff --git a/files/irc_bot/riseup-nagios-client.pl b/files/irc_bot/riseup-nagios-client.pl
index fd28996..2467058 100644
--- a/files/irc_bot/riseup-nagios-client.pl
+++ b/files/irc_bot/riseup-nagios-client.pl
@@ -12,7 +12,39 @@ use IO::Socket;
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
# >> CONFIGURATION >>
-my $SOCKET = '/var/run/nagios/nsa.socket';
+# Read a configuration file
+# The arg can be a relative or full path, or
+# it can be a file located somewhere in @INC.
+sub ReadCfg
+{
+ my $file = $_[0];
+
+ our $err;
+
+ { # Put config data into a separate namespace
+ package CFG;
+
+ # Process the contents of the config file
+ my $rc = do($file);
+
+ # Check for errors
+ if ($@) {
+ $::err = "ERROR: Failure compiling '$file' - $@";
+ } elsif (! defined($rc)) {
+ $::err = "ERROR: Failure reading '$file' - $!";
+ } elsif (! $rc) {
+ $::err = "ERROR: Failure processing '$file'";
+ }
+ }
+
+ return ($err);
+}
+
+# Get our configuration information
+if (my $err = ReadCfg('/etc/nagios_nsa.cfg')) {
+ print(STDERR $err, "\n");
+ exit(1);
+}
# << CONFIGURATION <<
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@@ -22,19 +54,19 @@ if (@ARGV == 0) {
exit(1);
}
-unless (-S $SOCKET) {
- die "Socket '$SOCKET' doesn't exist or isn't a socket!\n";
+unless (-S $CFG::Nsa{'socket'}) {
+ die "Socket '$CFG::Nsa{'socket'}' doesn't exist or isn't a socket!\n";
}
-unless (-r $SOCKET) {
- die "Socket '$SOCKET' can't be read!\n";
+unless (-r $CFG::Nsa{'socket'}) {
+ die "Socket '$CFG::Nsa{'socket'}' can't be read!\n";
}
my $sock = IO::Socket::UNIX->new (
- Peer => $SOCKET,
+ Peer => $CFG::Nsa{'socket'},
Type => SOCK_DGRAM,
Timeout => 10
-) || die "Can't open socket '$SOCKET'!\n";
+) || die "Can't open socket '$CFG::Nsa{'socket'}'!\n";
print $sock "@ARGV";
close($sock);