NAME

Bot::BasicBot::Pluggable::Module::Nagios - report Nagios alerts to IRC

DESCRIPTION

A module for IRC bots powered by Bot::BasicBot::Pluggable to monitor a Nagios install and report alerts to IRC.

Multiple Nagios instances are supported; these could be separate Nagios systems, or just the same Nagios install but using different credentials. As each configured instance can have specific target channels defined, this means you could have the bot check with the username "development" and report all visible problems to the #development channel, then check again with the "sysad" username and report problems visible to that user to the #sysads channel.

Actual monitoring is done using Nagios::Scrape, which scrapes the information from the status.cgi script which powers Nagios' web interface. This means that, assuming your Nagios setup is configured to be viewable over the web, you need no further setup to allow the bot to monitor it.

SYNOPSIS

Load the module as you would any other Bot::BasicBot::Pluggable module, then configure it to watch a Nagios install and report problems to the desired channel(s) with the nagios add command.

In a direct message to the bot:

<user> nagios add http://nagios.example.com/cgi-bin/status.cgi username password #channel
<bot> OK
<user> nagios list
<bot> I'm currently monitoring the following Nagios instances:
      .. 1 : http://example.com/cgi-bin/status.cgi as dave for #chan
<user> nagios del 1
<bot> OK, deleted instance 1

(You can supply a list of channel names separated by commas, if you want reports from a given instance to be announced to more than one channel.)

TODO

Plenty of improvements are planned, including:

  • Better documentation

    I need to improve the module's documentation. For now, extra information is available by saying <help nagios> to the bot on IRC, or nagios set with no setting name for a list of valid settings with descriptions.

    I'd rather work out a good way to auto-generate documentation from the settings definitions in the code in order to make sure the docs stay in sync.

  • Acknowledging problems

    It should probably be possible to acknowledge a reported problem, preventing repeated reports of the same service/host in the same state.

  • Configurable reporting hours

    It would make sense to be able to configure the bot to only report problems during hours in which staff/volunteers are likely to be awake and paying attention to the IRC channel.

  • Configurable report templates

    It would be nice to be able to configure the format used for report messages - perhaps including colour codes to colourise elements of the message, where the channel allows it and users clients support it.

AUTHOR

David Precious, <davidp at preshweb.co.uk>

CONTRIBUTING

This module is developed on GitHub:

https://github.com/bigpresh/Bot-BasicBot-Pluggable-Module-Nagios

Pull requests / suggestions / bug reports are welcomed.

If you feel like it, even a "I'm using this and find it useful" mail to davidp@preshweb.co.uk would be appreciated - it's nice to know when people find your work useful.

(Reviews on cpanratings and/or ++'s on MetaCPAN are also very welcome.)

SUPPORT / BUGS / FEATURE REQUESTS

You can find documentation for this module with the perldoc command.

perldoc Bot::BasicBot::Pluggable::Module::Nagios

You can report bugs or make feature requests using GitHub Issues:

https://github.com/bigpresh/Bot-BasicBot-Pluggable-Module-Nagios/issues

ACKNOWLEDGEMENTS

LICENSE AND COPYRIGHT

Copyright 2011-2018 David Precious.

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.