From 4c2625e756f92c375a6f30c7aaec8f0ede7ce9e3 Mon Sep 17 00:00:00 2001 From: CPbN <40244829+CPbN@users.noreply.github.com> Date: Tue, 14 Jan 2020 19:23:32 +0100 Subject: [PATCH 1/3] 3CX, add HTTP status options --- apps/voip/3cx/restapi/custom/api.pm | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/apps/voip/3cx/restapi/custom/api.pm b/apps/voip/3cx/restapi/custom/api.pm index 3d9620dcb..57cd5f66c 100644 --- a/apps/voip/3cx/restapi/custom/api.pm +++ b/apps/voip/3cx/restapi/custom/api.pm @@ -51,6 +51,9 @@ sub new { "api-username:s" => { name => 'api_username' }, "api-password:s" => { name => 'api_password' }, "timeout:s" => { name => 'timeout', default => 30 }, + 'unknown-http-status:s' => { name => 'unknown_http_status' }, + 'warning-http-status:s' => { name => 'warning_http_status' }, + 'critical-http-status:s' => { name => 'critical_http_status' }, }); } @@ -96,6 +99,9 @@ sub check_options { $self->{ssl_opt} = (defined($self->{option_results}->{ssl_opt})) ? $self->{option_results}->{ssl_opt} : undef; $self->{api_username} = (defined($self->{option_results}->{api_username})) ? $self->{option_results}->{api_username} : undef; $self->{api_password} = (defined($self->{option_results}->{api_password})) ? $self->{option_results}->{api_password} : undef; + $self->{unknown_http_status} = (defined($self->{option_results}->{unknown_http_status})) ? $self->{option_results}->{unknown_http_status} : '%{http_code} < 200 or %{http_code} >= 300' ; + $self->{warning_http_status} = (defined($self->{option_results}->{warning_http_status})) ? $self->{option_results}->{warning_http_status} : ''; + $self->{critical_http_status} = (defined($self->{option_results}->{critical_http_status})) ? $self->{option_results}->{critical_http_status} : ''; if (!defined($self->{hostname}) || $self->{hostname} eq '') { $self->{output}->add_option_msg(short_msg => "Need to specify --hostname option."); @@ -190,8 +196,11 @@ sub request_api { $self->settings(); - my $content = $self->{http}->request(%options, - warning_status => '', unknown_status => '', critical_status => '%{http_code} < 200 or %{http_code} >= 300' + my $content = $self->{http}->request( + %options, + unknown_status => $self->{unknown_http_status}, + warning_status => $self->{warning_http_status}, + critical_status => $self->{critical_http_status}, ); # Some content may be strangely returned, for example : @@ -334,6 +343,16 @@ Set 3CX Password. Threshold for HTTP timeout (Default: '30'). +=item B<--unknown-http-status> +Threshold warning for http response code. +(Default: '%{http_code} < 200 or %{http_code} >= 300') + +=item B<--warning-http-status> +Threshold warning for http response code. + +=item B<--critical-http-status> +Threshold critical for http response code. + =back =cut From 39b1dac1445232bce5cf383747bccb17003090a8 Mon Sep 17 00:00:00 2001 From: CPbN <40244829+CPbN@users.noreply.github.com> Date: Tue, 14 Jan 2020 19:33:52 +0100 Subject: [PATCH 2/3] typo --- apps/voip/3cx/restapi/custom/api.pm | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/apps/voip/3cx/restapi/custom/api.pm b/apps/voip/3cx/restapi/custom/api.pm index 57cd5f66c..4e41dbb42 100644 --- a/apps/voip/3cx/restapi/custom/api.pm +++ b/apps/voip/3cx/restapi/custom/api.pm @@ -344,7 +344,7 @@ Set 3CX Password. Threshold for HTTP timeout (Default: '30'). =item B<--unknown-http-status> -Threshold warning for http response code. +Threshold unknown for http response code. (Default: '%{http_code} < 200 or %{http_code} >= 300') =item B<--warning-http-status> From 06115fbba27ed61281388c734bdc11fbc53545a6 Mon Sep 17 00:00:00 2001 From: CPbN <40244829+CPbN@users.noreply.github.com> Date: Wed, 15 Jan 2020 18:05:49 +0100 Subject: [PATCH 3/3] Simplify --- apps/voip/3cx/restapi/mode/system.pm | 12 ++---------- 1 file changed, 2 insertions(+), 10 deletions(-) diff --git a/apps/voip/3cx/restapi/mode/system.pm b/apps/voip/3cx/restapi/mode/system.pm index fbb22c1d6..72c82d761 100644 --- a/apps/voip/3cx/restapi/mode/system.pm +++ b/apps/voip/3cx/restapi/mode/system.pm @@ -24,7 +24,7 @@ use base qw(centreon::plugins::templates::counter); use strict; use warnings; -use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold); +use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold catalog_status_calc); sub custom_status_output { my ($self, %options) = @_; @@ -37,14 +37,6 @@ sub custom_status_output { return $msg; } -sub custom_status_calc { - my ($self, %options) = @_; - - $self->{result_values}->{error} = $options{new_datas}->{$self->{instance} . '_error'}; - $self->{result_values}->{service} = $options{new_datas}->{$self->{instance} . '_service'}; - return 0; -} - sub set_counters { my ($self, %options) = @_; @@ -77,7 +69,7 @@ sub set_counters { $self->{maps_counters}->{service} = [ { label => 'status', threshold => 0, set => { key_values => [ { name => 'error' }, { name => 'service' } ], - closure_custom_calc => $self->can('custom_status_calc'), + closure_custom_calc => \&catalog_status_calc, closure_custom_output => $self->can('custom_status_output'), closure_custom_perfdata => sub { return 0; }, closure_custom_threshold_check => \&catalog_status_threshold,