2020-09-30 13:09:48 +02:00
|
|
|
#!/usr/bin/perl
|
|
|
|
################################################################################
|
|
|
|
# Pandora FMS Omnishell client.
|
|
|
|
#
|
|
|
|
# (c) Fco de Borja Sánchez <fborja.sanchez@pandorafms.com>
|
|
|
|
#
|
2020-10-01 20:07:07 +02:00
|
|
|
# Usage: omnishell_client "C:\Program Files\pandora_agent\pandora_agent.conf"
|
|
|
|
#
|
2020-09-30 13:09:48 +02:00
|
|
|
################################################################################
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
2020-10-01 20:07:07 +02:00
|
|
|
use File::Basename;
|
2021-04-15 17:56:02 +02:00
|
|
|
BEGIN { push @INC, '/usr/lib/perl5'; }
|
2023-06-02 16:51:53 +02:00
|
|
|
|
|
|
|
# NOTE: The binary compiled with PAR::Packer for Pandora FMS doesn't work well
|
|
|
|
# with JSON:XS, probably because JSON::Backend::XS is defined in the __DATA__
|
|
|
|
# section of JSON.pm and that doesn't work well with PAR::Filter. If this
|
|
|
|
# becomes a bottleneck, a workaround would be possible (e.g., redefining
|
|
|
|
# JSON::Backend::XS here).
|
|
|
|
BEGIN { $ENV{PERL_JSON_BACKEND} = 'JSON::PP' };
|
|
|
|
|
2020-10-01 20:07:07 +02:00
|
|
|
use PandoraFMS::PluginTools;
|
2020-09-30 13:09:48 +02:00
|
|
|
use PandoraFMS::Omnishell;
|
|
|
|
|
2020-10-01 20:07:07 +02:00
|
|
|
################################################################################
|
|
|
|
# Definitions
|
|
|
|
################################################################################
|
|
|
|
my $HELP=<<EO_H;
|
|
|
|
Pandora FMS Omnishell client.
|
|
|
|
|
|
|
|
Usage:
|
|
|
|
|
|
|
|
$0 <configuration_file> [-debug 1]
|
|
|
|
|
|
|
|
Where <configuration_file> is your Pandora FMS Agent configuration.
|
|
|
|
*Recommended: use full path.
|
|
|
|
|
|
|
|
Use -debug 1 to get information extra in STDERR
|
|
|
|
|
|
|
|
EO_H
|
|
|
|
|
|
|
|
################################################################################
|
|
|
|
# Parse commands.
|
|
|
|
################################################################################
|
|
|
|
sub read_commands {
|
|
|
|
my ($config, $exp, $line, $file) = @_;
|
|
|
|
|
|
|
|
if (empty($config->{'commands'})) {
|
|
|
|
$config->{'commands'} = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
my ($ref) = $line =~ /$exp\s+(.*)/;
|
|
|
|
$config->{'commands'}->{trim($ref)} = {};
|
|
|
|
|
|
|
|
return $config;
|
|
|
|
}
|
2020-09-30 13:09:48 +02:00
|
|
|
|
2020-10-01 20:07:07 +02:00
|
|
|
|
|
|
|
################################################################################
|
|
|
|
# MAIN
|
|
|
|
################################################################################
|
|
|
|
my $ConfFile = $ARGV[0];
|
|
|
|
|
|
|
|
my $config = read_configuration({},' ', [
|
|
|
|
{
|
|
|
|
'exp' => 'cmd_file',
|
|
|
|
'target' => \&read_commands
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
|
|
|
|
if (!defined($ConfFile) || !-e $ConfFile) {
|
|
|
|
print $HELP;
|
2021-06-07 10:58:05 +02:00
|
|
|
exit 0;
|
2020-10-01 20:07:07 +02:00
|
|
|
}
|
|
|
|
|
2020-10-02 13:21:08 +02:00
|
|
|
if(!-d dirname($ConfFile).'\commands') {
|
|
|
|
mkdir(dirname($ConfFile).'\commands');
|
|
|
|
}
|
|
|
|
|
2020-10-01 20:07:07 +02:00
|
|
|
eval {
|
2020-09-30 13:09:48 +02:00
|
|
|
# Check scheduled commands
|
2020-10-01 20:07:07 +02:00
|
|
|
my $omnishell = new PandoraFMS::Omnishell(
|
|
|
|
{
|
|
|
|
%{$config},
|
|
|
|
'ConfDir' => dirname($ConfFile)
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
if (empty($omnishell->run('xml')) && is_enabled($config->{'debug'}) ) {
|
|
|
|
print STDERR $omnishell->get_last_error()."\n";
|
|
|
|
}
|
|
|
|
};
|
|
|
|
if ($@) {
|
|
|
|
if (is_enabled($config->{'debug'})) {
|
|
|
|
print STDERR $@."\n";
|
|
|
|
}
|
2021-06-07 10:58:05 +02:00
|
|
|
exit 0;
|
2020-10-01 20:07:07 +02:00
|
|
|
}
|
|
|
|
|
2023-06-02 16:51:53 +02:00
|
|
|
exit 0;
|