enh sql sqlstring for dual tables (#1075)

This commit is contained in:
Colin Gagnaire 2018-07-23 18:19:33 +02:00 committed by GitHub
parent f020ab4518
commit e2e39da6b9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 11 additions and 1 deletions

View File

@ -116,13 +116,13 @@ sub new {
"critical-string:s" => { name => 'critical_string', default => '' }, "critical-string:s" => { name => 'critical_string', default => '' },
"printf-format:s" => { name => 'printf_format' }, "printf-format:s" => { name => 'printf_format' },
"printf-value:s" => { name => 'printf_value' }, "printf-value:s" => { name => 'printf_value' },
"dual-table" => { name => 'dual_table' },
}); });
return $self; return $self;
} }
sub check_options { sub check_options {
my ($self, %options) = @_; my ($self, %options) = @_;
#$self->SUPER::init(%options);
$self->SUPER::check_options(%options); $self->SUPER::check_options(%options);
$instance_mode = $self; $instance_mode = $self;
@ -152,6 +152,12 @@ sub manage_selection {
my $row_count = 0; my $row_count = 0;
while (my $row = $self->{sql}->fetchrow_hashref()) { while (my $row = $self->{sql}->fetchrow_hashref()) {
if (defined($self->{option_results}->{dual_table})) {
$row->{$self->{option_results}->{value_column}} = delete $row->{keys %{$row}};
foreach (keys %{$row}) {
$row->{$self->{option_results}->{value_column}} = $row->{$_};
}
}
if (!defined($self->{option_results}->{key_column})) { if (!defined($self->{option_results}->{key_column})) {
$self->{rows}->{$self->{option_results}->{value_column} . $row_count} = { key_field => $row->{$self->{option_results}->{value_column}}, $self->{rows}->{$self->{option_results}->{value_column} . $row_count} = { key_field => $row->{$self->{option_results}->{value_column}},
value_field => $row->{$self->{option_results}->{value_column}}}; value_field => $row->{$self->{option_results}->{value_column}}};
@ -212,6 +218,10 @@ e.g --warning-string '%{key_field} eq 'Central' && %{value_field} =~ /127.0.0.1/
Set critical condition (if statement syntax) for status evaluation. Set critical condition (if statement syntax) for status evaluation.
(Can be: %{key_field} or %{value_field}) (Can be: %{key_field} or %{value_field})
=item B<--dual-table>
Set this option to ensure compatibility with dual table and Oracle.
=back =back
=cut =cut