summaryrefslogtreecommitdiff
path: root/examples/hlapi/asyncio/manager/cmdgen/v1-get.py
diff options
context:
space:
mode:
Diffstat (limited to 'examples/hlapi/asyncio/manager/cmdgen/v1-get.py')
-rw-r--r--examples/hlapi/asyncio/manager/cmdgen/v1-get.py46
1 files changed, 46 insertions, 0 deletions
diff --git a/examples/hlapi/asyncio/manager/cmdgen/v1-get.py b/examples/hlapi/asyncio/manager/cmdgen/v1-get.py
new file mode 100644
index 0000000..7757dec
--- /dev/null
+++ b/examples/hlapi/asyncio/manager/cmdgen/v1-get.py
@@ -0,0 +1,46 @@
+"""
+SNMPv1
+++++++
+
+Send SNMP GET request using the following options:
+
+ * with SNMPv1, community 'public'
+ * over IPv4/UDP
+ * to an Agent at demo.snmplabs.com:161
+ * for an instance of SNMPv2-MIB::sysDescr.0 MIB object
+ * Based on asyncio I/O framework
+
+Functionally similar to:
+
+| $ snmpget -v1 -c public demo.snmplabs.com SNMPv2-MIB::sysDescr.0
+
+"""#
+import asyncio
+from pysnmp.hlapi.asyncio import *
+
+@asyncio.coroutine
+def run():
+ snmpEngine = SnmpEngine()
+ errorIndication, errorStatus, errorIndex, varBinds = yield from getCmd(
+ snmpEngine,
+ CommunityData('public', mpModel=0),
+ UdpTransportTarget(('demo.snmplabs.com', 161)),
+ ContextData(),
+ ObjectType(ObjectIdentity('SNMPv2-MIB', 'sysDescr', 0))
+ )
+
+ if errorIndication:
+ print(errorIndication)
+ elif 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 ]))
+
+ snmpEngine.transportDispatcher.closeDispatcher()
+
+asyncio.get_event_loop().run_until_complete(run())