This commit is contained in:
qgarnier 2020-10-20 11:05:41 +02:00 committed by GitHub
parent 07f8d27926
commit 42e5359e0d
4 changed files with 192 additions and 21 deletions

View File

@ -45,7 +45,10 @@ sub new {
'username:s' => { name => 'username' },
'password:s' => { name => 'password' },
'timeout:s' => { name => 'timeout' },
'api-path:s' => { name => 'api_path' }
'api-path:s' => { name => 'api_path' },
'unknown-http-status:s' => { name => 'unknown_http_status' },
'warning-http-status:s' => { name => 'warning_http_status' },
'critical-http-status:s' => { name => 'critical_http_status' }
});
}
$options{options}->add_help(package => __PACKAGE__, sections => 'REST API OPTIONS', once => 1);
@ -72,6 +75,9 @@ sub check_options {
$self->{password} = (defined($self->{option_results}->{password})) ? $self->{option_results}->{password} : undef;
$self->{timeout} = (defined($self->{option_results}->{timeout})) ? $self->{option_results}->{timeout} : 10;
$self->{api_path} = (defined($self->{option_results}->{api_path})) ? $self->{option_results}->{api_path} : '/api/1.11';
$self->{unknown_http_status} = (defined($self->{option_results}->{unknown_http_status})) ? $self->{option_results}->{unknown_http_status} : '%{http_code} < 200 or %{http_code} >= 300';
$self->{warning_http_status} = (defined($self->{option_results}->{warning_http_status})) ? $self->{option_results}->{warning_http_status} : '';
$self->{critical_http_status} = (defined($self->{option_results}->{critical_http_status})) ? $self->{option_results}->{critical_http_status} : '';
if (!defined($self->{hostname})) {
$self->{output}->add_option_msg(short_msg => "Need to specify hostname option.");
@ -119,22 +125,23 @@ sub settings {
sub request_api {
my ($self, %options) = @_;
my $content = $self->{http}->request(method => $options{method}, url_path => $options{url_path}, query_form_post => $options{query_form_post},
critical_status => '', warning_status => '', unknown_status => '');
my $content = $self->{http}->request(
method => $options{method},
url_path => $options{url_path},
query_form_post => $options{query_form_post},
unknown_status => $self->{unknown_http_status},
warning_status => $self->{warning_http_status},
critical_status => $self->{critical_http_status}
);
my $decoded;
eval {
$decoded = decode_json($content);
};
if ($@) {
$self->{output}->output_add(long_msg => $content, debug => 1);
$self->{output}->add_option_msg(short_msg => "Cannot decode json response");
$self->{output}->option_exit();
}
if ($self->{http}->get_code() != 200) {
$self->{output}->add_option_msg(short_msg => "Connection issue: " . $decoded->{msg});
$self->{output}->option_exit();
}
return $decoded;
}
@ -153,7 +160,11 @@ sub get_api_token {
}
$self->settings();
my $decoded = $self->request_api(method => 'POST', url_path => $self->{api_path} . '/auth/apitoken', query_form_post => $encoded);
my $decoded = $self->request_api(
method => 'POST',
url_path => $self->{api_path} . '/auth/apitoken',
query_form_post => $encoded
);
if (!defined($decoded->{api_token})) {
$self->{output}->add_option_msg(short_msg => "Cannot get api token");
$self->{output}->option_exit();
@ -200,7 +211,7 @@ sub get_object {
if (!defined($self->{api_token})) {
$self->connect();
}
$self->settings();
return $self->request_api(method => 'GET', url_path => $self->{api_path} . $options{path});
}

View File

@ -0,0 +1,159 @@
#
# Copyright 2020 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 storage::purestorage::restapi::mode::arrays;
use base qw(centreon::plugins::templates::counter);
use strict;
use warnings;
sub custom_usage_output {
my ($self, %options) = @_;
my ($total_size_value, $total_size_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{total});
my ($total_used_value, $total_used_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{used});
my ($total_free_value, $total_free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
return sprintf(
'space usage total: %s used: %s (%.2f%%) free: %s (%.2f%%)',
$total_size_value . " " . $total_size_unit,
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used},
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free}
);
}
sub prefix_array_output {
my ($self, %options) = @_;
return "Array '" . $options{instance_value}->{display} . "' ";
}
sub set_counters {
my ($self, %options) = @_;
$self->{maps_counters_type} = [
{ name => 'arrays', type => 1, cb_prefix_output => 'prefix_array_output', message_multiple => 'All arrays are ok' }
];
$self->{maps_counters}->{arrays} = [
{ label => 'space-usage', nlabel => 'array.space.usage.bytes', set => {
key_values => [ { name => 'used' }, { name => 'free' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ],
closure_custom_output => $self->can('custom_usage_output'),
perfdatas => [
{ template => '%d', min => 0, max => 'total', unit => 'B', cast_int => 1, label_extra_instance => 1 }
]
}
},
{ label => 'space-usage-free', display_ok => 0, nlabel => 'array.space.free.bytes', set => {
key_values => [ { name => 'free' }, { name => 'used' }, { name => 'prct_used' }, { name => 'prct_free' }, { name => 'total' } ],
closure_custom_output => $self->can('custom_usage_output'),
perfdatas => [
{ template => '%d', min => 0, max => 'total', unit => 'B', cast_int => 1, label_extra_instance => 1 }
]
}
},
{ label => 'space-usage-prct', display_ok => 0, nlabel => 'array.space.usage.percentage', set => {
key_values => [ { name => 'prct_used' }, { name => 'used' }, { name => 'free' }, { name => 'prct_free' }, { name => 'total' } ],
closure_custom_output => $self->can('custom_usage_output'),
perfdatas => [
{ template => '%.2f', min => 0, max => 100, unit => '%', label_extra_instance => 1 }
]
}
},
{ label => 'data-reduction', nlabel => 'array.data.reduction.count', set => {
key_values => [ { name => 'data_reduction' } ],
output_template => 'data reduction: %.3f',
perfdatas => [
{ template => '%.3f', min => 0, label_extra_instance => 1 }
]
}
}
];
}
sub new {
my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
bless $self, $class;
$options{options}->add_options(arguments => {
'filter-name:s' => { name => 'filter_name' }
});
return $self;
}
sub manage_selection {
my ($self, %options) = @_;
my $results = $options{custom}->get_object(path => '/volume?space=true');
#[
# {"parity": 1.0, "capacity": 90089907364616, "provisioned": 98155035099136, "hostname": "frparadm224", "system": 0, "snapshots": 51928476177070, "volumes": 18963118791241, "data_reduction": 2.116144198166552, "total": 84076618640795, "shared_space": 13185023672484, "thin_provisioning": 0.5184735201906719, "total_reduction": 4.394658003033373}
# ...
#]
$self->{arrays} = {};
foreach my $entry (@$results) {
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
$entry->{hostname} !~ /$self->{option_results}->{filter_name}/) {
$self->{output}->output_add(long_msg => "skipping '" . $entry->{hostname} . "': no matching filter.", debug => 1);
next;
}
$self->{arrays}->{ $entry->{hostname} } = {
display => $entry->{hostname},
data_reduction => $entry->{data_reduction},
total => $entry->{capacity},
used => $entry->{total},
free => $entry->{capacity} - $entry->{total},
prct_used => $entry->{total} * 100 / $entry->{capacity},
prct_free => (100 - ($entry->{total} * 100 / $entry->{capacity}))
};
}
}
1;
__END__
=head1 MODE
Check arrays.
=over 8
=item B<--filter-counters>
Only display some counters (regexp can be used).
Example: --filter-counters='data-reduction'
=item B<--filter-name>
Filter arrays by name (can be a regexp).
=item B<--warning-*> B<--critical-*>
Thresholds.
Can be: 'space-usage' (B), 'space-usage-free' (B), 'space-usage-prct' (%),
'data-reduction'.
=back
=cut

View File

@ -104,25 +104,25 @@ sub set_counters {
closure_custom_calc => $self->can('custom_usage_calc'),
closure_custom_output => $self->can('custom_usage_output'),
closure_custom_perfdata => $self->can('custom_usage_perfdata'),
closure_custom_threshold_check => $self->can('custom_usage_threshold'),
closure_custom_threshold_check => $self->can('custom_usage_threshold')
}
},
{ label => 'data-reduction', set => {
key_values => [ { name => 'data_reduction' }, { name => 'display' } ],
output_template => 'Data Reduction : %.3f',
perfdatas => [
{ label => 'data_reduction', value => 'data_reduction', template => '%.3f',
min => 0, label_extra_instance => 1, instance_use => 'display' },
],
{ label => 'data_reduction', template => '%.3f',
min => 0, label_extra_instance => 1, instance_use => 'display' }
]
}
},
{ label => 'total-reduction', set => {
key_values => [ { name => 'total_reduction' }, { name => 'display' } ],
output_template => 'Total Reduction : %.3f',
perfdatas => [
{ label => 'total_reduction', value => 'total_reduction', template => '%.3f',
min => 0, label_extra_instance => 1, instance_use => 'display' },
],
{ label => 'total_reduction', template => '%.3f',
min => 0, label_extra_instance => 1, instance_use => 'display' }
]
}
},
{ label => 'snapshots', set => {
@ -130,11 +130,11 @@ sub set_counters {
output_template => 'Snapshots : %s %s',
output_change_bytes => 1,
perfdatas => [
{ label => 'snapshots', value => 'snapshots', template => '%s',
unit => 'B', min => 0, label_extra_instance => 1, instance_use => 'display' },
],
{ label => 'snapshots', template => '%s',
unit => 'B', min => 0, label_extra_instance => 1, instance_use => 'display' }
]
}
},
}
];
}

View File

@ -32,6 +32,7 @@ sub new {
$self->{version} = '0.1';
$self->{modes} = {
'alarms' => 'storage::purestorage::restapi::mode::alarms',
'arrays' => 'storage::purestorage::restapi::mode::arrays',
'hardware' => 'storage::purestorage::restapi::mode::hardware',
'list-pgroups' => 'storage::purestorage::restapi::mode::listpgroups',
'list-volumes' => 'storage::purestorage::restapi::mode::listvolumes',