This commit is contained in:
garnier-quentin 2020-09-11 09:51:08 +02:00
parent cc5c7c5159
commit f806155c90
4 changed files with 34 additions and 61 deletions

View File

@ -24,13 +24,12 @@ use base qw(centreon::plugins::templates::counter);
use strict; use strict;
use warnings; use warnings;
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold catalog_status_calc); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold_ng);
sub custom_health_output { sub custom_health_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = sprintf("health current: %d%%, previous: %d%%", $self->{result_values}->{current}, $self->{result_values}->{previous}); return sprintf('health current: %d%%, previous: %d%%', $self->{result_values}->{current}, $self->{result_values}->{previous});
return $msg;
} }
sub custom_health_perfdata { sub custom_health_perfdata {
@ -38,7 +37,6 @@ sub custom_health_perfdata {
foreach ('current', 'previous') { foreach ('current', 'previous') {
$self->{output}->perfdata_add( $self->{output}->perfdata_add(
label => $_,
nlabel => 'fabric.health.' . $_ . '.percentage', nlabel => 'fabric.health.' . $_ . '.percentage',
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{dn} : undef, instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{dn} : undef,
value => $self->{result_values}->{$_}, value => $self->{result_values}->{$_},
@ -51,18 +49,17 @@ sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'fabric', type => 1, cb_prefix_output => 'prefix_fabric_output', message_multiple => 'all fabrics are ok' }, { name => 'fabric', type => 1, cb_prefix_output => 'prefix_fabric_output', message_multiple => 'all fabrics are ok' }
]; ];
$self->{maps_counters}->{fabric} = [ $self->{maps_counters}->{fabric} = [
{ label => 'health', threshold => 0, set => { { label => 'health', type => 2, set => {
key_values => [ { name => 'current' }, { name => 'previous' }, { name => 'dn' } ], key_values => [ { name => 'current' }, { name => 'previous' }, { name => 'dn' } ],
closure_custom_calc => \&catalog_status_calc,
closure_custom_output => $self->can('custom_health_output'), closure_custom_output => $self->can('custom_health_output'),
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold_ng,
closure_custom_perfdata => $self->can('custom_health_perfdata'), closure_custom_perfdata => $self->can('custom_health_perfdata')
}
} }
},
]; ];
} }
@ -78,20 +75,11 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'warning-health:s' => { name => 'warning_health' },
'critical-health:s' => { name => 'critical_health' },
}); });
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
$self->change_macros(macros => ['warning_health', 'critical_health']);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;

View File

