summaryrefslogtreecommitdiff
path: root/examples/v3arch/asyncore/oneliner/manager/cmdgen/getnext-v3-pull-whole-mib-with-options.py
blob: 19d795004c0bc83b9de99816e02f63251d8b1181 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
"""
Fetch fixed amount of MIB variables
+++++++++++++++++++++++++++++++++++

Send a series of SNMP GETNEXT requests using the following options:

* with SNMPv3, user 'usr-sha-aes128', SHA auth, AES128 privacy
* over UDP/IPv4
* to an Agent at demo.snmplabs.com:161
* for all OIDs past SNMPv2-MIB
* run till end-of-mib condition is reported by Agent OR maxRows == 100
* ignoring non-increasing OIDs whenever reported by Agent

Functionally similar to:

| $ snmpwalk -v3 -lauthPriv -u usr-sha-aes128 -A authkey1 -X privkey1 \
|            -a MD5 -x AES  demo.snmplabs.com \
|            SNMPv2-MIB::system

"""#
from pysnmp.entity.rfc3413.oneliner.cmdgen import *

for errorIndication, \
    errorStatus, errorIndex, \
    varBinds in nextCmd(SnmpEngine(),
                        UsmUserData('usr-sha-aes128', 'authkey1', 'privkey1',
                                    authProtocol=usmHMACSHAAuthProtocol,
                                    privProtocol=usmAesCfb128Protocol),
                        UdpTransportTarget(('demo.snmplabs.com', 161)),
                        ContextData(),
                        ObjectType(ObjectIdentity('SNMPv2-MIB')),
                        maxRows=100, ignoreNonIncreasingOid=True):

    if errorIndication:
        print(errorIndication)
        break
    elif 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 ]))