2020-05-01 16:55:09 -04: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.
|
|
|
|
|
|
|
|
case "$BLOCK_BUTTON" in
|
|
|
|
3) notify-send "🌐 Network traffic module" "🔻: Traffic received
|
|
|
|
🔺: Traffic transmitted" ;;
|
2020-05-07 17:31:42 -04:00
|
|
|
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
2020-05-01 16:55:09 -04:00
|
|
|
esac
|
|
|
|
|
2020-05-29 16:03:19 -04:00
|
|
|
logfile="${XDG_CACHE_HOME:-$HOME/.cache}/netlog"
|
2020-05-30 17:50:37 -04:00
|
|
|
read -r rxprev txprev < "$logfile"
|
2020-05-01 16:55:09 -04:00
|
|
|
|
2020-05-30 11:09:12 -04:00
|
|
|
rxcurrent="$(($(paste -d '+' /sys/class/net/[ew]*/statistics/rx_bytes)))"
|
2020-05-30 14:09:39 -04:00
|
|
|
txcurrent="$(($(paste -d '+' /sys/class/net/[ew]*/statistics/tx_bytes)))"
|
2020-05-01 16:55:09 -04:00
|
|
|
|
2020-05-30 17:50:37 -04:00
|
|
|
printf "🔻%sKiB 🔺%sKiB\\n" "$(((rxcurrent-rxprev)/1024))" "$(((txcurrent-txprev)/1024))"
|
2020-05-01 16:55:09 -04:00
|
|
|
|
2020-05-29 16:03:19 -04:00
|
|
|
echo "$rxcurrent $txcurrent" > "$logfile"
|