diff options
author | elie <elie> | 2015-07-06 21:30:04 +0000 |
---|---|---|
committer | elie <elie> | 2015-07-06 21:30:04 +0000 |
commit | f5fff54ff3737b739e7597ab16591d28d3c7e6d6 (patch) | |
tree | d7756674acb22b60eaf8a226444d7c1941998605 /examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v3-over-ipv6-with-mib-lookup.py | |
parent | 286c02d388e34fc3c0697a5f4ffaa7d5af9070ce (diff) | |
download | pysnmp-f5fff54ff3737b739e7597ab16591d28d3c7e6d6.tar.gz |
synchronous oneliner apps redesigned to offer Python generator-based
API along with more comprehensive set of accepted parameters
Diffstat (limited to 'examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v3-over-ipv6-with-mib-lookup.py')
-rw-r--r-- | examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v3-over-ipv6-with-mib-lookup.py | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v3-over-ipv6-with-mib-lookup.py b/examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v3-over-ipv6-with-mib-lookup.py new file mode 100644 index 0000000..01c74be --- /dev/null +++ b/examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v3-over-ipv6-with-mib-lookup.py @@ -0,0 +1,39 @@ +# +# Command Generator +# +# Send SNMP GETNEXT requests using the following options: +# +# * with SNMPv3 with user 'usr-md5-des', MD5 auth and DES privacy protocols +# * over IPv6/UDP +# * to an Agent at [::1]:161 +# * for all columns of the IF-MIB::ifEntry table +# * stop when response OIDs leave the scopes of the table +# * perform response OIDs and values resolution at MIB +# +# make sure IF-MIB.py is in search path +# +from pysnmp.entity.rfc3413.oneliner.cmdgen import * + +for errorIndication, \ + errorStatus, errorIndex, \ + varBinds in nextCmd(SnmpEngine(), + UsmUserData('usr-md5-des', 'authkey1', 'privkey1'), + Udp6TransportTarget(('::1', 161)), + ContextData(), + ObjectType(ObjectIdentity('IF-MIB', 'ifEntry')), + lookupNames=True, lookupValues=True): + # Check for errors and print out results + if errorIndication: + print(errorIndication) + break + else: + if errorStatus: + print('%s at %s' % ( + errorStatus.prettyPrint(), + errorIndex and varBinds[int(errorIndex)-1][0] or '?' + ) + ) + break + else: + for varBind in varBinds: + print(' = '.join([ x.prettyPrint() for x in varBind ])) |