diff options
-rwxr-xr-x | etc/NetworkManager/dispatcher.d/90-sbar | 5 | ||||
-rw-r--r-- | home/xyz/.config/qrcp/config.json | 2 | ||||
-rwxr-xr-x | home/xyz/.local/bin/sbar | 53 |
3 files changed, 13 insertions, 47 deletions
diff --git a/etc/NetworkManager/dispatcher.d/90-sbar b/etc/NetworkManager/dispatcher.d/90-sbar new file mode 100755 index 00000000..c45232da --- /dev/null +++ b/etc/NetworkManager/dispatcher.d/90-sbar @@ -0,0 +1,5 @@ +#!/bin/sh + +case "$2" in + up|down) kill -RTMIN+2 $(pidof -x sbar);; +esac diff --git a/home/xyz/.config/qrcp/config.json b/home/xyz/.config/qrcp/config.json index b7f02141..1bbb0ae1 100644 --- a/home/xyz/.config/qrcp/config.json +++ b/home/xyz/.config/qrcp/config.json @@ -1,6 +1,6 @@ { "fqdn": "", - "interface": "wlp6s0", + "interface": "enp2s0", "port": 49153, "keepAlive": false, "path": "", diff --git a/home/xyz/.local/bin/sbar b/home/xyz/.local/bin/sbar index 0a80dd4d..ce80ceda 100755 --- a/home/xyz/.local/bin/sbar +++ b/home/xyz/.local/bin/sbar @@ -1,35 +1,9 @@ #!/bin/sh -# steal from pystardust, GPL3 license: https://github.com/pystardust/sbar -# modified to fit my own need +# modified from pystardust, GPLv3 license: https://github.com/pystardust/sbar # INIT -pid_file="$XDG_CACHE_HOME/pidofbar" -vpn_fifo="$XDG_CACHE_HOME/sbar_vpn_fifo" sec=0 -# exit if sbar is already running, fix when startx in another tty, the other tty sbar not working -# maybe try dwmblocks's approach of using `kill $(pidof -x sbar)`, so can run different sbar in different tty -# but then vpn_fifo becomes a problem too, not sure how to solve -if ! [ -e "$pid_file" ] || ! pidof -qsx sbar -o "$$"; then - printf '%s' "$$" > "$pid_file" -else - exit -fi -if ! [ -e "$vpn_fifo" ]; then - mkfifo "$vpn_fifo" -elif ! [ -p "$vpn_fifo" ]; then - exit 1 -fi - -bool () { - read str - if [ "$str" = "on" ] || [ "$str" = "up" ] || [ "$str" = "Connected" ]; then - echo 1 - else - echo 0 - fi -} - # MODULES update_time () { time="$(date '+%a %m/%d %H:%M') $(TZ=Asia/Shanghai date '+/%d %H:')" @@ -40,11 +14,8 @@ update_cap () { } update_net () { - net="$(bool < /sys/class/net/wlp6s0/operstate)" -} - -update_vpn () { - vpn="$(awk '{print $3}' "$vpn_fifo" | bool)" + net="$(if nmcli -t --fields type,state device | grep -q '\(ethernet\|wifi\):connected'; then echo 1; else echo 0; fi)" + vpn="$(if nmcli -t --fields type,state device | grep -q 'tun:connected'; then echo 1; else echo 0; fi)" } update_vol () { @@ -54,7 +25,7 @@ update_vol () { update_mic () { # $(NF-1) for both alsa and pulseaudio - mic="$(amixer get Capture | awk -F'[][]' 'END{print $(NF-1)}' | bool)" + mic="$(amixer get Capture | awk -F '[][]' 'END{print ($(NF-1)=="on")?1:0}')" } update_bat () { @@ -73,6 +44,7 @@ display () { } # modules that don't update on their own need to be run at the start for getting their initial value +update_net update_vol update_mic @@ -81,28 +53,17 @@ update_mic trap "update_mic;display" "RTMIN" trap "update_vol;display" "RTMIN+1" # xev can't read my toggle internet keyboard key, don't know what key to use in sxhkd to send signal -#trap "update_net;display" "RTMIN+2" +trap "update_net;display" "RTMIN+2" trap "update_cap;display" "RTMIN+3" -trap "update_vpn;display" "RTMIN+4" # to update it from external commands ## kill -m "$(cat "$XDG_CACHE_HOME/pidofbar")" # where m = 34 + n -# `mullvad status` write logs everytime it is called -# so I use `mullvad status listen`, this implementation is kinda bloat, maybe there's better way -# should be put after trap? -sh -c ' - mullvad status listen | while read -r line; do - kill -RTMIN+4 "$(cat "$1")" - echo "$line" > "$2" - done & -' shell "$pid_file" "$vpn_fifo" - while :; do sleep 1 & wait [ $((sec % 5 )) -eq 0 ] && update_time # update time every 5 seconds - [ $((sec % 5 )) -eq 0 ] && update_net + [ $((sec % 60)) -eq 0 ] && update_net update_cap [ $((sec % 60)) -eq 0 ] && update_bat #[ $((sec % 300)) -eq 1 ] && update_event |