2020-07-07 10:55:06 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
# Module showing network traffic. Shows how much data has been received (RX) or
|
|
|
|
# transmitted (TX) since the previous time this script ran. So if run every
|
|
|
|
# second, gives network traffic per second.
|
|
|
|
|
2020-10-02 15:33:33 +02:00
|
|
|
lasttime=${XDG_CACHE_HOME:-$HOME/.cache}/nettraf_time
|
2020-07-07 10:55:06 +02:00
|
|
|
|
|
|
|
update() {
|
|
|
|
sum=0
|
|
|
|
for arg; do
|
|
|
|
read -r i < "$arg"
|
|
|
|
sum=$(( sum + i ))
|
|
|
|
done
|
|
|
|
cache=${XDG_CACHE_HOME:-$HOME/.cache}/${1##*/}
|
|
|
|
[ -f "$cache" ] && read -r old < "$cache" || old=0
|
|
|
|
printf %d\\n "$sum" > "$cache"
|
|
|
|
printf %d\\n $(( sum - old ))
|
|
|
|
}
|
|
|
|
|
|
|
|
[ -f "$lasttime" ] && read -r previoustime < "$lasttime" || previoustime=0
|
|
|
|
rx=$(update /sys/class/net/[ew]*/statistics/rx_bytes)
|
|
|
|
tx=$(update /sys/class/net/[ew]*/statistics/tx_bytes)
|
|
|
|
timedifference=$(( "$(date +'%s')" - "$previoustime" ))
|
2020-10-02 15:33:33 +02:00
|
|
|
|
|
|
|
if [ "$timedifference" -gt 0 ]; then
|
2020-07-17 15:05:59 +02:00
|
|
|
rx_avg=$(( "$rx" / "$timedifference" ))
|
2020-07-18 12:47:08 +02:00
|
|
|
tx_avg=$(( "$tx" / "$timedifference" ))
|
2020-07-17 15:05:59 +02:00
|
|
|
else
|
2020-10-02 15:33:33 +02:00
|
|
|
rx_avg=$rx
|
|
|
|
tx_avg=$tx
|
2020-07-17 15:05:59 +02:00
|
|
|
fi
|
|
|
|
|
2020-10-02 15:33:33 +02:00
|
|
|
printf '⬇%s ⬆%s\n' $(numfmt --to=iec $rx_avg) $(numfmt --to=iec $tx_avg)
|
|
|
|
date +'%s' > "$lasttime"
|