Fix #1664
This commit is contained in:
parent
ab7b7ac892
commit
d6046caea2
|
@ -25,17 +25,19 @@ 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);
|
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold catalog_status_calc);
|
||||||
|
|
||||||
sub custom_status_output {
|
sub custom_member_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = sprintf("role: %s",
|
my $msg = sprintf(
|
||||||
$self->{result_values}->{role});
|
'role: %s',
|
||||||
|
$self->{result_values}->{role}
|
||||||
|
);
|
||||||
return $msg;
|
return $msg;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_member_status_calc {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{result_values}->{roleLast} = $options{old_datas}->{$self->{instance} . '_role'};
|
$self->{result_values}->{roleLast} = $options{old_datas}->{$self->{instance} . '_role'};
|
||||||
|
@ -48,18 +50,45 @@ sub custom_status_calc {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub custom_port_status_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $msg = sprintf(
|
||||||
|
'operational status: %s [admin status: %s]',
|
||||||
|
$self->{result_values}->{oper_status},
|
||||||
|
$self->{result_values}->{admin_status}
|
||||||
|
);
|
||||||
|
return $msg;
|
||||||
|
}
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
$self->{maps_counters_type} = [
|
||||||
{ name => 'stack', type => 1, cb_prefix_output => 'prefix_stack_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 => [
|
||||||
|
{ name => 'global', type => 0, skipped_code => { -10 => 1 } },
|
||||||
|
{ name => 'port', display_long => 1, cb_prefix_output => 'prefix_port_output', message_multiple => 'All ports are ok', type => 1, skipped_code => { -10 => 1 } },
|
||||||
|
]
|
||||||
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
$self->{maps_counters}->{stack} = [
|
$self->{maps_counters}->{member} = [
|
||||||
{ label => 'status', threshold => 0, set => {
|
{ label => 'member-status', threshold => 0, set => {
|
||||||
key_values => [ { name => 'role' }, { name => 'display' } ],
|
key_values => [ { name => 'role' }, { name => 'display' } ],
|
||||||
closure_custom_calc => $self->can('custom_status_calc'),
|
closure_custom_calc => $self->can('custom_member_status_calc'),
|
||||||
closure_custom_output => $self->can('custom_status_output'),
|
closure_custom_output => $self->can('custom_member_status_output'),
|
||||||
|
closure_custom_perfdata => sub { return 0; },
|
||||||
|
closure_custom_threshold_check => \&catalog_status_threshold,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{port} = [
|
||||||
|
{ label => 'port-status', threshold => 0, set => {
|
||||||
|
key_values => [ { name => 'oper_status' }, { name => 'admin_status' }, { name => 'display' } ],
|
||||||
|
closure_custom_calc => \&catalog_status_calc,
|
||||||
|
closure_custom_output => $self->can('custom_port_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,
|
||||||
}
|
}
|
||||||
|
@ -67,21 +96,36 @@ sub set_counters {
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
sub prefix_stack_output {
|
sub member_long_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return "checking stack member '" . $options{instance_value}->{display} . "'";
|
||||||
|
}
|
||||||
|
|
||||||
|
sub prefix_member_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
return "Stack member '" . $options{instance_value}->{display} . "' ";
|
return "Stack member '" . $options{instance_value}->{display} . "' ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub prefix_port_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return "port '" . $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 => '' },
|
'unknown-member-status:s' => { name => 'unknown_member_status', default => '' },
|
||||||
'warning-status:s' => { name => 'warning_status', default => '' },
|
'warning-member-status:s' => { name => 'warning_member_status', default => '' },
|
||||||
'critical-status:s' => { name => 'critical_status', default => '%{role} ne %{roleLast}' },
|
'critical-member-status:s' => { name => 'critical_member_status', default => '%{role} ne %{roleLast}' },
|
||||||
|
'unknown-port-status:s' => { name => 'unknown_port_status', default => '' },
|
||||||
|
'warning-port-status:s' => { name => 'warning_port_status', default => '' },
|
||||||
|
'critical-port-status:s' => { name => 'critical_port_status', default => '%{admin_status} eq "up" and %{oper_status} ne "up"' },
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -91,41 +135,66 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
$self->change_macros(macros => ['unknown_status', 'warning_status', 'critical_status']);
|
$self->change_macros(
|
||||||
|
macros => [
|
||||||
|
'unknown_member_status', 'warning_member_status', 'critical_member_status',
|
||||||
|
'unknown_port_status', 'warning_port_status', 'critical_port_status'
|
||||||
|
]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
my %map_role = (
|
my $map_role = { 1 => 'master', 2 => 'backup', 3 => 'linecard' };
|
||||||
1 => 'master',
|
my $map_status = { 1 => 'up', 2 => 'down', 3 => 'unknown' };
|
||||||
2 => 'backup',
|
|
||||||
3 => 'linecard',
|
|
||||||
);
|
|
||||||
|
|
||||||
my $mapping = {
|
my $mapping = {
|
||||||
jnxVirtualChassisMemberSerialnumber => { oid => '.1.3.6.1.4.1.2636.3.40.1.4.1.1.1.2' },
|
jnxVirtualChassisMemberSerialnumber => { oid => '.1.3.6.1.4.1.2636.3.40.1.4.1.1.1.2' },
|
||||||
jnxVirtualChassisMemberRole => { oid => '.1.3.6.1.4.1.2636.3.40.1.4.1.1.1.3', map => \%map_role },
|
jnxVirtualChassisMemberRole => { oid => '.1.3.6.1.4.1.2636.3.40.1.4.1.1.1.3', map => $map_role },
|
||||||
|
};
|
||||||
|
my $mapping2 = {
|
||||||
|
jnxVirtualChassisPortAdminStatus => { oid => '.1.3.6.1.4.1.2636.3.40.1.4.1.2.1.3', map => $map_status },
|
||||||
|
jnxVirtualChassisPortOperStatus => { oid => '.1.3.6.1.4.1.2636.3.40.1.4.1.2.1.4', map => $map_status },
|
||||||
};
|
};
|
||||||
my $oid_jnxVirtualChassisMemberEntry = '.1.3.6.1.4.1.2636.3.40.1.4.1.1.1';
|
my $oid_jnxVirtualChassisMemberEntry = '.1.3.6.1.4.1.2636.3.40.1.4.1.1.1';
|
||||||
|
my $oid_jnxVirtualChassisPortEntry = '.1.3.6.1.4.1.2636.3.40.1.4.1.2.1';
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{stack} = {};
|
$self->{member} = {};
|
||||||
my $snmp_result = $options{snmp}->get_table(
|
my $snmp_result = $options{snmp}->get_multiple_table(
|
||||||
oid => $oid_jnxVirtualChassisMemberEntry,
|
oids => [
|
||||||
start => $mapping->{jnxVirtualChassisMemberSerialnumber}->{oid},
|
{ oid => $oid_jnxVirtualChassisMemberEntry, start => $mapping->{jnxVirtualChassisMemberSerialnumber}->{oid}, end => $mapping->{jnxVirtualChassisMemberRole}->{oid} },
|
||||||
end => $mapping->{jnxVirtualChassisMemberRole}->{oid},
|
{ oid => $oid_jnxVirtualChassisPortEntry, start => $mapping2->{jnxVirtualChassisPortAdminStatus}->{oid}, end => $mapping2->{jnxVirtualChassisPortOperStatus}->{oid} },
|
||||||
|
],
|
||||||
nothing_quit => 1
|
nothing_quit => 1
|
||||||
);
|
);
|
||||||
|
|
||||||
foreach my $oid (keys %$snmp_result) {
|
foreach my $oid (keys %{$snmp_result->{$oid_jnxVirtualChassisMemberEntry}}) {
|
||||||
next if ($oid !~ /^$mapping->{jnxVirtualChassisMemberRole}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$mapping->{jnxVirtualChassisMemberRole}->{oid}\.(.*)$/);
|
||||||
my $instance_id = $1;
|
my $chassis_id = $1;
|
||||||
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result, instance => $instance_id);
|
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result->{$oid_jnxVirtualChassisMemberEntry}, instance => $chassis_id);
|
||||||
|
|
||||||
$self->{stack}->{$instance_id} = {
|
$self->{member}->{$result->{jnxVirtualChassisMemberSerialnumber}} = {
|
||||||
display => $result->{jnxVirtualChassisMemberSerialnumber},
|
display => $result->{jnxVirtualChassisMemberSerialnumber},
|
||||||
role => $result->{jnxVirtualChassisMemberRole},
|
global => {
|
||||||
|
display => $result->{jnxVirtualChassisMemberSerialnumber},
|
||||||
|
role => $result->{jnxVirtualChassisMemberRole},
|
||||||
|
},
|
||||||
|
port => {},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
foreach (keys %{$snmp_result->{$oid_jnxVirtualChassisPortEntry}}) {
|
||||||
|
next if (!/^$mapping2->{jnxVirtualChassisPortAdminStatus}->{oid}\.$chassis_id\.(.*?)\.(.*)$/);
|
||||||
|
my $port_name = $2;
|
||||||
|
my $result2 = $options{snmp}->map_instance(mapping => $mapping2, results => $snmp_result->{$oid_jnxVirtualChassisPortEntry}, instance => $chassis_id . '.' . $1 . '.' . $port_name);
|
||||||
|
|
||||||
|
$port_name = $self->{output}->to_utf8(join('', map(chr($_), split(/\./, $port_name))));
|
||||||
|
$self->{member}->{$result->{jnxVirtualChassisMemberSerialnumber}}->{port}->{$port_name} = {
|
||||||
|
display => $port_name,
|
||||||
|
admin_status => $result2->{jnxVirtualChassisPortAdminStatus},
|
||||||
|
oper_status => $result2->{jnxVirtualChassisPortOperStatus},
|
||||||
|
};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{cache_name} = "juniper_junos_" . $self->{mode} . '_' . $options{snmp}->get_hostname() . '_' . $options{snmp}->get_port() . '_' .
|
$self->{cache_name} = "juniper_junos_" . $self->{mode} . '_' . $options{snmp}->get_hostname() . '_' . $options{snmp}->get_port() . '_' .
|
||||||
|
@ -142,21 +211,36 @@ Check stack members.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--unknown-status>
|
=item B<--unknown-member-status>
|
||||||
|
|
||||||
Set warning threshold for status (Default: '').
|
Set warning threshold for status (Default: '').
|
||||||
Can used special variables like: %{role}, %{roleLast}
|
Can used special variables like: %{role}, %{roleLast}
|
||||||
|
|
||||||
=item B<--warning-status>
|
=item B<--warning-member-status>
|
||||||
|
|
||||||
Set warning threshold for status (Default: '').
|
Set warning threshold for status (Default: '').
|
||||||
Can used special variables like: %{role}, %{roleLast}
|
Can used special variables like: %{role}, %{roleLast}
|
||||||
|
|
||||||
=item B<--critical-status>
|
=item B<--critical-member-status>
|
||||||
|
|
||||||
Set critical threshold for status (Default: '%{role} ne %{roleLast}').
|
Set critical threshold for status (Default: '%{role} ne %{roleLast}').
|
||||||
Can used special variables like: %{role}, %{roleLast}
|
Can used special variables like: %{role}, %{roleLast}
|
||||||
|
|
||||||
|
=item B<--unknown-port-status>
|
||||||
|
|
||||||
|
Set warning threshold for status (Default: '').
|
||||||
|
Can used special variables like: %{admin_status}, %{oper_status}, %{display}
|
||||||
|
|
||||||
|
=item B<--warning-port-status>
|
||||||
|
|
||||||
|
Set warning threshold for status (Default: '').
|
||||||
|
Can used special variables like: %{admin_status}, %{oper_status}, %{display}
|
||||||
|
|
||||||
|
=item B<--critical-port-status>
|
||||||
|
|
||||||
|
Set critical threshold for status (Default: '%{admin_status} eq "up" and %{oper_status} ne "up"').
|
||||||
|
Can used special variables like: %{admin_status}, %{oper_status}, %{display}
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
Loading…
Reference in New Issue