fix emc unisphere rest api plugin
This commit is contained in:
parent
794623fa3f
commit
19fc6affce
|
@ -27,7 +27,7 @@ use storage::emc::unisphere::restapi::mode::components::resources qw($health_sta
|
|||
sub load {
|
||||
my ($self) = @_;
|
||||
|
||||
$self->{json_results}->{battery} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/battery/instances');
|
||||
$self->{json_results}->{battery} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/battery/instances?fields=name,health');
|
||||
}
|
||||
|
||||
sub check {
|
||||
|
|
|
@ -27,7 +27,7 @@ use storage::emc::unisphere::restapi::mode::components::resources qw($health_sta
|
|||
sub load {
|
||||
my ($self) = @_;
|
||||
|
||||
$self->{json_results}->{disks} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/disk/instances');
|
||||
$self->{json_results}->{disks} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/disk/instances?fields=name,health');
|
||||
}
|
||||
|
||||
sub check {
|
||||
|
|
|
@ -27,7 +27,7 @@ use storage::emc::unisphere::restapi::mode::components::resources qw($health_sta
|
|||
sub load {
|
||||
my ($self) = @_;
|
||||
|
||||
$self->{json_results}->{dpe} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/dpe/instances');
|
||||
$self->{json_results}->{dpe} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/dpe/instances?fields=name,health,currentPower,currentTemperature');
|
||||
}
|
||||
|
||||
sub check {
|
||||
|
|
|
@ -27,7 +27,7 @@ use storage::emc::unisphere::restapi::mode::components::resources qw($health_sta
|
|||
sub load {
|
||||
my ($self) = @_;
|
||||
|
||||
$self->{json_results}->{fans} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/fan/instances');
|
||||
$self->{json_results}->{fans} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/fan/instances?fields=health');
|
||||
}
|
||||
|
||||
sub check {
|
||||
|
|
|
@ -27,7 +27,7 @@ use storage::emc::unisphere::restapi::mode::components::resources qw($health_sta
|
|||
sub load {
|
||||
my ($self) = @_;
|
||||
|
||||
$self->{json_results}->{iomodules} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/ioModule/instances');
|
||||
$self->{json_results}->{iomodules} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/ioModule/instances?fields=name,health');
|
||||
}
|
||||
|
||||
sub check {
|
||||
|
|
|
@ -27,7 +27,7 @@ use storage::emc::unisphere::restapi::mode::components::resources qw($health_sta
|
|||
sub load {
|
||||
my ($self) = @_;
|
||||
|
||||
$self->{json_results}->{psus} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/powerSupply/instances');
|
||||
$self->{json_results}->{psus} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/powerSupply/instances?fields=name,health');
|
||||
}
|
||||
|
||||
sub check {
|
||||
|
|
|
@ -27,7 +27,7 @@ use storage::emc::unisphere::restapi::mode::components::resources qw($health_sta
|
|||
sub load {
|
||||
my ($self) = @_;
|
||||
|
||||
$self->{json_results}->{sp} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/storageProcessor/instances');
|
||||
$self->{json_results}->{sp} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/storageProcessor/instances?fields=health');
|
||||
}
|
||||
|
||||
sub check {
|
||||
|
|
|
@ -27,7 +27,7 @@ use storage::emc::unisphere::restapi::mode::components::resources qw($health_sta
|
|||
sub load {
|
||||
my ($self) = @_;
|
||||
|
||||
$self->{json_results}->{ssd} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/ssd/instances');
|
||||
$self->{json_results}->{ssd} = $self->{custom}->request_api(method => 'GET', url_path => '/api/types/ssd/instances?fields=health');
|
||||
}
|
||||
|
||||
sub check {
|
||||
|
|
|
@ -46,7 +46,7 @@ sub check_options {
|
|||
sub manage_selection {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
return $options{custom}->request_api(url_path => '/api/types/pool/instances');
|
||||
return $options{custom}->request_api(url_path => '/api/types/pool/instances?fields=name,health');
|
||||
}
|
||||
|
||||
sub run {
|
||||
|
|
|
@ -46,7 +46,7 @@ sub check_options {
|
|||
sub manage_selection {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
return $options{custom}->request_api(url_path => '/api/types/storageResource/instances');
|
||||
return $options{custom}->request_api(url_path => '/api/types/storageResource/instances?fields=name,health');
|
||||
}
|
||||
|
||||
sub run {
|
||||
|
|
|
@ -159,7 +159,7 @@ sub prefix_pool_output {
|
|||
sub manage_selection {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
my $results = $options{custom}->request_api(url_path => '/api/types/pool/instances');
|
||||
my $results = $options{custom}->request_api(url_path => '/api/types/pool/instances?fields=name,sizeFree,sizeSubscribed,sizeTotal,health');
|
||||
|
||||
$self->{pool} = {};
|
||||
foreach (@{$results->{entries}}) {
|
||||
|
|
|
@ -68,7 +68,7 @@ sub set_counters {
|
|||
my ($self, %options) = @_;
|
||||
|
||||
$self->{maps_counters_type} = [
|
||||
{ name => 'sr', type => 1, cb_prefix_output => 'prefix_sr_output', message_multiple => 'All storage resources are ok' },
|
||||
{ name => 'sr', type => 1, cb_prefix_output => 'prefix_sr_output', message_multiple => 'All storage resources are ok', skipped_code => { -10 => 1 } },
|
||||
];
|
||||
|
||||
$self->{maps_counters}->{sr} = [
|
||||
|
@ -159,7 +159,7 @@ sub prefix_sr_output {
|
|||
sub manage_selection {
|
||||
my ($self, %options) = @_;
|
||||
|
||||
my $results = $options{custom}->request_api(url_path => '/api/types/storageResource/instances');
|
||||
my $results = $options{custom}->request_api(url_path => '/api/types/storageResource/instances?fields=name,health,sizeUsed,sizeAllocated,sizeTotal');
|
||||
|
||||
$self->{sr} = {};
|
||||
foreach (@{$results->{entries}}) {
|
||||
|
@ -173,16 +173,20 @@ sub manage_selection {
|
|||
display => $_->{content}->{name},
|
||||
status => $health_status->{ $_->{content}->{health}->{value} },
|
||||
total_space => $_->{content}->{sizeTotal},
|
||||
used_space => $_->{content}->{sizeUsed},
|
||||
free_space => $_->{content}->{sizeTotal} - $_->{content}->{sizeUsed},
|
||||
prct_used_space => $_->{content}->{sizeUsed} * 100 / $_->{content}->{sizeTotal},
|
||||
prct_free_space => 100 - ($_->{content}->{sizeUsed} * 100 / $_->{content}->{sizeTotal}),
|
||||
|
||||
used_alloc => $_->{content}->{sizeAllocated},
|
||||
free_alloc => $_->{content}->{sizeTotal} - $_->{content}->{sizeAllocated},
|
||||
prct_used_alloc => $_->{content}->{sizeAllocated} * 100 / $_->{content}->{sizeTotal},
|
||||
prct_free_alloc => 100 - ($_->{content}->{sizeAllocated} * 100 / $_->{content}->{sizeTotal}),
|
||||
};
|
||||
|
||||
if (defined($_->{content}->{sizeUsed})) {
|
||||
$self->{sr}->{$_->{content}->{id}}->{used_space} = $_->{content}->{sizeUsed};
|
||||
$self->{sr}->{$_->{content}->{id}}->{free_space} = $_->{content}->{sizeTotal} - $_->{content}->{sizeUsed};
|
||||
$self->{sr}->{$_->{content}->{id}}->{prct_used_space} = $_->{content}->{sizeUsed} * 100 / $_->{content}->{sizeTotal};
|
||||
$self->{sr}->{$_->{content}->{id}}->{prct_free_space} = 100 - ($_->{content}->{sizeUsed} * 100 / $_->{content}->{sizeTotal});
|
||||
}
|
||||
if (defined($_->{content}->{sizeAllocated})) {
|
||||
$self->{sr}->{$_->{content}->{id}}->{used_alloc} = $_->{content}->{sizeAllocated};
|
||||
$self->{sr}->{$_->{content}->{id}}->{free_alloc} = $_->{content}->{sizeTotal} - $_->{content}->{sizeAllocated};
|
||||
$self->{sr}->{$_->{content}->{id}}->{prct_used_alloc} = $_->{content}->{sizeAllocated} * 100 / $_->{content}->{sizeTotal};
|
||||
$self->{sr}->{$_->{content}->{id}}->{prct_free_alloc} = 100 - ($_->{content}->{sizeAllocated} * 100 / $_->{content}->{sizeTotal});
|
||||
}
|
||||
}
|
||||
|
||||
if (scalar(keys %{$self->{sr}}) <= 0) {
|
||||
|
|
Loading…
Reference in New Issue