diff options
Diffstat (limited to 'examples/hlapi/v1arch/asyncio/manager')
4 files changed, 243 insertions, 0 deletions
diff --git a/examples/hlapi/v1arch/asyncio/manager/cmdgen/getbulk-to-eom.py b/examples/hlapi/v1arch/asyncio/manager/cmdgen/getbulk-to-eom.py new file mode 100644 index 00000000..c0532c09 --- /dev/null +++ b/examples/hlapi/v1arch/asyncio/manager/cmdgen/getbulk-to-eom.py @@ -0,0 +1,65 @@ +""" +Bulk walk MIB ++++++++++++++ + +Send a series of SNMP GETBULK requests using the following options: + +* with SNMPv2c, community 'public' +* over IPv4/UDP +* to an Agent at demo.snmplabs.com:161 +* for all OIDs past SNMPv2-MIB::system +* run till end-of-mib condition is reported by Agent +* based on asyncio I/O framework + +Functionally similar to: + +| $ snmpbulkwalk -v2c -c public -Cn0 -Cr50 \ +| demo.snmplabs.com SNMPv2-MIB::system + +"""# +import asyncio +from pysnmp.hlapi.v1arch.asyncio import * + + +@asyncio.coroutine +def run(varBinds): + + snmpDispatcher = SnmpDispatcher() + + while True: + iterator = bulkCmd( + snmpDispatcher, + CommunityData('public'), + UdpTransportTarget(('demo.snmplabs.com', 161)), + 0, 50, + *varBinds + ) + + errorIndication, errorStatus, errorIndex, varBindTable = yield from iterator + + if errorIndication: + print(errorIndication) + break + + elif errorStatus: + print('%s at %s' % ( + errorStatus.prettyPrint(), + errorIndex and varBinds[int(errorIndex) - 1][0] or '?' + ) + ) + else: + for varBindRow in varBindTable: + for varBind in varBindRow: + print(' = '.join([x.prettyPrint() for x in varBind])) + + varBinds = varBindTable[-1] + if isEndOfMib(varBinds): + break + + snmpDispatcher.transportDispatcher.closeDispatcher() + + +loop = asyncio.get_event_loop() +loop.run_until_complete( + run([ObjectType(ObjectIdentity('SNMPv2-MIB', 'sysDescr'))]) +) diff --git a/examples/hlapi/v1arch/asyncio/manager/cmdgen/multiple-concurrent-queries-over-ipv4-and-ipv6.py b/examples/hlapi/v1arch/asyncio/manager/cmdgen/multiple-concurrent-queries-over-ipv4-and-ipv6.py new file mode 100644 index 00000000..f0e14ae5 --- /dev/null +++ b/examples/hlapi/v1arch/asyncio/manager/cmdgen/multiple-concurrent-queries-over-ipv4-and-ipv6.py @@ -0,0 +1,59 @@ +""" +Concurrent queries +++++++++++++++++++ + +Send multiple SNMP GET requests at once using the following options: + +* with SNMPv2c, community 'public' +* over IPv4/UDP +* to multiple Agents at demo.snmplabs.com +* for instance of SNMPv2-MIB::sysDescr.0 MIB object +* based on asyncio I/O framework + +Functionally similar to: + +| $ snmpget -v2c -c public demo.snmplabs.com:1161 SNMPv2-MIB::sysDescr.0 +| $ snmpget -v2c -c public demo.snmplabs.com:2161 SNMPv2-MIB::sysDescr.0 +| $ snmpget -v2c -c public demo.snmplabs.com:3161 SNMPv2-MIB::sysDescr.0 + +"""# +import asyncio +from pysnmp.hlapi.v1arch.asyncio import * + + +@asyncio.coroutine +def getone(snmpDispatcher, hostname): + + iterator = getCmd( + snmpDispatcher, + CommunityData('public'), + UdpTransportTarget(hostname), + ObjectType(ObjectIdentity('SNMPv2-MIB', 'sysDescr', 0)) + ) + + errorIndication, errorStatus, errorIndex, varBinds = yield from iterator + + 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])) + + +snmpDispatcher = SnmpDispatcher() + +loop = asyncio.get_event_loop() +loop.run_until_complete( + asyncio.wait( + [getone(snmpDispatcher, ('demo.snmplabs.com', 1161)), + getone(snmpDispatcher, ('demo.snmplabs.com', 2161)), + getone(snmpDispatcher, ('demo.snmplabs.com', 3161))] + ) +) diff --git a/examples/hlapi/v1arch/asyncio/manager/cmdgen/multiple-sequential-queries.py b/examples/hlapi/v1arch/asyncio/manager/cmdgen/multiple-sequential-queries.py new file mode 100644 index 00000000..3ce3c232 --- /dev/null +++ b/examples/hlapi/v1arch/asyncio/manager/cmdgen/multiple-sequential-queries.py @@ -0,0 +1,68 @@ +""" +Sequential queries +++++++++++++++++++ + +Send multiple SNMP GET requests one by one using the following options: + +* with SNMPv2c, community 'public' +* over IPv4/UDP +* to multiple Agents at demo.snmplabs.com +* for instance of SNMPv2-MIB::sysDescr.0 MIB object +* based on asyncio I/O framework + +Functionally similar to: + +| $ snmpget -v2c -c public demo.snmplabs.com:1161 SNMPv2-MIB::sysDescr.0 +| $ snmpget -v2c -c public demo.snmplabs.com:2161 SNMPv2-MIB::sysDescr.0 +| $ snmpget -v2c -c public demo.snmplabs.com:3161 SNMPv2-MIB::sysDescr.0 + +"""# +import asyncio +from pysnmp.hlapi.v1arch.asyncio import * + + +@asyncio.coroutine +def getone(snmpDispatcher, hostname): + + iterator = getCmd( + snmpDispatcher, + CommunityData('public'), + UdpTransportTarget(hostname), + ObjectType(ObjectIdentity('SNMPv2-MIB', 'sysDescr', 0)) + ) + + errorIndication, errorStatus, errorIndex, varBinds = yield from iterator + + 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])) + + +@asyncio.coroutine +def getall(snmpDispatcher, hostnames): + for hostname in hostnames: + yield from getone(snmpDispatcher, hostname) + + +snmpDispatcher = SnmpDispatcher() + +loop = asyncio.get_event_loop() + +loop.run_until_complete( + getall( + snmpDispatcher, [ + ('demo.snmplabs.com', 1161), + ('demo.snmplabs.com', 2161), + ('demo.snmplabs.com', 3161) + ] + ) +) diff --git a/examples/hlapi/v1arch/asyncio/manager/cmdgen/v1-get.py b/examples/hlapi/v1arch/asyncio/manager/cmdgen/v1-get.py new file mode 100644 index 00000000..5659a3a5 --- /dev/null +++ b/examples/hlapi/v1arch/asyncio/manager/cmdgen/v1-get.py @@ -0,0 +1,51 @@ +""" +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 the 1.3.6.1.2.1.1.1.0 OID (e.g. 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.v1arch.asyncio import * + + +@asyncio.coroutine +def run(): + snmpDispatcher = SnmpDispatcher() + + iterator = getCmd( + snmpDispatcher, + CommunityData('public', mpModel=0), + UdpTransportTarget(('demo.snmplabs.com', 161)), + ('1.3.6.1.2.1.1.1.0', None) + ) + + errorIndication, errorStatus, errorIndex, varBinds = yield from iterator + + 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])) + + snmpDispatcher.transportDispatcher.closeDispatcher() + + +asyncio.get_event_loop().run_until_complete(run()) |