NAME

Nagios::Cmd

DESCRIPTION

A module for reading a fifo or regular file similar to the way Nagios does.

SYNOPSIS

use Nagios::Cmd;
use Nagios::Cmd::Read;
use POSIX qw/mkfifo/;

my $fifo = '/var/tmp/test.pipe';
mkfifo( $fifo, 600 );
my $writer = Nagios::Cmd->new( $fifo );
my $reader = Nagios::Cmd::Read->new( $fifo );

$writer->service_check('SSH', 'localhost', 0, 'version 1 waiting');
print $reader->readcmd(), " was written to $fifo\n";

METHODS

new()

Pass in the name of a fifo to open and read from. The fifo must already exist.

my $reader = Nagios::Cmd::Read->new( $fifo );
new_anyfile()

Same as new, but can be any type of file such as regular files or /dev/null.

my $reader = Nagios::Cmd::Read->new_anyfile( '/tmp/commands.txt' );
readcmd()

Read a single command. Just like in Nagios, the filehandle is kept open for the duration of the program. If the target file is a regular file, sysseek() will be used to rewind to the top of the file (which may not be what you want).

To turn of seeking for regular files, call $object->seek(undef);.

seek()

Turn seek on/off. Default is off.

$reader->seek(undef); # turn off seeking
$reader->seek(1);     # turn it back on

Nagios::Cmd::Read::seek(undef);
safe()

Turn use of flock() on/off. Setting it to a defined value will enable flock()ing of filehandles before reading. Setting to undef turns it off.

$reader->lock(1);     # turn on use of flock() around reads
$reader->lock(undef); # turn it off

Nagios::Cmd::Read::lock(1);

AUTHOR

Al Tobey <tobeya@cpan.org>