indent + manage no vm running

This commit is contained in:
garnier-quentin 2020-02-04 15:29:37 +01:00
parent 9cf9e3d165
commit 90aa222b5e
3 changed files with 45 additions and 35 deletions

View File

@ -183,11 +183,11 @@ sub connector_response_status {
$self->{output}->add_option_msg(short_msg => 'response format incorrect - need connector vmware version >= 3.x.x'); $self->{output}->add_option_msg(short_msg => 'response format incorrect - need connector vmware version >= 3.x.x');
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
foreach (('unknown_connector_status', 'warning_connector_status', 'critical_connector_status')) { foreach (('unknown_connector_status', 'warning_connector_status', 'critical_connector_status')) {
$self->{$_} =~ s/%\{(.*?)\}/\$self->{result}->{$1}/g; $self->{$_} =~ s/%\{(.*?)\}/\$self->{result}->{$1}/g;
} }
# Check response # Check response
my $status = 'ok'; my $status = 'ok';
my $message; my $message;
@ -213,8 +213,10 @@ sub connector_response_status {
if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) { if (!$self->{output}->is_status(value => $status, compare => 'ok', litteral => 1)) {
$self->{output}->output_add(long_msg => $self->{result}->{extra_message}, debug => 1); $self->{output}->output_add(long_msg => $self->{result}->{extra_message}, debug => 1);
$self->{output}->output_add(severity => $status, $self->{output}->output_add(
short_msg => $self->{result}->{short_message}); severity => $status,
short_msg => $self->{result}->{short_message}
);
$self->{output}->display(); $self->{output}->display();
$self->{output}->exit(); $self->{output}->exit();
} }

View File

@ -155,14 +155,17 @@ sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{datastore} = {}; $self->{datastore} = {};
my $response = $options{custom}->execute(params => $self->{option_results}, my $response = $options{custom}->execute(
command => 'datastoreiops'); params => $self->{option_results},
command => 'datastoreiops'
);
if ($response->{code} == 200) { if ($response->{code} == 200) {
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(
short_msg => $response->{short_message}); severity => 'OK',
short_msg => $response->{short_message}
);
return ; return ;
} }
foreach my $ds_id (keys %{$response->{data}}) { foreach my $ds_id (keys %{$response->{data}}) {

View File

@ -135,20 +135,20 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"vm-hostname:s" => { name => 'vm_hostname' }, 'vm-hostname:s' => { name => 'vm_hostname' },
"filter" => { name => 'filter' }, 'filter' => { name => 'filter' },
"scope-datacenter:s" => { name => 'scope_datacenter' }, 'scope-datacenter:s' => { name => 'scope_datacenter' },
"scope-cluster:s" => { name => 'scope_cluster' }, 'scope-cluster:s' => { name => 'scope_cluster' },
"scope-host:s" => { name => 'scope_host' }, 'scope-host:s' => { name => 'scope_host' },
"filter-description:s" => { name => 'filter_description' }, 'filter-description:s' => { name => 'filter_description' },
"filter-os:s" => { name => 'filter_os' }, 'filter-os:s' => { name => 'filter_os' },
"filter-uuid:s" => { name => 'filter_uuid' }, 'filter-uuid:s' => { name => 'filter_uuid' },
"display-description" => { name => 'display_description' }, 'display-description' => { name => 'display_description' },
"datastore-name:s" => { name => 'datastore_name' }, 'datastore-name:s' => { name => 'datastore_name' },
"filter-datastore:s" => { name => 'filter_datastore' }, 'filter-datastore:s' => { name => 'filter_datastore' },
"unknown-status:s" => { name => 'unknown_status', default => '%{connection_state} !~ /^connected$/i or %{power_state} !~ /^poweredOn$/i' }, 'unknown-status:s' => { name => 'unknown_status', default => '%{connection_state} !~ /^connected$/i or %{power_state} !~ /^poweredOn$/i' },
"warning-status:s" => { name => 'warning_status', default => '' }, 'warning-status:s' => { name => 'warning_status', default => '' },
"critical-status:s" => { name => 'critical_status', default => '' }, 'critical-status:s' => { name => 'critical_status', default => '' },
}); });
return $self; return $self;
@ -157,7 +157,7 @@ sub new {
sub check_options { sub check_options {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->SUPER::check_options(%options); $self->SUPER::check_options(%options);
$self->change_macros(macros => ['unknown_status', 'warning_status', 'critical_status']); $self->change_macros(macros => ['unknown_status', 'warning_status', 'critical_status']);
} }
@ -165,8 +165,18 @@ sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{vm} = {}; $self->{vm} = {};
my $response = $options{custom}->execute(params => $self->{option_results}, my $response = $options{custom}->execute(
command => 'datastorevm'); params => $self->{option_results},
command => 'datastorevm'
);
if ($response->{code} == 200) {
$self->{output}->output_add(
severity => 'OK',
short_msg => $response->{short_message}
);
return ;
}
foreach my $vm_id (keys %{$response->{data}}) { foreach my $vm_id (keys %{$response->{data}}) {
my $vm_name = $response->{data}->{$vm_id}->{name}; my $vm_name = $response->{data}->{$vm_id}->{name};
@ -181,11 +191,11 @@ sub manage_selection {
total_latency => $response->{data}->{$vm_id}->{'disk.maxTotalLatency.latest'}, total_latency => $response->{data}->{$vm_id}->{'disk.maxTotalLatency.latest'},
}, },
}; };
if (defined($self->{option_results}->{display_description})) { if (defined($self->{option_results}->{display_description})) {
$self->{vm}->{$vm_name}->{config_annotation} = $options{custom}->strip_cr(value => $response->{data}->{$vm_id}->{'config.annotation'}); $self->{vm}->{$vm_name}->{config_annotation} = $options{custom}->strip_cr(value => $response->{data}->{$vm_id}->{'config.annotation'});
} }
foreach my $ds_name (sort keys %{$response->{data}->{$vm_id}->{datastore}}) { foreach my $ds_name (sort keys %{$response->{data}->{$vm_id}->{datastore}}) {
$self->{vm}->{$vm_name}->{datastore}->{$ds_name} = { display => $ds_name, $self->{vm}->{$vm_name}->{datastore}->{$ds_name} = { display => $ds_name,
read => $response->{data}->{$vm_id}->{datastore}->{$ds_name}->{'disk.numberRead.summation'}, read => $response->{data}->{$vm_id}->{datastore}->{$ds_name}->{'disk.numberRead.summation'},
@ -262,14 +272,9 @@ Can used special variables like: %{connection_state}, %{power_state}
Set critical threshold for status (Default: ''). Set critical threshold for status (Default: '').
Can used special variables like: %{connection_state}, %{power_state} Can used special variables like: %{connection_state}, %{power_state}
=item B<--warning-*> =item B<--warning-*> B<--critical-*>
Threshold warning. Thresholds.
Can be: 'max-total-latency', 'read', 'write'.
=item B<--critical-*>
Threshold critical.
Can be: 'max-total-latency', 'read', 'write'. Can be: 'max-total-latency', 'read', 'write'.
=back =back