NAME
POE::Component::Server::NRPE - A POE Component implementation of NRPE Daemon.
VERSION
version 0.18
SYNOPSIS
my
$port
= 5666;
my
$nrped
= POE::Component::Server::NRPE->spawn(
port
=>
$port
;
);
$nrped
->add_command(
command
=>
'meep'
,
program
=> \
&_meep
);
$poe_kernel
->run();
exit
0;
sub
_meep {
STDOUT
"OK meep\n"
;
exit
NRPE_STATE_OK;
}
DESCRIPTION
POE::Component::Server::NRPE is a POE component that implements an NRPE (Nagios Remote Plugin Executor) daemon supporting both version 1 and version 2 protocols. It also supports SSL encryption using Net::SSLeay and a hacked version of POE::Component::SSLify.
Access is controlled by specifying Net::Netmask objects to the constructor. The default behaviour is to allow access from any IP address.
CONSTRUCTOR
- spawn
-
Takes a number of parameters, which are optional:
'address'
,
bind
the listening
socket
to a particular address,
default
is IN_ADDR_ANY;
'port'
, specify a port to
listen
on,
default
is 5666;
'version'
, the NRPE protocol version to
use
,
default
is 2;
'usessl'
, set this to 0 to disable SSL support
with
NRPE Version 2,
default
is 1;
'time_out'
, specify a
time
out in seconds
for
socket
connections and commands,
default
is 10;
'access'
, an arrayref of Net::Netmask objects that will be granted access,
default
is
'any'
;
Returns a POE::Component::Server::NRPE object.
METHODS
- session_id
-
Returns the POE::Session ID of the component.
- shutdown
-
Terminates the component. Shuts down the listener and disconnects connected clients.
- getsockname
-
Access to the POE::Wheel::SocketFactory method of the underlying listening socket.
- add_command
-
This will add a command that can be run. Takes a number of parameters:
'command'
, a label
for
the command. This is what clients will request, mandatory;
'program'
, the program to run. Can be a coderef, mandatory;
'args'
, the command line arguments to pass to the above program, must be an arrayref;
The 'command' should behave like an NRPE plugin: It should print a status message to STDOUT and exit() with the test's outcome. POE::Component::Server::NRPE::Constants defines constants for the valid exit() values.
add_command() eturns 1 if successful, undef otherwise.
- del_command
-
Removes a previously defined command. Takes one argument, the previously defined label to remove.
Returns 1 if successful, undef otherwise.
INPUT EVENTS
These are events from other POE sessions that our component will handle:
- register_command
-
This will register the sending session with given command. Takes a number of parameters:
'command'
, a label
for
the command. This is what clients will request, mandatory;
'event'
, the name of the event in the registering session that will be triggered, mandatory;
'context'
, a
scalar
containing any reference data that your session demands;
The component will increment the refcount of the calling session to make sure it hangs around for events. Therefore, you should use either
unregister_command
orshutdown
to terminate registered sessions.Whenever clients request the given command, the component will send the indicated event to the registering session with the following parameters:
ARG0, a unique id of the client;
ARG1, the context (
if
any );
Your session should then do any necessary processing and use
return_result
event to return the status and output to the component. - unregister_command
-
This will unregister the sending session with the given command. Takes one parameter:
'command'
, a previously registered command, mandatory;
- return_result
-
After processing a command your session must use this event to return the status and output to the component. Takes three values:
The unique id of the client;
The status which should be 0, 1 , 2 or 3, indicating OK, WARNING, CRITICAL or UNKNOWN, respectively;
A string
with
some meaning output;
$kernel
->post(
'nrped'
,
'return_result'
,
$id
, 0,
'OK Everything was cool'
);
- shutdown
-
Terminates the component. Shuts down the listener and disconnects connected clients.
CAVEATS
Due to problems with Net::SSLeay mixing of client and server SSL is not encouraged unless fork() is employed.
TODO
Add a logging capability.
SEE ALSO
KUDOS
This module uses code derived from http://www.stic-online.de/stic/html/nrpe-generic.html Copyright (C) 2006, 2007 STIC GmbH, http://www.stic-online.de
AUTHORS
Chris Williams <chris@bingosnet.co.uk>
Rocco Caputo <rcaputo@cpan.org>
Olivier Raginel <github@babar.us>
COPYRIGHT AND LICENSE
This software is copyright (c) 2012 by Chris Williams, Rocco Caputo, Olivier Raginel and STIC GmbH.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.