X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=system-status;h=e137d06f3b4b15c44b884e6dc04e8eb17d0a3759;hb=246e575caf357c06b97fc728cb78295ab3bd8630;hp=25a637ee9606788c97e22949b470a811428abf16;hpb=7e4f3d0a6130b69b7f76a3ff13e510ffbeb1484b;p=distro-setup diff --git a/system-status b/system-status index 25a637e..e137d06 100755 --- a/system-status +++ b/system-status @@ -2,7 +2,8 @@ # Copyright (C) 2019 Ian Kelling # SPDX-License-Identifier: AGPL-3.0-or-later -# usage: runs 4 times every 15 seconds unless any args are passed, then just runs once +# usage: runs 4 times every 15 seconds unless any args are passed, or we +# are on battery power, then just runs once. if [ -z "$BASH_VERSION" ]; then echo "error: shell is not bash" >&2; exit 1; fi @@ -15,7 +16,7 @@ shopt -s dotglob lo() { /usr/local/bin/log-once "$@"; } write-status() { - chars=() + chars=("${first_chars[@]}") glob=(/nocow/btrfs-stale/*) if [[ -e ${glob[0]} ]]; then @@ -35,7 +36,12 @@ write-status() { chars+=("MAILPING!") fi + qlen=$(/usr/sbin/exiqgrep -o 60 -c -b | awk '{print $1}') + if ((qlen)); then + chars+=("q $qlen") + fi + cd /b/ds if ! make -q ~/.local/distro-begin || [[ $(<~/.local/distro-begin) != 0 ]]; then chars+=("DISTRO-BEGIN!") fi @@ -46,7 +52,6 @@ write-status() { f=~/.local/conflink if [[ -e $f ]]; then - cd /b/ds now=$(date +%s) fsec=$(stat -c%Y $f) fmin=$(( (fsec - now ) / 60 + 1 )) @@ -77,7 +82,7 @@ write-status() { spamcount=0 fi if (( spamcount <= 4 )); then - if grep -q 'spam acl condition' /var/log/exim4/paniclog; then + if grep -q 'spam acl condition' /var/log/exim4/paniclog &>/dev/null; then printf . >>$loglog fi /a/bin/distro-setup/epanic-clean @@ -92,6 +97,7 @@ write-status() { source /a/bin/bash_unpublished/source-state if [[ $MAIL_HOST == "$HOSTNAME" ]]; then + bbkmsg= if [[ $(systemctl is-active btrbk.timer) != active ]]; then chars+=("BTRBK.TIMER!") bbkmsg="btrbk.timer not enabled" @@ -100,7 +106,13 @@ write-status() { ## check if last snapshot was within an hour vol=o - snaps=(/mnt/root/btrbk/$vol.20*) + # this section generally copied from btrbk scripts, but + # this part modified to speed things up by about half a second. + # I'm not sure if its quite as reliable, but it looks pretty safe. + # Profiled it using time and also adding to the top of the file: + # set -x + # PS4='+ $(date "+%2N") ' + snaps=($(ls -1avdr /mnt/root/btrbk/$vol.20*|head -n1)) now=$(date +%s) maxtime=0 for s in ${snaps[@]}; do @@ -124,11 +136,23 @@ write-status() { fi } +# use this if we want to do something just once per minute +first_chars=() + +power=true +if [[ -e /sys/class/power_supply/AC/online && $(