Fix #2210
This commit is contained in:
parent
cc5c7c5159
commit
f806155c90
|
@ -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) = @_;
|
||||||
|
|
||||||
|
|
|
@ -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} = {
|
||||||
|
|
|
@ -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} = {
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue