X-Git-Url: https://git.madduck.net/etc/mutt.git/blobdiff_plain/6e0fbe0a20e45362d6cff2d9d4d7ff3516f98f5e..db13fabef4016b65602264e263ac23ae332ec660:/.mutt/sendmail diff --git a/.mutt/sendmail b/.mutt/sendmail index 9efaea3..b125941 100755 --- a/.mutt/sendmail +++ b/.mutt/sendmail @@ -20,10 +20,30 @@ settrap () { trap "$@" 0 1 2 3 4 5 6 7 8 10 11 12 13 14 15; } cleanup () { rm -f "$TMPFILE"; settrap -; } settrap cleanup +argtype=s +recipients= sendmail_args= +for i in "$@"; do + case "$argtype/$i" in + (s/--) argtype=r;; + (s/*) sendmail_args="${sendmail_args} $i";; + (r/*) recipients="${recipients} $i";; + esac +done + cat > $TMPFILE -args=$(for a in $@; do case "$a" in (*@*) echo "--arg=$a";; esac; done) -run-parts --umask=0077 --arg="$TMPFILE" $args -- "$CHECKSDIR" -[ "$1" = -- ] && shift -$SENDMAIL "$@" < "$TMPFILE" + +remove_headers= +if ! formail -czx "Resent-" < "$TMPFILE" | grep -q .; then + # only do this for original mails, not bounces + recipients="$recipients $(formail -czx "X-Bcc" < "$TMPFILE" | tr -d ',')" + remove_headers="$remove_headers -IX-Bcc" +fi +args=$(for i in $recipients; do echo "--arg=$i"; done) +run-parts --exit-on-error --umask=0077 --arg="$TMPFILE" $args -- "$CHECKSDIR" + +recipients=$(echo "$recipients" | xargs) + +formail $remove_headers < "$TMPFILE" \ + | eval $SENDMAIL "$sendmail_args" -- "$recipients" cleanup