X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=sysd-mail-once;h=c5cd8c84670c257448e19e6ec9b73b58f6a1c8f3;hb=bc712f26afdccd6ecea609edc3705ae719c55b8d;hp=e4305aec3ce621764cf517f9d311c179106bc79b;hpb=d9bc271d0faf80847ed819cbd6f9220667ff43d8;p=log-quiet diff --git a/sysd-mail-once b/sysd-mail-once index e4305ae..c5cd8c8 100755 --- a/sysd-mail-once +++ b/sysd-mail-once @@ -18,12 +18,19 @@ set -eE -o pipefail trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" returned $?" >&2' ERR errors=3 -cbase=/var/local/cron-errors -case "$1" in +tmp=(~) +cbase="${tmp[0]}/sysd-mail-once-state" +to=root +dryrun=false +print_all=false +while [[ $1 == -* ]]; do + case "$1" in -h|--help) - cat <>$file fi + fi fi -else # $@ failed - if [[ $file ]]; then - i=${file#$c} - if (( i < errors )); then - new_file=$c$((i+1)) - mv $file $new_file - file=$new_file - if [[ $file == $c$errors ]]; then - journalctl -u $service.service --after-cursor=$(<$file) | \ - mail -s "$HOSTNAME: $service failure" $u@localhost - fi - fi + else + file=${c}1 + if $dryrun; then + printf "dryrun: creating $file, contents: %s\n" "$cursor" + else + printf "%s\n" "$cursor" >$file + fi + if (( errors == 1 )); then + send_mail=true + fi + fi + if $send_mail; then + if $print_all; then + cursor=$(head -n1 $file) else - file=${c}1 - printf "%s\n" "$cursor" >$file + cursor=$(tail -n1 $file) + fi + echo "sysd-mail-once: emailing on $errors errors. exit code: $code" + mi exim -odf -t <= $errors errors." + mi exim -odf -t <