X-Git-Url: https://git.madduck.net/etc/mailfilter.git/blobdiff_plain/48a11b9090d810861f01fc1c66e02b34aa35eb3a..11af75d561b65b76ff0c83062909ba690ee1a2e6:/procmail/tickle diff --git a/procmail/tickle b/procmail/tickle index 1eb4ce6..f03d1ab 100644 --- a/procmail/tickle +++ b/procmail/tickle @@ -1,31 +1,40 @@ :0 +* ! DEST ?? . +* ! TICKLE_DELIVERED ?? . * ORIGINAL_TO ?? ^.+@tickle\.madduck\.net$ * ORIGINAL_TO ?? ^\/[^@]+ { + DELIVERY_TIME=04:20 STAMP + :0 * MATCH ?? ^[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]$ - { STAMP=$MATCH } + { DELAY="@$MATCH" } + + :0 E + * MATCH ?? ^[0-9]+h$ + * MATCH ?? ^\/[^h]+ + { DELAY="$DATE + $MATCH hours" } + + JUST_DATE="`$BIN_DATE -d \"$DATE\" +%x`" :0 E * MATCH ?? ^[0-9]+m$ * MATCH ?? ^\/[^m]+ - { DATESTR="$DATE + $MATCH months 00:00" } + { DELAY="$JUST_DATE + $MATCH months $DELIVERY_TIME" } :0 E * MATCH ?? ^[0-9]+w$ * MATCH ?? ^\/[^w]+ - { DATESTR="$DATE + $MATCH weeks 00:00" } + { DELAY="$JUST_DATE + $MATCH weeks $DELIVERY_TIME" } :0 E * MATCH ?? ^[0-9]+d?$ * MATCH ?? ^\/[^d]+ - { DATESTR="$DATE + $MATCH days 00:00" } + { DELAY="$JUST_DATE + $MATCH days $DELIVERY_TIME" } - :0 E - * MATCH ?? ^[0-9]+h$ - * MATCH ?? ^\/[^h]+ - { DATESTR="$DATE + $MATCH hours" } + JUST_DATE + DELIVERY_TIME :0 E { @@ -34,15 +43,30 @@ HOST } - :0 - * ! STAMP ?? . - { STAMP=`/bin/date +'%s (%c)' -d "$DATESTR"` } - - LOG="tickle: stamping message $MSGID with $STAMP$NL" + DELAYED_QUEUE=$BASE/.store/ :0 fw - |$FORMAIL -i "X-Tickle: $STAMP" + |$FORMAIL -i 'X-Tickle: yes' - :0 - $BASE/.tickler/ +# :0 +# * ! STAMP ?? . +# { STAMP=`$BIN_DATE +'%s (%c)' -d "$DELAY"` } +# +# :0 +# * ! STAMP ?? ^[0-9]+ \([A-Za-z ]+ [0-9 :]+\)$ +# { +# LOG="tickle: error creating timestamp ($STAMP), using \$now$NL" +# STAMP="`$BIN_DATE +%s` (ERROR: original stamp '$STAMP' invalid)" +# } +# +# :0 E +# { LOG="tickle: stamping message $MSGID with $STAMP$NL" } +# +# :0 fw +# |$FORMAIL -i "X-Tickle: $STAMP" +# +# :0 +# { DEST=$TICKLER_QUEUE } } + +# vim:ft=procmail