enhance indent + netbotz mib v5 managed

This commit is contained in:
garnier-quentin 2020-02-20 10:33:37 +01:00
parent befbae4c8c
commit c7c0ac0b21
9 changed files with 382 additions and 220 deletions

View File

@ -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',

View File

@ -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}
)
);
} }
} }
} }

View File

@ -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',

View File

@ -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}
)
);
} }
} }
} }

View File

@ -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',

View File

@ -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}
)
);
} }
} }
} }

View File

@ -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;

View File

@ -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',

View File

@ -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;