]> git.donarmstrong.com Git - bin.git/commitdiff
fix the learn from spam to handle needs_rules properly
authorDon Armstrong <don@donarmstrong.com>
Wed, 18 May 2016 16:54:21 +0000 (09:54 -0700)
committerDon Armstrong <don@donarmstrong.com>
Wed, 18 May 2016 16:54:21 +0000 (09:54 -0700)
learn_from_spam

index 306b227c4e13975c49efc4bde800dda786910f22..5644096225e033bbcc5340dd4a723a7511c03510 100755 (executable)
@@ -19,8 +19,13 @@ if [ "$(basename $0)" = "learn_from_spam" ]; then
         formail -c < "$file" | grep -e '^From ' -e 'From: ' | spamassassin --remove-from-whitelist >/dev/null 2>&1;
         # check to see if it's still spam
         if ! $SPAM_CHECK < "$file" >/dev/null 2>&1; then
+            TMP="$(mktemp -d)"
+            trap "rm -f '$TMP'/file; rmdir '$TMP'" EXIT
             # this message is still not spam; may need custom rules
-            spamc < "$file" > ~/Maildir/spam/needs_rules/cur/"$(basename "$file")" 2>/dev/null;
+            spamc < "$file" > "$TMP/file" 2>/dev/null;
+            mv "$TMP/file" ~/Maildir/spam/needs_rules/cur/"$(basename "$file")";
+            trap - EXIT;
+            rmdir "$TMP";
         fi;
     done;
 elif [ "$(basename $0)" = "learn_from_ham" ]; then
@@ -29,7 +34,12 @@ elif [ "$(basename $0)" = "learn_from_ham" ]; then
         formail -c < "$file" |grep -e '^From ' -e 'From: ' -e 'To: ' -e 'Cc: '|spamassassin --add-to-whitelist >/dev/null 2>&1;
         if $SPAM_CHECK < "$file" >/dev/null 2>&1; then
             mkdir -p ~/Maildir/spam/needs_ham_rules/cur;
-            spamc < "$file" > ~/Maildir/spam/needs_ham_rules/cur/"$(basename "$file")" 2>/dev/null;
+            TMP="$(mktemp -d)"
+            trap "rm -f '$TMP'/file; rmdir '$TMP'" EXIT
+            spamc < "$file" > "$TMP/file" 2>/dev/null;
+            mv "$TMP/file" ~/Maildir/spam/needs_ham_rules/cur/"$(basename "$file")";
+            trap - EXIT;
+            rmdir "$TMP";
         fi;
     done;
 else