Add network traffic icons & minor refactor

This commit is contained in:
Thaynã B. Moretti 2019-07-09 22:27:59 -03:00
parent 55478e2e8d
commit 21e2f46564
No known key found for this signature in database
GPG key ID: 6F6E110817B19E8D
4 changed files with 57 additions and 15 deletions

View file

@ -2,6 +2,7 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
"""Displays network traffic """Displays network traffic
No extra configuratio needed.
""" """
import psutil import psutil
@ -12,7 +13,11 @@ import bumblebee.output
import bumblebee.engine import bumblebee.engine
import bumblebee.util import bumblebee.util
WIDGET_NAME = 'network_traffic'
class Module(bumblebee.engine.Module): class Module(bumblebee.engine.Module):
"""Bumblebee main module """
def __init__(self, engine, config): def __init__(self, engine, config):
super(Module, self).__init__(engine, config) super(Module, self).__init__(engine, config)
@ -21,9 +26,21 @@ class Module(bumblebee.engine.Module):
self._download_tx = self._bandwidth.bytes_recv() self._download_tx = self._bandwidth.bytes_recv()
self._upload_tx = self._bandwidth.bytes_sent() self._upload_tx = self._bandwidth.bytes_sent()
except: except Exception:
""" We do not want do explode anything """
pass pass
@classmethod
def state(cls, widget):
"""Return the widget state"""
if widget.name == '{}.rx'.format(WIDGET_NAME):
return 'rx'
elif widget.name == '{}.tx'.format(WIDGET_NAME):
return 'tx'
return None
def update(self, widgets): def update(self, widgets):
try: try:
download_tx = self._bandwidth.bytes_recv() download_tx = self._bandwidth.bytes_recv()
@ -35,50 +52,63 @@ class Module(bumblebee.engine.Module):
self.update_widgets(widgets, download_rate, upload_rate) self.update_widgets(widgets, download_rate, upload_rate)
self._download_tx, self._upload_tx = download_tx, upload_tx self._download_tx, self._upload_tx = download_tx, upload_tx
except: except Exception:
""" We do not want do explode anything """
pass pass
def update_widgets(self, widgets, download_rate, upload_rate): @classmethod
def update_widgets(cls, widgets, download_rate, upload_rate):
"""Update tx/rx widgets with new rates"""
del widgets[:] del widgets[:]
widgets.extend(( widgets.extend((
TrafficWidget(text=download_rate, icon=''), TrafficWidget(text=download_rate, direction='tx'),
TrafficWidget(text=upload_rate, icon='') TrafficWidget(text=upload_rate, direction='rx')
)) ))
class BandwidthInfo(object): class BandwidthInfo(object):
"""Get received/sent bytes from network adapter"""
def bytes_recv(self): def bytes_recv(self):
"""Return received bytes"""
return self.bandwidth().bytes_recv return self.bandwidth().bytes_recv
def bytes_sent(self): def bytes_sent(self):
"""Return sent bytes"""
return self.bandwidth().bytes_sent return self.bandwidth().bytes_sent
def bandwidth(self): def bandwidth(self):
"""Return bandwidth information"""
io_counters = self.io_counters() io_counters = self.io_counters()
return io_counters[self.default_network_adapter()] return io_counters[self.default_network_adapter()]
def default_network_adapter(self): @classmethod
def default_network_adapter(cls):
"""Return default active network adapter"""
gateway = netifaces.gateways()['default'] gateway = netifaces.gateways()['default']
if (len(gateway) == 0): if not gateway:
raise 'No default gateway found' raise 'No default gateway found'
return gateway[netifaces.AF_INET][1] return gateway[netifaces.AF_INET][1]
def io_counters(self): @classmethod
def io_counters(cls):
"""Return IO counters"""
return psutil.net_io_counters(pernic=True) return psutil.net_io_counters(pernic=True)
class TrafficWidget(object): class TrafficWidget(object):
def __new__(self, text, icon): """Create a traffic widget with humanized bytes string with proper icon (up/down)"""
widget = bumblebee.output.Widget() def __new__(cls, text, direction):
widget.set('theme.minwidth', '00000000KiB/s') widget = bumblebee.output.Widget(name='{0}.{1}'.format(WIDGET_NAME, direction))
widget.full_text(self.humanize(text, icon)) widget.set('theme.minwidth', '0000000KiB/s')
widget.full_text(cls.humanize(text))
return widget return widget
@staticmethod @staticmethod
def humanize(text, icon): def humanize(text):
"""Return humanized bytes"""
humanized_byte_format = bumblebee.util.bytefmt(text) humanized_byte_format = bumblebee.util.bytefmt(text)
return '{0} {1}/s'.format(icon, humanized_byte_format) return '{0}/s'.format(humanized_byte_format)

View file

@ -92,6 +92,10 @@
"rx": { "prefix": "down"}, "rx": { "prefix": "down"},
"tx": { "prefix": "up"} "tx": { "prefix": "up"}
}, },
"network_traffic": {
"rx": { "prefix": "down" },
"tx": { "prefix": "up" }
},
"mpd": { "mpd": {
"playing": { "prefix": ">" }, "playing": { "prefix": ">" },
"paused": { "prefix": "||" }, "paused": { "prefix": "||" },

View file

@ -145,6 +145,10 @@
"rx": { "prefix": "" }, "rx": { "prefix": "" },
"tx": { "prefix": "" } "tx": { "prefix": "" }
}, },
"network_traffic": {
"rx": { "prefix": "" },
"tx": { "prefix": "" }
},
"mpd": { "mpd": {
"playing": { "prefix": "" }, "playing": { "prefix": "" },
"paused": { "prefix": "" }, "paused": { "prefix": "" },

View file

@ -129,6 +129,10 @@
"rx": { "prefix": "\uf365" }, "rx": { "prefix": "\uf365" },
"tx": { "prefix": "\uf35f" } "tx": { "prefix": "\uf35f" }
}, },
"network_traffic": {
"rx": { "prefix": "\uf365" },
"tx": { "prefix": "\uf35f" }
},
"mpd": { "mpd": {
"playing": { "prefix": "\uf488" }, "playing": { "prefix": "\uf488" },
"paused": { "prefix": "\uf210" }, "paused": { "prefix": "\uf210" },