+ Enhance http class (Fix #108)
This commit is contained in:
parent
1c500841c0
commit
aed5ed9304
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -44,8 +44,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,20 +62,13 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
# If not present: cpuload is 0
|
# If not present: cpuload is 0
|
||||||
my ($cpuload) = 0;
|
my ($cpuload) = 0;
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
|
@ -37,7 +37,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -49,8 +49,9 @@ sub new {
|
||||||
"critical-bytes:s" => { name => 'critical_bytes' },
|
"critical-bytes:s" => { name => 'critical_bytes' },
|
||||||
"warning-access:s" => { name => 'warning_access' },
|
"warning-access:s" => { name => 'warning_access' },
|
||||||
"critical-access:s" => { name => 'critical_access' },
|
"critical-access:s" => { name => 'critical_access' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -83,22 +84,15 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical-access threshold '" . $self->{option_results}->{critical_access} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical-access threshold '" . $self->{option_results}->{critical_access} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->{statefile_value}->check_options(%options);
|
$self->{statefile_value}->check_options(%options);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my ($rPerSec, $bPerReq, $total_access, $total_bytes, $avg_bPerSec);
|
my ($rPerSec, $bPerReq, $total_access, $total_bytes, $avg_bPerSec);
|
||||||
|
|
||||||
$total_access = $1 if ($webcontent =~ /^Total Accesses:\s+([^\s]+)/mi);
|
$total_access = $1 if ($webcontent =~ /^Total Accesses:\s+([^\s]+)/mi);
|
||||||
|
|
|
@ -25,7 +25,7 @@ use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Time::HiRes qw(gettimeofday tv_interval);
|
use Time::HiRes qw(gettimeofday tv_interval);
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -37,7 +37,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -45,8 +45,12 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
|
"unknown-status:s" => { name => 'unknown_status', default => '' },
|
||||||
|
"warning-status:s" => { name => 'warning_status' },
|
||||||
|
"critical-status:s" => { name => 'critical_status', default => '%{http_code} < 200 or %{http_code} >= 300' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,19 +67,7 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
|
@ -83,18 +75,19 @@ sub run {
|
||||||
|
|
||||||
my $timing0 = [gettimeofday];
|
my $timing0 = [gettimeofday];
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self, connection_exit => 'critical');
|
my $webcontent = $self->{http}->request();
|
||||||
|
|
||||||
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $timeelapsed,
|
my $exit = $self->{perfdata}->threshold_check(value => $timeelapsed,
|
||||||
threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(severity => $exit,
|
||||||
short_msg => sprintf("Response time %fs ", $timeelapsed));
|
short_msg => sprintf("Response time %.3fs", $timeelapsed));
|
||||||
$self->{output}->perfdata_add(label => "time",
|
$self->{output}->perfdata_add(label => "time", unit => 's',
|
||||||
value => $timeelapsed,
|
value => sprintf('%.3f', $timeelapsed),
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'));
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'),
|
||||||
|
min => 0);
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
@ -146,6 +139,18 @@ Proxy URL if any
|
||||||
|
|
||||||
Threshold for HTTP timeout
|
Threshold for HTTP timeout
|
||||||
|
|
||||||
|
=item B<--unknown-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--warning-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--critical-status>
|
||||||
|
|
||||||
|
Threshold critical for http response code (Default: '%{http_code} < 200 or %{http_code} >= 300')
|
||||||
|
|
||||||
=item B<--warning>
|
=item B<--warning>
|
||||||
|
|
||||||
Threshold warning in seconds (server-status page response time)
|
Threshold warning in seconds (server-status page response time)
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -44,8 +44,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,26 +62,14 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $ScoreBoard = "";
|
my $ScoreBoard = "";
|
||||||
if ($webcontent =~ /^Scoreboard:\s+([^\s]+)/mi) {
|
if ($webcontent =~ /^Scoreboard:\s+([^\s]+)/mi) {
|
||||||
$ScoreBoard = $1;
|
$ScoreBoard = $1;
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
"urlpath:s" => { name => 'url_path', default => "/server-status/?auto" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -44,8 +44,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,25 +62,13 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my ($BusyWorkers, $IdleWorkers, $ScoreBoard);
|
my ($BusyWorkers, $IdleWorkers, $ScoreBoard);
|
||||||
if ($webcontent =~ /^BusyWorkers:\s+([^\s]+)/mi) {
|
if ($webcontent =~ /^BusyWorkers:\s+([^\s]+)/mi) {
|
||||||
$BusyWorkers = $1;
|
$BusyWorkers = $1;
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use Digest::MD5 qw(md5_hex);
|
use Digest::MD5 qw(md5_hex);
|
||||||
use centreon::plugins::values;
|
use centreon::plugins::values;
|
||||||
|
@ -216,7 +216,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/apc.php" },
|
"urlpath:s" => { name => 'url_path', default => "/apc.php" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -225,6 +225,7 @@ sub new {
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
||||||
|
|
||||||
foreach (keys %{$maps_counters}) {
|
foreach (keys %{$maps_counters}) {
|
||||||
|
@ -246,25 +247,17 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (keys %{$maps_counters}) {
|
foreach (keys %{$maps_counters}) {
|
||||||
$maps_counters->{$_}->{obj}->init(option_results => $self->{option_results});
|
$maps_counters->{$_}->{obj}->init(option_results => $self->{option_results});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{statefile_value}->check_options(%options);
|
$self->{statefile_value}->check_options(%options);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->{webcontent} = centreon::plugins::httplib::connect($self);
|
$self->{webcontent} = $self->{http}->request();
|
||||||
|
|
||||||
$self->manage_selection();
|
$self->manage_selection();
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::values;
|
use centreon::plugins::values;
|
||||||
|
|
||||||
my $maps_counters = {
|
my $maps_counters = {
|
||||||
|
@ -92,7 +92,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/apc.php" },
|
"urlpath:s" => { name => 'url_path', default => "/apc.php" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -100,7 +100,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
"timeout:s" => { name => 'timeout', default => 30 },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
|
|
||||||
foreach (keys %{$maps_counters}) {
|
foreach (keys %{$maps_counters}) {
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
'warning-' . $_ . ':s' => { name => 'warning-' . $_ },
|
'warning-' . $_ . ':s' => { name => 'warning-' . $_ },
|
||||||
|
@ -118,24 +120,17 @@ sub new {
|
||||||
sub check_options {
|
sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (keys %{$maps_counters}) {
|
foreach (keys %{$maps_counters}) {
|
||||||
$maps_counters->{$_}->{obj}->init(option_results => $self->{option_results});
|
$maps_counters->{$_}->{obj}->init(option_results => $self->{option_results});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->{webcontent} = centreon::plugins::httplib::connect($self);
|
$self->{webcontent} = $self->{http}->request();
|
||||||
|
|
||||||
$self->manage_selection();
|
$self->manage_selection();
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
|
@ -38,18 +38,18 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '8086'},
|
"port:s" => { name => 'port', default => '8086'},
|
||||||
"proto:s" => { name => 'proto', default => 'http' },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/db" },
|
"urlpath:s" => { name => 'url_path', default => "/db" },
|
||||||
"database:s" => { name => 'database' },
|
"database:s" => { name => 'database' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
|
||||||
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -65,10 +65,6 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{database})) {
|
if (!defined($self->{option_results}->{database})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the database option");
|
$self->{output}->add_option_msg(short_msg => "Please set the database option");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -77,7 +73,13 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= option");
|
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= option");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
my $query = 'select sum("success") as "success_sum", sum("failure") as "failure_sum" from lmtpd.deliveries where time > '.$old_timestamp.'s and time < now()';
|
||||||
|
$self->{option_results}->{url_path} = $self->{option_results}->{url_path}."/".$self->{option_results}->{database}."/series";
|
||||||
|
$self->{option_results}->{get_param} = [];
|
||||||
|
push @{$self->{option_results}->{get_param}}, "q=" . $query, "p=" . $self->{option_results}->{password}, "u=" . $self->{option_results}->{username};
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{statefile_value}->check_options(%options);
|
$self->{statefile_value}->check_options(%options);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,14 +100,9 @@ sub run {
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = $self->{option_results}->{url_path}."/".$self->{option_results}->{database}."/series";
|
my $jsoncontent = $self->{http}->request();
|
||||||
$self->{option_results}->{query} = 'select sum("success") as "success_sum", sum("failure") as "failure_sum" from lmtpd.deliveries where time > '.$old_timestamp.'s and time < now()';
|
|
||||||
|
|
||||||
my $query_form_get = { q => $self->{option_results}->{query}, p => $self->{option_results}->{password}, u => $self->{option_results}->{username} };
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self, query_form_get => $query_form_get);
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
my $thresholds = {
|
my $thresholds = {
|
||||||
|
@ -50,10 +50,11 @@ sub new {
|
||||||
"urlpath:s" => { name => 'url_path', default => "/api/status" },
|
"urlpath:s" => { name => 'url_path', default => "/api/status" },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"uid:s" => { name => 'uid' },
|
"uid:s" => { name => 'uid' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"threshold-overload:s@" => { name => 'threshold_overload' },
|
"threshold-overload:s@" => { name => 'threshold_overload' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,19 +89,19 @@ sub check_options {
|
||||||
$self->{overload_th}->{$section} = [] if (!defined($self->{overload_th}->{$section}));
|
$self->{overload_th}->{$section} = [] if (!defined($self->{overload_th}->{$section}));
|
||||||
push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status};
|
push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{option_results}->{url_path} = $self->{option_results}->{url_path}."/".$self->{option_results}->{uid};
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = $self->{option_results}->{url_path}."/".$self->{option_results}->{uid};
|
my $jsoncontent = $self->{http}->request();
|
||||||
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self);
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
$webcontent = $json->decode($jsoncontent);
|
$webcontent = $json->decode($jsoncontent);
|
||||||
};
|
};
|
||||||
|
@ -214,7 +215,7 @@ ID for checkmyws API
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout (Default: '3')
|
Threshold for HTTP timeout (Default: 5)
|
||||||
|
|
||||||
=item B<--threshold-overload>
|
=item B<--threshold-overload>
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
my $thresholds = {
|
my $thresholds = {
|
||||||
|
@ -45,15 +45,16 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '9200'},
|
"port:s" => { name => 'port', default => '9200'},
|
||||||
"proto:s" => { name => 'proto', default => 'http' },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/' },
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"threshold-overload:s@" => { name => 'threshold_overload' },
|
"threshold-overload:s@" => { name => 'threshold_overload' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,15 +62,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->{overload_th} = {};
|
$self->{overload_th} = {};
|
||||||
foreach my $val (@{$self->{option_results}->{threshold_overload}}) {
|
foreach my $val (@{$self->{option_results}->{threshold_overload}}) {
|
||||||
if ($val !~ /^(.*?),(.*?),(.*)$/) {
|
if ($val !~ /^(.*?),(.*?),(.*)$/) {
|
||||||
|
@ -84,6 +76,9 @@ sub check_options {
|
||||||
$self->{overload_th}->{$section} = [] if (!defined($self->{overload_th}->{$section}));
|
$self->{overload_th}->{$section} = [] if (!defined($self->{overload_th}->{$section}));
|
||||||
push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status};
|
push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{option_results}->{url_path} = $self->{option_results}->{url_path} . "_cluster/health/";
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub get_severity {
|
sub get_severity {
|
||||||
|
@ -111,9 +106,7 @@ sub get_severity {
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = $self->{option_results}->{url_path}."_cluster/health/";
|
my $jsoncontent = $self->{http}->request();
|
||||||
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self, connection_exit => 'critical');
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
|
@ -199,7 +192,7 @@ Specify password for API authentification
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout (Default: 3)
|
Threshold for HTTP timeout (Default: 5)
|
||||||
|
|
||||||
=item B<--threshold-overload>
|
=item B<--threshold-overload>
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use JSON;
|
use JSON;
|
||||||
use Data::Dumper;
|
use Data::Dumper;
|
||||||
|
|
||||||
|
@ -52,15 +52,16 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '9200'},
|
"port:s" => { name => 'port', default => '9200'},
|
||||||
"proto:s" => { name => 'proto', default => 'http' },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/' },
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"threshold-overload:s@" => { name => 'threshold_overload' },
|
"threshold-overload:s@" => { name => 'threshold_overload' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,15 +69,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->{overload_th} = {};
|
$self->{overload_th} = {};
|
||||||
foreach my $val (@{$self->{option_results}->{threshold_overload}}) {
|
foreach my $val (@{$self->{option_results}->{threshold_overload}}) {
|
||||||
if ($val !~ /^(.*?),(.*?),(.*)$/) {
|
if ($val !~ /^(.*?),(.*?),(.*)$/) {
|
||||||
|
@ -92,6 +84,9 @@ sub check_options {
|
||||||
push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status};
|
push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{option_results}->{url_path} = $self->{option_results}->{url_path} . "_cluster/health";
|
||||||
|
$self->{option_results}->{get_param} = ['level=indices'];
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub get_severity {
|
sub get_severity {
|
||||||
|
@ -119,10 +114,7 @@ sub get_severity {
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = $self->{option_results}->{url_path}."_cluster/health";
|
my $jsoncontent = $self->{http}->request();
|
||||||
my $query_form_get = { level => 'indices' };
|
|
||||||
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self, query_form_get => $query_form_get, connection_exit => 'critical');
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
@ -130,7 +122,6 @@ sub run {
|
||||||
eval {
|
eval {
|
||||||
$webcontent = $json->decode($jsoncontent);
|
$webcontent = $json->decode($jsoncontent);
|
||||||
};
|
};
|
||||||
|
|
||||||
if ($@) {
|
if ($@) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot decode json response");
|
$self->{output}->add_option_msg(short_msg => "Cannot decode json response");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
|
@ -37,16 +37,17 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '9200'},
|
"port:s" => { name => 'port', default => '9200'},
|
||||||
"proto:s" => { name => 'proto', default => 'http' },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/' },
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,15 +55,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -71,17 +63,17 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{option_results}->{url_path} = $self->{option_results}->{url_path} . "_cluster/stats/";
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = $self->{option_results}->{url_path}."_cluster/stats/";
|
my $jsoncontent = $self->{http}->request();
|
||||||
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self, connection_exit => 'critical');
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
|
@ -173,7 +165,7 @@ Threshold critical.
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout (Default: 3)
|
Threshold for HTTP timeout (Default: 5)
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use JSON;
|
use JSON;
|
||||||
use DateTime;
|
use DateTime;
|
||||||
|
@ -45,9 +45,10 @@ sub new {
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"owner:s" => { name => 'owner' },
|
"owner:s" => { name => 'owner' },
|
||||||
"repository:s" => { name => 'repository' },
|
"repository:s" => { name => 'repository' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -57,14 +58,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{repository})) {
|
if (!defined($self->{option_results}->{repository})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the repository option");
|
$self->{output}->add_option_msg(short_msg => "Please set the repository option");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -74,6 +67,8 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{option_results}->{url_path} = "/repos/" . $self->{option_results}->{owner} . "/" . $self->{option_results}->{repository}."/commits";
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{statefile_value}->check_options(%options);
|
$self->{statefile_value}->check_options(%options);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -97,15 +92,10 @@ sub run {
|
||||||
# Change date format from epoch to iso8601
|
# Change date format from epoch to iso8601
|
||||||
my $old_iso8601 = DateTime->from_epoch(epoch => $old_timestamp)."Z";
|
my $old_iso8601 = DateTime->from_epoch(epoch => $old_timestamp)."Z";
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = "/repos/".$self->{option_results}->{owner}."/".$self->{option_results}->{repository}."/commits";
|
my $jsoncontent = $self->{http}->request(get_param => ['per_page=1000', 'since=' . $old_iso8601]);
|
||||||
|
|
||||||
my $query_form_get = { per_page => '1000', since => $old_iso8601 };
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self, query_form_get => $query_form_get , connection_exit => 'critical');
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
$webcontent = $json->decode($jsoncontent);
|
$webcontent = $json->decode($jsoncontent);
|
||||||
};
|
};
|
||||||
|
@ -127,7 +117,6 @@ sub run {
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -174,7 +163,7 @@ Specify GitHub's repository
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout (Default: 3)
|
Threshold for HTTP timeout (Default: 5)
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
|
@ -46,9 +46,10 @@ sub new {
|
||||||
"owner:s" => { name => 'owner' },
|
"owner:s" => { name => 'owner' },
|
||||||
"repository:s" => { name => 'repository' },
|
"repository:s" => { name => 'repository' },
|
||||||
"label:s" => { name => 'label', default => '' },
|
"label:s" => { name => 'label', default => '' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,14 +57,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{repository})) {
|
if (!defined($self->{option_results}->{repository})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the repository option");
|
$self->{output}->add_option_msg(short_msg => "Please set the repository option");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -73,33 +66,30 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'critical', value => $self->{option_results}->{critical})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'critical', value => $self->{option_results}->{critical})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{option_results}->{url_path} = "/repos/" . $self->{option_results}->{owner} . "/" . $self->{option_results}->{repository} . "/issues";
|
||||||
|
if (defined($self->{option_results}->{label}) && $self->{option_results}->{label} ne '') {
|
||||||
|
$self->{option_results}->{get_param} = ['state=open', 'labels=' . $self->{option_results}->{label}, 'per_page=1000'];
|
||||||
|
} else {
|
||||||
|
$self->{option_results}->{get_param} = ['state=open', 'per_page=1000'];
|
||||||
|
}
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
|
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = "/repos/".$self->{option_results}->{owner}."/".$self->{option_results}->{repository} . "/issues";
|
my $jsoncontent = $self->{http}->request();
|
||||||
|
|
||||||
my $query_form_get;
|
|
||||||
if (defined($self->{option_results}->{label}) && $self->{option_results}->{label} ne '') {
|
|
||||||
$query_form_get = { state => 'open', labels => $self->{option_results}->{label}, per_page => '1000' };
|
|
||||||
} else {
|
|
||||||
$query_form_get = { state => 'open', per_page => '1000' };
|
|
||||||
}
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self, query_form_get => $query_form_get , connection_exit => 'critical');
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
$webcontent = $json->decode($jsoncontent);
|
$webcontent = $json->decode($jsoncontent);
|
||||||
};
|
};
|
||||||
|
@ -136,7 +126,6 @@ sub run {
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname', default => 'api.github.com' },
|
"hostname:s" => { name => 'hostname', default => 'api.github.com' },
|
||||||
"port:s" => { name => 'port', default => '443'},
|
"port:s" => { name => 'port', default => '443' },
|
||||||
"proto:s" => { name => 'proto', default => 'https' },
|
"proto:s" => { name => 'proto', default => 'https' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -45,9 +45,10 @@ sub new {
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"owner:s" => { name => 'owner' },
|
"owner:s" => { name => 'owner' },
|
||||||
"repository:s" => { name => 'repository' },
|
"repository:s" => { name => 'repository' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -55,14 +56,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{repository})) {
|
if (!defined($self->{option_results}->{repository})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the repository option");
|
$self->{output}->add_option_msg(short_msg => "Please set the repository option");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -79,21 +72,19 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{option_results}->{url_path} = "/repos/".$self->{option_results}->{owner}."/".$self->{option_results}->{repository}."/pulls";
|
||||||
|
$self->{option_results}->{get_param} = ['state=open', 'per_page=1000'];
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = "/repos/".$self->{option_results}->{owner}."/".$self->{option_results}->{repository}."/pulls";
|
my $jsoncontent = $self->{http}->request();
|
||||||
|
|
||||||
my $query_form_get = { state => 'open', per_page => '1000' };
|
|
||||||
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self, query_form_get => $query_form_get , connection_exit => 'critical');
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
$webcontent = $json->decode($jsoncontent);
|
$webcontent = $json->decode($jsoncontent);
|
||||||
};
|
};
|
||||||
|
@ -118,7 +109,6 @@ sub run {
|
||||||
);
|
);
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -173,7 +163,7 @@ Specify GitHub's repository
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout (Default: 3)
|
Threshold for HTTP timeout (Default: 5)
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
my $thresholds = {
|
my $thresholds = {
|
||||||
|
@ -50,10 +50,11 @@ sub new {
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"threshold-overload:s@" => { name => 'threshold_overload' },
|
"threshold-overload:s@" => { name => 'threshold_overload' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,15 +62,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->{overload_th} = {};
|
$self->{overload_th} = {};
|
||||||
foreach my $val (@{$self->{option_results}->{threshold_overload}}) {
|
foreach my $val (@{$self->{option_results}->{threshold_overload}}) {
|
||||||
if ($val !~ /^(.*?),(.*)$/) {
|
if ($val !~ /^(.*?),(.*)$/) {
|
||||||
|
@ -84,6 +76,8 @@ sub check_options {
|
||||||
$self->{overload_th}->{$section} = [] if (!defined($self->{overload_th}->{$section}));
|
$self->{overload_th}->{$section} = [] if (!defined($self->{overload_th}->{$section}));
|
||||||
push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status};
|
push @{$self->{overload_th}->{$section}}, {filter => $filter, status => $status};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub get_severity {
|
sub get_severity {
|
||||||
|
@ -110,12 +104,10 @@ sub get_severity {
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self, connection_exit => 'critical');
|
my $jsoncontent = $self->{http}->request();
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
$webcontent = $json->decode($jsoncontent);
|
$webcontent = $json->decode($jsoncontent);
|
||||||
};
|
};
|
||||||
|
@ -132,7 +124,6 @@ sub run {
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -175,7 +166,7 @@ Specify password
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout (Default: 3)
|
Threshold for HTTP timeout (Default: 5
|
||||||
|
|
||||||
=item B<--threshold-overload>
|
=item B<--threshold-overload>
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
|
@ -37,8 +37,8 @@ sub new {
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '80'},
|
"port:s" => { name => 'port' },
|
||||||
"proto:s" => { name => 'proto', default => 'http' },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path' },
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"jobname:s" => { name => 'jobname' },
|
"jobname:s" => { name => 'jobname' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
|
@ -47,9 +47,10 @@ sub new {
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"checkstyle" => { name => 'checkstyle' },
|
"checkstyle" => { name => 'checkstyle' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -65,32 +66,23 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{jobname})) {
|
if (!defined($self->{option_results}->{jobname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the jobname option");
|
$self->{output}->add_option_msg(short_msg => "Please set the jobname option");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
$self->{option_results}->{url_path} = $self->{option_results}->{url_path} . "/job/" . $self->{option_results}->{jobname} . "/api/json";
|
||||||
$self->{output}->option_exit();
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $jsoncontent = $self->{http}->request();
|
||||||
$self->{option_results}->{url_path} = $self->{option_results}->{url_path}."/job/".$self->{option_results}->{jobname}."/api/json";
|
|
||||||
|
|
||||||
my $jsoncontent = centreon::plugins::httplib::connect($self);
|
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $json = JSON->new;
|
||||||
|
|
||||||
my $webcontent;
|
my $webcontent;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
$webcontent = $json->decode($jsoncontent);
|
$webcontent = $json->decode($jsoncontent);
|
||||||
};
|
};
|
||||||
|
@ -187,7 +179,7 @@ Add checkstyle's violation output and perfdata
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout (Default: 3)
|
Threshold for HTTP timeout (Default: 5)
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
use Digest::SHA qw(hmac_sha256_base64);
|
use Digest::SHA qw(hmac_sha256_base64);
|
||||||
|
|
||||||
|
@ -38,74 +38,49 @@ sub new {
|
||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port' },
|
"port:s" => { name => 'port' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
||||||
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
||||||
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
||||||
});
|
});
|
||||||
$self->set_signal_handlers;
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub set_signal_handlers {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$SIG{ALRM} = \&class_handle_ALRM;
|
|
||||||
$handlers{ALRM}->{$self} = sub { $self->handle_ALRM() };
|
|
||||||
}
|
|
||||||
|
|
||||||
sub class_handle_ALRM {
|
|
||||||
foreach (keys %{$handlers{ALRM}}) {
|
|
||||||
&{$handlers{ALRM}->{$_}}();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub handle_ALRM {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'UNKNOWN',
|
|
||||||
short_msg => sprintf("Cannot finished API execution (timeout received)"));
|
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
sub check_options {
|
sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{timeout}) && $self->{option_results}->{timeout} =~ /^\d+$/ &&
|
if (!defined($self->{option_results}->{kayako_api_key})) {
|
||||||
$self->{option_results}->{timeout} > 0) {
|
|
||||||
alarm($self->{option_results}->{timeout});
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{'kayako_api_key'})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{'kayako_secret_key'})) {
|
if (!defined($self->{option_results}->{kayako_secret_key})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
my $salt = '';
|
||||||
|
$salt .= int(rand(10)) for 1..10;
|
||||||
|
my $digest = hmac_sha256_base64($salt, $self->{option_results}->{kayako_secret_key});
|
||||||
|
$self->{option_results}->{url_path} .= "/Base/Department&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
my $salt;
|
|
||||||
$salt .= int(rand(10)) for 1..10;
|
my $webcontent = $self->{http}->set_options(%{$self->{option_results}});
|
||||||
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{'kayako_secret_key'});
|
my $xp = XML::XPath->new($webcontent);
|
||||||
$self->{option_results}->{'url_path'} .= "/Base/Department&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
my $nodes = $xp->find('departments/department');
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
my $xp = XML::XPath->new( $webcontent );
|
foreach my $actionNode ($nodes->get_nodelist) {
|
||||||
my $nodes = $xp->find('departments/department');
|
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
||||||
|
my $trim_id = centreon::plugins::misc::trim($id->string_value);
|
||||||
|
my ($title) = $xp->find('./title', $actionNode)->get_nodelist;
|
||||||
|
my $trim_title = centreon::plugins::misc::trim($title->string_value);
|
||||||
|
|
||||||
foreach my $actionNode ($nodes->get_nodelist) {
|
|
||||||
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
|
||||||
my $trim_id = centreon::plugins::misc::trim($id->string_value);
|
|
||||||
my ($title) = $xp->find('./title', $actionNode)->get_nodelist;
|
|
||||||
my $trim_title = centreon::plugins::misc::trim($title->string_value);
|
|
||||||
# print $trim_id." : ". $trim_title."\n";
|
|
||||||
# }
|
|
||||||
$self->{output}->output_add(long_msg => "'" . $trim_title . "' [id = " . $trim_id . "]");
|
$self->{output}->output_add(long_msg => "'" . $trim_title . "' [id = " . $trim_id . "]");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
use Digest::SHA qw(hmac_sha256_base64);
|
use Digest::SHA qw(hmac_sha256_base64);
|
||||||
|
|
||||||
|
@ -38,72 +38,49 @@ sub new {
|
||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port' },
|
"port:s" => { name => 'port' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
||||||
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
||||||
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
||||||
});
|
});
|
||||||
$self->set_signal_handlers;
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub set_signal_handlers {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$SIG{ALRM} = \&class_handle_ALRM;
|
|
||||||
$handlers{ALRM}->{$self} = sub { $self->handle_ALRM() };
|
|
||||||
}
|
|
||||||
|
|
||||||
sub class_handle_ALRM {
|
|
||||||
foreach (keys %{$handlers{ALRM}}) {
|
|
||||||
&{$handlers{ALRM}->{$_}}();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub handle_ALRM {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'UNKNOWN',
|
|
||||||
short_msg => sprintf("Cannot finished API execution (timeout received)"));
|
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
sub check_options {
|
sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{timeout}) && $self->{option_results}->{timeout} =~ /^\d+$/ &&
|
if (!defined($self->{option_results}->{kayako_api_key})) {
|
||||||
$self->{option_results}->{timeout} > 0) {
|
|
||||||
alarm($self->{option_results}->{timeout});
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{'kayako_api_key'})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{'kayako_secret_key'})) {
|
if (!defined($self->{option_results}->{kayako_secret_key})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
my $salt;
|
||||||
|
$salt .= int(rand(10)) for 1..10;
|
||||||
|
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{kayako_secret_key});
|
||||||
|
$self->{option_results}->{url_path} .= "/Tickets/TicketPriority&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
my $salt;
|
|
||||||
$salt .= int(rand(10)) for 1..10;
|
my $webcontent = $self->{http}->request();
|
||||||
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{'kayako_secret_key'});
|
my $xp = XML::XPath->new( $webcontent );
|
||||||
$self->{option_results}->{'url_path'} .= "/Tickets/TicketPriority&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
my $nodes = $xp->find('ticketpriorities/ticketpriority');
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
my $xp = XML::XPath->new( $webcontent );
|
|
||||||
my $nodes = $xp->find('ticketpriorities/ticketpriority');
|
|
||||||
|
|
||||||
foreach my $actionNode ($nodes->get_nodelist) {
|
foreach my $actionNode ($nodes->get_nodelist) {
|
||||||
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
||||||
my $trim_id = centreon::plugins::misc::trim($id->string_value);
|
my $trim_id = centreon::plugins::misc::trim($id->string_value);
|
||||||
my ($title) = $xp->find('./title', $actionNode)->get_nodelist;
|
my ($title) = $xp->find('./title', $actionNode)->get_nodelist;
|
||||||
my $trim_title = centreon::plugins::misc::trim($title->string_value);
|
my $trim_title = centreon::plugins::misc::trim($title->string_value);
|
||||||
$self->{output}->output_add(long_msg => "'" . $trim_title . "' [id = " . $trim_id . "]");
|
$self->{output}->output_add(long_msg => "'" . $trim_title . "' [id = " . $trim_id . "]");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,12 +24,10 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
use Digest::SHA qw(hmac_sha256_base64);
|
use Digest::SHA qw(hmac_sha256_base64);
|
||||||
|
|
||||||
my %handlers = (ALRM => {} );
|
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
|
@ -38,72 +36,50 @@ sub new {
|
||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port' },
|
"port:s" => { name => 'port' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
||||||
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
||||||
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
||||||
});
|
});
|
||||||
$self->set_signal_handlers;
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub set_signal_handlers {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$SIG{ALRM} = \&class_handle_ALRM;
|
|
||||||
$handlers{ALRM}->{$self} = sub { $self->handle_ALRM() };
|
|
||||||
}
|
|
||||||
|
|
||||||
sub class_handle_ALRM {
|
|
||||||
foreach (keys %{$handlers{ALRM}}) {
|
|
||||||
&{$handlers{ALRM}->{$_}}();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub handle_ALRM {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'UNKNOWN',
|
|
||||||
short_msg => sprintf("Cannot finished API execution (timeout received)"));
|
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
sub check_options {
|
sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{timeout}) && $self->{option_results}->{timeout} =~ /^\d+$/ &&
|
if (!defined($self->{option_results}->{kayako_api_key})) {
|
||||||
$self->{option_results}->{timeout} > 0) {
|
|
||||||
alarm($self->{option_results}->{timeout});
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{'kayako_api_key'})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{'kayako_secret_key'})) {
|
if (!defined($self->{option_results}->{kayako_secret_key})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
my $salt;
|
||||||
|
$salt .= int(rand(10)) for 1..10;
|
||||||
|
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{'kayako_secret_key'});
|
||||||
|
$self->{option_results}->{url_path} .= "/Base/Staff&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
my $salt;
|
|
||||||
$salt .= int(rand(10)) for 1..10;
|
my $webcontent = $self->{http}->request();
|
||||||
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{'kayako_secret_key'});
|
my $xp = XML::XPath->new( $webcontent );
|
||||||
$self->{option_results}->{'url_path'} .= "/Base/Staff&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
my $nodes = $xp->find('staffusers/staff');
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
my $xp = XML::XPath->new( $webcontent );
|
|
||||||
my $nodes = $xp->find('staffusers/staff');
|
|
||||||
|
|
||||||
foreach my $actionNode ($nodes->get_nodelist) {
|
foreach my $actionNode ($nodes->get_nodelist) {
|
||||||
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
||||||
my $trim_id = centreon::plugins::misc::trim($id->string_value);
|
my $trim_id = centreon::plugins::misc::trim($id->string_value);
|
||||||
my ($title) = $xp->find('./username', $actionNode)->get_nodelist;
|
my ($title) = $xp->find('./username', $actionNode)->get_nodelist;
|
||||||
my $trim_title = centreon::plugins::misc::trim($title->string_value);
|
my $trim_title = centreon::plugins::misc::trim($title->string_value);
|
||||||
$self->{output}->output_add(long_msg => "'" . $trim_title . "' [id = " . $trim_id . "]");
|
$self->{output}->output_add(long_msg => "'" . $trim_title . "' [id = " . $trim_id . "]");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,12 +24,10 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
use Digest::SHA qw(hmac_sha256_base64);
|
use Digest::SHA qw(hmac_sha256_base64);
|
||||||
|
|
||||||
my %handlers = (ALRM => {} );
|
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
|
@ -38,72 +36,50 @@ sub new {
|
||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port' },
|
"port:s" => { name => 'port' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
||||||
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
||||||
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
||||||
});
|
});
|
||||||
$self->set_signal_handlers;
|
|
||||||
return $self;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub set_signal_handlers {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$SIG{ALRM} = \&class_handle_ALRM;
|
|
||||||
$handlers{ALRM}->{$self} = sub { $self->handle_ALRM() };
|
|
||||||
}
|
|
||||||
|
|
||||||
sub class_handle_ALRM {
|
|
||||||
foreach (keys %{$handlers{ALRM}}) {
|
|
||||||
&{$handlers{ALRM}->{$_}}();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub handle_ALRM {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'UNKNOWN',
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
short_msg => sprintf("Cannot finished scenario execution (timeout received)"));
|
return $self;
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{timeout}) && $self->{option_results}->{timeout} =~ /^\d+$/ &&
|
if (!defined($self->{option_results}->{kayako_api_key})) {
|
||||||
$self->{option_results}->{timeout} > 0) {
|
|
||||||
alarm($self->{option_results}->{timeout});
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{'kayako_api_key'})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{'kayako_secret_key'})) {
|
if (!defined($self->{option_results}->{kayako_secret_key})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
my $salt;
|
||||||
|
$salt .= int(rand(10)) for 1..10;
|
||||||
|
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{'kayako_secret_key'});
|
||||||
|
$self->{option_results}->{'url_path'} .= "/Tickets/TicketStatus&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
my $salt;
|
|
||||||
$salt .= int(rand(10)) for 1..10;
|
|
||||||
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{'kayako_secret_key'});
|
|
||||||
$self->{option_results}->{'url_path'} .= "/Tickets/TicketStatus&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
my $xp = XML::XPath->new( $webcontent );
|
|
||||||
my $nodes = $xp->find('ticketstatuses/ticketstatus');
|
|
||||||
|
|
||||||
foreach my $actionNode ($nodes->get_nodelist) {
|
my $webcontent = $self->{http}->request();
|
||||||
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
my $xp = XML::XPath->new($webcontent);
|
||||||
my $trim_id = centreon::plugins::misc::trim($id->string_value);
|
my $nodes = $xp->find('ticketstatuses/ticketstatus');
|
||||||
my ($title) = $xp->find('./title', $actionNode)->get_nodelist;
|
|
||||||
my $trim_title = centreon::plugins::misc::trim($title->string_value);
|
foreach my $actionNode ($nodes->get_nodelist) {
|
||||||
|
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
||||||
|
my $trim_id = centreon::plugins::misc::trim($id->string_value);
|
||||||
|
my ($title) = $xp->find('./title', $actionNode)->get_nodelist;
|
||||||
|
my $trim_title = centreon::plugins::misc::trim($title->string_value);
|
||||||
$self->{output}->output_add(long_msg => "'" . $trim_title . "' [id = " . $trim_id . "]");
|
$self->{output}->output_add(long_msg => "'" . $trim_title . "' [id = " . $trim_id . "]");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
use Digest::SHA qw(hmac_sha256_base64);
|
use Digest::SHA qw(hmac_sha256_base64);
|
||||||
use Time::Local;
|
use Time::Local;
|
||||||
|
@ -38,7 +38,6 @@ my @priority_filters;
|
||||||
my $ticket_total = 0;
|
my $ticket_total = 0;
|
||||||
my %tickets;
|
my %tickets;
|
||||||
my $label;
|
my $label;
|
||||||
my %handlers = (ALRM => {} );
|
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -50,7 +49,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port' },
|
"port:s" => { name => 'port' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
"urlpath:s" => { name => 'url_path', default => '/api/index.php?' },
|
||||||
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
"kayako-api-key:s" => { name => 'kayako_api_key' },
|
||||||
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
"kayako-secret-key:s" => { name => 'kayako_secret_key' },
|
||||||
|
@ -64,82 +63,56 @@ sub new {
|
||||||
"start-date:s" => { name => 'start_date' },
|
"start-date:s" => { name => 'start_date' },
|
||||||
"end-date:s" => { name => 'end_date' },
|
"end-date:s" => { name => 'end_date' },
|
||||||
});
|
});
|
||||||
$self->set_signal_handlers;
|
|
||||||
$self->{statefile_cache} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_cache} = centreon::plugins::statefile->new(%options);
|
||||||
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub set_signal_handlers {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$SIG{ALRM} = \&class_handle_ALRM;
|
|
||||||
$handlers{ALRM}->{$self} = sub { $self->handle_ALRM() };
|
|
||||||
}
|
|
||||||
|
|
||||||
sub class_handle_ALRM {
|
|
||||||
foreach (keys %{$handlers{ALRM}}) {
|
|
||||||
&{$handlers{ALRM}->{$_}}();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub handle_ALRM {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$self->{output}->output_add(severity => 'UNKNOWN',
|
|
||||||
short_msg => sprintf("Cannot finished API execution (timeout received)"));
|
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
sub check_options {
|
sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{timeout}) && $self->{option_results}->{timeout} =~ /^\d+$/ &&
|
if (!defined($self->{option_results}->{kayako_api_key})) {
|
||||||
$self->{option_results}->{timeout} > 0) {
|
|
||||||
alarm($self->{option_results}->{timeout});
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{'kayako_api_key'})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify an API key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{'kayako_secret_key'})) {
|
if (!defined($self->{option_results}->{kayako_secret_key})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
$self->{output}->add_option_msg(short_msg => "Please specify a secret key for Kayako.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{'department_id'})) {
|
if (!defined($self->{option_results}->{department_id})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify at least one department ID.");
|
$self->{output}->add_option_msg(short_msg => "Please specify at least one department ID.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{'staff_id'})) {
|
if (!defined($self->{option_results}->{staff_id})) {
|
||||||
$self->{option_results}->{'staff_id'} = "-1";
|
$self->{option_results}->{staff_id} = "-1";
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{'status_id'})) {
|
if (!defined($self->{option_results}->{status_id})) {
|
||||||
$self->{option_results}->{'status_id'} = "-1";
|
$self->{option_results}->{status_id} = "-1";
|
||||||
}
|
}
|
||||||
if (defined($self->{option_results}->{'priority_id'})) {
|
if (defined($self->{option_results}->{priority_id})) {
|
||||||
@priority_filters = split(/,/, $self->{option_results}->{'priority_id'});
|
@priority_filters = split(/,/, $self->{option_results}->{priority_id});
|
||||||
}
|
}
|
||||||
if (defined($self->{option_results}->{'start_date'})) {
|
if (defined($self->{option_results}->{start_date})) {
|
||||||
if ($self->{option_results}->{'start_date'} !~ m/^\d{1,2}-\d{1,2}-\d{4}$/){
|
if ($self->{option_results}->{start_date} !~ m/^\d{1,2}-\d{1,2}-\d{4}$/){
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify a valid date (DD-MM-YYYY).");
|
$self->{output}->add_option_msg(short_msg => "Please specify a valid date (DD-MM-YYYY).");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
} else {
|
} else {
|
||||||
my ($mday,$mon,$year) = split(/-/, $self->{option_results}->{'start_date'});
|
my ($mday,$mon,$year) = split(/-/, $self->{option_results}->{start_date});
|
||||||
$start = $self->{option_results}->{'start_date'};
|
$start = $self->{option_results}->{start_date};
|
||||||
$self->{option_results}->{'start_date'} = timelocal(0,0,0,$mday,$mon-1,$year);
|
$self->{option_results}->{start_date} = timelocal(0,0,0,$mday,$mon-1,$year);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (defined($self->{option_results}->{'end_date'})) {
|
if (defined($self->{option_results}->{end_date})) {
|
||||||
if ($self->{option_results}->{'end_date'} !~ m/^\d{1,2}-\d{1,2}-\d{4}$/){
|
if ($self->{option_results}->{end_date} !~ m/^\d{1,2}-\d{1,2}-\d{4}$/){
|
||||||
$self->{output}->add_option_msg(short_msg => "Please specify a valid date (DD-MM-YYYY).");
|
$self->{output}->add_option_msg(short_msg => "Please specify a valid date (DD-MM-YYYY).");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
} else {
|
} else {
|
||||||
my ($mday,$mon,$year) = split(/-/, $self->{option_results}->{'end_date'});
|
my ($mday,$mon,$year) = split(/-/, $self->{option_results}->{end_date});
|
||||||
$end = $self->{option_results}->{'end_date'};
|
$end = $self->{option_results}->{end_date};
|
||||||
$self->{option_results}->{'end_date'} = timelocal(59,59,23,$mday,$mon-1,$year);
|
$self->{option_results}->{end_date} = timelocal(59,59,23,$mday,$mon-1,$year);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
|
@ -153,6 +126,9 @@ sub check_options {
|
||||||
|
|
||||||
$self->{statefile_cache}->check_options(%options);
|
$self->{statefile_cache}->check_options(%options);
|
||||||
$self->{statefile_value}->check_options(%options);
|
$self->{statefile_value}->check_options(%options);
|
||||||
|
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub reload_cache {
|
sub reload_cache {
|
||||||
|
@ -161,12 +137,12 @@ sub reload_cache {
|
||||||
|
|
||||||
$datas->{last_timestamp} = time();
|
$datas->{last_timestamp} = time();
|
||||||
|
|
||||||
my $salt;
|
my $salt = '';
|
||||||
$salt .= int(rand(10)) for 1..10;
|
$salt .= int(rand(10)) for 1..10;
|
||||||
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{'kayako_secret_key'});
|
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{kayako_secret_key});
|
||||||
$self->{option_results}->{'url_path'} = $url_original_path . "/Base/Department&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
my $webcontent = $self->{http}->request(url_path => $url_original_path . "/Base/Department&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=";);
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
my $xp = XML::XPath->new( $webcontent );
|
my $xp = XML::XPath->new($webcontent);
|
||||||
my $nodes = $xp->find('departments/department');
|
my $nodes = $xp->find('departments/department');
|
||||||
foreach my $actionNode ($nodes->get_nodelist) {
|
foreach my $actionNode ($nodes->get_nodelist) {
|
||||||
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
my ($id) = $xp->find('./id', $actionNode)->get_nodelist;
|
||||||
|
@ -176,8 +152,7 @@ sub reload_cache {
|
||||||
$datas->{"department_".$trim_id} = $self->{output}->to_utf8($trim_title);
|
$datas->{"department_".$trim_id} = $self->{output}->to_utf8($trim_title);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{option_results}->{'url_path'} = $url_original_path . "/Tickets/TicketPriority&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
$webcontent = $self->{http}->request(url_path => $url_original_path . "/Tickets/TicketPriority&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=");
|
||||||
$webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
$xp = XML::XPath->new( $webcontent );
|
$xp = XML::XPath->new( $webcontent );
|
||||||
$nodes = $xp->find('ticketpriorities/ticketpriority');
|
$nodes = $xp->find('ticketpriorities/ticketpriority');
|
||||||
foreach my $actionNode ($nodes->get_nodelist) {
|
foreach my $actionNode ($nodes->get_nodelist) {
|
||||||
|
@ -188,8 +163,7 @@ sub reload_cache {
|
||||||
$datas->{"priority_".$trim_id} = $self->{output}->to_utf8($trim_title);
|
$datas->{"priority_".$trim_id} = $self->{output}->to_utf8($trim_title);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{option_results}->{'url_path'} = $url_original_path . "/Base/Staff&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
$webcontent = $self->{http}->request(url_path => $url_original_path . "/Base/Staff&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=");
|
||||||
$webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
$xp = XML::XPath->new( $webcontent );
|
$xp = XML::XPath->new( $webcontent );
|
||||||
$nodes = $xp->find('staffusers/staff');
|
$nodes = $xp->find('staffusers/staff');
|
||||||
foreach my $actionNode ($nodes->get_nodelist) {
|
foreach my $actionNode ($nodes->get_nodelist) {
|
||||||
|
@ -200,8 +174,7 @@ sub reload_cache {
|
||||||
$datas->{"staff_".$trim_id} = $self->{output}->to_utf8($trim_title);
|
$datas->{"staff_".$trim_id} = $self->{output}->to_utf8($trim_title);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{option_results}->{'url_path'} = $url_original_path . "/Tickets/TicketStatus&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
$webcontent = $self->{http}->request(url_path => $url_original_path . "/Tickets/TicketStatus&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=");
|
||||||
$webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
$xp = XML::XPath->new( $webcontent );
|
$xp = XML::XPath->new( $webcontent );
|
||||||
$nodes = $xp->find('ticketstatuses/ticketstatus');
|
$nodes = $xp->find('ticketstatuses/ticketstatus');
|
||||||
foreach my $actionNode ($nodes->get_nodelist) {
|
foreach my $actionNode ($nodes->get_nodelist) {
|
||||||
|
@ -217,10 +190,10 @@ sub reload_cache {
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
my $salt;
|
my $salt = '';
|
||||||
$salt .= int(rand(10)) for 1..10;
|
$salt .= int(rand(10)) for 1..10;
|
||||||
my $digest = hmac_sha256_base64 ($salt, $self->{option_results}->{'kayako_secret_key'});
|
my $digest = hmac_sha256_base64($salt, $self->{option_results}->{kayako_secret_key});
|
||||||
$url_original_path = $self->{option_results}->{'url_path'};
|
$url_original_path = $self->{option_results}->{url_path};
|
||||||
|
|
||||||
my $has_cache_file = $self->{statefile_cache}->read(statefile => 'cache_api_' . ($self->{option_results}->{hostname}) . '_kayako');
|
my $has_cache_file = $self->{statefile_cache}->read(statefile => 'cache_api_' . ($self->{option_results}->{hostname}) . '_kayako');
|
||||||
my $timestamp_cache = $self->{statefile_cache}->get(name => 'last_timestamp');
|
my $timestamp_cache = $self->{statefile_cache}->get(name => 'last_timestamp');
|
||||||
|
@ -230,8 +203,7 @@ sub run {
|
||||||
$self->{statefile_cache}->read();
|
$self->{statefile_cache}->read();
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{option_results}->{'url_path'} = $url_original_path . "/Tickets/Ticket/ListAll/" . $self->{option_results}->{'department_id'} . "/" . $self->{option_results}->{'status_id'} . "/" . $self->{option_results}->{'staff_id'} . "/-1/-1/1420120620/-1/-1&apikey=" . $self->{option_results}->{'kayako_api_key'} . "&salt=" . $salt . "&signature=" . $digest . "=";
|
my $webcontent = $self->{http}->request(url_path => $url_original_path . "/Tickets/Ticket/ListAll/" . $self->{option_results}->{department_id} . "/" . $self->{option_results}->{status_id} . "/" . $self->{option_results}->{staff_id} . "/-1/-1/1420120620/-1/-1&apikey=" . $self->{option_results}->{kayako_api_key} . "&salt=" . $salt . "&signature=" . $digest . "=");
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
my $xp = XML::XPath->new( $webcontent );
|
my $xp = XML::XPath->new( $webcontent );
|
||||||
my $nodes = $xp->find('tickets/ticket');
|
my $nodes = $xp->find('tickets/ticket');
|
||||||
|
|
||||||
|
@ -243,9 +215,9 @@ sub run {
|
||||||
my $trim_priorityid = centreon::plugins::misc::trim($priorityid->string_value);
|
my $trim_priorityid = centreon::plugins::misc::trim($priorityid->string_value);
|
||||||
my ($date) = $xp->find('./lastactivity', $actionNode)->get_nodelist;
|
my ($date) = $xp->find('./lastactivity', $actionNode)->get_nodelist;
|
||||||
my $trim_date = centreon::plugins::misc::trim($date->string_value);
|
my $trim_date = centreon::plugins::misc::trim($date->string_value);
|
||||||
if (defined($self->{option_results}->{'start_date'}) and (defined($self->{option_results}->{'end_date'}))) {
|
if (defined($self->{option_results}->{start_date}) and (defined($self->{option_results}->{end_date}))) {
|
||||||
if ($trim_date > $self->{option_results}->{'start_date'} and $trim_date < $self->{option_results}->{'end_date'}) {
|
if ($trim_date > $self->{option_results}->{start_date} and $trim_date < $self->{option_results}->{end_date}) {
|
||||||
if (defined($self->{option_results}->{'priority_id'})){
|
if (defined($self->{option_results}->{priority_id})){
|
||||||
foreach $priority_filter (@priority_filters) {
|
foreach $priority_filter (@priority_filters) {
|
||||||
if ($priority_filter == $trim_priorityid){
|
if ($priority_filter == $trim_priorityid){
|
||||||
$tickets{$priority_filter}++;
|
$tickets{$priority_filter}++;
|
||||||
|
@ -256,9 +228,9 @@ sub run {
|
||||||
$ticket_total++;
|
$ticket_total++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} elsif (defined($self->{option_results}->{'start_date'}) and (!defined($self->{option_results}->{'end_date'}))) {
|
} elsif (defined($self->{option_results}->{start_date}) and (!defined($self->{option_results}->{end_date}))) {
|
||||||
if ($trim_date > $self->{option_results}->{'start_date'}) {
|
if ($trim_date > $self->{option_results}->{start_date}) {
|
||||||
if (defined($self->{option_results}->{'priority_id'})){
|
if (defined($self->{option_results}->{priority_id})){
|
||||||
foreach $priority_filter (@priority_filters) {
|
foreach $priority_filter (@priority_filters) {
|
||||||
if ($priority_filter == $trim_priorityid){
|
if ($priority_filter == $trim_priorityid){
|
||||||
$tickets{$priority_filter}++;
|
$tickets{$priority_filter}++;
|
||||||
|
@ -269,9 +241,9 @@ sub run {
|
||||||
$ticket_total++;
|
$ticket_total++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} elsif (!defined($self->{option_results}->{'start_date'}) and (defined($self->{option_results}->{'end_date'}))) {
|
} elsif (!defined($self->{option_results}->{start_date}) and (defined($self->{option_results}->{end_date}))) {
|
||||||
if ($trim_date < $self->{option_results}->{'end_date'}) {
|
if ($trim_date < $self->{option_results}->{end_date}) {
|
||||||
if (defined($self->{option_results}->{'priority_id'})){
|
if (defined($self->{option_results}->{priority_id})){
|
||||||
foreach $priority_filter (@priority_filters) {
|
foreach $priority_filter (@priority_filters) {
|
||||||
if ($priority_filter == $trim_priorityid){
|
if ($priority_filter == $trim_priorityid){
|
||||||
$tickets{$priority_filter}++;
|
$tickets{$priority_filter}++;
|
||||||
|
@ -283,7 +255,7 @@ sub run {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (defined($self->{option_results}->{'priority_id'})){
|
if (defined($self->{option_results}->{priority_id})){
|
||||||
foreach $priority_filter (@priority_filters) {
|
foreach $priority_filter (@priority_filters) {
|
||||||
if ($priority_filter == $trim_priorityid){
|
if ($priority_filter == $trim_priorityid){
|
||||||
$tickets{$priority_filter}++;
|
$tickets{$priority_filter}++;
|
||||||
|
@ -299,32 +271,32 @@ sub run {
|
||||||
###########
|
###########
|
||||||
# Manage Output
|
# Manage Output
|
||||||
###########
|
###########
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $ticket_total, threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
my $exit = $self->{perfdata}->threshold_check(value => $ticket_total, threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
||||||
my $staff = "";
|
my $staff = "";
|
||||||
my $ticket_status = "";
|
my $ticket_status = "";
|
||||||
my $period = "";
|
my $period = "";
|
||||||
|
|
||||||
if (defined($self->{option_results}->{'staff_id'}) && ($self->{option_results}->{'staff_id'} =~ m/^\d*$/)) {
|
if (defined($self->{option_results}->{staff_id}) && ($self->{option_results}->{staff_id} =~ m/^\d*$/)) {
|
||||||
$staff = " for staff '" . $self->{statefile_cache}->get(name => 'staff_'.$self->{option_results}->{'staff_id'}) ."'";
|
$staff = " for staff '" . $self->{statefile_cache}->get(name => 'staff_'.$self->{option_results}->{staff_id}) ."'";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{'status_id'}) && ($self->{option_results}->{'status_id'} =~ m/^\d*$/)) {
|
if (defined($self->{option_results}->{status_id}) && ($self->{option_results}->{status_id} =~ m/^\d*$/)) {
|
||||||
$ticket_status = " in status '" . $self->{statefile_cache}->get(name => 'status_'.$self->{option_results}->{'status_id'}) ."'";
|
$ticket_status = " in status '" . $self->{statefile_cache}->get(name => 'status_'.$self->{option_results}->{status_id}) ."'";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{'start_date'}) || defined($self->{option_results}->{'end_date'})){
|
if (defined($self->{option_results}->{start_date}) || defined($self->{option_results}->{end_date})){
|
||||||
$period = " -";
|
$period = " -";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{'start_date'})){
|
if (defined($self->{option_results}->{start_date})){
|
||||||
$start = " Start: " . $start;
|
$start = " Start: " . $start;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{'end_date'})){
|
if (defined($self->{option_results}->{end_date})){
|
||||||
$end = " End: " . $end;
|
$end = " End: " . $end;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (defined($self->{option_results}->{'priority_id'})){
|
if (defined($self->{option_results}->{priority_id})){
|
||||||
foreach $priority_filter (@priority_filters) {
|
foreach $priority_filter (@priority_filters) {
|
||||||
$label = $self->{statefile_cache}->get(name => 'priority_'.$priority_filter);
|
$label = $self->{statefile_cache}->get(name => 'priority_'.$priority_filter);
|
||||||
$self->{output}->perfdata_add(label => $label, value => $tickets{$priority_filter},
|
$self->{output}->perfdata_add(label => $label, value => $tickets{$priority_filter},
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
my $maps = [
|
my $maps = [
|
||||||
{ counter => 'active', output => 'Active connections %d', match => 'Active connections:\s*(\d+)' },
|
{ counter => 'active', output => 'Active connections %d', match => 'Active connections:\s*(\d+)' },
|
||||||
|
@ -43,13 +43,13 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/nginx_status" },
|
"urlpath:s" => { name => 'url_path', default => "/nginx_status" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
foreach (@{$maps}) {
|
foreach (@{$maps}) {
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
|
@ -57,6 +57,8 @@ sub new {
|
||||||
'critical-' . $_->{counter} . ':s' => { name => 'critical_' . $_->{counter} },
|
'critical-' . $_->{counter} . ':s' => { name => 'critical_' . $_->{counter} },
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,25 +76,14 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
foreach (@{$maps}) {
|
foreach (@{$maps}) {
|
||||||
if ($webcontent !~ /$_->{match}/msi) {
|
if ($webcontent !~ /$_->{match}/msi) {
|
||||||
$self->{output}->output_add(severity => 'UNKNOWN',
|
$self->{output}->output_add(severity => 'UNKNOWN',
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
|
|
||||||
my $maps = [
|
my $maps = [
|
||||||
|
@ -43,13 +43,13 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/nginx_status" },
|
"urlpath:s" => { name => 'url_path', default => "/nginx_status" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
foreach (@{$maps}) {
|
foreach (@{$maps}) {
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
|
@ -58,6 +58,7 @@ sub new {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,22 +76,15 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->{statefile_value}->check_options(%options);
|
$self->{statefile_value}->check_options(%options);
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my ($buffer_creation, $exit) = (0, 0);
|
my ($buffer_creation, $exit) = (0, 0);
|
||||||
my $new_datas = {};
|
my $new_datas = {};
|
||||||
my $old_datas = {};
|
my $old_datas = {};
|
||||||
|
|
|
@ -25,7 +25,7 @@ use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Time::HiRes qw(gettimeofday tv_interval);
|
use Time::HiRes qw(gettimeofday tv_interval);
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -37,7 +37,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/nginx_status" },
|
"urlpath:s" => { name => 'url_path', default => "/nginx_status" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -45,8 +45,12 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
|
"unknown-status:s" => { name => 'unknown_status', default => '' },
|
||||||
|
"warning-status:s" => { name => 'warning_status' },
|
||||||
|
"critical-status:s" => { name => 'critical_status', default => '%{http_code} < 200 or %{http_code} >= 300' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,19 +67,7 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
|
@ -83,12 +75,12 @@ sub run {
|
||||||
|
|
||||||
my $timing0 = [gettimeofday];
|
my $timing0 = [gettimeofday];
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self, connection_exit => 'critical');
|
my $webcontent = $self->{http}->request();
|
||||||
|
|
||||||
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $timeelapsed,
|
my $exit = $self->{perfdata}->threshold_check(value => $timeelapsed,
|
||||||
threshold => [ { label => 'critical', 'exit_litteral' => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(severity => $exit,
|
||||||
short_msg => sprintf("Response time %fs ", $timeelapsed));
|
short_msg => sprintf("Response time %fs ", $timeelapsed));
|
||||||
$self->{output}->perfdata_add(label => "time",
|
$self->{output}->perfdata_add(label => "time",
|
||||||
|
@ -146,6 +138,18 @@ Proxy URL if any
|
||||||
|
|
||||||
Threshold for HTTP timeout
|
Threshold for HTTP timeout
|
||||||
|
|
||||||
|
=item B<--unknown-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--warning-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--critical-status>
|
||||||
|
|
||||||
|
Threshold critical for http response code (Default: '%{http_code} < 200 or %{http_code} >= 300')
|
||||||
|
|
||||||
=item B<--warning>
|
=item B<--warning>
|
||||||
|
|
||||||
Threshold warning in seconds (nginx_status page response time)
|
Threshold warning in seconds (nginx_status page response time)
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -35,23 +35,33 @@ sub new {
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
|
"http-peer-addr:s" => { name => 'http_peer_addr' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"method:s" => { name => 'method' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/" },
|
"proto:s" => { name => 'proto' },
|
||||||
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"ntlm" => { name => 'ntlm' },
|
"ntlm" => { name => 'ntlm' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"expected-string:s" => { name => 'expected_string' },
|
"expected-string:s" => { name => 'expected_string' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"ssl:s" => { name => 'ssl', },
|
"ssl:s" => { name => 'ssl', },
|
||||||
"cert-file:s" => { name => 'cert_file' },
|
"cert-file:s" => { name => 'cert_file' },
|
||||||
"key-file:s" => { name => 'key_file' },
|
"key-file:s" => { name => 'key_file' },
|
||||||
"cacert-file:s" => { name => 'cacert_file' },
|
"cacert-file:s" => { name => 'cacert_file' },
|
||||||
"cert-pwd:s" => { name => 'cert_pwd' },
|
"cert-pwd:s" => { name => 'cert_pwd' },
|
||||||
"cert-pkcs12" => { name => 'cert_pkcs12' },
|
"cert-pkcs12" => { name => 'cert_pkcs12' },
|
||||||
|
"header:s@" => { name => 'header' },
|
||||||
|
"get-param:s@" => { name => 'get_param' },
|
||||||
|
"post-param:s@" => { name => 'post_param' },
|
||||||
|
"cookies-file:s" => { name => 'cookies_file' },
|
||||||
|
"unknown-status:s" => { name => 'unknown_status' },
|
||||||
|
"warning-status:s" => { name => 'warning_status' },
|
||||||
|
"critical-status:s" => { name => 'critical_status' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,36 +69,17 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to specify hostname.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{expected_string})) {
|
if (!defined($self->{option_results}->{expected_string})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to specify --expected-string option.");
|
$self->{output}->add_option_msg(short_msg => "You need to specify --expected-string option.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((!defined($self->{option_results}->{credentials})) && (defined($self->{option_results}->{ntlm}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "--ntlm option must be used with --credentials option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{pkcs12})) && (!defined($self->{option_results}->{cert_file}) && !defined($self->{option_results}->{cert_pwd}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --cert-file= and --cert-pwd= options when --pkcs12 is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{port})) {
|
my $webcontent = $self->{http}->request();
|
||||||
$self->{option_results}->{port} = centreon::plugins::httplib::get_port($self);
|
|
||||||
}
|
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
|
||||||
$self->{output}->output_add(long_msg => $webcontent);
|
$self->{output}->output_add(long_msg => $webcontent);
|
||||||
|
|
||||||
if ($webcontent =~ /$self->{option_results}->{expected_string}/mi) {
|
if ($webcontent =~ /$self->{option_results}->{expected_string}/mi) {
|
||||||
|
@ -116,6 +107,10 @@ Check Webpage content
|
||||||
|
|
||||||
IP Addr/FQDN of the Webserver host
|
IP Addr/FQDN of the Webserver host
|
||||||
|
|
||||||
|
=item B<--http-peer-addr>
|
||||||
|
|
||||||
|
Set the address you want to connect (Useful if hostname is only a vhost. no ip resolve)
|
||||||
|
|
||||||
=item B<--port>
|
=item B<--port>
|
||||||
|
|
||||||
Port used by Webserver
|
Port used by Webserver
|
||||||
|
@ -124,9 +119,13 @@ Port used by Webserver
|
||||||
|
|
||||||
Proxy URL if any
|
Proxy URL if any
|
||||||
|
|
||||||
|
=item B<--method>
|
||||||
|
|
||||||
|
Specify http method used (Default: 'GET')
|
||||||
|
|
||||||
=item B<--proto>
|
=item B<--proto>
|
||||||
|
|
||||||
Specify https if needed
|
Specify https if needed (Default: 'http')
|
||||||
|
|
||||||
=item B<--urlpath>
|
=item B<--urlpath>
|
||||||
|
|
||||||
|
@ -150,7 +149,7 @@ Specify password for basic authentification (Mandatory if --credentials is speci
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout
|
Threshold for HTTP timeout (Default: 5)
|
||||||
|
|
||||||
=item B<--ssl>
|
=item B<--ssl>
|
||||||
|
|
||||||
|
@ -176,6 +175,34 @@ Specify certificate's password
|
||||||
|
|
||||||
Specify type of certificate (PKCS12)
|
Specify type of certificate (PKCS12)
|
||||||
|
|
||||||
|
=item B<--header>
|
||||||
|
|
||||||
|
Set HTTP headers (Multiple option)
|
||||||
|
|
||||||
|
=item B<--get-param>
|
||||||
|
|
||||||
|
Set GET params (Multiple option. Example: --get-param='key=value')
|
||||||
|
|
||||||
|
=item B<--post-param>
|
||||||
|
|
||||||
|
Set POST params (Multiple option. Example: --post-param='key=value')
|
||||||
|
|
||||||
|
=item B<--cookies-file>
|
||||||
|
|
||||||
|
Save cookies in a file (Example: '/tmp/lwp_cookies.dat')
|
||||||
|
|
||||||
|
=item B<--unknown-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code (Default: '%{http_code} < 200 or %{http_code} >= 300')
|
||||||
|
|
||||||
|
=item B<--warning-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--critical-status>
|
||||||
|
|
||||||
|
Threshold critical for http response code
|
||||||
|
|
||||||
=item B<--expected-string>
|
=item B<--expected-string>
|
||||||
|
|
||||||
Specify String to check on the Webpage
|
Specify String to check on the Webpage
|
||||||
|
|
|
@ -25,7 +25,7 @@ use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Time::HiRes qw(gettimeofday tv_interval);
|
use Time::HiRes qw(gettimeofday tv_interval);
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use JSON::Path;
|
use JSON::Path;
|
||||||
use JSON;
|
use JSON;
|
||||||
|
|
||||||
|
@ -40,9 +40,11 @@ sub new {
|
||||||
"data:s" => { name => 'data' },
|
"data:s" => { name => 'data' },
|
||||||
"lookup:s@" => { name => 'lookup' },
|
"lookup:s@" => { name => 'lookup' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
|
"http-peer-addr:s" => { name => 'http_peer_addr' },
|
||||||
|
"vhost:s" => { name => 'vhost' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/" },
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"ntlm" => { name => 'ntlm' },
|
"ntlm" => { name => 'ntlm' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -57,6 +59,9 @@ sub new {
|
||||||
"cacert-file:s" => { name => 'cacert_file' },
|
"cacert-file:s" => { name => 'cacert_file' },
|
||||||
"cert-pwd:s" => { name => 'cert_pwd' },
|
"cert-pwd:s" => { name => 'cert_pwd' },
|
||||||
"cert-pkcs12" => { name => 'cert_pkcs12' },
|
"cert-pkcs12" => { name => 'cert_pkcs12' },
|
||||||
|
"unknown-status:s" => { name => 'unknown_status' },
|
||||||
|
"warning-status:s" => { name => 'warning_status' },
|
||||||
|
"critical-status:s" => { name => 'critical_status' },
|
||||||
|
|
||||||
"warning-numeric:s" => { name => 'warning_numeric' },
|
"warning-numeric:s" => { name => 'warning_numeric' },
|
||||||
"critical-numeric:s" => { name => 'critical_numeric' },
|
"critical-numeric:s" => { name => 'critical_numeric' },
|
||||||
|
@ -80,6 +85,7 @@ sub new {
|
||||||
$self->{values_string_ok} = [];
|
$self->{values_string_ok} = [];
|
||||||
$self->{values_string_warning} = [];
|
$self->{values_string_warning} = [];
|
||||||
$self->{values_string_critical} = [];
|
$self->{values_string_critical} = [];
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,47 +112,8 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical-time threshold '" . $self->{option_results}->{critical_time} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical-time threshold '" . $self->{option_results}->{critical_time} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to specify hostname.");
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((!defined($self->{option_results}->{credentials})) && (defined($self->{option_results}->{ntlm}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "--ntlm option must be used with --credentials option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{pkcs12})) && (!defined($self->{option_results}->{cert_file}) && !defined($self->{option_results}->{cert_pwd}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --cert-file= and --cert-pwd= options when --pkcs12 is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
$self->{headers} = {};
|
|
||||||
if (defined($self->{option_results}->{header})) {
|
|
||||||
foreach (@{$self->{option_results}->{header}}) {
|
|
||||||
if (/^(.*?):(.*)/) {
|
|
||||||
$self->{headers}->{$1} = $2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$self->{get_params} = {};
|
|
||||||
if (defined($self->{option_results}->{get_param})) {
|
|
||||||
foreach (@{$self->{option_results}->{get_param}}) {
|
|
||||||
if (/^([^=]+)={0,1}(.*)$/) {
|
|
||||||
my $key = $1;
|
|
||||||
my $value = defined($2) ? $2 : 1;
|
|
||||||
if (defined($self->{get_params}->{$key})) {
|
|
||||||
if (ref($self->{get_params}->{$key}) ne 'ARRAY') {
|
|
||||||
$self->{get_params}->{$key} = [ $self->{get_params}->{$key} ];
|
|
||||||
}
|
|
||||||
push @{$self->{get_params}->{$key}}, $value;
|
|
||||||
} else {
|
|
||||||
$self->{get_params}->{$key} = $value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub load_request {
|
sub load_request {
|
||||||
|
@ -265,14 +232,10 @@ sub lookup {
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{port})) {
|
|
||||||
$self->{option_results}->{port} = centreon::plugins::httplib::get_port($self);
|
|
||||||
}
|
|
||||||
$self->load_request();
|
$self->load_request();
|
||||||
|
|
||||||
my $timing0 = [gettimeofday];
|
my $timing0 = [gettimeofday];
|
||||||
$self->{json_response} = centreon::plugins::httplib::connect($self, headers => $self->{headers}, method => $self->{method},
|
$self->{json_response} = $self->{http}->request(method => $self->{method}, query_form_post => $self->{json_request});
|
||||||
query_form_get => $self->{get_params}, query_form_post => $self->{json_request});
|
|
||||||
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => $self->{json_response});
|
$self->{output}->output_add(long_msg => $self->{json_response});
|
||||||
|
@ -395,6 +358,10 @@ HTTP OPTIONS:
|
||||||
|
|
||||||
IP Addr/FQDN of the Webserver host
|
IP Addr/FQDN of the Webserver host
|
||||||
|
|
||||||
|
=item B<--http-peer-addr>
|
||||||
|
|
||||||
|
Set the address you want to connect (Useful if hostname is only a vhost. no ip resolve)
|
||||||
|
|
||||||
=item B<--port>
|
=item B<--port>
|
||||||
|
|
||||||
Port used by Webserver
|
Port used by Webserver
|
||||||
|
@ -463,6 +430,18 @@ Set GET params (Multiple option. Example: --get-param='key=value')
|
||||||
|
|
||||||
Set HTTP headers (Multiple option. Example: --header='Content-Type: xxxxx')
|
Set HTTP headers (Multiple option. Example: --header='Content-Type: xxxxx')
|
||||||
|
|
||||||
|
=item B<--unknown-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code (Default: '%{http_code} < 200 or %{http_code} >= 300')
|
||||||
|
|
||||||
|
=item B<--warning-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--critical-status>
|
||||||
|
|
||||||
|
Threshold critical for http response code
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -25,7 +25,7 @@ use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Time::HiRes qw(gettimeofday tv_interval);
|
use Time::HiRes qw(gettimeofday tv_interval);
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,9 +36,11 @@ sub new {
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments =>
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
|
"http-peer-addr:s" => { name => 'http_peer_addr' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"method:s" => { name => 'method' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/" },
|
"proto:s" => { name => 'proto' },
|
||||||
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"ntlm" => { name => 'ntlm' },
|
"ntlm" => { name => 'ntlm' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -46,14 +48,23 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"ssl:s" => { name => 'ssl' },
|
"ssl:s" => { name => 'ssl' },
|
||||||
"cert-file:s" => { name => 'cert_file' },
|
"cert-file:s" => { name => 'cert_file' },
|
||||||
"key-file:s" => { name => 'key_file' },
|
"key-file:s" => { name => 'key_file' },
|
||||||
"cacert-file:s" => { name => 'cacert_file' },
|
"cacert-file:s" => { name => 'cacert_file' },
|
||||||
"cert-pwd:s" => { name => 'cert_pwd' },
|
"cert-pwd:s" => { name => 'cert_pwd' },
|
||||||
"cert-pkcs12" => { name => 'cert_pkcs12' },
|
"cert-pkcs12" => { name => 'cert_pkcs12' },
|
||||||
|
"header:s@" => { name => 'header' },
|
||||||
|
"get-param:s@" => { name => 'get_param' },
|
||||||
|
"post-param:s@" => { name => 'post_param' },
|
||||||
|
"cookies-file:s" => { name => 'cookies_file' },
|
||||||
|
"unknown-status:s" => { name => 'unknown_status', default => '' },
|
||||||
|
"warning-status:s" => { name => 'warning_status' },
|
||||||
|
"critical-status:s" => { name => 'critical_status', default => '%{http_code} < 200 or %{http_code} >= 300' },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,37 +81,17 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{pkcs12})) && (!defined($self->{option_results}->{cert_file}) && !defined($self->{option_results}->{cert_pwd}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --cert-file= and --cert-pwd= options when --pkcs12 is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{port})) {
|
|
||||||
$self->{option_results}->{port} = centreon::plugins::httplib::get_port($self);
|
|
||||||
}
|
|
||||||
|
|
||||||
my $timing0 = [gettimeofday];
|
my $timing0 = [gettimeofday];
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self, connection_exit => 'critical');
|
my $webcontent = $self->{http}->request();
|
||||||
|
|
||||||
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
my $timeelapsed = tv_interval($timing0, [gettimeofday]);
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => $webcontent);
|
$self->{output}->output_add(long_msg => $webcontent);
|
||||||
|
|
||||||
|
@ -108,10 +99,11 @@ sub run {
|
||||||
threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
threshold => [ { label => 'critical', exit_litteral => 'critical' }, { label => 'warning', exit_litteral => 'warning' } ]);
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(severity => $exit,
|
||||||
short_msg => sprintf("Response time %.3fs", $timeelapsed));
|
short_msg => sprintf("Response time %.3fs", $timeelapsed));
|
||||||
$self->{output}->perfdata_add(label => "time",
|
$self->{output}->perfdata_add(label => "time", unit => 's',
|
||||||
value => sprintf('%.3f', $timeelapsed),
|
value => sprintf('%.3f', $timeelapsed),
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning'),
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'));
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical'),
|
||||||
|
min => 0);
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
@ -131,13 +123,21 @@ Check Webpage Time Response
|
||||||
|
|
||||||
IP Addr/FQDN of the webserver host
|
IP Addr/FQDN of the webserver host
|
||||||
|
|
||||||
|
=item B<--http-peer-addr>
|
||||||
|
|
||||||
|
Set the address you want to connect (Useful if hostname is only a vhost. no ip resolve)
|
||||||
|
|
||||||
=item B<--port>
|
=item B<--port>
|
||||||
|
|
||||||
Port used by Webserver
|
Port used by Webserver
|
||||||
|
|
||||||
|
=item B<--method>
|
||||||
|
|
||||||
|
Specify http method used (Default: 'GET')
|
||||||
|
|
||||||
=item B<--proto>
|
=item B<--proto>
|
||||||
|
|
||||||
Specify https if needed
|
Specify https if needed (Default: 'http')
|
||||||
|
|
||||||
=item B<--urlpath>
|
=item B<--urlpath>
|
||||||
|
|
||||||
|
@ -165,20 +165,12 @@ Proxy URL if any
|
||||||
|
|
||||||
=item B<--timeout>
|
=item B<--timeout>
|
||||||
|
|
||||||
Threshold for HTTP timeout
|
Threshold for HTTP timeout (Default: 5)
|
||||||
|
|
||||||
=item B<--ssl>
|
=item B<--ssl>
|
||||||
|
|
||||||
Specify SSL version (example : 'sslv3', 'tlsv1'...)
|
Specify SSL version (example : 'sslv3', 'tlsv1'...)
|
||||||
|
|
||||||
=item B<--warning>
|
|
||||||
|
|
||||||
Threshold warning in seconds (Webpage response time)
|
|
||||||
|
|
||||||
=item B<--critical>
|
|
||||||
|
|
||||||
Threshold critical in seconds (Webpage response time)
|
|
||||||
|
|
||||||
=item B<--cert-file>
|
=item B<--cert-file>
|
||||||
|
|
||||||
Specify certificate to send to the webserver
|
Specify certificate to send to the webserver
|
||||||
|
@ -199,6 +191,42 @@ Specify certificate's password
|
||||||
|
|
||||||
Specify type of certificate (PKCS12)
|
Specify type of certificate (PKCS12)
|
||||||
|
|
||||||
|
=item B<--header>
|
||||||
|
|
||||||
|
Set HTTP headers (Multiple option)
|
||||||
|
|
||||||
|
=item B<--get-param>
|
||||||
|
|
||||||
|
Set GET params (Multiple option. Example: --get-param='key=value')
|
||||||
|
|
||||||
|
=item B<--post-param>
|
||||||
|
|
||||||
|
Set POST params (Multiple option. Example: --post-param='key=value')
|
||||||
|
|
||||||
|
=item B<--cookies-file>
|
||||||
|
|
||||||
|
Save cookies in a file (Example: '/tmp/lwp_cookies.dat')
|
||||||
|
|
||||||
|
=item B<--unknown-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--warning-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--critical-status>
|
||||||
|
|
||||||
|
Threshold critical for http response code (Default: '%{http_code} < 200 or %{http_code} >= 300')
|
||||||
|
|
||||||
|
=item B<--warning>
|
||||||
|
|
||||||
|
Threshold warning in seconds (Webpage response time)
|
||||||
|
|
||||||
|
=item B<--critical>
|
||||||
|
|
||||||
|
Threshold critical in seconds (Webpage response time)
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -25,7 +25,7 @@ use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Time::HiRes qw(gettimeofday tv_interval);
|
use Time::HiRes qw(gettimeofday tv_interval);
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
|
@ -40,9 +40,11 @@ sub new {
|
||||||
"data:s" => { name => 'data' },
|
"data:s" => { name => 'data' },
|
||||||
"lookup:s@" => { name => 'lookup' },
|
"lookup:s@" => { name => 'lookup' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
|
"http-peer-addr:s" => { name => 'http_peer_addr' },
|
||||||
|
"vhost:s" => { name => 'vhost' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/" },
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"ntlm" => { name => 'ntlm' },
|
"ntlm" => { name => 'ntlm' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -56,6 +58,9 @@ sub new {
|
||||||
"cacert-file:s" => { name => 'cacert_file' },
|
"cacert-file:s" => { name => 'cacert_file' },
|
||||||
"cert-pwd:s" => { name => 'cert_pwd' },
|
"cert-pwd:s" => { name => 'cert_pwd' },
|
||||||
"cert-pkcs12" => { name => 'cert_pkcs12' },
|
"cert-pkcs12" => { name => 'cert_pkcs12' },
|
||||||
|
"unknown-status:s" => { name => 'unknown_status' },
|
||||||
|
"warning-status:s" => { name => 'warning_status' },
|
||||||
|
"critical-status:s" => { name => 'critical_status' },
|
||||||
|
|
||||||
"warning-numeric:s" => { name => 'warning_numeric' },
|
"warning-numeric:s" => { name => 'warning_numeric' },
|
||||||
"critical-numeric:s" => { name => 'critical_numeric' },
|
"critical-numeric:s" => { name => 'critical_numeric' },
|
||||||
|
@ -79,6 +84,7 @@ sub new {
|
||||||
$self->{values_string_ok} = [];
|
$self->{values_string_ok} = [];
|
||||||
$self->{values_string_warning} = [];
|
$self->{values_string_warning} = [];
|
||||||
$self->{values_string_critical} = [];
|
$self->{values_string_critical} = [];
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,31 +119,9 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to specify data.");
|
$self->{output}->add_option_msg(short_msg => "You need to specify data.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to specify hostname.");
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->option_exit();
|
$self->{http}->add_header(key => 'SOAPAction', value => $self->{option_results}->{service_soap});
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((!defined($self->{option_results}->{credentials})) && (defined($self->{option_results}->{ntlm}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "--ntlm option must be used with --credentials option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{pkcs12})) && (!defined($self->{option_results}->{cert_file}) && !defined($self->{option_results}->{cert_pwd}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --cert-file= and --cert-pwd= options when --pkcs12 is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
$self->{headers} = {};
|
|
||||||
if (defined($self->{option_results}->{header})) {
|
|
||||||
foreach (@{$self->{option_results}->{header}}) {
|
|
||||||
if (/^(.*?):(.*)/) {
|
|
||||||
$self->{headers}->{$1} = $2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$self->{headers}->{SOAPAction} = $self->{option_results}->{service_soap};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub load_request {
|
sub load_request {
|
||||||
|
@ -257,13 +241,10 @@ sub lookup {
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{port})) {
|
|
||||||
$self->{option_results}->{port} = centreon::plugins::httplib::get_port($self);
|
|
||||||
}
|
|
||||||
$self->load_request();
|
$self->load_request();
|
||||||
|
|
||||||
my $timing0 = [gettimeofday];
|
my $timing0 = [gettimeofday];
|
||||||
$self->{soap_response} = centreon::plugins::httplib::connect($self, headers => $self->{headers}, method => 'POST', query_form_post => $self->{soap_request});
|
$self->{soap_response} = $self->{http}->request(method => 'POST', query_form_post => $self->{soap_request});
|
||||||
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
my $timeelapsed = tv_interval ($timing0, [gettimeofday]);
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => $self->{soap_response});
|
$self->{output}->output_add(long_msg => $self->{soap_response});
|
||||||
|
@ -390,6 +371,10 @@ HTTP OPTIONS:
|
||||||
|
|
||||||
IP Addr/FQDN of the Webserver host
|
IP Addr/FQDN of the Webserver host
|
||||||
|
|
||||||
|
=item B<--http-peer-addr>
|
||||||
|
|
||||||
|
Set the address you want to connect (Useful if hostname is only a vhost. no ip resolve)
|
||||||
|
|
||||||
=item B<--port>
|
=item B<--port>
|
||||||
|
|
||||||
Port used by Webserver
|
Port used by Webserver
|
||||||
|
@ -454,6 +439,18 @@ Specify type of certificate (PKCS1
|
||||||
|
|
||||||
Set HTTP headers (Multiple option)
|
Set HTTP headers (Multiple option)
|
||||||
|
|
||||||
|
=item B<--unknown-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code (Default: '%{http_code} < 200 or %{http_code} >= 300')
|
||||||
|
|
||||||
|
=item B<--warning-status>
|
||||||
|
|
||||||
|
Threshold warning for http response code
|
||||||
|
|
||||||
|
=item B<--critical-status>
|
||||||
|
|
||||||
|
Threshold critical for http response code
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -23,7 +23,7 @@ package apps::tomcat::web::mode::applications;
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -35,12 +35,12 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '8080' },
|
"port:s" => { name => 'port', default => '8080' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/manager/text/list' },
|
"urlpath:s" => { name => 'url_path', default => '/manager/text/list' },
|
||||||
"name:s" => { name => 'name' },
|
"name:s" => { name => 'name' },
|
||||||
"regexp" => { name => 'use_regexp' },
|
"regexp" => { name => 'use_regexp' },
|
||||||
|
@ -49,7 +49,7 @@ sub new {
|
||||||
});
|
});
|
||||||
|
|
||||||
$self->{result} = {};
|
$self->{result} = {};
|
||||||
$self->{hostname} = undef;
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,27 +57,15 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
|
|
||||||
while ($webcontent =~ m/(.*):(.*):(.*):(.*)/g) {
|
while ($webcontent =~ m/(.*):(.*):(.*):(.*)/g) {
|
||||||
my ($context, $state, $sessions, $contextpath) = ($1, $2, $3, $4);
|
my ($context, $state, $sessions, $contextpath) = ($1, $2, $3, $4);
|
||||||
|
|
||||||
next if (defined($self->{option_results}->{filter_path}) && $self->{option_results}->{filter_path} ne '' &&
|
next if (defined($self->{option_results}->{filter_path}) && $self->{option_results}->{filter_path} ne '' &&
|
||||||
|
|
|
@ -23,7 +23,7 @@ package apps::tomcat::web::mode::listapplication;
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -35,12 +35,12 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '8080' },
|
"port:s" => { name => 'port', default => '8080' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/manager/text/list' },
|
"urlpath:s" => { name => 'url_path', default => '/manager/text/list' },
|
||||||
"filter-name:s" => { name => 'filter_name', },
|
"filter-name:s" => { name => 'filter_name', },
|
||||||
"filter-state:s" => { name => 'filter_state', },
|
"filter-state:s" => { name => 'filter_state', },
|
||||||
|
@ -48,7 +48,7 @@ sub new {
|
||||||
});
|
});
|
||||||
|
|
||||||
$self->{result} = {};
|
$self->{result} = {};
|
||||||
$self->{hostname} = undef;
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,25 +56,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
|
|
||||||
while ($webcontent =~ m/(.*):(.*):(.*):(.*)/g) {
|
while ($webcontent =~ m/(.*):(.*):(.*):(.*)/g) {
|
||||||
my ($context, $state, $sessions, $contextpath) = ($1, $2, $3, $4);
|
my ($context, $state, $sessions, $contextpath) = ($1, $2, $3, $4);
|
||||||
|
|
|
@ -23,7 +23,7 @@ package apps::tomcat::web::mode::memory;
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
|
@ -36,38 +36,26 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '8080' },
|
"port:s" => { name => 'port', default => '8080' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/manager/status?XML=true' },
|
"urlpath:s" => { name => 'url_path', default => '/manager/status?XML=true' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
});
|
});
|
||||||
|
|
||||||
$self->{result} = {};
|
$self->{result} = {};
|
||||||
$self->{hostname} = undef;
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -77,6 +65,7 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
my %xpath_to_check = (
|
my %xpath_to_check = (
|
||||||
|
@ -88,7 +77,7 @@ my %xpath_to_check = (
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $port = $self->{option_results}->{port};
|
my $port = $self->{option_results}->{port};
|
||||||
|
|
||||||
#EXAMPLE 1:
|
#EXAMPLE 1:
|
||||||
|
|
|
@ -23,7 +23,7 @@ package apps::tomcat::web::mode::requestinfo;
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use Digest::MD5 qw(md5_hex);
|
use Digest::MD5 qw(md5_hex);
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
|
@ -39,12 +39,12 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '8080' },
|
"port:s" => { name => 'port', default => '8080' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/manager/status?XML=true' },
|
"urlpath:s" => { name => 'url_path', default => '/manager/status?XML=true' },
|
||||||
"name:s" => { name => 'name' },
|
"name:s" => { name => 'name' },
|
||||||
"regexp" => { name => 'use_regexp' },
|
"regexp" => { name => 'use_regexp' },
|
||||||
|
@ -69,18 +69,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
#MaxTime
|
#MaxTime
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning-maxtime', value => $self->{option_results}->{warning_maxtime})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning-maxtime', value => $self->{option_results}->{warning_maxtime})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning 'warning-maxtime' threshold '" . $self->{option_results}->{warning_maxtime} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning 'warning-maxtime' threshold '" . $self->{option_results}->{warning_maxtime} . "'.");
|
||||||
|
@ -123,6 +111,8 @@ sub check_options {
|
||||||
if (!defined($self->{hostname})) {
|
if (!defined($self->{hostname})) {
|
||||||
$self->{hostname} = 'me';
|
$self->{hostname} = 'me';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
my %xpath_to_check = (
|
my %xpath_to_check = (
|
||||||
|
@ -135,7 +125,7 @@ my %xpath_to_check = (
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $port = $self->{option_results}->{port};
|
my $port = $self->{option_results}->{port};
|
||||||
|
|
||||||
#EXAMPLE 1:
|
#EXAMPLE 1:
|
||||||
|
@ -207,12 +197,12 @@ sub manage_selection {
|
||||||
};
|
};
|
||||||
|
|
||||||
if (scalar(keys %{$self->{result}}) <= 0) {
|
if (scalar(keys %{$self->{result}}) <= 0) {
|
||||||
if (defined($self->{option_results}->{name})) {
|
if (defined($self->{option_results}->{name})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "No information found for name '" . $self->{option_results}->{name} . "'.");
|
$self->{output}->add_option_msg(short_msg => "No information found for name '" . $self->{option_results}->{name} . "'.");
|
||||||
} else {
|
} else {
|
||||||
$self->{output}->add_option_msg(short_msg => "No information found.");
|
$self->{output}->add_option_msg(short_msg => "No information found.");
|
||||||
}
|
}
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
@ -23,7 +23,7 @@ package apps::tomcat::web::mode::sessions;
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -35,12 +35,12 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '8080' },
|
"port:s" => { name => 'port', default => '8080' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/manager/text/list' },
|
"urlpath:s" => { name => 'url_path', default => '/manager/text/list' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
|
@ -52,7 +52,7 @@ sub new {
|
||||||
});
|
});
|
||||||
|
|
||||||
$self->{result} = {};
|
$self->{result} = {};
|
||||||
$self->{hostname} = undef;
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,18 +60,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -80,15 +68,15 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
|
|
||||||
while ($webcontent =~ m/(.*):(.*):(.*):(.*)/g) {
|
while ($webcontent =~ m/(.*):(.*):(.*):(.*)/g) {
|
||||||
my ($context, $state, $sessions, $contextpath) = ($1, $2, $3, $4);
|
my ($context, $state, $sessions, $contextpath) = ($1, $2, $3, $4);
|
||||||
|
|
||||||
next if (defined($self->{option_results}->{filter_state}) && $self->{option_results}->{filter_state} ne '' &&
|
next if (defined($self->{option_results}->{filter_state}) && $self->{option_results}->{filter_state} ne '' &&
|
||||||
|
|
|
@ -23,7 +23,7 @@ package apps::tomcat::web::mode::threads;
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
use URI::Escape;
|
use URI::Escape;
|
||||||
|
|
||||||
|
@ -37,12 +37,12 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '8080' },
|
"port:s" => { name => 'port', default => '8080' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/manager/status?XML=true' },
|
"urlpath:s" => { name => 'url_path', default => '/manager/status?XML=true' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
|
@ -53,6 +53,7 @@ sub new {
|
||||||
|
|
||||||
$self->{result} = {};
|
$self->{result} = {};
|
||||||
$self->{hostname} = undef;
|
$self->{hostname} = undef;
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,18 +61,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -81,6 +70,7 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
my %xpath_to_check = (
|
my %xpath_to_check = (
|
||||||
|
@ -92,7 +82,7 @@ my %xpath_to_check = (
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $port = $self->{option_results}->{port};
|
my $port = $self->{option_results}->{port};
|
||||||
|
|
||||||
#EXAMPLE 1:
|
#EXAMPLE 1:
|
||||||
|
|
|
@ -23,7 +23,7 @@ package apps::tomcat::web::mode::traffic;
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::mode);
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use centreon::plugins::statefile;
|
use centreon::plugins::statefile;
|
||||||
use Digest::MD5 qw(md5_hex);
|
use Digest::MD5 qw(md5_hex);
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
|
@ -39,12 +39,12 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', default => '8080' },
|
"port:s" => { name => 'port', default => '8080' },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
"urlpath:s" => { name => 'url_path', default => '/manager/status?XML=true' },
|
"urlpath:s" => { name => 'url_path', default => '/manager/status?XML=true' },
|
||||||
"name:s" => { name => 'name' },
|
"name:s" => { name => 'name' },
|
||||||
"regexp" => { name => 'use_regexp' },
|
"regexp" => { name => 'use_regexp' },
|
||||||
|
@ -59,6 +59,7 @@ sub new {
|
||||||
$self->{result} = {};
|
$self->{result} = {};
|
||||||
$self->{hostname} = undef;
|
$self->{hostname} = undef;
|
||||||
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_value} = centreon::plugins::statefile->new(%options);
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -66,18 +67,6 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
$self->SUPER::init(%options);
|
||||||
|
|
||||||
if (($self->{option_results}->{proto} ne 'http') && ($self->{option_results}->{proto} ne 'https')) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning-in', value => $self->{option_results}->{warning_in})) == 0) {
|
if (($self->{perfdata}->threshold_validate(label => 'warning-in', value => $self->{option_results}->{warning_in})) == 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning 'in' threshold '" . $self->{option_results}->{warning_in} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong warning 'in' threshold '" . $self->{option_results}->{warning_in} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -109,6 +98,8 @@ sub check_options {
|
||||||
if (!defined($self->{hostname})) {
|
if (!defined($self->{hostname})) {
|
||||||
$self->{hostname} = 'me';
|
$self->{hostname} = 'me';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
|
||||||
my %xpath_to_check = (
|
my %xpath_to_check = (
|
||||||
|
@ -119,7 +110,7 @@ my %xpath_to_check = (
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $port = $self->{option_results}->{port};
|
my $port = $self->{option_results}->{port};
|
||||||
|
|
||||||
#EXAMPLE 1:
|
#EXAMPLE 1:
|
||||||
|
|
|
@ -0,0 +1,268 @@
|
||||||
|
#
|
||||||
|
# Copyright 2015 Centreon (http://www.centreon.com/)
|
||||||
|
#
|
||||||
|
# Centreon is a full-fledged industry-strength solution that meets
|
||||||
|
# the needs in IT infrastructure and application monitoring for
|
||||||
|
# service performance.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
package centreon::plugins::http;
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use centreon::plugins::misc;
|
||||||
|
use LWP::UserAgent;
|
||||||
|
use HTTP::Cookies;
|
||||||
|
use URI;
|
||||||
|
use IO::Socket::SSL;
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my ($class, %options) = @_;
|
||||||
|
my $self = {};
|
||||||
|
bless $self, $class;
|
||||||
|
|
||||||
|
$self->{output} = $options{output};
|
||||||
|
$self->{ua} = undef;
|
||||||
|
$self->{options} = {
|
||||||
|
proto => 'http',
|
||||||
|
url_path => '/',
|
||||||
|
timeout => 5,
|
||||||
|
method => 'GET',
|
||||||
|
unknown_status => '%{http_code} < 200 or %{http_code} >= 300',
|
||||||
|
warning_status => undef,
|
||||||
|
critical_status => undef,
|
||||||
|
};
|
||||||
|
$self->{add_headers} = {};
|
||||||
|
return $self;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub set_options {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{options} = { %{$self->{options}} };
|
||||||
|
foreach (keys %options) {
|
||||||
|
$self->{options}->{$_} = $options{$_} if (defined($options{$_}));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sub add_header {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{add_headers}->{$options{key}} = $options{value};
|
||||||
|
}
|
||||||
|
|
||||||
|
sub check_options {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
if (($options{request}->{proto} ne 'http') && ($options{request}->{proto} ne 'https')) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Unsupported protocol specified '" . $self->{option_results}->{proto} . "'.");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
if (!defined($options{request}->{hostname})) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
if ((defined($options{request}->{credentials})) && (!defined($options{request}->{username}) || !defined($options{request}->{password}))) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
if ((defined($options{request}->{pkcs12})) && (!defined($options{request}->{cert_file}) && !defined($options{request}->{cert_pwd}))) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "You need to set --cert-file= and --cert-pwd= options when --pkcs12 is used");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
$options{request}->{port} = $self->get_port();
|
||||||
|
|
||||||
|
$options{request}->{headers} = {};
|
||||||
|
if (defined($options{request}->{header})) {
|
||||||
|
foreach (@{$options{request}->{header}}) {
|
||||||
|
if (/^(.*?):(.*)/) {
|
||||||
|
$options{request}->{headers}->{$1} = $2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
foreach (keys %{$self->{add_headers}}) {
|
||||||
|
$options{request}->{headers}->{$_} = $self->{add_headers}->{$_};
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach my $method (('get', 'post')) {
|
||||||
|
if (defined($options{request}->{$method . '_param'})) {
|
||||||
|
$self->{$method . '_params'} = {};
|
||||||
|
foreach (@{$options{request}->{$method . '_param'}}) {
|
||||||
|
if (/^([^=]+)={0,1}(.*)$/) {
|
||||||
|
my $key = $1;
|
||||||
|
my $value = defined($2) ? $2 : 1;
|
||||||
|
if (defined($self->{$method . '_params'}->{$key})) {
|
||||||
|
if (ref($self->{$method . '_params'}->{$key}) ne 'ARRAY') {
|
||||||
|
$self->{$method . '_params'}->{$key} = [ $self->{$method . '_params'}->{$key} ];
|
||||||
|
}
|
||||||
|
push @{$self->{$method . '_params'}->{$key}}, $value;
|
||||||
|
} else {
|
||||||
|
$self->{$method . '_params'}->{$key} = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (('unknown_status', 'warning_status', 'critical_status')) {
|
||||||
|
if (defined($options{request}->{$_})) {
|
||||||
|
$options{request}->{$_} =~ s/%\{http_code\}/\$response->code/g;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sub get_port {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $port = '';
|
||||||
|
if (defined($self->{options}->{port}) && $self->{options}->{port} ne '') {
|
||||||
|
$port = $self->{options}->{port};
|
||||||
|
} else {
|
||||||
|
$port = 80 if ($self->{options}->{proto} eq 'http');
|
||||||
|
$port = 443 if ($self->{options}->{proto} eq 'https');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $port;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub request {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $request_options = { %{$self->{options}} };
|
||||||
|
foreach (keys %options) {
|
||||||
|
$request_options->{$_} = $options{$_} if (defined($options{$_}));
|
||||||
|
}
|
||||||
|
$self->check_options(request => $request_options);
|
||||||
|
|
||||||
|
if (!defined($self->{ua})) {
|
||||||
|
$self->{ua} = LWP::UserAgent->new(keep_alive => 1, protocols_allowed => ['http', 'https'], timeout => $request_options->{timeout},
|
||||||
|
requests_redirectable => [ 'GET', 'HEAD', 'POST' ]);
|
||||||
|
if (defined($request_options->{cookies_file})) {
|
||||||
|
$self->{ua}->cookie_jar(HTTP::Cookies->new(file => $request_options->{cookies_file},
|
||||||
|
autosave => 1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (defined($request_options->{http_peer_addr})) {
|
||||||
|
push @LWP::Protocol::http::EXTRA_SOCK_OPTS, PeerAddr => $request_options->{http_peer_addr};
|
||||||
|
}
|
||||||
|
|
||||||
|
my ($response, $content);
|
||||||
|
my ($req, $url);
|
||||||
|
if (defined($request_options->{port}) && $request_options->{port} =~ /^[0-9]+$/) {
|
||||||
|
$url = $request_options->{proto}. "://" . $request_options->{hostname} . ':' . $request_options->{port} . $request_options->{url_path};
|
||||||
|
} else {
|
||||||
|
$url = $request_options->{proto}. "://" . $request_options->{hostname} . $request_options->{url_path};
|
||||||
|
}
|
||||||
|
|
||||||
|
my $uri = URI->new($url);
|
||||||
|
if (defined($self->{get_params})) {
|
||||||
|
$uri->query_form($self->{get_params});
|
||||||
|
}
|
||||||
|
$req = HTTP::Request->new($request_options->{method}, $uri);
|
||||||
|
|
||||||
|
my $content_type_forced;
|
||||||
|
foreach my $key (keys %{$request_options->{headers}}) {
|
||||||
|
if ($key !~ /content-type/i) {
|
||||||
|
$req->header($key => $request_options->{headers}->{$key});
|
||||||
|
} else {
|
||||||
|
$content_type_forced = $request_options->{headers}->{$key};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request_options->{method} eq 'POST') {
|
||||||
|
if (defined($content_type_forced)) {
|
||||||
|
$req->content_type($content_type_forced);
|
||||||
|
$req->content($request_options->{query_form_post});
|
||||||
|
} else {
|
||||||
|
my $uri_post = URI->new();
|
||||||
|
if (defined($self->{post_params})) {
|
||||||
|
$uri_post->query_form($self->{post_params});
|
||||||
|
}
|
||||||
|
$req->content_type('application/x-www-form-urlencoded');
|
||||||
|
$req->content($uri_post->query);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined($request_options->{credentials}) && defined($request_options->{ntlm})) {
|
||||||
|
$self->{ua}->credentials($request_options->{hostname} . ':' . $request_options->{port}, '', $request_options->{username}, $request_options->{password});
|
||||||
|
} elsif (defined($request_options->{credentials})) {
|
||||||
|
$req->authorization_basic($request_options->{username}, $request_options->{password});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined($request_options->{proxyurl})) {
|
||||||
|
$self->{ua}->proxy(['http', 'https'], $request_options->{proxyurl});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined($request_options->{cert_pkcs12}) && $request_options->{cert_file} ne '' && $request_options->{cert_pwd} ne '') {
|
||||||
|
eval "use Net::SSL"; die $@ if $@;
|
||||||
|
$ENV{HTTPS_PKCS12_FILE} = $request_options->{cert_file};
|
||||||
|
$ENV{HTTPS_PKCS12_PASSWORD} = $request_options->{cert_pwd};
|
||||||
|
}
|
||||||
|
|
||||||
|
my $ssl_context;
|
||||||
|
if (defined($request_options->{ssl}) && $request_options->{ssl} ne '') {
|
||||||
|
$ssl_context = { SSL_version => $request_options->{ssl} };
|
||||||
|
}
|
||||||
|
if (defined($request_options->{cert_file}) && !defined($request_options->{cert_pkcs12})) {
|
||||||
|
$ssl_context = {} if (!defined($ssl_context));
|
||||||
|
$ssl_context->{SSL_use_cert} = 1;
|
||||||
|
$ssl_context->{SSL_cert_file} = $request_options->{cert_file};
|
||||||
|
$ssl_context->{SSL_key_file} = $request_options->{key_file} if (defined($request_options->{key_file}));
|
||||||
|
$ssl_context->{SSL_ca_file} = $request_options->{cacert_file} if (defined($request_options->{cacert_file}));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined($ssl_context)) {
|
||||||
|
my $context = new IO::Socket::SSL::SSL_Context(%{$ssl_context});
|
||||||
|
IO::Socket::SSL::set_default_context($context);
|
||||||
|
}
|
||||||
|
|
||||||
|
$response = $self->{ua}->request($req);
|
||||||
|
|
||||||
|
# Check response
|
||||||
|
my $status = 'ok';
|
||||||
|
my $message;
|
||||||
|
|
||||||
|
eval {
|
||||||
|
local $SIG{__WARN__} = sub { $message = $_[0]; };
|
||||||
|
local $SIG{__DIE__} = sub { $message = $_[0]; };
|
||||||
|
|
||||||
|
if (defined($request_options->{critical_status}) && $request_options->{critical_status} ne '' &&
|
||||||
|
eval "$request_options->{critical_status}") {
|
||||||
|
$status = 'critical';
|
||||||
|
} elsif (defined($request_options->{warning_status}) && $request_options->{warning_status} ne '' &&
|
||||||
|
eval "$request_options->{warning_status}") {
|
||||||
|
$status = 'warning';
|
||||||
|
} elsif (defined($request_options->{unknown_status}) && $request_options->{unknown_status} ne '' &&
|
||||||
|
eval "$request_options->{unknown_status}") {
|
||||||
|
$status = 'unknown';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
if (defined($message)) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => 'filter status issue: ' . $message);
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
|
||||||
|
$self->{output}->output_add(severity => $status,
|
||||||
|
short_msg => $response->status_line);
|
||||||
|
$self->{output}->display();
|
||||||
|
$self->{output}->exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $response->content;
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
|
@ -1,141 +0,0 @@
|
||||||
#
|
|
||||||
# Copyright 2015 Centreon (http://www.centreon.com/)
|
|
||||||
#
|
|
||||||
# Centreon is a full-fledged industry-strength solution that meets
|
|
||||||
# the needs in IT infrastructure and application monitoring for
|
|
||||||
# service performance.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
#
|
|
||||||
|
|
||||||
package centreon::plugins::httplib;
|
|
||||||
|
|
||||||
use strict;
|
|
||||||
use warnings;
|
|
||||||
use LWP::UserAgent;
|
|
||||||
use HTTP::Cookies;
|
|
||||||
use URI;
|
|
||||||
use IO::Socket::SSL;
|
|
||||||
|
|
||||||
sub get_port {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
|
|
||||||
my $cache_port = '';
|
|
||||||
if (defined($self->{option_results}->{port}) && $self->{option_results}->{port} ne '') {
|
|
||||||
$cache_port = $self->{option_results}->{port};
|
|
||||||
} else {
|
|
||||||
$cache_port = 80 if ($self->{option_results}->{proto} eq 'http');
|
|
||||||
$cache_port = 443 if ($self->{option_results}->{proto} eq 'https');
|
|
||||||
}
|
|
||||||
|
|
||||||
return $cache_port;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub connect {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
my $method = defined($options{method}) ? $options{method} : 'GET';
|
|
||||||
my $connection_exit = defined($options{connection_exit}) ? $options{connection_exit} : 'unknown';
|
|
||||||
|
|
||||||
my $ua = LWP::UserAgent->new(keep_alive => 1, protocols_allowed => ['http', 'https'], timeout => $self->{option_results}->{timeout},
|
|
||||||
requests_redirectable => [ 'GET', 'HEAD', 'POST' ]);
|
|
||||||
if (defined($options{cookies_file})) {
|
|
||||||
$ua->cookie_jar(HTTP::Cookies->new(file => $options{cookies_file},
|
|
||||||
autosave => 1));
|
|
||||||
}
|
|
||||||
|
|
||||||
my ($response, $content);
|
|
||||||
my ($req, $url);
|
|
||||||
if (defined($self->{option_results}->{port}) && $self->{option_results}->{port} =~ /^[0-9]+$/) {
|
|
||||||
$url = $self->{option_results}->{proto}. "://" . $self->{option_results}->{hostname}.':'. $self->{option_results}->{port} . $self->{option_results}->{url_path};
|
|
||||||
} else {
|
|
||||||
$url = $self->{option_results}->{proto}. "://" . $self->{option_results}->{hostname} . $self->{option_results}->{url_path};
|
|
||||||
}
|
|
||||||
|
|
||||||
my $uri = URI->new($url);
|
|
||||||
if (defined($options{query_form_get})) {
|
|
||||||
$uri->query_form($options{query_form_get});
|
|
||||||
}
|
|
||||||
$req = HTTP::Request->new($method => $uri);
|
|
||||||
|
|
||||||
my $content_type_forced;
|
|
||||||
if (defined($options{headers})) {
|
|
||||||
foreach my $key (keys %{$options{headers}}) {
|
|
||||||
if ($key !~ /content-type/i) {
|
|
||||||
$req->header($key => $options{headers}->{$key});
|
|
||||||
} else {
|
|
||||||
$content_type_forced = $options{headers}->{$key};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($method eq 'POST') {
|
|
||||||
if (defined($content_type_forced)) {
|
|
||||||
$req->content_type($content_type_forced);
|
|
||||||
$req->content($options{query_form_post});
|
|
||||||
} else {
|
|
||||||
my $uri_post = URI->new();
|
|
||||||
if (defined($options{query_form_post})) {
|
|
||||||
$uri_post->query_form($options{query_form_post});
|
|
||||||
}
|
|
||||||
$req->content_type('application/x-www-form-urlencoded');
|
|
||||||
$req->content($uri_post->query);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (defined($self->{option_results}->{credentials}) && defined($self->{option_results}->{ntlm})) {
|
|
||||||
$ua->credentials($self->{option_results}->{hostname} . ':' . $self->{option_results}->{port}, '', $self->{option_results}->{username}, $self->{option_results}->{password});
|
|
||||||
} elsif (defined($self->{option_results}->{credentials})) {
|
|
||||||
$req->authorization_basic($self->{option_results}->{username}, $self->{option_results}->{password});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (defined($self->{option_results}->{proxyurl})) {
|
|
||||||
$ua->proxy(['http', 'https'], $self->{option_results}->{proxyurl});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (defined($self->{option_results}->{cert_pkcs12}) && $self->{option_results}->{cert_file} ne '' && $self->{option_results}->{cert_pwd} ne '') {
|
|
||||||
eval "use Net::SSL"; die $@ if $@;
|
|
||||||
$ENV{HTTPS_PKCS12_FILE} = $self->{option_results}->{cert_file};
|
|
||||||
$ENV{HTTPS_PKCS12_PASSWORD} = $self->{option_results}->{cert_pwd};
|
|
||||||
}
|
|
||||||
|
|
||||||
my $ssl_context;
|
|
||||||
if (defined($self->{option_results}->{ssl}) && $self->{option_results}->{ssl} ne '') {
|
|
||||||
$ssl_context = { SSL_version => $self->{option_results}->{ssl} };
|
|
||||||
}
|
|
||||||
if (defined($self->{option_results}->{cert_file}) && !defined($self->{option_results}->{cert_pkcs12})) {
|
|
||||||
$ssl_context = {} if (!defined($ssl_context));
|
|
||||||
$ssl_context->{SSL_use_cert} = 1;
|
|
||||||
$ssl_context->{SSL_cert_file} = $self->{option_results}->{cert_file};
|
|
||||||
$ssl_context->{SSL_key_file} = $self->{option_results}->{key_file} if (defined($self->{option_results}->{key_file}));
|
|
||||||
$ssl_context->{SSL_ca_file} = $self->{option_results}->{cacert_file} if (defined($self->{option_results}->{cacert_file}));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (defined($ssl_context)) {
|
|
||||||
my $context = new IO::Socket::SSL::SSL_Context(%{$ssl_context});
|
|
||||||
IO::Socket::SSL::set_default_context($context);
|
|
||||||
}
|
|
||||||
|
|
||||||
$response = $ua->request($req);
|
|
||||||
|
|
||||||
if ($response->is_success) {
|
|
||||||
$content = $response->content;
|
|
||||||
return $content;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->{output}->output_add(severity => $connection_exit,
|
|
||||||
short_msg => $response->status_line);
|
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
1;
|
|
|
@ -318,13 +318,13 @@ sub powershell_escape {
|
||||||
|
|
||||||
sub minimal_version {
|
sub minimal_version {
|
||||||
my ($version_src, $version_dst) = @_;
|
my ($version_src, $version_dst) = @_;
|
||||||
|
|
||||||
# No Version. We skip
|
# No Version. We skip
|
||||||
if (!defined($version_src) || !defined($version_dst) ||
|
if (!defined($version_src) || !defined($version_dst) ||
|
||||||
$version_src !~ /^[0-9]+(?:\.[0-9\.])*$/ || $version_dst !~ /^[0-9x]+(?:\.[0-9x\.])*$/) {
|
$version_src !~ /^[0-9]+(?:\.[0-9\.]+)*$/ || $version_dst !~ /^[0-9x]+(?:\.[0-9x]+)*$/) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
my @version_src = split /\./, $version_src;
|
my @version_src = split /\./, $version_src;
|
||||||
my @versions = split /\./, $version_dst;
|
my @versions = split /\./, $version_dst;
|
||||||
for (my $i = 0; $i < scalar(@versions); $i++) {
|
for (my $i = 0; $i < scalar(@versions); $i++) {
|
||||||
|
|
|
@ -1192,7 +1192,7 @@ To use it, add the following line at the beginning of your **mode**:
|
||||||
|
|
||||||
.. code-block:: perl
|
.. code-block:: perl
|
||||||
|
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
Some options must be set in **plugin.pm**:
|
Some options must be set in **plugin.pm**:
|
||||||
|
|
||||||
|
@ -1244,7 +1244,9 @@ We suppose these options are defined :
|
||||||
|
|
||||||
.. code-block:: perl
|
.. code-block:: perl
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
|
my $webcontent = $self->{http}->request();
|
||||||
print $webcontent;
|
print $webcontent;
|
||||||
|
|
||||||
Output displays content of the webpage '\http://google.com/'.
|
Output displays content of the webpage '\http://google.com/'.
|
||||||
|
|
|
@ -1191,7 +1191,7 @@ Pour l'utiliser, ajouter la ligne suivante au début de votre **mode** :
|
||||||
|
|
||||||
.. code-block:: perl
|
.. code-block:: perl
|
||||||
|
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
Certaines options doivent être spécifiées dans **plugin.pm** :
|
Certaines options doivent être spécifiées dans **plugin.pm** :
|
||||||
|
|
||||||
|
@ -1243,7 +1243,9 @@ Nous supposons que ces options sont définies :
|
||||||
|
|
||||||
.. code-block:: perl
|
.. code-block:: perl
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
|
my $webcontent = $self->{http}->request();
|
||||||
print $webcontent;
|
print $webcontent;
|
||||||
|
|
||||||
La sortie affichera le contenu de la page web '\http://google.com/'.
|
La sortie affichera le contenu de la page web '\http://google.com/'.
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/index.htm?eL" },
|
"urlpath:s" => { name => 'url_path', default => "/index.htm?eL" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -45,9 +45,10 @@ sub new {
|
||||||
"warning" => { name => 'warning' },
|
"warning" => { name => 'warning' },
|
||||||
"critical" => { name => 'critical' },
|
"critical" => { name => 'critical' },
|
||||||
"closed" => { name => 'closed' },
|
"closed" => { name => 'closed' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
$self->{status} = { closed => 'ok', opened => 'ok' };
|
$self->{status} = { closed => 'ok', opened => 'ok' };
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,20 +64,13 @@ sub check_options {
|
||||||
$self->{status}->{$label} = 'warning';
|
$self->{status}->{$label} = 'warning';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $contact;
|
my $contact;
|
||||||
|
|
||||||
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /([NW]).*?:/) {
|
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /([NW]).*?:/) {
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,8 +36,8 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/" },
|
"urlpath:s" => { name => 'url_path' },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
"password:s" => { name => 'password' },
|
"password:s" => { name => 'password' },
|
||||||
|
@ -45,9 +45,10 @@ sub new {
|
||||||
"warning" => { name => 'warning' },
|
"warning" => { name => 'warning' },
|
||||||
"critical" => { name => 'critical' },
|
"critical" => { name => 'critical' },
|
||||||
"dry" => { name => 'dry' },
|
"dry" => { name => 'dry' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
$self->{status} = { dry => 'ok', wet => 'ok' };
|
$self->{status} = { dry => 'ok', wet => 'ok' };
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,20 +64,13 @@ sub check_options {
|
||||||
$self->{status}->{$label} = 'warning';
|
$self->{status}->{$label} = 'warning';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $flood;
|
my $flood;
|
||||||
|
|
||||||
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /(dry|wet)/i) {
|
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /(dry|wet)/i) {
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/index.htm?em" },
|
"urlpath:s" => { name => 'url_path', default => "/index.htm?em" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -44,8 +44,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,20 +62,13 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $humidity;
|
my $humidity;
|
||||||
|
|
||||||
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /HU:\s*([0-9\.]+)/i) {
|
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /HU:\s*([0-9\.]+)/i) {
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/index.htm?em" },
|
"urlpath:s" => { name => 'url_path', default => "/index.htm?em" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -44,8 +44,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,20 +62,13 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $illumination;
|
my $illumination;
|
||||||
|
|
||||||
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /IL(?:\s*:\s*|\s*)([0-9\.]+)/i) {
|
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /IL(?:\s*:\s*|\s*)([0-9\.]+)/i) {
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/index.htm?em" },
|
"urlpath:s" => { name => 'url_path', default => "/index.htm?em" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -44,8 +44,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,20 +62,13 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
|
|
||||||
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /T([CF]):\s*([0-9\.]+)/i) {
|
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /T([CF]):\s*([0-9\.]+)/i) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Could not find temperature information.");
|
$self->{output}->add_option_msg(short_msg => "Could not find temperature information.");
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/index.htm?eR" },
|
"urlpath:s" => { name => 'url_path', default => "/index.htm?eR" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -44,8 +44,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,20 +62,13 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
|
|
||||||
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /R([CF])\s*([0-9\.]+)/i) {
|
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /R([CF])\s*([0-9\.]+)/i) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Could not find thermistor temperature information.");
|
$self->{output}->add_option_msg(short_msg => "Could not find thermistor temperature information.");
|
||||||
|
|
|
@ -24,7 +24,7 @@ use base qw(centreon::plugins::mode);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -36,7 +36,7 @@ sub new {
|
||||||
{
|
{
|
||||||
"hostname:s" => { name => 'hostname' },
|
"hostname:s" => { name => 'hostname' },
|
||||||
"port:s" => { name => 'port', },
|
"port:s" => { name => 'port', },
|
||||||
"proto:s" => { name => 'proto', default => "http" },
|
"proto:s" => { name => 'proto' },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/index.htm?ev" },
|
"urlpath:s" => { name => 'url_path', default => "/index.htm?ev" },
|
||||||
"credentials" => { name => 'credentials' },
|
"credentials" => { name => 'credentials' },
|
||||||
"username:s" => { name => 'username' },
|
"username:s" => { name => 'username' },
|
||||||
|
@ -44,8 +44,9 @@ sub new {
|
||||||
"proxyurl:s" => { name => 'proxyurl' },
|
"proxyurl:s" => { name => 'proxyurl' },
|
||||||
"warning:s" => { name => 'warning' },
|
"warning:s" => { name => 'warning' },
|
||||||
"critical:s" => { name => 'critical' },
|
"critical:s" => { name => 'critical' },
|
||||||
"timeout:s" => { name => 'timeout', default => '3' },
|
"timeout:s" => { name => 'timeout' },
|
||||||
});
|
});
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,20 +62,13 @@ sub check_options {
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
if (!defined($self->{option_results}->{hostname})) {
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
$self->{output}->add_option_msg(short_msg => "Please set the hostname option");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if ((defined($self->{option_results}->{credentials})) && (!defined($self->{option_results}->{username}) || !defined($self->{option_results}->{password}))) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "You need to set --username= and --password= options when --credentials is used");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = centreon::plugins::httplib::connect($self);
|
my $webcontent = $self->{http}->request();
|
||||||
my $voltage;
|
my $voltage;
|
||||||
|
|
||||||
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /CV\s*([0-9\.]+)/i) {
|
if ($webcontent !~ /<body>(.*)<\/body>/msi || $1 !~ /CV\s*([0-9\.]+)/i) {
|
||||||
|
|
|
@ -22,7 +22,7 @@ package storage::hp::p2000::xmlapi::custom;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::httplib;
|
use centreon::plugins::http;
|
||||||
use XML::XPath;
|
use XML::XPath;
|
||||||
use Digest::MD5 qw(md5_hex);
|
use Digest::MD5 qw(md5_hex);
|
||||||
|
|
||||||
|
@ -108,7 +108,7 @@ sub check_options {
|
||||||
$self->{proto} = (defined($self->{option_results}->{proto})) ? shift(@{$self->{option_results}->{proto}}) : 'http';
|
$self->{proto} = (defined($self->{option_results}->{proto})) ? shift(@{$self->{option_results}->{proto}}) : 'http';
|
||||||
$self->{url_path} = (defined($self->{option_results}->{url_path})) ? shift(@{$self->{option_results}->{url_path}}) : '/api/';
|
$self->{url_path} = (defined($self->{option_results}->{url_path})) ? shift(@{$self->{option_results}->{url_path}}) : '/api/';
|
||||||
$self->{proxyurl} = (defined($self->{option_results}->{proxyurl})) ? shift(@{$self->{option_results}->{proxyurl}}) : undef;
|
$self->{proxyurl} = (defined($self->{option_results}->{proxyurl})) ? shift(@{$self->{option_results}->{proxyurl}}) : undef;
|
||||||
|
|
||||||
if (!defined($self->{hostname})) {
|
if (!defined($self->{hostname})) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Need to specify hostname option.");
|
$self->{output}->add_option_msg(short_msg => "Need to specify hostname option.");
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
|
@ -129,8 +129,6 @@ sub build_options_for_httplib {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{option_results}->{hostname} = $self->{hostname};
|
$self->{option_results}->{hostname} = $self->{hostname};
|
||||||
$self->{option_results}->{username} = $self->{username};
|
|
||||||
$self->{option_results}->{password} = $self->{password};
|
|
||||||
$self->{option_results}->{timeout} = $self->{timeout};
|
$self->{option_results}->{timeout} = $self->{timeout};
|
||||||
$self->{option_results}->{port} = $self->{port};
|
$self->{option_results}->{port} = $self->{port};
|
||||||
$self->{option_results}->{proto} = $self->{proto};
|
$self->{option_results}->{proto} = $self->{proto};
|
||||||
|
@ -179,9 +177,9 @@ sub DESTROY {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
|
|
||||||
if ($self->{logon} == 1) {
|
if ($self->{logon} == 1) {
|
||||||
$self->{option_results}->{url_path} = $self->{url_path} . 'exit';
|
$self->{option_results}->{url_path} = ;
|
||||||
centreon::plugins::httplib::connect($self,
|
$self->{http}->request(url_path => $self->{url_path} . 'exit',
|
||||||
headers => {dataType => 'api', sessionKey => $self->{session_id} });
|
header => ['dataType: api', 'sessionKey: ' . $self->{session_id}]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,9 +189,8 @@ sub get_infos {
|
||||||
|
|
||||||
my $cmd = $options{cmd};
|
my $cmd = $options{cmd};
|
||||||
$cmd =~ s/ /\//g;
|
$cmd =~ s/ /\//g;
|
||||||
$self->{option_results}->{url_path} = $self->{url_path} . $cmd;
|
my $response =$self->{http}->request(url_path => $self->{url_path} . $cmd,
|
||||||
my $response = centreon::plugins::httplib::connect($self,
|
header => ['dataType: api', 'sessionKey: '. $self->{session_id}]);
|
||||||
headers => {dataType => 'api', sessionKey => $self->{session_id} });
|
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
$xpath = XML::XPath->new(xml => $response);
|
$xpath = XML::XPath->new(xml => $response);
|
||||||
|
@ -232,11 +229,12 @@ sub login {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->build_options_for_httplib();
|
$self->build_options_for_httplib();
|
||||||
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
|
|
||||||
# Login First
|
# Login First
|
||||||
my $md5_hash = md5_hex($self->{username} . '_' . $self->{password});
|
my $md5_hash = md5_hex($self->{username} . '_' . $self->{password});
|
||||||
$self->{option_results}->{url_path} = $self->{url_path} . 'login/' . $md5_hash;
|
my $response = $self->{http}->request(url_path => $self->{url_path} . 'login/' . $md5_hash);
|
||||||
my $response = centreon::plugins::httplib::connect($self);
|
|
||||||
$self->check_login(content => $response);
|
$self->check_login(content => $response);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue