(plugin) network::hp::procurve::snmp - mode virtual-chassis add --filter-member-serial option (#3473)

This commit is contained in:
qgarnier 2022-02-09 08:51:23 +01:00 committed by GitHub
parent a362286aae
commit 6376948f3a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 53 additions and 69 deletions

View File

@ -25,26 +25,24 @@ use base qw(centreon::plugins::templates::counter);
use strict; use strict;
use warnings; use warnings;
use Digest::MD5 qw(md5_hex); use Digest::MD5 qw(md5_hex);
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_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = sprintf( return sprintf(
'virtual chassis operational status: %s', 'virtual chassis operational status: %s',
$self->{result_values}->{status} $self->{result_values}->{status}
); );
return $msg;
} }
sub custom_member_status_output { sub custom_member_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = sprintf( return sprintf(
'state: %s', 'state: %s',
$self->{result_values}->{state} $self->{result_values}->{state}
); );
return $msg;
} }
sub custom_member_status_calc { sub custom_member_status_calc {
@ -63,11 +61,10 @@ sub custom_member_status_calc {
sub custom_link_status_output { sub custom_link_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = sprintf( return sprintf(
'operational status: %s', 'operational status: %s',
$self->{result_values}->{link_status} $self->{result_values}->{link_status}
); );
return $msg;
} }
sub custom_memory_usage_output { sub custom_memory_usage_output {
@ -76,13 +73,30 @@ sub custom_memory_usage_output {
my ($total_size_value, $total_size_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{total}); my ($total_size_value, $total_size_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{total});
my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used}); my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used});
my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free}); my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
my $msg = sprintf( return sprintf(
"memory usage total: %s used: %s (%.2f%%) free: %s (%.2f%%)", "memory usage total: %s used: %s (%.2f%%) free: %s (%.2f%%)",
$total_size_value . " " . $total_size_unit, $total_size_value . " " . $total_size_unit,
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used}, $total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used},
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free} $total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free}
); );
return $msg; }
sub member_long_output {
my ($self, %options) = @_;
return "checking stack member '" . $options{instance_value}->{display} . "'";
}
sub prefix_member_output {
my ($self, %options) = @_;
return "Stack member '" . $options{instance_value}->{display} . "' ";
}
sub prefix_link_output {
my ($self, %options) = @_;
return "link '" . $options{instance_value}->{display} . "' ";
} }
sub set_counters { sub set_counters {
@ -93,18 +107,17 @@ sub set_counters {
{ name => 'member', type => 3, cb_prefix_output => 'prefix_member_output', cb_long_output => 'member_long_output', indent_long_output => ' ', message_multiple => 'All stack members are ok', { name => 'member', type => 3, cb_prefix_output => 'prefix_member_output', cb_long_output => 'member_long_output', indent_long_output => ' ', message_multiple => 'All stack members are ok',
group => [ group => [
{ name => 'member_global', type => 0, skipped_code => { -10 => 1 } }, { name => 'member_global', type => 0, skipped_code => { -10 => 1 } },
{ name => 'link', display_long => 1, cb_prefix_output => 'prefix_link_output', message_multiple => 'All links are ok', type => 1, skipped_code => { -10 => 1 } }, { name => 'link', display_long => 1, cb_prefix_output => 'prefix_link_output', message_multiple => 'All links are ok', type => 1, skipped_code => { -10 => 1 } }
] ]
} }
]; ];
$self->{maps_counters}->{global} = [ $self->{maps_counters}->{global} = [
{ label => 'status', threshold => 0, set => { { label => 'status', type => 2, critical_default => '%{status} !~ /active/i', set => {
key_values => [ { name => 'status' } ], key_values => [ { name => 'status' } ],
closure_custom_calc => \&catalog_status_calc,
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold closure_custom_threshold_check => \&catalog_status_threshold_ng
} }
}, },
{ label => 'members-total', nlabel => 'stack.members.total.count', set => { { label => 'members-total', nlabel => 'stack.members.total.count', set => {
@ -118,12 +131,12 @@ sub set_counters {
]; ];
$self->{maps_counters}->{member_global} = [ $self->{maps_counters}->{member_global} = [
{ label => 'member-status', threshold => 0, set => { { label => 'member-status', type => 2, critical_default => '%{state} ne %{stateLast} || %{state} =~ /communicationFailure|incompatibleOS/i', set => {
key_values => [ { name => 'state' }, { name => 'display' } ], key_values => [ { name => 'state' }, { name => 'display' } ],
closure_custom_calc => $self->can('custom_member_status_calc'), closure_custom_calc => $self->can('custom_member_status_calc'),
closure_custom_output => $self->can('custom_member_status_output'), closure_custom_output => $self->can('custom_member_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold closure_custom_threshold_check => \&catalog_status_threshold_ng
} }
}, },
{ label => 'cpu-utilization', nlabel => 'member.cpu.utilization.percentage', set => { { label => 'cpu-utilization', nlabel => 'member.cpu.utilization.percentage', set => {
@ -165,68 +178,28 @@ sub set_counters {
]; ];
$self->{maps_counters}->{link} = [ $self->{maps_counters}->{link} = [
{ label => 'link-status', threshold => 0, set => { { label => 'link-status', type => 2, critical_default => '%{link_status} eq "down"', set => {
key_values => [ { name => 'link_status' }, { name => 'display' } ], key_values => [ { name => 'link_status' }, { name => 'display' }, { name => 'member_serial' } ],
closure_custom_calc => \&catalog_status_calc,
closure_custom_output => $self->can('custom_link_status_output'), closure_custom_output => $self->can('custom_link_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold closure_custom_threshold_check => \&catalog_status_threshold_ng
} }
} }
]; ];
} }
sub member_long_output {
my ($self, %options) = @_;
return "checking stack member '" . $options{instance_value}->{display} . "'";
}
sub prefix_member_output {
my ($self, %options) = @_;
return "Stack member '" . $options{instance_value}->{display} . "' ";
}
sub prefix_link_output {
my ($self, %options) = @_;
return "link '" . $options{instance_value}->{display} . "' ";
}
sub new { sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options, statefile => 1, force_new_perfdata => 1); my $self = $class->SUPER::new(package => __PACKAGE__, %options, statefile => 1, force_new_perfdata => 1);
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'unknown-status:s' => { name => 'unknown_status', default => '' }, "filter-member-serial:s" => { name => 'filter_member_serial' }
'warning-status:s' => { name => 'warning_status', default => '' },
'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /active/i' },
'unknown-member-status:s' => { name => 'unknown_member_status', default => '' },
'warning-member-status:s' => { name => 'warning_member_status', default => '' },
'critical-member-status:s' => { name => 'critical_member_status', default => '%{state} ne %{stateLast} || %{state} =~ /communicationFailure|incompatibleOS/i' },
'unknown-link-status:s' => { name => 'unknown_link_status', default => '' },
'warning-link-status:s' => { name => 'warning_link_status', default => '' },
'critical-link-status:s' => { name => 'critical_link_status', default => '%{link_status} eq "down"' },
}); });
return $self; return $self;
} }
sub check_options {
my ($self, %options) = @_;
$self->SUPER::check_options(%options);
$self->change_macros(
macros => [
'unknown_status', 'warning_status', 'critical_status',
'unknown_member_status', 'warning_member_status', 'critical_member_status',
'unknown_link_status', 'warning_link_status', 'critical_link_status'
]
);
}
my $mapping_oper_status = { my $mapping_oper_status = {
0 => 'unAvailable', 1 => 'disabled', 2 => 'active', 0 => 'unAvailable', 1 => 'disabled', 2 => 'active',
3 => 'fragmentInactive', 4 => 'fragmentActive' 3 => 'fragmentInactive', 4 => 'fragmentActive'
@ -272,7 +245,7 @@ sub manage_selection {
oids => [ oids => [
{ oid => $oid_hpicfVsfVCConfig, start => $mapping->{hpicfVsfVCOperStatus}->{oid}, end => $mapping->{hpicfVsfVCAdminStatus}->{oid} }, { oid => $oid_hpicfVsfVCConfig, start => $mapping->{hpicfVsfVCOperStatus}->{oid}, end => $mapping->{hpicfVsfVCAdminStatus}->{oid} },
{ oid => $oid_hpicfVsfVCMemberEntry, start => $mapping2->{hpicfVsfVCMemberState}->{oid} }, { oid => $oid_hpicfVsfVCMemberEntry, start => $mapping2->{hpicfVsfVCMemberState}->{oid} },
{ oid => $oid_hpicfVsfVCLinkEntry, start => $mapping3->{hpicfVsfVCLinkName}->{oid}, end => $mapping3->{hpicfVsfVCLinkOperStatus}->{oid} }, { oid => $oid_hpicfVsfVCLinkEntry, start => $mapping3->{hpicfVsfVCLinkName}->{oid}, end => $mapping3->{hpicfVsfVCLinkOperStatus}->{oid} }
], ],
nothing_quit => 1 nothing_quit => 1
); );
@ -295,6 +268,9 @@ sub manage_selection {
$result = $options{snmp}->map_instance(mapping => $mapping2, results => $snmp_result->{$oid_hpicfVsfVCMemberEntry}, instance => $member_id); $result = $options{snmp}->map_instance(mapping => $mapping2, results => $snmp_result->{$oid_hpicfVsfVCMemberEntry}, instance => $member_id);
my $member_name = $result->{hpicfVsfVCMemberSerialNum}; my $member_name = $result->{hpicfVsfVCMemberSerialNum};
next if (defined($self->{option_results}->{filter_member_serial}) && $self->{option_results}->{filter_member_serial} ne '' &&
$member_name !~ /$self->{option_results}->{filter_member_serial}/);
$self->{member}->{$member_name} = { $self->{member}->{$member_name} = {
display => $member_name, display => $member_name,
member_global => { member_global => {
@ -307,7 +283,7 @@ sub manage_selection {
prct_used => ($result->{hpicfVsfVCMemberTotalMemory} - $result->{hpicfVsfVCMemberFreeMemory}) * 100 / $result->{hpicfVsfVCMemberTotalMemory}, prct_used => ($result->{hpicfVsfVCMemberTotalMemory} - $result->{hpicfVsfVCMemberFreeMemory}) * 100 / $result->{hpicfVsfVCMemberTotalMemory},
prct_free => $result->{hpicfVsfVCMemberFreeMemory} * 100 / $result->{hpicfVsfVCMemberTotalMemory} prct_free => $result->{hpicfVsfVCMemberFreeMemory} * 100 / $result->{hpicfVsfVCMemberTotalMemory}
}, },
link => {}, link => {}
}; };
foreach (keys %{$snmp_result->{$oid_hpicfVsfVCLinkEntry}}) { foreach (keys %{$snmp_result->{$oid_hpicfVsfVCLinkEntry}}) {
@ -315,8 +291,9 @@ sub manage_selection {
$result = $options{snmp}->map_instance(mapping => $mapping3, results => $snmp_result->{$oid_hpicfVsfVCLinkEntry}, instance => $member_id . '.' . $1); $result = $options{snmp}->map_instance(mapping => $mapping3, results => $snmp_result->{$oid_hpicfVsfVCLinkEntry}, instance => $member_id . '.' . $1);
$self->{member}->{$member_name}->{link}->{$result->{hpicfVsfVCLinkName}} = { $self->{member}->{$member_name}->{link}->{$result->{hpicfVsfVCLinkName}} = {
member_serial => $member_name,
display => $result->{hpicfVsfVCLinkName}, display => $result->{hpicfVsfVCLinkName},
link_status => $result->{hpicfVsfVCLinkOperStatus}, link_status => $result->{hpicfVsfVCLinkOperStatus}
}; };
} }
} }
@ -324,7 +301,10 @@ sub manage_selection {
$self->{global}->{members} = scalar(keys %{$self->{member}}); $self->{global}->{members} = scalar(keys %{$self->{member}});
$self->{cache_name} = 'hp_procurve_' . $self->{mode} . '_' . $options{snmp}->get_hostname() . '_' . $options{snmp}->get_port() . '_' . $self->{cache_name} = 'hp_procurve_' . $self->{mode} . '_' . $options{snmp}->get_hostname() . '_' . $options{snmp}->get_port() . '_' .
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all')); md5_hex(
(defined($self->{option_results}->{filter_counters}) ? $self->{option_results}->{filter_counters} : 'all') . '_' .
(defined($self->{option_results}->{filter_member_serial}) ? $self->{option_results}->{filter_member_serial} : 'all')
);
} }
1; 1;
@ -337,14 +317,18 @@ Check vsf virtual chassis.
=over 8 =over 8
=item B<--filter-member-serial>
Filter members by serial (can be a regexp).
=item B<--unknown-status> =item B<--unknown-status>
Set unknown threshold for status (Default: ''). Set unknown threshold for status.
Can used special variables like: %{status} Can used special variables like: %{status}
=item B<--warning-status> =item B<--warning-status>
Set warning threshold for status (Default: ''). Set warning threshold for status.
Can used special variables like: %{status} Can used special variables like: %{status}
=item B<--critical-status> =item B<--critical-status>
@ -354,12 +338,12 @@ Can used special variables like: %{status}
=item B<--unknown-member-status> =item B<--unknown-member-status>
Set unknown threshold for status (Default: ''). Set unknown threshold for status.
Can used special variables like: %{state}, %{stateLast} Can used special variables like: %{state}, %{stateLast}
=item B<--warning-member-status> =item B<--warning-member-status>
Set warning threshold for status (Default: ''). Set warning threshold for status.
Can used special variables like: %{state}, %{stateLast} Can used special variables like: %{state}, %{stateLast}
=item B<--critical-member-status> =item B<--critical-member-status>
@ -369,12 +353,12 @@ Can used special variables like: %{state}, %{stateLast}
=item B<--unknown-link-status> =item B<--unknown-link-status>
Set unknown threshold for status (Default: ''). Set unknown threshold for status.
Can used special variables like: %{link_status}, %{display} Can used special variables like: %{link_status}, %{display}
=item B<--warning-link-status> =item B<--warning-link-status>
Set warning threshold for status (Default: ''). Set warning threshold for status.
Can used special variables like: %{link_status}, %{display} Can used special variables like: %{link_status}, %{display}
=item B<--critical-link-status> =item B<--critical-link-status>