From 6bf44622dcdc30fc5d33152380c236423754ac98 Mon Sep 17 00:00:00 2001 From: Jan-Philipp Litza Date: Thu, 16 Jan 2014 10:58:03 +0100 Subject: [PATCH] alfred: add statistics (uptime+traffic) --- .../files/lib/gluon/alfred/announce.sh | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/package/gluon-alfred/files/lib/gluon/alfred/announce.sh b/package/gluon-alfred/files/lib/gluon/alfred/announce.sh index 54d30b5a..0d716c59 100755 --- a/package/gluon-alfred/files/lib/gluon/alfred/announce.sh +++ b/package/gluon-alfred/files/lib/gluon/alfred/announce.sh @@ -12,11 +12,31 @@ fi . /lib/gluon/functions/model.sh . /lib/gluon/functions/sysconfig.sh +# set defaults [ -z "$ALFRED_DATA_TYPE" ] && ALFRED_DATA_TYPE=158 [ -z "$NET_IF" ] && NET_IF=br-client +[ -z "$TRAFFIC_FILE" ] && TRAFFIC_FILE=/var/run/traffic set -e +get_traffic() { + if [ -f "$TRAFFIC_FILE" ]; then + OLD_TIME="$(cut -d' ' -f1 "$TRAFFIC_FILE")" + OLD_RX="$(cut -d' ' -f2 "$TRAFFIC_FILE")" + OLD_TX="$(cut -d' ' -f3 "$TRAFFIC_FILE")" + else + OLD_TIME=0 + OLD_RX=0 + OLD_TX=0 + fi + NEW_TIME="$(cut -d' ' -f1 /proc/uptime)" + NEW_RX="$(cat /sys/class/net/bat0/statistics/rx_bytes)" + NEW_TX="$(cat /sys/class/net/bat0/statistics/tx_bytes)" + echo "$NEW_TIME $NEW_RX $NEW_TX" > "$TRAFFIC_FILE" + echo "$OLD_TIME $OLD_RX $OLD_TX $NEW_TIME $NEW_RX $NEW_TX" |\ + awk '{tdiff=$4-$1; print ($5-$2)/tdiff " " ($6-$3)/tdiff;}' +} + json_init json_add_string "hostname" "$(uci get 'system.@system[0].hostname')" @@ -61,4 +81,13 @@ json_add_object "network" json_close_array # adresses json_close_object # network +json_add_object "statistics" + json_add_int "uptime" "$(cut -d' ' -f1 /proc/uptime)" + TRAFFIC="$(get_traffic)" + json_add_object "traffic" + json_add_double "rx" "$(echo $TRAFFIC | cut -d' ' -f1)" + json_add_double "tx" "$(echo $TRAFFIC | cut -d' ' -f2)" + json_close_object +json_close_object # statistics + json_dump | tr -d '\n' | alfred -s "$ALFRED_DATA_TYPE"