Mail filter and rules¶
You can filter your incoming mails with Sieve. Sieve scripts can be used to automatically delete or forward messages, to send autoreplies, to sort emails into folders as they arrive, to mark messages as read or flagged or to reject messages at or after delivery.
A Sieve script consists of a number of conditions which are applied to incoming mail; if an email matches a test, then the actions associated with that test are performed.
Warning
The spamfolder needs to be enabled to use Sieve filtering.
ManageSieve¶
To create and manage scripts, you can use any tool speaking the ManageSieve protocol. Many E-Mail clients support the protocol, you can find a list of tools and plugins at sieve.info. You can edit your scripts in the webmailer.
Tip
We recommend the Sieve Script Editor which has a GUI to drag and drop the rules and is available for many platforms and apps.
Access¶
If you need to provide access data you can use the following:
Server |
your Hostname ( |
Port |
|
Username |
Your email address, including the domain |
Password |
Your password for the email address |
Scripts¶
You can store as many Sieve scripts as you like but only one can be active at a time. There’s a good Sieve reference online which describes the components which make up a script.
Examples¶
Sort mails into folder¶
In this example we sort mails from a mailinglist into a folder, sort mails to *@allcolorsarebeautiful.example
into another folder and lower the maximum spam score to 4.
require ["fileinto", "reject", "relational", "comparator-i;ascii-numeric"];
# Mails with a spam score greater than 4 are probably SPAM, sort them and stop
if allof (
not header :matches "X-Rspamd-Score" "-*",
header :value "ge" :comparator "i;ascii-numeric" "X-Rspamd-Score" "4")
{
fileinto "Spam";
stop;
}
# Sort mails from mailinglist into folder mailinglist
if address :is "from" ["mailinglist@allcolorsarebeautiful.example", "anothermailinglist@allcolorsarebeautiful.example" ]
{
fileinto "mailinglist";
stop;
}
# Sort mails to *@allcolorsarebeautiful.example into a special folder
if address :is :domain "to" "allcolorsarebeautiful.example"
{
fileinto "important";
stop;
}
# Forward all incoming mails to multiple recipients
redirect "recipient1@example.com";
redirect "recipient2@example.com";
# The command "keep" is executed automatically, if no other action is taken.
Tip
stop;
tells the Sieve engine to stop here, without checking for more rules.
Vacation auto reply¶
require ["variables", "vacation"];
if header :matches "Subject" "*" {
set "subjwas" "${1}";
}
vacation
# Reply at most once a week to a same sender
:days 7
:subject "Out of office ${subjwas}"
"I'm not in the office from 20 May until 31 May.
Best regards
Jane Doe";
# The command "keep" is executed automatically, if no other action is taken.
Send notification about new mails to another mail address¶
require ["enotify", "variables"];
# Set notification address
set "notify_address" "mailto:notfyme@example.com";
# Set from address for notification
set "notify_from" "mailnotifier@example.com";
# Store From and Subject in variables
if address :matches "from" "*" {
set "from_address" "${1}";
}
if header :matches "subject" "*" {
set "subject" "${1}";
}
# Send notification mail
notify :from "${notify_from}" :message "New mail received from: ${from_address} Subject: ${subject}" "${notify_address}";
You can find many more examples in the Dovecot Wiki.
Troubleshooting¶
Logging¶
If something does not work check the log at ~/users/$MAILBOX/.dovecot.sieve.log
. However, this log is only written if Sieve itself encounters an error. If it does not exist, your script was executed successfully.
Debugging tools¶
You can use the sieve-test
command-line utility to test your Sieve filter script and see which options would be performed:
[isabell@stardust ~]$ SENDER_ADDRESS=mail@example.com # replace mail@example.com with the sender address to test
[isabell@stardust ~]$ TEST_MAILBOX=isa # replace isa with the name of the mailbox to test
[isabell@stardust ~]$ EMAIL_FILE=/home/isabell/testmail.eml # replace the path with the path to the mail file you want to test
[isabell@stardust ~]$ sieve-test -D -t - -Tlevel=matching -a $SENDER_ADDRESS -l $HOME/users/$TEST_MAILBOX $HOME/users/$TEST_MAILBOX/.dovecot.sieve $EMAIL_FILE
You can also use Fastmail’s Sieve Tester to test the syntax of scripts and checks what actions a script causes to the provided email message.
Mailaddress with dots¶
Warning
In some cases Sieve may not work with mail addresses with a dot in the local part like my.address@example.com
.
Existing maildirs with a dot in the local part have a path like ~/users/my:address
but Sieve expects a double colon like ~/users/my::address
. The simple workaround for existing maildirs is to set a symlink:
[isabell@stardust ~/users]$ ln -s my\:address my\:\:address
Sieve will then store and read the scripts from the linked folder. For newly created mailboxes, this problem is already fixed and you dont need a workaround.
Background¶
Sieve scripts are stored in the corresponding mailbox folder ~/users/$MAILBOX/sieve/
. The active script is symlinked from ~/users/$MAILBOX/.dovecot.sieve
:
[isabell@stardust ~/users/anna]$ readlink -f .dovecot.sieve
/home/isabell/users/anna/sieve/test.sieve
Dovecot will compile a ~/users/$MAILBOX/.dovecot.svbin
from this script for the first mail delivered to the mailbox. It will also recompile for each new mail if the symlink or the script has been changed and the timestamp is updated. You can also trigger this by using sievec /path/to/script.sieve
and check if it compiles correctly.
Tip
When using ManageSieve the scripts are compiled and validated before they are uploaded and installed by symlinking. This can prevent you from inadvertently installing a broken Sieve script.