+ add subsettable option (fix some errors)

This commit is contained in:
garnier-quentin 2017-03-13 10:55:46 +01:00
parent 5e81ac8e69
commit 6d42b3e179
1 changed files with 4 additions and 3 deletions

View File

@ -52,6 +52,7 @@ sub new {
"snmp-retries:s" => { name => 'snmp_retries', default => 5 }, "snmp-retries:s" => { name => 'snmp_retries', default => 5 },
"maxrepetitions:s" => { name => 'maxrepetitions', default => 50 }, "maxrepetitions:s" => { name => 'maxrepetitions', default => 50 },
"subsetleef:s" => { name => 'subsetleef', default => 50 }, "subsetleef:s" => { name => 'subsetleef', default => 50 },
"subsettable:s" => { name => 'subsettable', default => 100 },
"snmp-force-getnext" => { name => 'snmp_force_getnext' }, "snmp-force-getnext" => { name => 'snmp_force_getnext' },
"snmp-username:s" => { name => 'snmp_security_name' }, "snmp-username:s" => { name => 'snmp_security_name' },
"authpassphrase:s" => { name => 'snmp_auth_passphrase' }, "authpassphrase:s" => { name => 'snmp_auth_passphrase' },
@ -68,7 +69,6 @@ sub new {
##### #####
$self->{session} = undef; $self->{session} = undef;
$self->{output} = $options{output}; $self->{output} = $options{output};
$self->{maxrepetitions} = undef;
$self->{snmp_params} = {}; $self->{snmp_params} = {};
# Dont load MIB # Dont load MIB
@ -348,6 +348,7 @@ sub get_multiple_table {
push @bases, $key; push @bases, $key;
$current_oids++; $current_oids++;
last if ($current_oids > $self->{subsettable});
} }
# Nothing more to check. We quit # Nothing more to check. We quit
@ -358,7 +359,7 @@ sub get_multiple_table {
if ($self->is_snmpv1() || defined($self->{snmp_force_getnext})) { if ($self->is_snmpv1() || defined($self->{snmp_force_getnext})) {
$self->{session}->getnext($vb); $self->{session}->getnext($vb);
} else { } else {
my $current_repeat_count = floor($repeat_count / (scalar(keys %{$working_oids}))); my $current_repeat_count = floor($repeat_count / $current_oids);
$current_repeat_count = 1 if ($current_repeat_count == 0); $current_repeat_count = 1 if ($current_repeat_count == 0);
$self->{session}->getbulk(0, $current_repeat_count, $vb); $self->{session}->getbulk(0, $current_repeat_count, $vb);
} }
@ -433,7 +434,6 @@ sub get_multiple_table {
if ($nothing_quit == 1) { if ($nothing_quit == 1) {
if ($return_type == 1) { if ($return_type == 1) {
$total = scalar(keys %{$results}); $total = scalar(keys %{$results});
} else { } else {
foreach (keys %{$results}) { foreach (keys %{$results}) {
$total += scalar(keys %{$results->{$_}}); $total += scalar(keys %{$results->{$_}});
@ -646,6 +646,7 @@ sub check_options {
$self->{snmp_force_getnext} = $options{option_results}->{snmp_force_getnext}; $self->{snmp_force_getnext} = $options{option_results}->{snmp_force_getnext};
$self->{maxrepetitions} = $options{option_results}->{maxrepetitions}; $self->{maxrepetitions} = $options{option_results}->{maxrepetitions};
$self->{subsetleef} = (defined($options{option_results}->{subsetleef}) && $options{option_results}->{subsetleef} =~ /^[0-9]+$/) ? $options{option_results}->{subsetleef} : 50; $self->{subsetleef} = (defined($options{option_results}->{subsetleef}) && $options{option_results}->{subsetleef} =~ /^[0-9]+$/) ? $options{option_results}->{subsetleef} : 50;
$self->{subsettable} = (defined($options{option_results}->{subsettable}) && $options{option_results}->{subsettable} =~ /^[0-9]+$/) ? $options{option_results}->{subsettable} : 100;
$self->{snmp_errors_exit} = $options{option_results}->{snmp_errors_exit}; $self->{snmp_errors_exit} = $options{option_results}->{snmp_errors_exit};
%{$self->{snmp_params}} = (DestHost => $options{option_results}->{host}, %{$self->{snmp_params}} = (DestHost => $options{option_results}->{host},