I have a pretty usual requirement with procmail but I am unable to get the results somehow. I have procmailrc file with this content:
:0
* ^To.*@myhost
| /usr/bi
That is just fine, just put fw
after :0
(:0 fw
). Your python program will receive the mail on stdin
. You have to 'echo' the possibly transformed mail on stdout
.
fw
means:
f
Consider the pipe as a filter.w
Wait for the filter or program to finish and check its exitcode (normally ignored); if the filter is unsuccessful, then the text will not have been filtered.My SPAM checker (bogofilter) just works like that. It adds headers and later procmail-rules do something depending on these headers.
The log excerpt clearly states that your script is executed, even if it doesn't show the desired effect. I'd expect procmail to log an error if the execution failed.
Anyway, make sure that the user (uid) that procmail is executed with has the correct permissions to execute your script. Wire the script into procmail only if you succeeded testing with something like this (replace 'procmail' with the correct uid):
# sudo -u procmail /bin/sh -c '/bin/cat /work/scripts/mail.txt | /usr/bin/python /work/scripts/privilege_emails_forward.py'
Depending on your sudo configuration, you'd have to run this as root. Oh, and make sure you use absolute file paths.