Поддержка и обезьяны Кода внизу
Неудавшиеся обезьяны кода выше в пищевой цепи... аналитики, менеджеры проектов, непосредственные руководители и т.д.
Я довольно серьезен: разработчики главным образом счастливы быть разработчиками и не рассматривают BA/PM/LM как продвижение по службе...
Я нахожусь в подразделении IT крупной международной компании.
По умолчанию sieve обрабатывает почту, поступающую в почтовый ящик пользователя извне. Не существует встроенного способа последующей обработки папок.
Однако можно было бы собирать сообщения из папки cyrus ("горячая папка") и повторно отправлять их через обычный MTA в специальный почтовый ящик (" specialmailbox "), который, в свою очередь, имеет нужные вам правила сита.
Для этой цели вы можете использовать что-то вроде этого, например, через cron:
#!/bin/sh
for msg in /var/spool/cyrus/mail/hotfolder; do
sendmail speicalmailbox <$msg && rm $msg
done
Сообщения в" горячей "папке удаляются из файловой системы без удаления их из индекса cyrus это неоптимально. Вы можете использовать iprune
(часть дистрибутива cyrus, он удаляет сообщения из папок в зависимости от их возраста), чтобы исправить это. Необходимо удаление из файловой системы, поэтому мы не обрабатываем каждое сообщение несколько раз.
Новые версии dovecot и pidgeonhole теперь поставляются с командой sieve-filter. Таким образом, вы можете написать сценарий для сканирования всех почтовых ящиков на наличие папки «INBOX.Refilter», а затем запустить фильтр sieve для этой папки.
Этот сценарий предполагает, что вы структурировали свою почтовую папку как / var / vmail / domain / пользователь.
#!/bin/bash
FIND=/usr/bin/find
GREP=/bin/grep
RM=/bin/rm
SED=/bin/sed
SORT=/bin/sort
# BASE should point at /var/vmail/ and should have trailing slash
BASE="/var/vmail/"
RESORTFOLDER="INBOX.Refilter"
SEARCHFILE="dovecot-uidlist"
echo ""
echo "Search for messages to resort under ${BASE}"
echo "Started at: " `date`
echo "Looking for mailboxes with ${RESORTFOLDER}"
echo ""
# since RHEL5/CentOS5 don't have "sort -R" option to randomize, use the following example
# echo -e "2\n1\n3\n5\n4" | perl -MList::Util -e 'print List::Util::shuffle <>'
DIRS=`$FIND ${BASE} -maxdepth 3 -name ${SEARCHFILE} | \
$SED -n "s:^${BASE}::p" | $SED "s:/${SEARCHFILE}$:/:" | \
perl -MList::Util -e 'print List::Util::shuffle <>'`
# keep track of directories processed so far
DCNT=0
for DIR in ${DIRS}
do
UD="${BASE}${DIR}.${RESORTFOLDER}"
D=`echo "$DIR" | tr '/' ' ' | awk '{print $1}'`
U=`echo "$DIR" | tr '/' ' ' | awk '{print $2}'`
if [ -d "$UD/cur" ]
then
echo "`date` - $DIR"
echo " domain: $D"
echo " user: $U"
FILES=`find $UD/cur/ $UD/new/ -type f -name '*' | wc -l`
echo " files: $FILES"
if [[ $FILES -ge 1 ]]; then
echo "Run $FILES messages back through the sieve filter."
# -c2 means run at best-effort, -n7 is least priority possible
ionice -c2 -n7 sieve-filter -e -W -C -u "${U}@${D}" "${BASE}${DIR}.dovecot.sieve" "${RESORTFOLDER}"
fi
echo ""
fi
# the following is debug code, to stop the script after N directories
#DCNT=$(($DCNT+1))
#echo "DCNT: $DCNT"
#if [[ $DCNT -ge 5 ]]; then exit 0; fi
done
echo ""
echo "Finished at:" `date`
echo ""