In Progress
This commit is contained in:
garnier-quentin 2014-04-27 11:41:26 +02:00
parent 43316f9dee
commit fcee8ab7d4
7 changed files with 86 additions and 65 deletions

View File

@ -195,6 +195,7 @@ sub explode_perfdatas {
sub output_json { sub output_json {
my ($self, %options) = @_; my ($self, %options) = @_;
my $force_ignore_perfdata = (defined($options{force_ignore_perfdata}) && $options{force_ignore_perfdata} == 1) ? 1 : 0; my $force_ignore_perfdata = (defined($options{force_ignore_perfdata}) && $options{force_ignore_perfdata} == 1) ? 1 : 0;
my $force_long_output = (defined($options{force_long_output}) && $options{force_long_output} == 1) ? 1 : 0;
my $json_content = {plugin => { my $json_content = {plugin => {
name => $self->{plugin}, name => $self->{plugin},
mode => $self->{mode}, mode => $self->{mode},
@ -217,7 +218,7 @@ sub output_json {
} }
} }
if (defined($self->{option_results}->{verbose}) || defined($options{force_long_output})) { if (defined($self->{option_results}->{verbose}) || $force_long_output == 1) {
foreach (@{$self->{global_long_output}}) { foreach (@{$self->{global_long_output}}) {
push @{$json_content->{plugin}->{outputs}}, { push @{$json_content->{plugin}->{outputs}}, {
type => 2, type => 2,
@ -249,6 +250,7 @@ sub output_json {
sub output_xml { sub output_xml {
my ($self, %options) = @_; my ($self, %options) = @_;
my $force_ignore_perfdata = (defined($options{force_ignore_perfdata}) && $options{force_ignore_perfdata} == 1) ? 1 : 0; my $force_ignore_perfdata = (defined($options{force_ignore_perfdata}) && $options{force_ignore_perfdata} == 1) ? 1 : 0;
my $force_long_output = (defined($options{force_long_output}) && $options{force_long_output} == 1) ? 1 : 0;
my ($child_plugin_name, $child_plugin_mode, $child_plugin_exit, $child_plugin_output, $child_plugin_perfdata); my ($child_plugin_name, $child_plugin_mode, $child_plugin_exit, $child_plugin_output, $child_plugin_perfdata);
my $root = $self->{xml_output}->createElement('plugin'); my $root = $self->{xml_output}->createElement('plugin');
@ -294,7 +296,7 @@ sub output_xml {
} }
} }
if (defined($self->{option_results}->{verbose}) || defined($options{force_long_output})) { if (defined($self->{option_results}->{verbose}) || $force_long_output == 1) {
foreach (@{$self->{global_long_output}}) { foreach (@{$self->{global_long_output}}) {
my ($child_output, $child_type, $child_msg); my ($child_output, $child_type, $child_msg);
@ -335,6 +337,7 @@ sub output_xml {
sub output_txt { sub output_txt {
my ($self, %options) = @_; my ($self, %options) = @_;
my $force_ignore_perfdata = (defined($options{force_ignore_perfdata}) && $options{force_ignore_perfdata} == 1) ? 1 : 0; my $force_ignore_perfdata = (defined($options{force_ignore_perfdata}) && $options{force_ignore_perfdata} == 1) ? 1 : 0;
my $force_long_output = (defined($options{force_long_output}) && $options{force_long_output} == 1) ? 1 : 0;
if (defined($self->{global_short_concat_outputs}->{UNQUALIFIED_YET})) { if (defined($self->{global_short_concat_outputs}->{UNQUALIFIED_YET})) {
$self->output_add(severity => uc($options{exit_litteral}), short_msg => $self->{global_short_concat_outputs}->{UNQUALIFIED_YET}); $self->output_add(severity => uc($options{exit_litteral}), short_msg => $self->{global_short_concat_outputs}->{UNQUALIFIED_YET});
@ -366,7 +369,7 @@ sub output_txt {
print "\n"; print "\n";
} }
if (defined($self->{option_results}->{verbose}) || defined($options{force_long_output})) { if (defined($self->{option_results}->{verbose}) || $force_long_output == 1) {
if (scalar(@{$self->{global_long_output}})) { if (scalar(@{$self->{global_long_output}})) {
print join("\n", @{$self->{global_long_output}}); print join("\n", @{$self->{global_long_output}});
print "\n"; print "\n";
@ -378,25 +381,29 @@ sub display {
my ($self, %options) = @_; my ($self, %options) = @_;
my $nolabel = defined($options{nolabel}) ? 1 : 0; my $nolabel = defined($options{nolabel}) ? 1 : 0;
my $force_ignore_perfdata = (defined($options{force_ignore_perfdata}) && $options{force_ignore_perfdata} == 1) ? 1 : 0; my $force_ignore_perfdata = (defined($options{force_ignore_perfdata}) && $options{force_ignore_perfdata} == 1) ? 1 : 0;
my $force_long_output = (defined($options{force_long_output}) && $options{force_long_output} == 1) ? 1 : 0;
if (defined($self->{option_results}->{output_xml})) { if (defined($self->{option_results}->{output_xml})) {
$self->create_xml_document(); $self->create_xml_document();
if ($self->{is_output_xml}) { if ($self->{is_output_xml}) {
$self->output_xml(exit_litteral => $self->get_litteral_status(), $self->output_xml(exit_litteral => $self->get_litteral_status(),
nolabel => $nolabel, force_ignore_perfdata => $force_ignore_perfdata); nolabel => $nolabel,
force_ignore_perfdata => $force_ignore_perfdata, force_long_output => $force_long_output);
return ; return ;
} }
} elsif (defined($self->{option_results}->{output_json})) { } elsif (defined($self->{option_results}->{output_json})) {
$self->create_json_document(); $self->create_json_document();
if ($self->{is_output_json}) { if ($self->{is_output_json}) {
$self->output_json(exit_litteral => $self->get_litteral_status(), $self->output_json(exit_litteral => $self->get_litteral_status(),
nolabel => $nolabel, force_ignore_perfdata => $force_ignore_perfdata); nolabel => $nolabel,
force_ignore_perfdata => $force_ignore_perfdata, force_long_output => $force_long_output);
return ; return ;
} }
} }
$self->output_txt(exit_litteral => $self->get_litteral_status(), $self->output_txt(exit_litteral => $self->get_litteral_status(),
nolabel => $nolabel, force_ignore_perfdata => $force_ignore_perfdata); nolabel => $nolabel,
force_ignore_perfdata => $force_ignore_perfdata, force_long_output => $force_long_output);
} }
sub die_exit { sub die_exit {

View File

@ -87,12 +87,20 @@ sub manage_selection {
$states .= 'R' if ($values =~ /RUNNING/ms); $states .= 'R' if ($values =~ /RUNNING/ms);
$states .= 'U' if ($values =~ /UP/ms); $states .= 'U' if ($values =~ /UP/ms);
next if (defined($self->{option_results}->{no_loopback}) && $values =~ /LOOPBACK/ms); if (defined($self->{option_results}->{no_loopback}) && $values =~ /LOOPBACK/ms) {
next if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' && $self->{output}->output_add(long_msg => "Skipping interface '" . $interface_name . "': option --no-loopback");
$interface_name !~ /$self->{option_results}->{filter_name}/); next;
next if (defined($self->{option_results}->{filter_state}) && $self->{option_results}->{filter_state} ne '' && }
$states !~ /$self->{option_results}->{filter_state}/); if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
$interface_name !~ /$self->{option_results}->{filter_name}/) {
$self->{output}->output_add(long_msg => "Skipping interface '" . $interface_name . "': no matching filter name");
next;
}
if (defined($self->{option_results}->{filter_state}) && $self->{option_results}->{filter_state} ne '' &&
$states !~ /$self->{option_results}->{filter_state}/) {
$self->{output}->output_add(long_msg => "Skipping interface '" . $interface_name . "': no matching filter state");
next;
}
$self->{result}->{$interface_name} = {state => $states}; $self->{result}->{$interface_name} = {state => $states};
} }
} }
@ -101,16 +109,13 @@ sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->manage_selection(); $self->manage_selection();
my $interfaces_display = '';
my $interfaces_display_append = '';
foreach my $name (sort(keys %{$self->{result}})) { foreach my $name (sort(keys %{$self->{result}})) {
$interfaces_display .= $interfaces_display_append . 'name = ' . $name . ' [state = ' . $self->{result}->{$name}->{state} . ']'; $self->{output}->output_add(long_msg => "'" . $name . "' [state = " . $self->{result}->{$name}->{state} . ']');
$interfaces_display_append = ', ';
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List interfaces: ' . $interfaces_display); short_msg => 'List interfaces:');
$self->{output}->display(nolabel => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }

View File

@ -86,8 +86,11 @@ sub manage_selection {
next if ($line !~ /^\s*(\S+)\s+(\S+)\s+(\S+)\s+(\S+)/); next if ($line !~ /^\s*(\S+)\s+(\S+)\s+(\S+)\s+(\S+)/);
my ($major, $minor, $blocks, $name) = ($1, $2, $3, $4); my ($major, $minor, $blocks, $name) = ($1, $2, $3, $4);
next if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' && if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
$name !~ /$self->{option_results}->{filter_name}/); $name !~ /$self->{option_results}->{filter_name}/) {
$self->{output}->output_add(long_msg => "Skipping partition '" . $name . "': no matching filter name");
next;
}
$self->{result}->{$name} = 1; $self->{result}->{$name} = 1;
} }
@ -97,16 +100,13 @@ sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->manage_selection(); $self->manage_selection();
my $partitions_display = '';
my $partitions_display_append = '';
foreach my $name (sort(keys %{$self->{result}})) { foreach my $name (sort(keys %{$self->{result}})) {
$partitions_display .= $partitions_display_append . 'name = ' . $name; $self->{output}->output_add(long_msg => "'" . $name . "'");
$partitions_display_append = ', ';
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List partitions: ' . $partitions_display); short_msg => 'List partitions:');
$self->{output}->display(nolabel => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }

View File

@ -88,12 +88,21 @@ sub manage_selection {
next if ($line !~ /^(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(.*)/); next if ($line !~ /^(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(\S+)\s+(.*)/);
my ($fs, $type, $size, $used, $available, $percent, $mount) = ($1, $2, $3, $4, $5, $6, $7); my ($fs, $type, $size, $used, $available, $percent, $mount) = ($1, $2, $3, $4, $5, $6, $7);
next if (defined($self->{option_results}->{filter_fs}) && $self->{option_results}->{filter_fs} ne '' && if (defined($self->{option_results}->{filter_fs}) && $self->{option_results}->{filter_fs} ne '' &&
$fs !~ /$self->{option_results}->{filter_fs}/); $fs !~ /$self->{option_results}->{filter_fs}/) {
next if (defined($self->{option_results}->{filter_type}) && $self->{option_results}->{filter_type} ne '' && $self->{output}->output_add(long_msg => "Skipping storage '" . $mount . "': no matching filter filesystem");
$type !~ /$self->{option_results}->{filter_type}/); next;
next if (defined($self->{option_results}->{filter_mount}) && $self->{option_results}->{filter_mount} ne '' && }
$mount !~ /$self->{option_results}->{filter_mount}/); if (defined($self->{option_results}->{filter_type}) && $self->{option_results}->{filter_type} ne '' &&
$type !~ /$self->{option_results}->{filter_type}/) {
$self->{output}->output_add(long_msg => "Skipping storage '" . $mount . "': no matching filter filesystem type");
next;
}
if (defined($self->{option_results}->{filter_mount}) && $self->{option_results}->{filter_mount} ne '' &&
$mount !~ /$self->{option_results}->{filter_mount}/) {
$self->{output}->output_add(long_msg => "Skipping storage '" . $mount . "': no matching filter mount point");
next;
}
$self->{result}->{$mount} = {fs => $fs, type => $type}; $self->{result}->{$mount} = {fs => $fs, type => $type};
} }
@ -103,16 +112,13 @@ sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->manage_selection(); $self->manage_selection();
my $storages_display = '';
my $storages_display_append = '';
foreach my $name (sort(keys %{$self->{result}})) { foreach my $name (sort(keys %{$self->{result}})) {
$storages_display .= $storages_display_append . 'name = ' . $name . ' [fs = ' . $self->{result}->{$name}->{fs} . ', type = ' . $self->{result}->{$name}->{type} . ']'; $self->{output}->output_add(long_msg => "'" . $name . "' [fs = " . $self->{result}->{$name}->{fs} . ', type = ' . $self->{result}->{$name}->{type} . ']');
$storages_display_append = ', ';
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List storages: ' . $storages_display); short_msg => 'List storages:');
$self->{output}->display(nolabel => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }

View File

@ -79,22 +79,23 @@ sub run {
$self->manage_selection(); $self->manage_selection();
my $result = $self->get_additional_information(); my $result = $self->get_additional_information();
my $diskpath_display = '';
my $diskpath_display_append = '';
foreach (sort @{$self->{diskpath_id_selected}}) { foreach (sort @{$self->{diskpath_id_selected}}) {
if (defined($result)) {
my $total_size = (($result->{$oid_dskTotalHigh . "." . $_} << 32) + $result->{$oid_dskTotalLow . "." . $_});
next if ($total_size == 0);
}
my $display_value = $self->get_display_value(id => $_); my $display_value = $self->get_display_value(id => $_);
$diskpath_display .= $diskpath_display_append . "name = $display_value [id = $_]"; if (defined($result)) {
$diskpath_display_append = ', '; my $total_size = (($result->{$oid_dskTotalHigh . "." . $_} << 32) + $result->{$oid_dskTotalLow . "." . $_});
if ($total_size == 0) {
$self->{output}->output_add(long_msg => "Skipping disk path '" . $display_value . "': size is 0");
next;
}
}
$self->{output}->output_add(long_msg => "'" . $display_value . "' [id = " . $_ . ']');
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List disk path: ' . $diskpath_display); short_msg => 'List disk path:');
$self->{output}->display(nolabel => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }

View File

@ -103,8 +103,6 @@ sub run {
$self->manage_selection(); $self->manage_selection();
my $result = $self->get_additional_information(); my $result = $self->get_additional_information();
my $interfaces_display = '';
my $interfaces_display_append = '';
foreach (sort @{$self->{interface_id_selected}}) { foreach (sort @{$self->{interface_id_selected}}) {
my $display_value = $self->get_display_value(id => $_); my $display_value = $self->get_display_value(id => $_);
@ -113,21 +111,25 @@ sub run {
$interface_speed = $self->{option_results}->{speed}; $interface_speed = $self->{option_results}->{speed};
} }
next if (defined($self->{option_results}->{skip_speed0}) && $interface_speed == 0); if (defined($self->{option_results}->{skip_speed0}) && $interface_speed == 0) {
$self->{output}->output_add(long_msg => "Skipping interface '" . $display_value . "': interface speed is 0 and option --skip-speed0 is set");
next;
}
if (defined($self->{option_results}->{filter_status}) && $operstatus[$result->{$oid_operstatus . "." . $_} - 1] !~ /$self->{option_results}->{filter_status}/i) { if (defined($self->{option_results}->{filter_status}) && $operstatus[$result->{$oid_operstatus . "." . $_} - 1] !~ /$self->{option_results}->{filter_status}/i) {
$self->{output}->output_add(long_msg => "Skipping interface '" . $display_value . "': no matching filter status");
next; next;
} }
if (defined($self->{option_results}->{use_adminstatus}) && $operstatus[$result->{$oid_adminstatus . "." . $_} - 1] ne 'up') { if (defined($self->{option_results}->{use_adminstatus}) && $operstatus[$result->{$oid_adminstatus . "." . $_} - 1] ne 'up') {
$self->{output}->output_add(long_msg => "Skipping interface '" . $display_value . "': adminstatus is not 'up' and option --use-adminstatus is set");
next; next;
} }
$interfaces_display .= $interfaces_display_append . "name = $display_value [speed = $interface_speed, status = " . $operstatus[$result->{$oid_operstatus . "." . $_} - 1] . ", id = $_]"; $self->{output}->output_add(long_msg => "'" . $display_value . "' [speed = $interface_speed, status = " . $operstatus[$result->{$oid_operstatus . "." . $_} - 1] . ", id = $_]");
$interfaces_display_append = ', ';
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List interfaces: ' . $interfaces_display); short_msg => 'List interfaces:');
$self->{output}->display(nolabel => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }

View File

@ -134,21 +134,21 @@ sub run {
$self->manage_selection(); $self->manage_selection();
my $result = $self->get_additional_information(); my $result = $self->get_additional_information();
my $storage_display = '';
my $storage_display_append = '';
foreach (sort @{$self->{storage_id_selected}}) { foreach (sort @{$self->{storage_id_selected}}) {
my $display_value = $self->get_display_value(id => $_); my $display_value = $self->get_display_value(id => $_);
my $storage_type = $result->{$oid_hrStorageType . "." . $_}; my $storage_type = $result->{$oid_hrStorageType . "." . $_};
next if (!defined($storage_type) || if (!defined($storage_type) ||
($storage_types_manage{$storage_type} !~ /$self->{option_results}->{filter_storage_type}/i)); ($storage_types_manage{$storage_type} !~ /$self->{option_results}->{filter_storage_type}/i)) {
$self->{output}->output_add(long_msg => "Skipping storage '" . $display_value . "': no type or no matching filter type");
next;
}
$storage_display .= $storage_display_append . "name = $display_value [size = " . $result->{$oid_hrStorageSize . "." . $_} * $result->{$oid_hrStorageAllocationUnits . "." . $_} . "B, id = $_]"; $self->{output}->output_add(long_msg => "'" . $display_value . "' [size = " . $result->{$oid_hrStorageSize . "." . $_} * $result->{$oid_hrStorageAllocationUnits . "." . $_} . "B, id = $_]");
$storage_display_append = ', ';
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List storage: ' . $storage_display); short_msg => 'List storage:');
$self->{output}->display(nolabel => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }