indent + manage no vm running
This commit is contained in:
parent
9cf9e3d165
commit
90aa222b5e
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
|
@ -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}}) {
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue