add mode time for ups hp

This commit is contained in:
garnier-quentin 2019-12-26 14:46:51 +01:00
parent ef48f61939
commit cfd1ccfbce
2 changed files with 102 additions and 5 deletions

View File

@ -0,0 +1,96 @@
#
# Copyright 2019 Centreon (http://www.centreon.com/)
#
# Centreon is a full-fledged industry-strength solution that meets
# the needs in IT infrastructure and application monitoring for
# service performance.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
package hardware::ups::hp::snmp::mode::time;
use base qw(snmp_standard::mode::ntp);
use strict;
use warnings;
sub get_target_time {
my ($self, %options) = @_;
my $oid_upsConfigDateAndTime = '.1.3.6.1.4.1.232.165.3.9.5.0';
my $snmp_result = $options{snmp}->get_leef(oids => [ $oid_upsConfigDateAndTime ], nothing_quit => 1);
# format: "11/18/2019 20:13:17"
if ($snmp_result->{$oid_upsConfigDateAndTime} !~ /^(\d+)\/(\d+)\/(\d+)\s+(\d+):(\d+):(\d+)/) {
$self->{output}->add_option_msg(short_msg => 'cannot parse date format: ' . $snmp_result->{$oid_upsConfigDateAndTime});
$self->{output}->option_exit();
}
my $remote_date = [$3, $1, $2, $4, $5, $6];
my $timezone = 'UTC';
if (defined($self->{option_results}->{timezone}) && $self->{option_results}->{timezone} ne '') {
$timezone = $self->{option_results}->{timezone};
}
my $tz = centreon::plugins::misc::set_timezone(name => $timezone);
my $dt = DateTime->new(
year => $remote_date->[0],
month => $remote_date->[1],
day => $remote_date->[2],
hour => $remote_date->[3],
minute => $remote_date->[4],
second => $remote_date->[5],
%$tz
);
return ($dt->epoch, $remote_date, $timezone);
}
1;
__END__
=head1 MODE
Check time offset of server with ntp server. Use local time if ntp-host option is not set.
SNMP gives a date with second precision (no milliseconds). Time precision is not very accurate.
Use threshold with (+-) 2 seconds offset (minimum).
=over 8
=item B<--warning-offset>
Time offset warning threshold (in seconds).
=item B<--critical-offset>
Time offset critical Threshold (in seconds).
=item B<--ntp-hostname>
Set the ntp hostname (if not set, localtime is used).
=item B<--ntp-port>
Set the ntp port (Default: 123).
=item B<--timezone>
Set the timezone of distant server. For Windows, you need to set it.
Can use format: 'Europe/London' or '+0100'.
=back
=cut

View File

@ -31,11 +31,12 @@ sub new {
$self->{version} = '0.1';
%{$self->{modes}} = (
'battery-status' => 'hardware::ups::hp::snmp::mode::batterystatus',
'environment' => 'hardware::ups::hp::snmp::mode::environment',
'input-lines' => 'hardware::ups::hp::snmp::mode::inputlines',
'uptime' => 'snmp_standard::mode::uptime',
'output-lines' => 'hardware::ups::hp::snmp::mode::outputlines',
'battery-status' => 'hardware::ups::hp::snmp::mode::batterystatus',
'environment' => 'hardware::ups::hp::snmp::mode::environment',
'input-lines' => 'hardware::ups::hp::snmp::mode::inputlines',
'output-lines' => 'hardware::ups::hp::snmp::mode::outputlines',
'time' => 'hardware::ups::hp::snmp::mode::time',
'uptime' => 'snmp_standard::mode::uptime'
);
return $self;