mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-31 01:24:35 +02:00
+ Add a command to get host times (for debug)
This commit is contained in:
parent
dcee7cb0e6
commit
390eeb6aee
106
connectors/vmware/src/centreon/esxd/cmdtimehost.pm
Normal file
106
connectors/vmware/src/centreon/esxd/cmdtimehost.pm
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
|
||||||
|
package centreon::esxd::cmdtimehost;
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use centreon::esxd::common;
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my $class = shift;
|
||||||
|
my $self = {};
|
||||||
|
$self->{logger} = shift;
|
||||||
|
$self->{commandName} = 'timehost';
|
||||||
|
|
||||||
|
bless $self, $class;
|
||||||
|
return $self;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub getCommandName {
|
||||||
|
my $self = shift;
|
||||||
|
return $self->{commandName};
|
||||||
|
}
|
||||||
|
|
||||||
|
sub checkArgs {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
if (defined($options{arguments}->{esx_hostname}) && $options{arguments}->{esx_hostname} eq "") {
|
||||||
|
$options{manager}->{output}->output_add(severity => 'UNKNOWN',
|
||||||
|
short_msg => "Argument error: esx hostname cannot be null");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub initArgs {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
foreach (keys %{$options{arguments}}) {
|
||||||
|
$self->{$_} = $options{arguments}->{$_};
|
||||||
|
}
|
||||||
|
$self->{manager} = centreon::esxd::common::init_response();
|
||||||
|
$self->{manager}->{output}->{plugin} = $options{arguments}->{identity};
|
||||||
|
}
|
||||||
|
|
||||||
|
sub set_connector {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{connector} = $options{connector};
|
||||||
|
}
|
||||||
|
|
||||||
|
sub run {
|
||||||
|
my $self = shift;
|
||||||
|
|
||||||
|
if ($self->{connector}->{module_date_parse_loaded} == 0) {
|
||||||
|
$self->{manager}->{output}->output_add(severity => 'UNKNOWN',
|
||||||
|
short_msg => "Need to install Date::Parse CPAN Module");
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
|
||||||
|
my %filters = ();
|
||||||
|
my $multiple = 0;
|
||||||
|
|
||||||
|
if (defined($self->{esx_hostname}) && !defined($self->{filter})) {
|
||||||
|
$filters{name} = qr/^\Q$self->{esx_hostname}\E$/;
|
||||||
|
} elsif (!defined($self->{esx_hostname})) {
|
||||||
|
$filters{name} = qr/.*/;
|
||||||
|
} else {
|
||||||
|
$filters{name} = qr/$self->{esx_hostname}/;
|
||||||
|
}
|
||||||
|
my @properties = ('name', 'configManager.dateTimeSystem', 'runtime.connectionState');
|
||||||
|
|
||||||
|
my $result = centreon::esxd::common::search_entities(command => $self, view_type => 'HostSystem', properties => \@properties, filter => \%filters);
|
||||||
|
return if (!defined($result));
|
||||||
|
|
||||||
|
$self->{manager}->{output}->output_add(severity => 'OK',
|
||||||
|
short_msg => 'Time Host(s):');
|
||||||
|
my @host_array = ();
|
||||||
|
foreach my $entity_view (@$result) {
|
||||||
|
if (centreon::esxd::common::is_connected(state => $entity_view->{'runtime.connectionState'}->{val}) == 0) {
|
||||||
|
$self->{manager}->{output}->output_add(long_msg => sprintf(" '%s' is disconnected",
|
||||||
|
$entity_view->{name}));
|
||||||
|
next;
|
||||||
|
}
|
||||||
|
if (defined($entity_view->{'configManager.dateTimeSystem'})) {
|
||||||
|
push @host_array, $entity_view->{'configManager.dateTimeSystem'};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@properties = ();
|
||||||
|
my $result2 = centreon::esxd::common::get_views($self->{connector}, \@host_array, \@properties);
|
||||||
|
return if (!defined($result2));
|
||||||
|
|
||||||
|
foreach my $entity_view (@$result) {
|
||||||
|
my $host_dts_value = $entity_view->{'configManager.dateTimeSystem'}->{value};
|
||||||
|
foreach my $host_dts_view (@$result2) {
|
||||||
|
if ($host_dts_view->{mo_ref}->{value} eq $host_dts_value) {
|
||||||
|
my $time = $host_dts_view->QueryDateTime();
|
||||||
|
my $timestamp = Date::Parse::str2time($time);
|
||||||
|
$self->{manager}->{output}->output_add(long_msg => sprintf(" '%s': unix timestamp %s, date: %s",
|
||||||
|
$entity_view->{name}, $timestamp, $time));
|
||||||
|
last;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
@ -56,6 +56,7 @@ my @load_modules = (
|
|||||||
'centreon::esxd::cmdswaphost',
|
'centreon::esxd::cmdswaphost',
|
||||||
'centreon::esxd::cmdswapvm',
|
'centreon::esxd::cmdswapvm',
|
||||||
'centreon::esxd::cmdthinprovisioningvm',
|
'centreon::esxd::cmdthinprovisioningvm',
|
||||||
|
'centreon::esxd::cmdtimehost',
|
||||||
'centreon::esxd::cmdtoolsvm',
|
'centreon::esxd::cmdtoolsvm',
|
||||||
'centreon::esxd::cmduptimehost',
|
'centreon::esxd::cmduptimehost',
|
||||||
'centreon::esxd::cmdvmoperationcluster',
|
'centreon::esxd::cmdvmoperationcluster',
|
||||||
|
Loading…
x
Reference in New Issue
Block a user