From f5fff54ff3737b739e7597ab16591d28d3c7e6d6 Mon Sep 17 00:00:00 2001 From: elie Date: Mon, 6 Jul 2015 21:30:04 +0000 Subject: synchronous oneliner apps redesigned to offer Python generator-based API along with more comprehensive set of accepted parameters --- .../asyncore/oneliner/manager/cmdgen/get-v1.py | 35 ++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 examples/v3arch/asyncore/oneliner/manager/cmdgen/get-v1.py (limited to 'examples/v3arch/asyncore/oneliner/manager/cmdgen/get-v1.py') diff --git a/examples/v3arch/asyncore/oneliner/manager/cmdgen/get-v1.py b/examples/v3arch/asyncore/oneliner/manager/cmdgen/get-v1.py new file mode 100644 index 0000000..aca4129 --- /dev/null +++ b/examples/v3arch/asyncore/oneliner/manager/cmdgen/get-v1.py @@ -0,0 +1,35 @@ +# +# Command Generator +# +# Send SNMP GET request using the following options: +# +# * with SNMPv1, community 'public' +# * over IPv4/UDP +# * to an Agent at demo.snmplabs.com:161 +# * for two instances of SNMPv2-MIB::sysDescr.0 MIB object, +# * one in label and another in MIB symbol form +# +from pysnmp.entity.rfc3413.oneliner.cmdgen import * + +for errorIndication, \ + errorStatus, errorIndex, \ + varBinds in getCmd(SnmpEngine(), + CommunityData('public', mpModel=0), + UdpTransportTarget(('demo.snmplabs.com', 161)), + ContextData(), + ObjectType(ObjectIdentity('SNMPv2-MIB', 'sysDescr', 0)), + lookupNames=True, lookupValues=True): + # Check for errors and print out results + if errorIndication: + print(errorIndication) + else: + if errorStatus: + print('%s at %s' % ( + errorStatus.prettyPrint(), + errorIndex and varBinds[int(errorIndex)-1][0] or '?' + ) + ) + else: + for varBind in varBinds: + print(' = '.join([ x.prettyPrint() for x in varBind ])) + break -- cgit v1.2.1