Fix #585
This commit is contained in:
parent
3f92e41141
commit
9be46dafa0
|
@ -24,8 +24,6 @@ use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::hwgste::snmp::mode::components::resources qw($mapping);
|
use hardware::sensors::hwgste::snmp::mode::components::resources qw($mapping);
|
||||||
|
|
||||||
my $oid_sensEntry = '.1.3.6.1.4.1.21796.4.1.3.1';
|
|
||||||
|
|
||||||
sub load {}
|
sub load {}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -35,17 +33,19 @@ sub check {
|
||||||
$self->{components}->{humidity} = {name => 'humidity', total => 0, skip => 0};
|
$self->{components}->{humidity} = {name => 'humidity', total => 0, skip => 0};
|
||||||
return if ($self->check_filter(section => 'humidity'));
|
return if ($self->check_filter(section => 'humidity'));
|
||||||
|
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_sensEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $mapping->{branch_sensors}->{$self->{branch}} }})) {
|
||||||
next if ($oid !~ /^$mapping->{sensState}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$mapping->{$self->{branch}}->{sensState}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_sensEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(mapping => $mapping->{$self->{branch}}, results => $self->{results}->{ $mapping->{branch_sensors}->{$self->{branch}} }, instance => $instance);
|
||||||
|
|
||||||
next if (!(defined($result->{sensUnit}) && $result->{sensUnit} eq '%'));
|
next if (!(defined($result->{sensUnit}) && $result->{sensUnit} eq '%'));
|
||||||
next if ($self->check_filter(section => 'humidity', instance => $instance));
|
next if ($self->check_filter(section => 'humidity', instance => $instance));
|
||||||
$self->{components}->{humidity}->{total}++;
|
$self->{components}->{humidity}->{total}++;
|
||||||
|
|
||||||
|
$result->{sensValue} /= 10 if ($result->{sensValue} =~ /\d+/);
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("humidity '%s' state is '%s' [instance: %s, value: %s]",
|
$self->{output}->output_add(long_msg => sprintf("humidity '%s' state is '%s' [instance: %s, value: %s]",
|
||||||
$result->{sensName}, $result->{sensState}, $instance, $result->{sensTemp}));
|
$result->{sensName}, $result->{sensState}, $instance, $result->{sensValue}));
|
||||||
my $exit = $self->get_severity(section => 'humidity', label => 'default',
|
my $exit = $self->get_severity(section => 'humidity', label => 'default',
|
||||||
instance => $instance, value => $result->{sensState});
|
instance => $instance, value => $result->{sensState});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
|
@ -53,18 +53,18 @@ sub check {
|
||||||
short_msg => sprintf("humidity '%s' state is '%s'", $result->{sensName}, $result->{sensState}));
|
short_msg => sprintf("humidity '%s' state is '%s'", $result->{sensName}, $result->{sensState}));
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($result->{sensTemp} =~ /\d+/) {
|
if ($result->{sensValue} =~ /\d+/) {
|
||||||
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'humidity', instance => $instance, value => $result->{sensTemp});
|
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'humidity', instance => $instance, value => $result->{sensValue});
|
||||||
if (!$self->{output}->is_status(value => $exit2, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit2, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit2,
|
$self->{output}->output_add(severity => $exit2,
|
||||||
short_msg => sprintf("humidity '%s' value is %s %s", $result->{sensName}, $result->{sensTemp}, $result->{sensUnit}));
|
short_msg => sprintf("humidity '%s' value is %s %s", $result->{sensName}, $result->{sensValue}, $result->{sensUnit}));
|
||||||
}
|
}
|
||||||
$self->{output}->perfdata_add(label => 'sensor_' . $result->{sensName}, unit => $result->{sensUnit},
|
$self->{output}->perfdata_add(label => 'sensor_' . $result->{sensName}, unit => $result->{sensUnit},
|
||||||
value => $result->{sensTemp},
|
value => $result->{sensValue},
|
||||||
warning => $warn,
|
warning => $warn,
|
||||||
critical => $crit, min => 0, max => 100);
|
critical => $crit, min => 0, max => 100);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -48,10 +48,22 @@ our @EXPORT_OK = qw($mapping);
|
||||||
);
|
);
|
||||||
|
|
||||||
$mapping = {
|
$mapping = {
|
||||||
sensName => { oid => '.1.3.6.1.4.1.21796.4.1.3.1.2' },
|
branch_sensors => {
|
||||||
sensState => { oid => '.1.3.6.1.4.1.21796.4.1.3.1.3', map => \%map_sens_state },
|
hwgste => '.1.3.6.1.4.1.21796.4.1.3',
|
||||||
sensTemp => { oid => '.1.3.6.1.4.1.21796.4.1.3.1.4' },
|
hwgste2 => '.1.3.6.1.4.1.21796.4.9.3',
|
||||||
sensUnit => { oid => '.1.3.6.1.4.1.21796.4.1.3.1.7', map => \%map_sens_unit },
|
},
|
||||||
|
hwgste => {
|
||||||
|
sensName => { oid => '.1.3.6.1.4.1.21796.4.1.3.1.2' },
|
||||||
|
sensState => { oid => '.1.3.6.1.4.1.21796.4.1.3.1.3', map => \%map_sens_state },
|
||||||
|
sensValue => { oid => '.1.3.6.1.4.1.21796.4.1.3.1.5' },
|
||||||
|
sensUnit => { oid => '.1.3.6.1.4.1.21796.4.1.3.1.7', map => \%map_sens_unit },
|
||||||
|
},
|
||||||
|
hwgste2 => {
|
||||||
|
sensName => { oid => '.1.3.6.1.4.1.21796.4.9.3.1.2' },
|
||||||
|
sensState => { oid => '.1.3.6.1.4.1.21796.4.9.3.1.3', map => \%map_sens_state },
|
||||||
|
sensValue => { oid => '.1.3.6.1.4.1.21796.4.9.3.1.5' },
|
||||||
|
sensUnit => { oid => '.1.3.6.1.4.1.21796.4.9.3.1.7', map => \%map_sens_unit },
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -24,8 +24,6 @@ use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::hwgste::snmp::mode::components::resources qw($mapping);
|
use hardware::sensors::hwgste::snmp::mode::components::resources qw($mapping);
|
||||||
|
|
||||||
my $oid_sensEntry = '.1.3.6.1.4.1.21796.4.1.3.1';
|
|
||||||
|
|
||||||
sub load {}
|
sub load {}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -35,17 +33,19 @@ sub check {
|
||||||
$self->{components}->{temperature} = {name => 'temperature', total => 0, skip => 0};
|
$self->{components}->{temperature} = {name => 'temperature', total => 0, skip => 0};
|
||||||
return if ($self->check_filter(section => 'temperature'));
|
return if ($self->check_filter(section => 'temperature'));
|
||||||
|
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_sensEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $mapping->{branch_sensors}->{$self->{branch}} }})) {
|
||||||
next if ($oid !~ /^$mapping->{sensState}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$mapping->{$self->{branch}}->{sensState}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_sensEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(mapping => $mapping->{$self->{branch}}, results => $self->{results}->{ $mapping->{branch_sensors}->{$self->{branch}} }, instance => $instance);
|
||||||
|
|
||||||
next if (!(defined($result->{sensUnit}) && $result->{sensUnit} =~ /C|F|K/i));
|
next if (!(defined($result->{sensUnit}) && $result->{sensUnit} =~ /C|F|K/i));
|
||||||
next if ($self->check_filter(section => 'temperature', instance => $instance));
|
next if ($self->check_filter(section => 'temperature', instance => $instance));
|
||||||
$self->{components}->{temperature}->{total}++;
|
$self->{components}->{temperature}->{total}++;
|
||||||
|
|
||||||
|
$result->{sensValue} /= 10 if ($result->{sensValue} =~ /\d+/);
|
||||||
|
|
||||||
$self->{output}->output_add(long_msg => sprintf("temperature '%s' state is '%s' [instance: %s, value: %s]",
|
$self->{output}->output_add(long_msg => sprintf("temperature '%s' state is '%s' [instance: %s, value: %s]",
|
||||||
$result->{sensName}, $result->{sensState}, $instance, $result->{sensTemp}));
|
$result->{sensName}, $result->{sensState}, $instance, $result->{sensValue}));
|
||||||
my $exit = $self->get_severity(section => 'temperature', label => 'default',
|
my $exit = $self->get_severity(section => 'temperature', label => 'default',
|
||||||
instance => $instance, value => $result->{sensState});
|
instance => $instance, value => $result->{sensState});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
|
@ -53,18 +53,18 @@ sub check {
|
||||||
short_msg => sprintf("temperature '%s' state is '%s'", $result->{sensName}, $result->{sensState}));
|
short_msg => sprintf("temperature '%s' state is '%s'", $result->{sensName}, $result->{sensState}));
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($result->{sensTemp} =~ /\d+/) {
|
if ($result->{sensValue} =~ /\d+/) {
|
||||||
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'temperature', instance => $instance, value => $result->{sensTemp});
|
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'temperature', instance => $instance, value => $result->{sensValue});
|
||||||
if (!$self->{output}->is_status(value => $exit2, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit2, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit2,
|
$self->{output}->output_add(severity => $exit2,
|
||||||
short_msg => sprintf("temperature '%s' value is %s %s", $result->{sensName}, $result->{sensTemp}, $result->{sensUnit}));
|
short_msg => sprintf("temperature '%s' value is %s %s", $result->{sensName}, $result->{sensValue}, $result->{sensUnit}));
|
||||||
}
|
}
|
||||||
$self->{output}->perfdata_add(label => 'sensor_' . $result->{sensName}, unit => $result->{sensUnit},
|
$self->{output}->perfdata_add(label => 'sensor_' . $result->{sensName}, unit => $result->{sensUnit},
|
||||||
value => $result->{sensTemp},
|
value => $result->{sensValue},
|
||||||
warning => $warn,
|
warning => $warn,
|
||||||
critical => $crit);
|
critical => $crit);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -24,6 +24,7 @@ use base qw(centreon::plugins::templates::hardware);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
use hardware::sensors::hwgste::snmp::mode::components::resources qw($mapping);
|
||||||
|
|
||||||
sub set_system {
|
sub set_system {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
@ -52,9 +53,13 @@ sub snmp_execute {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{snmp} = $options{snmp};
|
$self->{snmp} = $options{snmp};
|
||||||
my $oid_sensEntry = '.1.3.6.1.4.1.21796.4.1.3.1';
|
$self->{results} = $self->{snmp}->get_multiple_table(
|
||||||
push @{$self->{request}}, { oid => $oid_sensEntry };
|
oids => [{ oid => $mapping->{branch_sensors}->{hwgste} }, { oid => $mapping->{branch_sensors}->{hwgste2} }]
|
||||||
$self->{results} = $self->{snmp}->get_multiple_table(oids => $self->{request});
|
);
|
||||||
|
$self->{branch} = 'hwgste';
|
||||||
|
if (defined($self->{results}->{ $mapping->{branch_sensors}->{hwgste2} }) && scalar($self->{results}->{ $mapping->{branch_sensors}->{hwgste2} }) > 0) {
|
||||||
|
$self->{branch} = 'hwgste2';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
|
@ -63,9 +68,8 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$self->{version} = '1.0';
|
$self->{version} = '1.0';
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {
|
||||||
{
|
});
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue