X-Git-Url: https://git.madduck.net/etc/mailfilter.git/blobdiff_plain/42effe4dc98d32fde6d40f4038f106b205ee29df..4077e14fe05f8b5b2988c91368e95afd5e21cc15:/procmail/tickle

diff --git a/procmail/tickle b/procmail/tickle
index 5c7d19b..2128713 100644
--- a/procmail/tickle
+++ b/procmail/tickle
@@ -1,50 +1,70 @@
+# The X-Tickle header has priority over the Original-To address
 :0
-* ! DEST ?? .
-* ! TICKLE_DELIVERED ?? .
+* ! POSTPONED ?? .
+*$ ^X-Tickle:${RE_SPACE}+\/${RE_NOT_SPACE}+
+{ TICKLE="$MATCH" }
+
+:0 E
+* ! POSTPONED ?? .
 * ORIGINAL_TO ?? ^.+@tickle\.madduck\.net$
 * ORIGINAL_TO ?? ^\/[^@]+
+{ TICKLE="$MATCH" }
+
+:0
+* TICKLE ?? .
+* ! DEST ?? .
 {
   DAILY_DELIVERY_TIME=04:20
   JUST_DATE="`$BIN_DATE -d \"$DATE\" +%x`"
 
   :0
-  * MATCH ?? ^[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]$
-  { DELAY="@$MATCH" }
+  * TICKLE ?? ^[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]$
+  { DELAY="@$TICKLE" }
 
   :0 E
-  * MATCH ?? ^[0-9]+h$
-  * MATCH ?? ^\/[^h]+
+  * TICKLE ?? ^[0-9]+h$
+  * TICKLE ?? ^\/[^h]+
   { DELAY="$DATE + $MATCH hours" }
 
   :0 E
-  * MATCH ?? ^[0-9]+m$
-  * MATCH ?? ^\/[^m]+
+  * TICKLE ?? ^[0-9]+m$
+  * TICKLE ?? ^\/[^m]+
   { DELAY="$JUST_DATE + $MATCH months $DAILY_DELIVERY_TIME" }
 
   :0 E
-  * MATCH ?? ^[0-9]+w$
-  * MATCH ?? ^\/[^w]+
+  * TICKLE ?? ^[0-9]+w$
+  * TICKLE ?? ^\/[^w]+
   { DELAY="$JUST_DATE + $MATCH weeks $DAILY_DELIVERY_TIME" }
 
   :0 E
-  * MATCH ?? ^[0-9]+d?$
-  * MATCH ?? ^\/[^d]+
+  * TICKLE ?? ^[0-9]+d?$
+  * TICKLE ?? ^\/[^d]+
   { DELAY="$JUST_DATE + $MATCH days $DAILY_DELIVERY_TIME" }
 
-  JUST_DATE
-  DAILY_DELIVERY_TIME
-
   :0 E
   {
-    LOG="tickle:      invalid date string: $MATCH$NL"
+    LOG="tickle:      invalid tickler date string: $TICKLE$NL"
     EXITCODE=69
     HOST
   }
 
+  JUST_DATE
+  DAILY_DELIVERY_TIME
+
+  :0
+  { RELEASE="`$BIN_DATE -d \"$DELAY\" +'%s (%c)'`" }
+
+  LOG="tickle:      delaying message until $RELEASE$NL"
+  DELAYED_QUEUE=$TICKLER_QUEUE
+
   :0 fw
-  |$FORMAIL -i "X-Tickle: $DELAY"
+  |$FORMAIL -I"X-Tickle: $RELEASE"
+
+  # store messages as read
+  MARK_READ=tickler
 
-  LOG="tickle:      delaying message until $DELAY$NL"
+  # unset DISABLE_DELAYS to always enable delaying for tickle messages
+  DISABLE_DELAYS
 }
 
 # vim:ft=procmail