X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fpart_export%2Fbroadband_snmp_get.pm;h=35dcd31541e7f24c25cda8b5f0592737d3db6e44;hb=6702f62122aeca25cedd635914a9bd9d1d5a35eb;hp=fafe91a65d9f9269001b5ea6b5a609fd2cf64dac;hpb=dd003d59f56742f9374cec309ad81d527e88c846;p=freeside.git diff --git a/FS/FS/part_export/broadband_snmp_get.pm b/FS/FS/part_export/broadband_snmp_get.pm index fafe91a65..35dcd3154 100644 --- a/FS/FS/part_export/broadband_snmp_get.pm +++ b/FS/FS/part_export/broadband_snmp_get.pm @@ -21,6 +21,7 @@ tie my %options, 'Tie::IxHash', 'snmp_community' => { 'label'=>'Community', 'default'=>'public' }, 'snmp_timeout' => { label=>'Timeout (seconds)', 'default'=>1 }, 'snmp_oid' => { label=>'Object ID', multiple=>1 }, + 'snmp_oid_name' => { label=>'Object Name', multiple=>1 }, ; %info = ( @@ -61,15 +62,15 @@ Configuration for realtime snmp requests to svc_broadband IP address =item snmp_results SVC -Request statistics from SVC ip address. Returns an array of hashes with keys +Request statistics from SVC ip address. Returns an array of hashrefs with keys -objectID +error - error message -label +objectID - dotted decimal fully qualified OID -value +label - leaf textual identifier (e.g., 'sysDescr') -error - error when attempting to load this object +values - arrayref of arrayrefs describing values, [, , , ] =cut @@ -78,8 +79,9 @@ sub snmp_results { my $host = $svc->ip_addr; my $comm = $self->option('snmp_community'); my $vers = $self->option('snmp_version'); - my $time = ($self->option('snmp_timeout') || 1) * 1000; + my $time = ($self->option('snmp_timeout') || 1) * 1000000; my @oids = split("\n", $self->option('snmp_oid')); + my @oidnames = split("\n", $self->option('snmp_oid_name')); my %connect = ( 'DestHost' => $host, 'Community' => $comm, @@ -90,15 +92,39 @@ sub snmp_results { return { 'error' => 'Error creating SNMP session' } unless $snmp; return { 'error' => $snmp->{'ErrorStr'} } if $snmp->{'ErrorStr'}; my @out; - foreach my $oid (@oids) { + for (my $i=0; $i <= $#oids; $i++) { + my $oid = $oids[$i]; + my $oidname = $oidnames[$i]; $oid = $SNMP::MIB{$oid}->{'objectID'} if $SNMP::MIB{$oid}; - my $value = $snmp->get($oid.'.0'); - if ($snmp->{'ErrorStr'}) { - push @out, { 'error' => $snmp->{'ErrorStr'} }; + my @values; + if ($vers eq '1') { + my $varbind = new SNMP::Varbind [$oid]; + my $max = 1000; #sanity check + while ($max > 0 and defined($snmp->getnext($varbind))) { + last if $snmp->{'ErrorStr'}; + last unless $SNMP::MIB{$varbind->[0]}; # does this happen? + my $nextoid = $SNMP::MIB{$varbind->[0]}->{'objectID'}; + last unless $nextoid =~ /^$oid/; + $max--; + push @values, [ @$varbind ]; + } + } else { + # not clear on what max-repeaters (25) does, plucked value from example code + # but based on testing, it isn't capping number of returned values + my ($values) = $snmp->bulkwalk(0,25,$oid); + @values = @$values if $values; + } + if ($snmp->{'ErrorStr'} || !@values) { + push @out, { 'error' => $snmp->{'ErrorStr'} || 'No values retrieved' }; next; } - my %result = map { $_ => $SNMP::MIB{$oid}{$_} } qw( objectID label value ); - $result{'value'} = $value; + my %result = map { $_ => $SNMP::MIB{$oid}{$_} } qw( objectID label ); + $result{'name'} = $oidname; + # unbless @values, for ease of JSON encoding + $result{'values'} = []; + foreach my $value (@values) { + push @{$result{'values'}}, [ map { $_ } @$value ]; + } push @out, \%result; } return @out;