enhance indent big

This commit is contained in:
garnier-quentin 2019-10-10 14:32:03 +02:00
parent 2844aa5107
commit e583ec0639
7 changed files with 145 additions and 98 deletions

View File

@ -122,10 +122,14 @@ sub manage_selection {
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
my $result = $options{snmp}->get_leef(oids => [$oid_sysStatClientCurConns, $oid_sysStatServerCurConns, my $result = $options{snmp}->get_leef(
$oid_sysClientsslStatCurConns, $oid_sysServersslStatCurConns, oids => [
$oid_sysClientsslStatTotNativeConns, $oid_sysClientsslStatTotCompatConns], $oid_sysStatClientCurConns, $oid_sysStatServerCurConns,
nothing_quit => 1); $oid_sysClientsslStatCurConns, $oid_sysServersslStatCurConns,
$oid_sysClientsslStatTotNativeConns, $oid_sysClientsslStatTotCompatConns
],
nothing_quit => 1
);
$self->{global} = { $self->{global} = {
client => $result->{$oid_sysStatClientCurConns}, client => $result->{$oid_sysStatClientCurConns},
client_ssl => $result->{$oid_sysClientsslStatCurConns}, client_ssl => $result->{$oid_sysClientsslStatCurConns},

View File

@ -86,15 +86,13 @@ sub new {
my $self = $class->SUPER::new(package => __PACKAGE__, %options); my $self = $class->SUPER::new(package => __PACKAGE__, %options);
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ 'warning-sync-status:s' => { name => 'warning_sync_status', default => '' },
"filter-counters:s" => { name => 'filter_counters' }, 'critical-sync-status:s' => { name => 'critical_sync_status', default => '%{syncstatus} =~ /unknown|syncFailed|syncDisconnected|incompatibleVersion/' },
"warning-sync-status:s" => { name => 'warning_sync_status', default => '' }, 'warning-failover-status:s' => { name => 'warning_failover_status', default => '' },
"critical-sync-status:s" => { name => 'critical_sync_status', default => '%{syncstatus} =~ /unknown|syncFailed|syncDisconnected|incompatibleVersion/' }, 'critical-failover-status:s' => { name => 'critical_failover_status', default => '%{failoverstatus} =~ /unknown/' },
"warning-failover-status:s" => { name => 'warning_failover_status', default => '' }, });
"critical-failover-status:s" => { name => 'critical_failover_status', default => '%{failoverstatus} =~ /unknown/' },
});
return $self; return $self;
} }
@ -139,32 +137,40 @@ my $mapping = {
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $result = $options{snmp}->get_leef(oids => [$mapping->{sysAttrFailoverIsRedundant}->{oid} . '.0', my $snmp_result = $options{snmp}->get_leef(
$mapping->{sysAttrModeMaint}->{oid} . '.0', oids => [
$mapping->{sysCmSyncStatusId}->{oid} . '.0', $mapping->{sysAttrFailoverIsRedundant}->{oid} . '.0',
$mapping->{sysCmFailoverStatusId}->{oid} . '.0'], $mapping->{sysAttrModeMaint}->{oid} . '.0',
nothing_quit => 1); $mapping->{sysCmSyncStatusId}->{oid} . '.0',
my $result2 = $options{snmp}->map_instance(mapping => $mapping, results => $result, instance => '0'); $mapping->{sysCmFailoverStatusId}->{oid} . '.0'
],
nothing_quit => 1
);
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result, instance => '0');
if ($result2->{sysAttrModeMaint} eq 'true') { if ($result->{sysAttrModeMaint} eq 'true') {
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(
short_msg => 'maintenance mode is active'); severity => 'OK',
short_msg => 'maintenance mode is active'
);
$self->{output}->display(); $self->{output}->display();
$self->{output}->exit(); $self->{output}->exit();
} }
if ($result2->{sysAttrFailoverIsRedundant} eq 'false') { if ($result->{sysAttrFailoverIsRedundant} eq 'false') {
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(
short_msg => 'failover mode is disable'); severity => 'OK',
short_msg => 'failover mode is disable'
);
$self->{output}->display(); $self->{output}->display();
$self->{output}->exit(); $self->{output}->exit();
} }
$self->{global} = { $self->{global} = {
syncstatus => $result2->{sysCmSyncStatusId}, syncstatus => $result->{sysCmSyncStatusId},
failoverstatus => $result2->{sysCmFailoverStatusId}, failoverstatus => $result->{sysCmFailoverStatusId},
}; };
} }
1; 1;
__END__ __END__

