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-v1.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-v1.py')
-rw-r--r-- | examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v1.py | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v1.py b/examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v1.py new file mode 100644 index 0000000..1c3a998 --- /dev/null +++ b/examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v1.py @@ -0,0 +1,40 @@ +# +# Command Generator +# +# Send SNMP GETNEXT request using the following options: +# +# * with SNMPv1, community 'public' +# * over IPv4/UDP +# * to an Agent at demo.snmplabs.com:161 +# * for some columns of the IF-MIB::ifEntry table +# * stop when response OIDs leave the scopes of initial OIDs +# +from pysnmp.entity.rfc3413.oneliner.cmdgen import * + +for errorIndication, \ + errorStatus, errorIndex, \ + varBinds in nextCmd(SnmpEngine(), + CommunityData('public', mpModel=0), + UdpTransportTarget(('demo.snmplabs.com', 161)), + ContextData(), + ObjectType(ObjectIdentity('IF-MIB', 'ifDescr')), + ObjectType(ObjectIdentity('IF-MIB', 'ifType')), + ObjectType(ObjectIdentity('IF-MIB', 'ifMtu')), + ObjectType(ObjectIdentity('IF-MIB', 'ifSpeed')), + ObjectType(ObjectIdentity('IF-MIB', 'ifPhysAddress')), + ObjectType(ObjectIdentity('IF-MIB', 'ifType'))): + # 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 ])) |