Reimplement net status as checking carrier rather than addr
[khatus.git] / x2 / src / bash / exe / khatus.sh
CommitLineData
438d0d5f
SK
1#! /bin/bash
2
75b23ff8
SK
3MSG_FS='|'
4
4d314e0f
SK
5set -e
6
75b23ff8
SK
7executable_name_of_cmd() {
8 basename "$(echo $1 | awk '{print $1; exit}')"
d33e9656
SK
9}
10
9ab9a718 11run_producer() {
d33e9656
SK
12 pipe="$1"
13 bin="$2"
14 cmd="$3"
75b23ff8 15 executable_name="$4"
c40b9076
SK
16 perf_log="$5"
17
18 if [ ! "$perf_log" = '' ]
19 then
20 # %S system time in seconds
21 # %U user time in seconds
22 # %e elapsed time in seconds
23 # %c context switches involuntary
24 # %w context switches voluntary
25 # %x exit code
26 time_fmt='%S %U %e %c %w %x'
27 time="/usr/bin/time -ao ${perf_log} -f "
28 time_sep=' '
29 else
30 time_fmt=''
31 time=''
32 time_sep=''
33 fi
34
35 ${time}"${time_fmt}"${time_sep}$bin/$cmd \
688fb20e
SK
36 2> >(
37 while read line
15a44039 38 do
8482fea6 39 echo "${NODE}${MSG_FS}${executable_name}${MSG_FS}error${MSG_FS}$line" > "$pipe"
15a44039 40 done \
688fb20e
SK
41 ) \
42 | while read line
43 do
8482fea6 44 echo "${NODE}${MSG_FS}${executable_name}${MSG_FS}data${MSG_FS}$line" > "$pipe"
688fb20e 45 done
7a2b16ba
SK
46 cmd_exit_code=${PIPESTATUS[0]}
47 if [ "$cmd_exit_code" -ne 0 ]
48 then
75b23ff8 49 echo
8482fea6 50 "${NODE}${MSG_FS}${executable_name}${MSG_FS}error${MSG_FS}NON_ZERO_EXIT_CODE${MSG_FS}$cmd_exit_code" \
75b23ff8 51 > "$pipe"
7a2b16ba 52 fi
ab99b556
SK
53}
54
ff74b448 55fork_watcher() {
75b23ff8
SK
56 pipe="$1"
57 bin="$2"
58 cmd="$3"
59 executable_name=$(executable_name_of_cmd "$cmd")
60 run_producer "$pipe" "$bin" "$cmd" "$executable_name" &
9ab9a718
SK
61}
62
63fork_poller() {
64 interval="$1"
c40b9076
SK
65 perf_log_dir="$2"
66 shift 2
75b23ff8
SK
67 pipe="$1"
68 bin="$2"
69 cmd="$3"
70
71 executable_name=$(basename "$(echo $cmd | awk '{print $1; exit}')")
c40b9076
SK
72
73 if [ ! "$perf_log_dir" = '' ]
74 then
75 cmd="$3"
75b23ff8 76 perf_log_file=${executable_name}.log
c40b9076
SK
77 mkdir -p "$perf_log_dir"
78 perf_log_path="$perf_log_dir/$perf_log_file"
79 fi
80
15a44039 81 while :
9ab9a718 82 do
75b23ff8 83 run_producer "$pipe" "$bin" "$cmd" "$executable_name" "$perf_log_path"
2b221665 84 sleep "$interval"
438d0d5f
SK
85 done &
86}
87
88main() {
d77c7373 89 declare -A opts=(
8482fea6 90 ["--node"]=$(hostname)
d77c7373 91 ["--dir_bin"]="$HOME/bin"
c40b9076 92 ["--dir_perf_logs"]=''
d33e9656 93 ["--file_pipe"]=$(mktemp)
d77c7373
SK
94 ["--weather_station_id"]='KJFK'
95 ["--screen_brightness_device_name"]='acpi_video0'
b4612a8a 96 ["--wifi_interface"]=''
d77c7373
SK
97 ["--disk_space_device"]='/'
98 ["--disk_io_device"]='sda'
99 ["--thermal_zone"]=0
100 ["--fan_path"]='/proc/acpi/ibm/fan'
75b23ff8 101 ["--pulseaudio_sink"]='0'
e3f715dd 102 ["--interval_datetime"]=1
b9d5cfd4 103 ["--interval_procs"]=1
e3f715dd
SK
104 ["--interval_brightness"]=1
105 ["--interval_weather"]=$(( 30 * 60)) # 30 minutes
106 ["--interval_mpd"]=1
107 ["--interval_volume"]=1
108 ["--interval_bluetooth"]=1
109 ["--interval_net_wifi"]=1
110 ["--interval_net_io"]=1
01da02dd 111 ["--interval_net_carrier"]=1
e3f715dd
SK
112 ["--interval_disk_space"]=1
113 ["--interval_disk_io"]=1
114 ["--interval_loadavg"]=1
115 ["--interval_temp"]=1
116 ["--interval_fan"]=1
117 ["--interval_mem"]=1
4d314e0f 118 )
d77c7373 119 while :
4d314e0f 120 do
d77c7373
SK
121 key="$1"
122 val="$2"
123 case "$key" in
124 '')
4d314e0f
SK
125 break
126 ;;
d77c7373
SK
127 * )
128 if [ -v opts["$key"] ]
129 then
44cfa739 130 if [ "$val" != "" ]
d77c7373
SK
131 then
132 opts["$key"]="$val"
133 shift
134 shift
135 else
136 echo "Option $key requires an argument" >&2
137 exit 1
138 fi
139 else
140 echo "Unknown option: $key" >&2
141 exit 1
142 fi
4d314e0f
SK
143 esac
144 done
145
b4612a8a
SK
146 if [ "${opts['--wifi_interface']}" = '' ]
147 then
148 echo 'Please provide the required parameter: --wifi_interface' >&2
149 exit 1
150 fi
151
6a12cab1
SK
152 (
153 echo '=============================================='
154 echo "Khatus starting with the following parameters:"
155 echo '=============================================='
d77c7373 156 for param in ${!opts[@]}
6a12cab1 157 do
d77c7373 158 echo "$param := ${opts[$param]}"
6a12cab1 159 done \
d77c7373
SK
160 | column -ts: \
161 | sort
6a12cab1 162 echo '----------------------------------------------'
4d314e0f
SK
163 ) >&2
164
8482fea6
SK
165 NODE="${opts['--node']}"
166
d77c7373
SK
167 screen_brightness_device_path='/sys/class/backlight'
168 screen_brightness_device_path+="/${opts['--screen_brightness_device_name']}"
169
170 # Just shorthand
d33e9656 171 pipe="${opts['--file_pipe']}"
d77c7373 172 bin="${opts['--dir_bin']}"
c40b9076 173 perf="${opts['--dir_perf_logs']}"
d77c7373 174
d33e9656
SK
175 rm -f "$pipe"
176 mkfifo "$pipe"
177
f37162a4
SK
178 cmd_sens_screen_brightness='khatus_sensor_screen_brightness'
179 cmd_sens_screen_brightness+=" $screen_brightness_device_path"
2b221665 180
654ea6e2 181 cmd_sens_weather="khatus_sensor_weather $bin ${opts['--weather_station_id']}"
75b23ff8
SK
182 cmd_sens_disk_space="khatus_sensor_disk_space $bin ${opts['--disk_space_device']}"
183 cmd_sens_disk_io="khatus_sensor_disk_io $bin ${opts['--disk_io_device']}"
d77c7373 184 cmd_sens_temperature="khatus_sensor_temperature ${opts['--thermal_zone']}"
75b23ff8 185 cmd_sens_fan="khatus_sensor_fan $bin ${opts['--fan_path']}"
d77c7373 186 cmd_sens_bluetooth="khatus_sensor_bluetooth_power $bin"
75b23ff8 187 cmd_sens_mpd="khatus_sensor_mpd $bin"
d77c7373
SK
188 cmd_sens_net_addr_io="khatus_sensor_net_addr_io $bin"
189 cmd_sens_volume="khatus_sensor_volume $bin"
b4612a8a 190 cmd_sens_wifi="khatus_sensor_net_wifi_status $bin ${opts['--wifi_interface']}"
75b23ff8
SK
191 cmd_sens_loadavg="khatus_sensor_loadavg $bin"
192 cmd_sens_memory="khatus_sensor_memory $bin"
193
e3f715dd 194 fork_watcher "$pipe" "$bin" "khatus_sensor_energy $bin"
cf7cff1c 195 fork_watcher "$pipe" "$bin" "khatus_sensor_devices $bin"
e3f715dd 196 fork_poller "${opts['--interval_datetime']}" "$perf" "$pipe" "$bin" khatus_sensor_datetime
b9d5cfd4 197 fork_poller "${opts['--interval_procs']}" "$perf" "$pipe" "$bin" "khatus_sensor_procs $bin"
e3f715dd
SK
198 fork_poller "${opts['--interval_brightness']}" "$perf" "$pipe" "$bin" "$cmd_sens_screen_brightness"
199 fork_poller "${opts['--interval_weather']}" "$perf" "$pipe" "$bin" "$cmd_sens_weather"
200 fork_poller "${opts['--interval_mpd']}" "$perf" "$pipe" "$bin" "$cmd_sens_mpd"
201 fork_poller "${opts['--interval_volume']}" "$perf" "$pipe" "$bin" "$cmd_sens_volume"
202 fork_poller "${opts['--interval_bluetooth']}" "$perf" "$pipe" "$bin" "$cmd_sens_bluetooth"
203 fork_poller "${opts['--interval_net_wifi']}" "$perf" "$pipe" "$bin" "$cmd_sens_wifi"
204 fork_poller "${opts['--interval_net_io']}" "$perf" "$pipe" "$bin" "$cmd_sens_net_addr_io"
205 fork_poller "${opts['--interval_disk_space']}" "$perf" "$pipe" "$bin" "$cmd_sens_disk_space"
206 fork_poller "${opts['--interval_disk_io']}" "$perf" "$pipe" "$bin" "$cmd_sens_disk_io"
207 fork_poller "${opts['--interval_loadavg']}" "$perf" "$pipe" "$bin" "$cmd_sens_loadavg"
208 fork_poller "${opts['--interval_temp']}" "$perf" "$pipe" "$bin" "$cmd_sens_temperature"
209 fork_poller "${opts['--interval_fan']}" "$perf" "$pipe" "$bin" "$cmd_sens_fan"
210 fork_poller "${opts['--interval_mem']}" "$perf" "$pipe" "$bin" "$cmd_sens_memory"
01da02dd 211 fork_poller "${opts['--interval_net_carrier']}" "$perf" "$pipe" "$bin" khatus_sensor_net_carrier
75b23ff8 212
9d47c179 213 stdbuf -o L tail -f "$pipe"
438d0d5f
SK
214}
215
216main $@
This page took 0.068255 seconds and 4 git commands to generate.