@ -30,7 +30,7 @@ sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'nodes', type => 1, cb_prefix_output => 'prefix_nodes_output', message_multiple => 'All fabric nodes are ok' }, { name => 'nodes', type => 1, cb_prefix_output => 'prefix_nodes_output', message_multiple => 'All fabric nodes are ok' }
]; ];
$self->{maps_counters}->{nodes} = [ $self->{maps_counters}->{nodes} = [
@ -38,29 +38,26 @@ sub set_counters {
key_values => [ { name => 'current' }, { name => 'dn' } ], key_values => [ { name => 'current' }, { name => 'dn' } ],
output_template => 'current: %s %%', output_error_template => "current: %s %%", output_template => 'current: %s %%', output_error_template => "current: %s %%",
perfdatas => [ perfdatas => [
{ label => 'health_current', value => 'current', template => '%d', { template => '%d', unit => '%', min => 0, max => 100, label_extra_instance => 1, instance_use => 'dn' }
unit => '%', min => 0, max => 100, label_extra_instance => 1, instance_use => 'dn' }, ]
],
} }
}, },
{ label => 'health-minimum', nlabel => 'node.health.minimum.percentage', set => { { label => 'health-minimum', nlabel => 'node.health.minimum.percentage', set => {
key_values => [ { name => 'min' }, { name => 'dn' } ], key_values => [ { name => 'min' }, { name => 'dn' } ],
output_template => 'min: %s %%', output_error_template => "min: %s %%", output_template => 'min: %s %%', output_error_template => "min: %s %%",
perfdatas => [ perfdatas => [
{ label => 'health_min', value => 'min', template => '%d', { template => '%d', unit => '%', min => 0, max => 100, label_extra_instance => 1, instance_use => 'dn' }
unit => '%', min => 0, max => 100, label_extra_instance => 1, instance_use => 'dn' }, ]
],
} }
}, },
{ label => 'health-average', nlabel => 'node.health.average.percentage', set => { { label => 'health-average', nlabel => 'node.health.average.percentage', set => {
key_values => [ { name => 'avg' }, { name => 'dn' } ], key_values => [ { name => 'avg' }, { name => 'dn' } ],
output_template => 'average: %s %%', output_error_template => "average %s %%", output_template => 'average: %s %%', output_error_template => "average %s %%",
perfdatas => [ perfdatas => [
{ label => 'health_avg', value => 'avg', template => '%d', { template => '%d', unit => '%', min => 0, max => 100, label_extra_instance => 1, instance_use => 'dn' }
unit => '%', min => 0, max => 100, label_extra_instance => 1, instance_use => 'dn' }, ]
], }
} }
},
]; ];
} }
@ -76,7 +73,7 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'filter-node:s' => { name => 'filter_node' }, 'filter-node:s' => { name => 'filter_node' }
}); });
return $self; return $self;
@ -91,8 +88,8 @@ sub manage_selection {
$node->{fabricNodeHealth5min}->{attributes}->{dn} =~ /^topology\/(.*)\/sys\/CDfabricNodeHealth5min$/; $node->{fabricNodeHealth5min}->{attributes}->{dn} =~ /^topology\/(.*)\/sys\/CDfabricNodeHealth5min$/;
my $node_dn = $1; my $node_dn = $1;
if (defined($self->{option_results}->{filter_node}) && $self->{option_results}->{filter_node} ne '' && if (defined($self->{option_results}->{filter_node}) && $self->{option_results}->{filter_node} ne '' &&
$node_dn =~ /$self->{option_results}->{filter_node}/) { $node_dn !~ /$self->{option_results}->{filter_node}/) {
$self->{output}->output_add(long_msg => "skipping '" . $node_dn . "': no matching filter node '" . $node . "'", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node_dn . "': no matching filter", debug => 1);
next; next;
} }
$self->{nodes}->{$node_dn} = { $self->{nodes}->{$node_dn} = {

View File

@ -24,13 +24,12 @@ use base qw(centreon::plugins::templates::counter);
use strict; use strict;
use warnings; use warnings;
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold catalog_status_calc); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold_ng);
sub custom_health_output { sub custom_health_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = sprintf("health current: %d%%, previous: %d%%", $self->{result_values}->{current}, $self->{result_values}->{previous}); return sprintf('health current: %d%%, previous: %d%%', $self->{result_values}->{current}, $self->{result_values}->{previous});
return $msg;
} }
sub custom_health_perfdata { sub custom_health_perfdata {
@ -38,7 +37,6 @@ sub custom_health_perfdata {
foreach ('current', 'previous') { foreach ('current', 'previous') {
$self->{output}->perfdata_add( $self->{output}->perfdata_add(
label => $_,
nlabel => 'tenant.health.' . $_ . '.percentage', nlabel => 'tenant.health.' . $_ . '.percentage',
instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{dn} : undef, instances => $self->use_instances(extra_instance => $options{extra_instance}) ? $self->{result_values}->{dn} : undef,
value => $self->{result_values}->{$_}, value => $self->{result_values}->{$_},
@ -51,18 +49,17 @@ sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'tenant', type => 1, cb_prefix_output => 'prefix_tenant_output', message_multiple => 'All tenants are ok' }, { name => 'tenant', type => 1, cb_prefix_output => 'prefix_tenant_output', message_multiple => 'All tenants are ok' }
]; ];
$self->{maps_counters}->{tenant} = [ $self->{maps_counters}->{tenant} = [
{ label => 'health', threshold => 0, set => { { label => 'health', type => 2, set => {
key_values => [ { name => 'current' }, { name => 'previous' }, { name => 'dn' } ], key_values => [ { name => 'current' }, { name => 'previous' }, { name => 'dn' } ],
closure_custom_calc => \&catalog_status_calc,
closure_custom_output => $self->can('custom_health_output'), closure_custom_output => $self->can('custom_health_output'),
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold_ng,
closure_custom_perfdata => $self->can('custom_health_perfdata') closure_custom_perfdata => $self->can('custom_health_perfdata')
} }
}, }
]; ];
} }
@ -78,21 +75,12 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'filter-tenant:s' => { name => 'filter_tenant' }, 'filter-tenant:s' => { name => 'filter_tenant' }
'warning-health:s' => { name => 'warning_health' },
'critical-health:s' => { name => 'critical_health' },
}); });
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
$self->change_macros(macros => ['warning_health', 'critical_health']);
}
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -103,8 +91,8 @@ sub manage_selection {
foreach my $object (@{$result->{imdata}}) { foreach my $object (@{$result->{imdata}}) {
my $dn = $object->{fvTenant}->{attributes}->{name}; my $dn = $object->{fvTenant}->{attributes}->{name};
if (defined($self->{option_results}->{filter_tenant}) && $self->{option_results}->{filter_tenant} ne '' && if (defined($self->{option_results}->{filter_tenant}) && $self->{option_results}->{filter_tenant} ne '' &&
$dn =~ /$self->{option_results}->{filter_tenant}/) { $dn !~ /$self->{option_results}->{filter_tenant}/) {
$self->{output}->output_add(long_msg => "skipping '" . $dn . "': no matching filter ", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $dn . "': no matching filter", debug => 1);
next; next;
} }
$self->{tenant}->{$dn} = { $self->{tenant}->{$dn} = {

View File

@ -30,13 +30,13 @@ sub new {
bless $self, $class; bless $self, $class;
$self->{version} = '0.1'; $self->{version} = '0.1';
%{ $self->{modes} } = ( $self->{modes} = {
'node' => 'network::cisco::aci::apic::restapi::mode::node', 'node' => 'network::cisco::aci::apic::restapi::mode::node',
'tenant' => 'network::cisco::aci::apic::restapi::mode::tenant', 'tenant' => 'network::cisco::aci::apic::restapi::mode::tenant',
'fabric' => 'network::cisco::aci::apic::restapi::mode::fabric', 'fabric' => 'network::cisco::aci::apic::restapi::mode::fabric'
); };
$self->{custom_modes}{api} = 'network::cisco::aci::apic::restapi::custom::api'; $self->{custom_modes}->{api} = 'network::cisco::aci::apic::restapi::custom::api';
return $self; return $self;
} }