enhance indent + netbotz mib v5 managed
This commit is contained in:
parent
befbae4c8c
commit
c7c0ac0b21
|
@ -22,21 +22,22 @@ package hardware::sensors::netbotz::snmp::mode::components::airflow;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::netbotz::snmp::mode::components::resources qw(%map_status);
|
use hardware::sensors::netbotz::snmp::mode::components::resources qw($map_status);
|
||||||
|
|
||||||
my $mapping = {
|
|
||||||
airFlowSensorId => { oid => '.1.3.6.1.4.1.5528.100.4.1.5.1.1' },
|
|
||||||
airFlowSensorValue => { oid => '.1.3.6.1.4.1.5528.100.4.1.5.1.2' },
|
|
||||||
airFlowSensorErrorStatus => { oid => '.1.3.6.1.4.1.5528.100.4.1.5.1.3', map => \%map_status },
|
|
||||||
airFlowSensorLabel => { oid => '.1.3.6.1.4.1.5528.100.4.1.5.1.4' },
|
|
||||||
};
|
|
||||||
|
|
||||||
my $oid_airFlowSensorEntry = '.1.3.6.1.4.1.5528.100.4.1.5.1';
|
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_airFlowSensorEntry };
|
$self->{mapping_airflow} = {
|
||||||
|
airFlowSensorId => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.5.1.1' },
|
||||||
|
airFlowSensorValue => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.5.1.2' },
|
||||||
|
airFlowSensorErrorStatus => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.5.1.3', map => $map_status },
|
||||||
|
airFlowSensorLabel => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.5.1.4' }
|
||||||
|
};
|
||||||
|
$self->{oid_airFlowSensorEntry} = '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.5.1';
|
||||||
|
push @{$self->{request}}, {
|
||||||
|
oid => $self->{oid_airFlowSensorEntry},
|
||||||
|
end => $self->{mapping_airflow}->{airFlowSensorLabel}->{oid}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -46,32 +47,54 @@ sub check {
|
||||||
$self->{components}->{airflow} = { name => 'air flows', total => 0, skip => 0 };
|
$self->{components}->{airflow} = { name => 'air flows', total => 0, skip => 0 };
|
||||||
return if ($self->check_filter(section => 'airflow'));
|
return if ($self->check_filter(section => 'airflow'));
|
||||||
|
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_airFlowSensorEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $self->{oid_airFlowSensorEntry} }})) {
|
||||||
next if ($oid !~ /^$mapping->{airFlowSensorErrorStatus}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$self->{mapping_airflow}->{airFlowSensorErrorStatus}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_airFlowSensorEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(
|
||||||
|
mapping => $self->{mapping_airflow},
|
||||||
|
results => $self->{results}->{ $self->{oid_airFlowSensorEntry} },
|
||||||
|
instance => $instance
|
||||||
|
);
|
||||||
|
|
||||||
next if ($self->check_filter(section => 'airflow', instance => $instance));
|
next if ($self->check_filter(section => 'airflow', instance => $instance));
|
||||||
$self->{components}->{airflow}->{total}++;
|
$self->{components}->{airflow}->{total}++;
|
||||||
|
|
||||||
$result->{airFlowSensorValue} *= 0.1;
|
$result->{airFlowSensorValue} *= 0.1;
|
||||||
my $label = defined($result->{airFlowSensorLabel}) && $result->{airFlowSensorLabel} ne '' ? $result->{airFlowSensorLabel} : $result->{airFlowSensorId};
|
my $label = defined($result->{airFlowSensorLabel}) && $result->{airFlowSensorLabel} ne '' ? $result->{airFlowSensorLabel} : $result->{airFlowSensorId};
|
||||||
$self->{output}->output_add(long_msg => sprintf("air flow '%s' status is '%s' [instance = %s] [value = %s]",
|
$self->{output}->output_add(
|
||||||
$label, $result->{airFlowSensorErrorStatus}, $instance,
|
long_msg => sprintf(
|
||||||
$result->{airFlowSensorValue}));
|
"air flow '%s' status is '%s' [instance = %s] [value = %s]",
|
||||||
|
$label,
|
||||||
|
$result->{airFlowSensorErrorStatus},
|
||||||
|
$instance,
|
||||||
|
$result->{airFlowSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
my $exit = $self->get_severity(label => 'default', section => 'airflow', value => $result->{airFlowSensorErrorStatus});
|
my $exit = $self->get_severity(label => 'default', section => 'airflow', value => $result->{airFlowSensorErrorStatus});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("Air flow '%s' status is '%s'", $label, $result->{airFlowSensorErrorStatus}));
|
severity => $exit,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Air flow '%s' status is '%s'",
|
||||||
|
$label,
|
||||||
|
$result->{airFlowSensorErrorStatus}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'airflow', instance => $instance, value => $result->{airFlowSensorValue});
|
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'airflow', instance => $instance, value => $result->{airFlowSensorValue});
|
||||||
|
|
||||||
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(
|
||||||
short_msg => sprintf("Air flow '%s' is %s m/min", $label, $result->{airFlowSensorValue}));
|
severity => $exit2,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Air flow '%s' is %s m/min",
|
||||||
|
$label,
|
||||||
|
$result->{airFlowSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->perfdata_add(
|
$self->{output}->perfdata_add(
|
||||||
label => 'airflow', unit => 'm/min',
|
label => 'airflow', unit => 'm/min',
|
||||||
nlabel => 'hardware.sensor.airflow.cubicmeterperminute',
|
nlabel => 'hardware.sensor.airflow.cubicmeterperminute',
|
||||||
|
|
|
@ -22,21 +22,22 @@ package hardware::sensors::netbotz::snmp::mode::components::camera;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::netbotz::snmp::mode::components::resources qw(%map_status %map_camera_value);
|
use hardware::sensors::netbotz::snmp::mode::components::resources qw($map_status $map_camera_value);
|
||||||
|
|
||||||
my $mapping = {
|
|
||||||
cameraMotionSensorId => { oid => '.1.3.6.1.4.1.5528.100.4.2.3.1.1' },
|
|
||||||
cameraMotionSensorValue => { oid => '.1.3.6.1.4.1.5528.100.4.2.3.1.2', map => \%map_camera_value },
|
|
||||||
cameraMotionSensorErrorStatus => { oid => '.1.3.6.1.4.1.5528.100.4.2.3.1.3', map => \%map_status },
|
|
||||||
cameraMotionSensorLabel => { oid => '.1.3.6.1.4.1.5528.100.4.2.3.1.4' },
|
|
||||||
};
|
|
||||||
|
|
||||||
my $oid_cameraMotionSensorEntry = '.1.3.6.1.4.1.5528.100.4.2.3.1';
|
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_cameraMotionSensorEntry };
|
$self->{mapping_camera} = {
|
||||||
|
cameraMotionSensorId => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.3.1.1' },
|
||||||
|
cameraMotionSensorValue => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.3.1.2', map => $map_camera_value },
|
||||||
|
cameraMotionSensorErrorStatus => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.3.1.3', map => $map_status },
|
||||||
|
cameraMotionSensorLabel => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.3.1.4' }
|
||||||
|
};
|
||||||
|
$self->{oid_cameraMotionSensorEntry} = '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.3.1';
|
||||||
|
push @{$self->{request}}, {
|
||||||
|
oid => $self->{oid_cameraMotionSensorEntry},
|
||||||
|
end => $self->{mapping_camera}->{cameraMotionSensorLabel}->{oid}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -46,23 +47,39 @@ sub check {
|
||||||
$self->{components}->{camera} = { name => 'cameras', total => 0, skip => 0 };
|
$self->{components}->{camera} = { name => 'cameras', total => 0, skip => 0 };
|
||||||
return if ($self->check_filter(section => 'camera'));
|
return if ($self->check_filter(section => 'camera'));
|
||||||
|
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_cameraMotionSensorEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $self->{oid_cameraMotionSensorEntry} }})) {
|
||||||
next if ($oid !~ /^$mapping->{cameraMotionSensorErrorStatus}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$self->{mapping_camera}->{cameraMotionSensorErrorStatus}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_cameraMotionSensorEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(
|
||||||
|
mapping => $self->{mapping_camera},
|
||||||
|
results => $self->{results}->{ $self->{oid_cameraMotionSensorEntry} },
|
||||||
|
instance => $instance
|
||||||
|
);
|
||||||
|
|
||||||
next if ($self->check_filter(section => 'camera', instance => $instance));
|
next if ($self->check_filter(section => 'camera', instance => $instance));
|
||||||
$self->{components}->{camera}->{total}++;
|
$self->{components}->{camera}->{total}++;
|
||||||
|
|
||||||
my $label = defined($result->{cameraMotionSensorLabel}) && $result->{cameraMotionSensorLabel} ne '' ? $result->{cameraMotionSensorLabel} : $result->{cameraMotionSensorId};
|
my $label = defined($result->{cameraMotionSensorLabel}) && $result->{cameraMotionSensorLabel} ne '' ? $result->{cameraMotionSensorLabel} : $result->{cameraMotionSensorId};
|
||||||
$self->{output}->output_add(long_msg => sprintf("camera motion '%s' status is '%s' [instance = %s] [value = %s]",
|
$self->{output}->output_add(
|
||||||
$label, $result->{cameraMotionSensorErrorStatus}, $instance,
|
long_msg => sprintf(
|
||||||
$result->{cameraMotionSensorValue}));
|
"camera motion '%s' status is '%s' [instance = %s] [value = %s]",
|
||||||
|
$label,
|
||||||
|
$result->{cameraMotionSensorErrorStatus},
|
||||||
|
$instance,
|
||||||
|
$result->{cameraMotionSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
my $exit = $self->get_severity(label => 'default', section => 'camera', value => $result->{cameraMotionSensorErrorStatus});
|
my $exit = $self->get_severity(label => 'default', section => 'camera', value => $result->{cameraMotionSensorErrorStatus});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("Camera motion '%s' status is '%s'", $label, $result->{cameraMotionSensorErrorStatus}));
|
severity => $exit,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Camera motion '%s' status is '%s'",
|
||||||
|
$label,
|
||||||
|
$result->{cameraMotionSensorErrorStatus}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,21 +22,22 @@ package hardware::sensors::netbotz::snmp::mode::components::dewpoint;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::netbotz::snmp::mode::components::resources qw(%map_status);
|
use hardware::sensors::netbotz::snmp::mode::components::resources qw($map_status);
|
||||||
|
|
||||||
my $mapping = {
|
|
||||||
dewPointSensorId => { oid => '.1.3.6.1.4.1.5528.100.4.1.3.1.1' },
|
|
||||||
dewPointSensorValue => { oid => '.1.3.6.1.4.1.5528.100.4.1.3.1.2' },
|
|
||||||
dewPointSensorErrorStatus => { oid => '.1.3.6.1.4.1.5528.100.4.1.3.1.3', map => \%map_status },
|
|
||||||
dewPointSensorLabel => { oid => '.1.3.6.1.4.1.5528.100.4.1.3.1.4' },
|
|
||||||
};
|
|
||||||
|
|
||||||
my $oid_dewPointSensorEntry = '.1.3.6.1.4.1.5528.100.4.1.3.1';
|
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_dewPointSensorEntry };
|
$self->{mapping_dewpoint} = {
|
||||||
|
dewPointSensorId => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.3.1.1' },
|
||||||
|
dewPointSensorValue => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.3.1.2' },
|
||||||
|
dewPointSensorErrorStatus => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.3.1.3', map => $map_status },
|
||||||
|
dewPointSensorLabel => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.3.1.4' }
|
||||||
|
};
|
||||||
|
$self->{oid_dewPointSensorEntry} = '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.3.1';
|
||||||
|
push @{$self->{request}}, {
|
||||||
|
oid => $self->{oid_dewPointSensorEntry},
|
||||||
|
end => $self->{mapping_dewpoint}->{dewPointSensorLabel}->{oid}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -46,32 +47,54 @@ sub check {
|
||||||
$self->{components}->{dewpoint} = { name => 'dew points', total => 0, skip => 0 };
|
$self->{components}->{dewpoint} = { name => 'dew points', total => 0, skip => 0 };
|
||||||
return if ($self->check_filter(section => 'dewpoint'));
|
return if ($self->check_filter(section => 'dewpoint'));
|
||||||
|
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_dewPointSensorEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $self->{oid_dewPointSensorEntry} }})) {
|
||||||
next if ($oid !~ /^$mapping->{dewPointSensorErrorStatus}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$self->{mapping_dewpoint}->{dewPointSensorErrorStatus}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_dewPointSensorEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(
|
||||||
|
mapping => $self->{mapping_dewpoint},
|
||||||
|
results => $self->{results}->{ $self->{oid_dewPointSensorEntry} },
|
||||||
|
instance => $instance
|
||||||
|
);
|
||||||
|
|
||||||
next if ($self->check_filter(section => 'dewpoint', instance => $instance));
|
next if ($self->check_filter(section => 'dewpoint', instance => $instance));
|
||||||
$self->{components}->{dewpoint}->{total}++;
|
$self->{components}->{dewpoint}->{total}++;
|
||||||
|
|
||||||
$result->{dewPointSensorValue} *= 0.1;
|
$result->{dewPointSensorValue} *= 0.1;
|
||||||
my $label = defined($result->{dewPointSensorLabel}) && $result->{dewPointSensorLabel} ne '' ? $result->{dewPointSensorLabel} : $result->{dewPointSensorId};
|
my $label = defined($result->{dewPointSensorLabel}) && $result->{dewPointSensorLabel} ne '' ? $result->{dewPointSensorLabel} : $result->{dewPointSensorId};
|
||||||
$self->{output}->output_add(long_msg => sprintf("dew point '%s' status is '%s' [instance = %s] [value = %s]",
|
$self->{output}->output_add(
|
||||||
$label, $result->{dewPointSensorErrorStatus}, $instance,
|
long_msg => sprintf(
|
||||||
$result->{dewPointSensorValue}));
|
"dew point '%s' status is '%s' [instance = %s] [value = %s]",
|
||||||
|
$label,
|
||||||
|
$result->{dewPointSensorErrorStatus},
|
||||||
|
$instance,
|
||||||
|
$result->{dewPointSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
my $exit = $self->get_severity(label => 'default', section => 'dewpoint', value => $result->{dewPointSensorErrorStatus});
|
my $exit = $self->get_severity(label => 'default', section => 'dewpoint', value => $result->{dewPointSensorErrorStatus});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("Dew point '%s' status is '%s'", $label, $result->{dewPointSensorErrorStatus}));
|
severity => $exit,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Dew point '%s' status is '%s'",
|
||||||
|
$label,
|
||||||
|
$result->{dewPointSensorErrorStatus}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'dewpoint', instance => $instance, value => $result->{dewPointSensorValue});
|
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'dewpoint', instance => $instance, value => $result->{dewPointSensorValue});
|
||||||
|
|
||||||
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(
|
||||||
short_msg => sprintf("Dew point '%s' is %s C", $label, $result->{dewPointSensorValue}));
|
severity => $exit2,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Dew point '%s' is %s C",
|
||||||
|
$label,
|
||||||
|
$result->{dewPointSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->perfdata_add(
|
$self->{output}->perfdata_add(
|
||||||
label => 'dewpoint', unit => 'C',
|
label => 'dewpoint', unit => 'C',
|
||||||
nlabel => 'hardware.sensor.dewpoint.celsius',
|
nlabel => 'hardware.sensor.dewpoint.celsius',
|
||||||
|
|
|
@ -22,21 +22,22 @@ package hardware::sensors::netbotz::snmp::mode::components::doorswitch;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::netbotz::snmp::mode::components::resources qw(%map_status %map_door_value);
|
use hardware::sensors::netbotz::snmp::mode::components::resources qw($map_status $map_door_value);
|
||||||
|
|
||||||
my $mapping = {
|
|
||||||
doorSwitchSensorId => { oid => '.1.3.6.1.4.1.5528.100.4.2.2.1.1' },
|
|
||||||
doorSwitchSensorValue => { oid => '.1.3.6.1.4.1.5528.100.4.2.2.1.2', map => \%map_door_value },
|
|
||||||
doorSwitchSensorErrorStatus => { oid => '.1.3.6.1.4.1.5528.100.4.2.2.1.3', map => \%map_status },
|
|
||||||
doorSwitchSensorLabel => { oid => '.1.3.6.1.4.1.5528.100.4.2.2.1.4' },
|
|
||||||
};
|
|
||||||
|
|
||||||
my $oid_doorSwitchSensorEntry = '.1.3.6.1.4.1.5528.100.4.2.2.1';
|
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_doorSwitchSensorEntry };
|
$self->{mapping_doorswitch} = {
|
||||||
|
doorSwitchSensorId => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.2.1.1' },
|
||||||
|
doorSwitchSensorValue => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.2.1.2', map => $map_door_value },
|
||||||
|
doorSwitchSensorErrorStatus => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.2.1.3', map => $map_status },
|
||||||
|
doorSwitchSensorLabel => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.2.1.4' }
|
||||||
|
};
|
||||||
|
$self->{oid_doorSwitchSensorEntry} = '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.2.1';
|
||||||
|
push @{$self->{request}}, {
|
||||||
|
oid => $self->{oid_doorSwitchSensorEntry},
|
||||||
|
end => $self->{mapping_doorswitch}->{doorSwitchSensorLabel}->{oid}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -46,23 +47,39 @@ sub check {
|
||||||
$self->{components}->{doorswitch} = { name => 'door switches', total => 0, skip => 0 };
|
$self->{components}->{doorswitch} = { name => 'door switches', total => 0, skip => 0 };
|
||||||
return if ($self->check_filter(section => 'doorswitch'));
|
return if ($self->check_filter(section => 'doorswitch'));
|
||||||
|
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_doorSwitchSensorEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $self->{oid_doorSwitchSensorEntry} }})) {
|
||||||
next if ($oid !~ /^$mapping->{doorSwitchSensorErrorStatus}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$self->{mapping_doorswitch}->{doorSwitchSensorErrorStatus}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_doorSwitchSensorEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(
|
||||||
|
mapping => $self->{mapping_doorswitch},
|
||||||
|
results => $self->{results}->{ $self->{oid_doorSwitchSensorEntry} },
|
||||||
|
instance => $instance
|
||||||
|
);
|
||||||
|
|
||||||
next if ($self->check_filter(section => 'doorswitch', instance => $instance));
|
next if ($self->check_filter(section => 'doorswitch', instance => $instance));
|
||||||
$self->{components}->{doorswitch}->{total}++;
|
$self->{components}->{doorswitch}->{total}++;
|
||||||
|
|
||||||
my $label = defined($result->{doorSwitchSensorLabel}) && $result->{doorSwitchSensorLabel} ne '' ? $result->{doorSwitchSensorLabel} : $result->{doorSwitchSensorId};
|
my $label = defined($result->{doorSwitchSensorLabel}) && $result->{doorSwitchSensorLabel} ne '' ? $result->{doorSwitchSensorLabel} : $result->{doorSwitchSensorId};
|
||||||
$self->{output}->output_add(long_msg => sprintf("door switch '%s' status is '%s' [instance = %s] [value = %s]",
|
$self->{output}->output_add(
|
||||||
$label, $result->{doorSwitchSensorErrorStatus}, $instance,
|
long_msg => sprintf(
|
||||||
$result->{doorSwitchSensorValue}));
|
"door switch '%s' status is '%s' [instance = %s] [value = %s]",
|
||||||
|
$label,
|
||||||
|
$result->{doorSwitchSensorErrorStatus},
|
||||||
|
$instance,
|
||||||
|
$result->{doorSwitchSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
my $exit = $self->get_severity(label => 'default', section => 'doorswitch', value => $result->{doorSwitchSensorErrorStatus});
|
my $exit = $self->get_severity(label => 'default', section => 'doorswitch', value => $result->{doorSwitchSensorErrorStatus});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("Door switch '%s' status is '%s'", $label, $result->{doorSwitchSensorErrorStatus}));
|
severity => $exit,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Door switch '%s' status is '%s'",
|
||||||
|
$label,
|
||||||
|
$result->{doorSwitchSensorErrorStatus}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,21 +22,22 @@ package hardware::sensors::netbotz::snmp::mode::components::humidity;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::netbotz::snmp::mode::components::resources qw(%map_status);
|
use hardware::sensors::netbotz::snmp::mode::components::resources qw($map_status);
|
||||||
|
|
||||||
my $mapping = {
|
|
||||||
humiSensorId => { oid => '.1.3.6.1.4.1.5528.100.4.1.2.1.1' },
|
|
||||||
humiSensorValue => { oid => '.1.3.6.1.4.1.5528.100.4.1.2.1.2' },
|
|
||||||
humiSensorErrorStatus => { oid => '.1.3.6.1.4.1.5528.100.4.1.2.1.3', map => \%map_status },
|
|
||||||
humiSensorLabel => { oid => '.1.3.6.1.4.1.5528.100.4.1.2.1.4' },
|
|
||||||
};
|
|
||||||
|
|
||||||
my $oid_humiSensorEntry = '.1.3.6.1.4.1.5528.100.4.1.2.1';
|
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_humiSensorEntry };
|
$self->{mapping_humidity} = {
|
||||||
|
humiSensorId => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.2.1.1' },
|
||||||
|
humiSensorValue => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.2.1.2' },
|
||||||
|
humiSensorErrorStatus => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.2.1.3', map => $map_status },
|
||||||
|
humiSensorLabel => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.2.1.4' }
|
||||||
|
};
|
||||||
|
$self->{oid_humiSensorEntry} = '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.2.1';
|
||||||
|
push @{$self->{request}}, {
|
||||||
|
oid => $self->{oid_humiSensorEntry},
|
||||||
|
end => $self->{mapping_humidity}->{humiSensorLabel}->{oid}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -46,32 +47,54 @@ 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_humiSensorEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $self->{oid_humiSensorEntry} }})) {
|
||||||
next if ($oid !~ /^$mapping->{humiSensorErrorStatus}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$self->{mapping_humidity}->{humiSensorErrorStatus}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_humiSensorEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(
|
||||||
|
mapping => $self->{mapping_humidity},
|
||||||
|
results => $self->{results}->{ $self->{oid_humiSensorEntry} },
|
||||||
|
instance => $instance
|
||||||
|
);
|
||||||
|
|
||||||
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->{humiSensorValue} *= 0.1;
|
$result->{humiSensorValue} *= 0.1;
|
||||||
my $label = defined($result->{humiSensorLabel}) && $result->{humiSensorLabel} ne '' ? $result->{humiSensorLabel} : $result->{humiSensorId};
|
my $label = defined($result->{humiSensorLabel}) && $result->{humiSensorLabel} ne '' ? $result->{humiSensorLabel} : $result->{humiSensorId};
|
||||||
$self->{output}->output_add(long_msg => sprintf("humidity '%s' status is '%s' [instance = %s] [value = %s]",
|
$self->{output}->output_add(
|
||||||
$label, $result->{humiSensorErrorStatus}, $instance,
|
long_msg => sprintf(
|
||||||
$result->{humiSensorValue}));
|
"humidity '%s' status is '%s' [instance = %s] [value = %s]",
|
||||||
|
$label,
|
||||||
|
$result->{humiSensorErrorStatus},
|
||||||
|
$instance,
|
||||||
|
$result->{humiSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
my $exit = $self->get_severity(label => 'default', section => 'humidity', value => $result->{humiSensorErrorStatus});
|
my $exit = $self->get_severity(label => 'default', section => 'humidity', value => $result->{humiSensorErrorStatus});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("Humidity '%s' status is '%s'", $label, $result->{humiSensorErrorStatus}));
|
severity => $exit,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Humidity '%s' status is '%s'",
|
||||||
|
$label,
|
||||||
|
$result->{humiSensorErrorStatus}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'humidity', instance => $instance, value => $result->{humiSensorValue});
|
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'humidity', instance => $instance, value => $result->{humiSensorValue});
|
||||||
|
|
||||||
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(
|
||||||
short_msg => sprintf("Humidity '%s' is %s %%", $label, $result->{humiSensorValue}));
|
severity => $exit2,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Humidity '%s' is %s %%",
|
||||||
|
$label,
|
||||||
|
$result->{humiSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output}->perfdata_add(
|
$self->{output}->perfdata_add(
|
||||||
label => 'humidity', unit => '%',
|
label => 'humidity', unit => '%',
|
||||||
nlabel => 'hardware.sensor.humidity.percentage',
|
nlabel => 'hardware.sensor.humidity.percentage',
|
||||||
|
|
|
@ -22,21 +22,19 @@ package hardware::sensors::netbotz::snmp::mode::components::otherstate;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::netbotz::snmp::mode::components::resources qw(%map_status);
|
use hardware::sensors::netbotz::snmp::mode::components::resources qw($map_status);
|
||||||
|
|
||||||
my $mapping = {
|
|
||||||
otherStateSensorId => { oid => '.1.3.6.1.4.1.5528.100.4.2.10.1.1' },
|
|
||||||
otherStateSensorErrorStatus => { oid => '.1.3.6.1.4.1.5528.100.4.2.10.1.3', map => \%map_status },
|
|
||||||
otherStateSensorLabel => { oid => '.1.3.6.1.4.1.5528.100.4.2.10.1.4' },
|
|
||||||
otherStateSensorValueStr => { oid => '.1.3.6.1.4.1.5528.100.4.2.10.1.7' },
|
|
||||||
};
|
|
||||||
|
|
||||||
my $oid_otherStateSensorEntry = '.1.3.6.1.4.1.5528.100.4.2.10.1';
|
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_otherStateSensorEntry };
|
$self->{mapping_otherstate} = {
|
||||||
|
otherStateSensorId => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.10.1.1' },
|
||||||
|
otherStateSensorErrorStatus => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.10.1.3', map => $map_status },
|
||||||
|
otherStateSensorLabel => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.10.1.4' },
|
||||||
|
otherStateSensorValueStr => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.10.1.7' }
|
||||||
|
};
|
||||||
|
$self->{oid_otherStateSensorEntry} = '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.2.10.1';
|
||||||
|
push @{$self->{request}}, { oid => $self->{oid_otherStateSensorEntry} };
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -46,23 +44,39 @@ sub check {
|
||||||
$self->{components}->{otherstate} = { name => 'other state', total => 0, skip => 0 };
|
$self->{components}->{otherstate} = { name => 'other state', total => 0, skip => 0 };
|
||||||
return if ($self->check_filter(section => 'otherstate'));
|
return if ($self->check_filter(section => 'otherstate'));
|
||||||
|
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_otherStateSensorEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $self->{oid_otherStateSensorEntry} }})) {
|
||||||
next if ($oid !~ /^$mapping->{otherStateSensorErrorStatus}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$self->{mapping_otherstate}->{otherStateSensorErrorStatus}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_otherStateSensorEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(
|
||||||
|
mapping => $self->{mapping_otherstate},
|
||||||
|
results => $self->{results}->{ $self->{oid_otherStateSensorEntry} },
|
||||||
|
instance => $instance
|
||||||
|
);
|
||||||
|
|
||||||
next if ($self->check_filter(section => 'otherstate', instance => $instance));
|
next if ($self->check_filter(section => 'otherstate', instance => $instance));
|
||||||
$self->{components}->{otherstate}->{total}++;
|
$self->{components}->{otherstate}->{total}++;
|
||||||
|
|
||||||
my $label = defined($result->{otherStateSensorLabel}) && $result->{otherStateSensorLabel} ne '' ? $result->{otherStateSensorLabel} : $result->{otherStateSensorId};
|
my $label = defined($result->{otherStateSensorLabel}) && $result->{otherStateSensorLabel} ne '' ? $result->{otherStateSensorLabel} : $result->{otherStateSensorId};
|
||||||
$self->{output}->output_add(long_msg => sprintf("other state '%s' status is '%s' [instance = %s] [value = %s]",
|
$self->{output}->output_add(
|
||||||
$label, $result->{otherStateSensorErrorStatus}, $instance,
|
long_msg => sprintf(
|
||||||
$result->{otherStateSensorValueStr}));
|
"other state '%s' status is '%s' [instance = %s] [value = %s]",
|
||||||
|
$label,
|
||||||
|
$result->{otherStateSensorErrorStatus},
|
||||||
|
$instance,
|
||||||
|
$result->{otherStateSensorValueStr}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
my $exit = $self->get_severity(label => 'default', section => 'otherstate', value => $result->{otherStateSensorErrorStatus});
|
my $exit = $self->get_severity(label => 'default', section => 'otherstate', value => $result->{otherStateSensorErrorStatus});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("Other state '%s' status is '%s'", $label, $result->{otherStateSensorErrorStatus}));
|
severity => $exit,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Other state '%s' status is '%s'",
|
||||||
|
$label,
|
||||||
|
$result->{otherStateSensorErrorStatus}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,32 +24,32 @@ use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Exporter;
|
use Exporter;
|
||||||
|
|
||||||
our %map_status;
|
our $map_status;
|
||||||
our %map_door_value;
|
our $map_door_value;
|
||||||
our %map_camera_value;
|
our $map_camera_value;
|
||||||
|
|
||||||
our @ISA = qw(Exporter);
|
our @ISA = qw(Exporter);
|
||||||
our @EXPORT_OK = qw(%map_status %map_door_value %map_camera_value);
|
our @EXPORT_OK = qw($map_status $map_door_value $map_camera_value);
|
||||||
|
|
||||||
%map_status = (
|
$map_status = {
|
||||||
0 => 'normal',
|
0 => 'normal',
|
||||||
1 => 'info',
|
1 => 'info',
|
||||||
2 => 'warning',
|
2 => 'warning',
|
||||||
3 => 'error',
|
3 => 'error',
|
||||||
4 => 'critical',
|
4 => 'critical',
|
||||||
5 => 'failure',
|
5 => 'failure'
|
||||||
);
|
};
|
||||||
|
|
||||||
%map_door_value = (
|
$map_door_value = {
|
||||||
-1 => 'null',
|
-1 => 'null',
|
||||||
0 => 'open',
|
0 => 'open',
|
||||||
1 => 'closed',
|
1 => 'closed'
|
||||||
);
|
};
|
||||||
|
|
||||||
%map_camera_value = (
|
$map_camera_value = {
|
||||||
-1 => 'null',
|
-1 => 'null',
|
||||||
0 => 'noMotion',
|
0 => 'noMotion',
|
||||||
1 => 'motionDetected',
|
1 => 'motionDetected'
|
||||||
);
|
};
|
||||||
|
|
||||||
1;
|
1;
|
|
@ -22,21 +22,22 @@ package hardware::sensors::netbotz::snmp::mode::components::temperature;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use hardware::sensors::netbotz::snmp::mode::components::resources qw(%map_status);
|
use hardware::sensors::netbotz::snmp::mode::components::resources qw($map_status);
|
||||||
|
|
||||||
my $mapping = {
|
|
||||||
tempSensorId => { oid => '.1.3.6.1.4.1.5528.100.4.1.1.1.1' },
|
|
||||||
tempSensorValue => { oid => '.1.3.6.1.4.1.5528.100.4.1.1.1.2' },
|
|
||||||
tempSensorErrorStatus => { oid => '.1.3.6.1.4.1.5528.100.4.1.1.1.3', map => \%map_status },
|
|
||||||
tempSensorLabel => { oid => '.1.3.6.1.4.1.5528.100.4.1.1.1.4' },
|
|
||||||
};
|
|
||||||
|
|
||||||
my $oid_tempSensorEntry = '.1.3.6.1.4.1.5528.100.4.1.1.1';
|
|
||||||
|
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_tempSensorEntry };
|
$self->{mapping_temperature} = {
|
||||||
|
tempSensorId => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.1.1.1' },
|
||||||
|
tempSensorValue => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.1.1.2' },
|
||||||
|
tempSensorErrorStatus => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.1.1.3', map => $map_status },
|
||||||
|
tempSensorLabel => { oid => '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.1.1.4' },
|
||||||
|
};
|
||||||
|
$self->{oid_tempSensorEntry} = '.1.3.6.1.4.1.' . $self->{netbotz_branch} . '.4.1.1.1';
|
||||||
|
push @{$self->{request}}, {
|
||||||
|
oid => $self->{oid_tempSensorEntry},
|
||||||
|
end => $self->{mapping_temperature}->{tempSensorLabel}->{oid}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -46,31 +47,53 @@ sub check {
|
||||||
$self->{components}->{temperature} = { name => 'temperatures', total => 0, skip => 0 };
|
$self->{components}->{temperature} = { name => 'temperatures', 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_tempSensorEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{ $self->{oid_tempSensorEntry} }})) {
|
||||||
next if ($oid !~ /^$mapping->{tempSensorErrorStatus}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$self->{mapping_temperature}->{tempSensorErrorStatus}->{oid}\.(.*)$/);
|
||||||
my $instance = $1;
|
my $instance = $1;
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_tempSensorEntry}, instance => $instance);
|
my $result = $self->{snmp}->map_instance(
|
||||||
|
mapping => $self->{mapping_temperature},
|
||||||
|
results => $self->{results}->{ $self->{oid_tempSensorEntry} },
|
||||||
|
instance => $instance
|
||||||
|
);
|
||||||
|
|
||||||
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->{tempSensorValue} *= 0.1;
|
$result->{tempSensorValue} *= 0.1;
|
||||||
my $label = defined($result->{tempSensorLabel}) && $result->{tempSensorLabel} ne '' ? $result->{tempSensorLabel} : $result->{tempSensorId};
|
my $label = defined($result->{tempSensorLabel}) && $result->{tempSensorLabel} ne '' ? $result->{tempSensorLabel} : $result->{tempSensorId};
|
||||||
$self->{output}->output_add(long_msg => sprintf("temperature '%s' status is '%s' [instance = %s] [value = %s]",
|
$self->{output}->output_add(
|
||||||
$label, $result->{tempSensorErrorStatus}, $instance,
|
long_msg => sprintf(
|
||||||
$result->{tempSensorValue}));
|
"temperature '%s' status is '%s' [instance = %s] [value = %s]",
|
||||||
|
$label,
|
||||||
|
$result->{tempSensorErrorStatus},
|
||||||
|
$instance,
|
||||||
|
$result->{tempSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
my $exit = $self->get_severity(label => 'default', section => 'temperature', value => $result->{tempSensorErrorStatus});
|
my $exit = $self->get_severity(label => 'default', section => 'temperature', value => $result->{tempSensorErrorStatus});
|
||||||
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
if (!$self->{output}->is_status(value => $exit, compare => 'ok', litteral => 1)) {
|
||||||
$self->{output}->output_add(severity => $exit,
|
$self->{output}->output_add(
|
||||||
short_msg => sprintf("Temperature '%s' status is '%s'", $label, $result->{tempSensorErrorStatus}));
|
severity => $exit,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Temperature '%s' status is '%s'",
|
||||||
|
$label,
|
||||||
|
$result->{tempSensorErrorStatus}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'temperature', instance => $instance, value => $result->{tempSensorValue});
|
my ($exit2, $warn, $crit, $checked) = $self->get_severity_numeric(section => 'temperature', instance => $instance, value => $result->{tempSensorValue});
|
||||||
|
|
||||||
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(
|
||||||
short_msg => sprintf("Temperature '%s' is %s C", $label, $result->{tempSensorValue}));
|
severity => $exit2,
|
||||||
|
short_msg => sprintf(
|
||||||
|
"Temperature '%s' is %s C",
|
||||||
|
$label,
|
||||||
|
$result->{tempSensorValue}
|
||||||
|
)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
$self->{output}->perfdata_add(
|
$self->{output}->perfdata_add(
|
||||||
label => 'temperature', unit => 'C',
|
label => 'temperature', unit => 'C',
|
||||||
|
|
|
@ -31,6 +31,7 @@ sub set_system {
|
||||||
$self->{regexp_threshold_overload_check_section_option} = '^(temperature|humidity|dewpoint|airflow|doorswitch|camera|otherstate)$';
|
$self->{regexp_threshold_overload_check_section_option} = '^(temperature|humidity|dewpoint|airflow|doorswitch|camera|otherstate)$';
|
||||||
$self->{regexp_threshold_numeric_check_section_option} = '^(temperature|humidity|dewpoint|airflow)$';
|
$self->{regexp_threshold_numeric_check_section_option} = '^(temperature|humidity|dewpoint|airflow)$';
|
||||||
|
|
||||||
|
$self->{cb_hook1} = 'get_version';
|
||||||
$self->{cb_hook2} = 'snmp_execute';
|
$self->{cb_hook2} = 'snmp_execute';
|
||||||
|
|
||||||
$self->{thresholds} = {
|
$self->{thresholds} = {
|
||||||
|
@ -45,8 +46,30 @@ sub set_system {
|
||||||
};
|
};
|
||||||
|
|
||||||
$self->{components_path} = 'hardware::sensors::netbotz::snmp::mode::components';
|
$self->{components_path} = 'hardware::sensors::netbotz::snmp::mode::components';
|
||||||
$self->{components_module} = ['temperature', 'humidity', 'dewpoint', 'airflow',
|
$self->{components_module} = [
|
||||||
'doorswitch', 'camera', 'otherstate'];
|
'temperature', 'humidity', 'dewpoint', 'airflow',
|
||||||
|
'doorswitch', 'camera', 'otherstate'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
sub get_version {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $v1_netBotzErrorStatus = '.1.3.6.1.4.1.5528.100.100';
|
||||||
|
my $v5_netBotzErrorStatus = '.1.3.6.1.4.1.52674.500.100.0';
|
||||||
|
my $result = $options{snmp}->get_leef(
|
||||||
|
oids => [$v1_netBotzErrorStatus, $v1_netBotzErrorStatus . '.0', $v5_netBotzErrorStatus]
|
||||||
|
);
|
||||||
|
|
||||||
|
$self->{is_v5} = 0;
|
||||||
|
$self->{netbotz_branch} = '5528.100';
|
||||||
|
if (defined($result->{$v5_netBotzErrorStatus})) {
|
||||||
|
$self->{is_v5} = 1;
|
||||||
|
$self->{netbotz_branch} = '52674.500';
|
||||||
|
} elsif (!defined($result->{$v1_netBotzErrorStatus}) && !defined($result->{$v1_netBotzErrorStatus . '.0'})) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => 'cannot find netbotz version');
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub snmp_execute {
|
sub snmp_execute {
|
||||||
|
@ -61,8 +84,7 @@ sub new {
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options, no_absent => 1);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options, no_absent => 1);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {
|
||||||
{
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
|
Loading…
Reference in New Issue