mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-30 00:55:18 +02:00
parent
07f8d27926
commit
42e5359e0d
@ -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});
|
||||
}
|
||||
|
159
centreon-plugins/storage/purestorage/restapi/mode/arrays.pm
Normal file
159
centreon-plugins/storage/purestorage/restapi/mode/arrays.pm
Normal 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
|
@ -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' }
|
||||
]
|
||||
}
|
||||
},
|
||||
}
|
||||
];
|
||||
}
|
||||
|
||||
|
@ -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',
|
||||
|
Loading…
x
Reference in New Issue
Block a user