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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
# -*- python -*-
'''
xpybar – xmobar replacement written in python
Copyright © 2014, 2015, 2016 Mattias Andrée (maandree@member.fsf.org)
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
'''
from util import *
class SNMP:
'''
IPv4 SNMP data
@variable keys:list<str> List of avaiable keys
'''
def __init__(self):
'''
Constructor
'''
snmp = None
with open('/proc/net/snmp', 'rb') as file:
snmp = file.read()
snmp = snmp.decode('utf-8', 'replace')
filter_ = lambda array : filter(lambda x : not x == '', array)
snmp = list(map(lambda x : x.split(' '), filter_(snmp.split('\n'))))
snmp_h = filter(lambda i : i % 2 == 0, range(len(snmp)))
snmp_d = filter(lambda i : i % 2 == 0, range(len(snmp)))
snmp_h = list(map(lambda i : snmp[i], snmp_h))
snmp_d = list(map(lambda i : snmp[i], snmp_d))
snmp = zip(snmp_h, snmp_d)
self.__info = {}
self.keys = []
for header_list, data_list in snmp:
prefix = header_list[0][:-1]
for suffix, value in zip(header_list[1:], data_list[1:]):
key = prefix + suffix
self.__info[key] = int(value)
self.keys.append(key)
def __contains__(self, key):
'''
Get whether or not a key is available
@param key:str The key
@return :bool The availability
'''
return key in self.__info
def __getitem__(self, key):
'''
Lookup a field from '/proc/net/snmp'
@param key:str The field name
@return :int The value of the field
'''
return self.__info[key]
|