View File

@ -25,9 +25,6 @@ use base qw(centreon::plugins::mode);
use strict; use strict;
use warnings; use warnings;
my $oid_ltmNodeAddrName = '.1.3.6.1.4.1.3375.2.2.4.1.2.1.17'; # old
my $oid_ltmNodeAddrStatusName = '.1.3.6.1.4.1.3375.2.2.4.3.2.1.7'; # new
sub new { sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options); my $self = $class->SUPER::new(package => __PACKAGE__, %options);
@ -48,36 +45,66 @@ sub check_options {
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
my $snmp_result = $self->{snmp}->get_multiple_table(oids => [ { oid => $oid_ltmNodeAddrName }, { oid => $oid_ltmNodeAddrStatusName } ], nothing_quit => 1); my $map_pool_status = {
0 => 'none', 1 => 'green',
my ($branch_name) = ($oid_ltmNodeAddrStatusName); 2 => 'yellow', 3 => 'red',
if (!defined($snmp_result->{$oid_ltmNodeAddrStatusName}) || scalar(keys %{$snmp_result->{$oid_ltmNodeAddrStatusName}}) == 0) { 4 => 'blue', 5 => 'gray',
($branch_name) = ($oid_ltmNodeAddrName); };
} my $map_pool_enabled = {
0 => 'none', 1 => 'enabled', 2 => 'disabled', 3 => 'disabledbyparent',
$self->{node} = {}; };
foreach my $oid (keys %{$snmp_result->{$branch_name}}) { my $mapping = {
AvailState => { oid => '.1.3.6.1.4.1.3375.2.2.4.3.2.1.3', map => $map_pool_status },
EnabledState => { oid => '.1.3.6.1.4.1.3375.2.2.4.3.2.1.4', map => $map_pool_enabled },
};
my $oid_ltmNodeAddrStatusEntry = '.1.3.6.1.4.1.3375.2.2.4.3.2.1';
my $snmp_result = $options{snmp}->get_table(
oid => $oid_ltmNodeAddrStatusEntry,
start => $mapping->{AvailState}->{oid},
end => $mapping->{EnabledState}->{oid},
nothing_quit => 1
);
my $results = {};
foreach my $oid (keys %$snmp_result) {
next if ($oid !~ /^$mapping->{AvailState}->{oid}\.(.*?)\.(.*)$/);
my ($num, $index) = ($1, $2);
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result, instance => $num . '.' . $index);
my $name = $self->{output}->to_utf8(join('', map(chr($_), split(/\./, $index))));
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 '' &&
$snmp_result->{$branch_name}->{$oid} !~ /$self->{option_results}->{filter_name}/) { $name !~ /$self->{option_results}->{filter_name}/) {
$self->{output}->output_add(long_msg => "skipping service class '" . $snmp_result->{$branch_name}->{$oid} . "'.", debug => 1); $self->{output}->output_add(long_msg => "skipping node '" . $name . "'.", debug => 1);
next; next;
} }
$self->{node}->{$snmp_result->{$branch_name}->{$oid}} = { name => $snmp_result->{$branch_name}->{$oid} }; $results->{$name} = {
status => $result->{AvailState},
state => $result->{EnabledState},
};
} }
return $results;
} }
sub run { sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{snmp} = $options{snmp};
$self->manage_selection(); my $results = $self->manage_selection(snmp => $options{snmp});
foreach my $name (sort keys %{$self->{node}}) { foreach my $name (sort keys %$results) {
$self->{output}->output_add(long_msg => "'" . $name . "'"); $self->{output}->output_add(
long_msg => sprintf(
'[name: %s] [status: %s] [state: %s]',
$name,
$results->{$name}->{status},
$results->{$name}->{state},
)
);
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List Nodes:'); short_msg => 'List nodes:');
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }
@ -85,16 +112,19 @@ sub run {
sub disco_format { sub disco_format {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{output}->add_disco_format(elements => ['name']); $self->{output}->add_disco_format(elements => ['name', 'status', 'state']);
} }
sub disco_show { sub disco_show {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{snmp} = $options{snmp};
$self->manage_selection(); my $results = $self->manage_selection(snmp => $options{snmp});
foreach my $name (sort keys %{$self->{node}}) { foreach my $name (sort keys %$results) {
$self->{output}->add_disco_entry(name => $name); $self->{output}->add_disco_entry(
name => $name,
status => $results->{$name}->{status},
state => $results->{$name}->{state}
);
} }
} }

View File

@ -82,7 +82,6 @@ sub manage_selection {
} }
$results->{$name} = { $results->{$name} = {
display => $name,
status => $result->{AvailState}, status => $result->{AvailState},
state => $result->{EnabledState}, state => $result->{EnabledState},
}; };
@ -108,7 +107,7 @@ sub run {
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List Pools:'); short_msg => 'List pools:');
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }

View File

@ -31,8 +31,7 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
'name:s' => { name => 'name' }, 'filter-name:s' => { name => 'filter_name' },
'regexp' => { name => 'use_regexp' },
}); });
return $self; return $self;
@ -86,36 +85,45 @@ sub manage_selection {
($branch, $map) = ($oid_ltmVirtualServEntry, 'old'); ($branch, $map) = ($oid_ltmVirtualServEntry, 'old');
} }
$self->{vs} = {}; my $results = {};
foreach my $oid (keys %{$snmp_result->{$branch}}) { foreach my $oid (keys %{$snmp_result->{$branch}}) {
next if ($oid !~ /^$mapping->{$map}->{AvailState}->{oid}\.(.*?)\.(.*)$/); next if ($oid !~ /^$mapping->{$map}->{AvailState}->{oid}\.(.*?)\.(.*)$/);
my ($num, $index) = ($1, $2); my ($num, $index) = ($1, $2);
my $result = $options{snmp}->map_instance(mapping => $mapping->{$map}, results => $snmp_result->{$branch}, instance => $num . '.' . $index); my $result = $options{snmp}->map_instance(mapping => $mapping->{$map}, results => $snmp_result->{$branch}, instance => $num . '.' . $index);
$result->{Name} = $self->{output}->to_utf8(join('', map(chr($_), split(/\./, $index)))); my $name = $self->{output}->to_utf8(join('', map(chr($_), split(/\./, $index))));
if (defined($self->{option_results}->{name}) && $self->{option_results}->{name} ne '') { if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
next if (defined($self->{option_results}->{use_regexp}) && $result->{Name} !~ /$self->{option_results}->{name}/); $name !~ /$self->{option_results}->{filter_name}/) {
next if ($result->{Name} ne $self->{option_results}->{name}); $self->{output}->output_add(long_msg => "skipping virtual server '" . $name . "'.", debug => 1);
next;
} }
$self->{vs}->{$result->{Name}} = { %$result }; $results->{$name} = {
status => $result->{AvailState},
state => $result->{EnabledState},
};
} }
return $results;
} }
sub run { sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->manage_selection(%options); my $results = $self->manage_selection(snmp => $options{snmp});
foreach (sort keys %{$self->{vs}}) { foreach my $name (sort keys %$results) {
$self->{output}->output_add(long_msg => $self->{output}->output_add(
"[name = '" . $self->{vs}->{$_}->{Name} . "']" . long_msg => sprintf(
"[availstate = '" . $self->{vs}->{$_}->{AvailState} . "']" . '[name: %s] [status: %s] [state: %s]',
"[enabledtate = '" . $self->{vs}->{$_}->{EnabledState} . "']" $name,
$results->{$name}->{status},
$results->{$name}->{state},
)
); );
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
short_msg => 'List Virtual Servers:'); short_msg => 'List virtual servers:');
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
$self->{output}->exit(); $self->{output}->exit();
} }
@ -123,18 +131,18 @@ sub run {
sub disco_format { sub disco_format {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{output}->add_disco_format(elements => ['name', 'availstate', 'enabledtate']); $self->{output}->add_disco_format(elements => ['name', 'status', 'state']);
} }
sub disco_show { sub disco_show {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->manage_selection(%options); my $results = $self->manage_selection(snmp => $options{snmp});
foreach (sort keys %{$self->{vs}}) { foreach my $name (sort keys %$results) {
$self->{output}->add_disco_entry( $self->{output}->add_disco_entry(
name => $self->{vs}->{$_}->{Name}, name => $name,
availstate => $self->{vs}->{$_}->{AvailState}, status => $results->{$name}->{status},
enabledtate => $self->{vs}->{$_}->{EnabledState}, state => $results->{$name}->{state}
); );
} }
} }
@ -149,13 +157,9 @@ List F-5 Virtual Servers.
=over 8 =over 8
=item B<--name> =item B<--filter-name>
Set the virtual server name. Filter by virtual server name.
=item B<--regexp>
Allows to use regexp to filter virtual server name (with option --name).
=back =back

View File

@ -157,11 +157,10 @@ sub new {
my $self = $class->SUPER::new(package => __PACKAGE__, %options, statefile => 1); my $self = $class->SUPER::new(package => __PACKAGE__, %options, statefile => 1);
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ 'filter-name:s' => { name => 'filter_name' },
"filter-name:s" => { name => 'filter_name' }, });
});
return $self; return $self;
} }
@ -186,8 +185,10 @@ sub manage_selection {
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
my $results = $options{snmp}->get_table(oid => $oid_sysTmmStatEntry, my $results = $options{snmp}->get_table(
nothing_quit => 1); oid => $oid_sysTmmStatEntry,
nothing_quit => 1
);
$self->{tmm} = {}; $self->{tmm} = {};
foreach my $oid (keys %$results) { foreach my $oid (keys %$results) {

View File

@ -301,10 +301,10 @@ sub new {
bless $self, $class; bless $self, $class;
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"filter-name:s" => { name => 'filter_name' }, 'filter-name:s' => { name => 'filter_name' },
"threshold-overload:s@" => { name => 'threshold_overload' }, 'threshold-overload:s@' => { name => 'threshold_overload' },
"units-traffic:s" => { name => 'units_traffic', default => '%' }, 'units-traffic:s' => { name => 'units_traffic', default => '%' },
"speed:s" => { name => 'speed' }, 'speed:s' => { name => 'speed' },
}); });
return $self; return $self;
@ -388,10 +388,13 @@ sub manage_selection {
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
my $results = $options{snmp}->get_multiple_table(oids => [ my $results = $options{snmp}->get_multiple_table(
{ oid => $oid_sysTrunkTable }, oids => [
{ oid => $oid_sysTrunkStatTable }, { oid => $oid_sysTrunkTable },
], nothing_quit => 1); { oid => $oid_sysTrunkStatTable },
],
nothing_quit => 1
);
$self->{trunks} = {}; $self->{trunks} = {};
foreach my $oid (keys %{$results->{$oid_sysTrunkTable}}) { foreach my $oid (keys %{$results->{$oid_sysTrunkTable}}) {