How do I make "vnd.dovecot.environment" available?
Hi all,
According to the docs at https://wiki.dovecot.org/Pigeonhole/Sieve, some extensions are not available by default.
The docs tell me the sieve_plugins, sieve_extensions and/or sieve_global_extensions configs are involved, but I can find no authoritative documentation as to what the values should be.
What values must I use to make “vnd.dovecot.environment” available?
Adding "sieve_global_extensions = +vnd.dovecot.environment” to 90-sieve.conf seems to not be enough.
[root@gatekeeper ~]# sievec -D /var/lib/dovecot-sieve/default.sieve
sievec(root): Debug: sieve: Pigeonhole version 0.5.8 (b7b03ba2) initializing
sievec(root): Debug: sieve: include: sieve_global is not set; it is currently not possible to include :global' scripts. sievec(root): Debug: sieve: file storage: Using Sieve script path: /var/lib/dovecot-sieve/default.sieve sievec(root): Debug: sieve: file script: Opened script
default' from /var/lib/dovecot-sieve/default.sieve' default: line 5: error: require command: unknown Sieve capability
vnd.dovecot.environment'.
default: line 19: error: referring to variable in unknown namespace 'vnd'.
default: error: validation failed.
sievec(root): Fatal: failed to compile sieve script '/var/lib/dovecot-sieve/default.sieve'
Regards, Graham —
On 24. Sep 2020, at 18.58, Graham Leggett <minfrin@sharp.fm> wrote:
Hi all,
According to the docs at https://wiki.dovecot.org/Pigeonhole/Sieve, some extensions are not available by default.
The docs tell me the sieve_plugins, sieve_extensions and/or sieve_global_extensions configs are involved, but I can find no authoritative documentation as to what the values should be.
What values must I use to make “vnd.dovecot.environment” available?
Adding "sieve_global_extensions = +vnd.dovecot.environment” to 90-sieve.conf seems to not be enough.
[root@gatekeeper ~]# sievec -D /var/lib/dovecot-sieve/default.sieve sievec(root): Debug: sieve: Pigeonhole version 0.5.8 (b7b03ba2) initializing sievec(root): Debug: sieve: include: sieve_global is not set; it is currently not possible to include
:global' scripts. sievec(root): Debug: sieve: file storage: Using Sieve script path: /var/lib/dovecot-sieve/default.sieve sievec(root): Debug: sieve: file script: Opened script
default' from/var/lib/dovecot-sieve/default.sieve' default: line 5: error: require command: unknown Sieve capability
vnd.dovecot.environment'. default: line 19: error: referring to variable in unknown namespace 'vnd'. default: error: validation failed. sievec(root): Fatal: failed to compile sieve script '/var/lib/dovecot-sieve/default.sieve'
can you link your doveconf -n and the sieve script?
Sami
On 24 Sep 2020, at 20:45, Sami Ketola <sami.ketola@dovecot.fi> wrote:
can you link your doveconf -n and the sieve script?
The user’s detail are:
[root@gatekeeper ~]# doveadm user minfrin@example.com field value uid vmail gid vmail home /home/vmail/minfrin@example.com/ mail maildir:~/mail mail_auto_reply_mode reply mail_auto_reply_text I am truly away...
The sieve script is:
[root@gatekeeper ~]# cat /var/lib/dovecot-sieve/default.sieve #
require ["fileinto", "mailbox"]; require ["vacation", "variables"]; require ["vnd.dovecot.environment"];
# fileinto: for putting mail into a imap folder # mailbox: for creating imap folder if not exists # if header :contains "X-Spam-Flag" "YES" { # move mail into folder Junk, create folder if not exists fileinto :create "Junk"; stop; }
#if string :matches "${vnd.dovecot.mail_auto_reply_mode}" "reply" { if header :matches "subject" "*" { vacation :subject "AutoReply: ${1}" "${vnd.dovecot.mail_auto_reply_text}"; } #}
The dovecot -n is:
[root@gatekeeper ~]# dovecot -n
# 2.3.8 (9df20d2db): /etc/dovecot/dovecot.conf
# Pigeonhole version 0.5.8 (b7b03ba2)
# OS: Linux 4.18.0-193.19.1.el8_2.x86_64 x86_64 CentOS Linux release 8.2.2004 (Core)
# Hostname: gatekeeper.horizonmarine.co.za
first_valid_uid = 201
mail_gid = vmail
mail_location = maildir:~/mail
mail_plugins = acl
mail_uid = vmail
managesieve_notify_capability = mailto
managesieve_sieve_capability = fileinto reject envelope encoded-character vacation subaddress comparator-i;ascii-numeric relational regex imap4flags copy include variables body enotify environment mailbox date index ihave duplicate mime foreverypart extracttext
mbox_write_locks = fcntl
namespace {
list = children
location = maildir:%%h/mail:INDEXPVT=~/shared/%%u
prefix = Shared/%%u/
separator = /
subscriptions = yes
type = shared
}
namespace inbox {
inbox = yes
location =
mailbox Drafts {
special_use = \Drafts
}
mailbox Junk {
special_use = \Junk
}
mailbox Sent {
special_use = \Sent
}
mailbox "Sent Messages" {
special_use = \Sent
}
mailbox Trash {
special_use = \Trash
}
prefix =
separator = /
type = private
}
passdb {
args = /etc/dovecot/dovecot-ldap.conf.ext
driver = ldap
}
plugin {
sieve = file:~/sieve;active=~/.dovecot.sieve
sieve_default = /var/lib/dovecot-sieve/default.sieve
sieve_global_extensions = +vnd.dovecot.environment
sieve_plugins = sieve_extprograms
}
protocols = lmtp imap pop3 submission
service imap-login {
inet_listener imap {
address = 127.0.0.1, ::1
}
inet_listener imaps {
port = 993
ssl = yes
}
}
service imap {
vsz_limit = 1 G
}
service pop3-login {
inet_listener pop3 {
address = 127.0.0.1, ::1
}
inet_listener pop3s {
port = 995
ssl = yes
}
}
service submission-login {
inet_listener submission {
port = 587
}
inet_listener submissions {
haproxy = no
port = 465
reuse_port = no
ssl = yes
}
}
ssl = required
ssl_cert = </etc/device/services/mail-server/ssl-cert.pem
ssl_cipher_list = PROFILE=SYSTEM
ssl_key = # hidden, use -P to show it
submission_relay_host = localhost
submission_relay_trusted = yes
userdb {
args = /etc/dovecot/dovecot-ldap.conf.ext
driver = ldap
}
The sieve test is:
sieve-test(root): Debug: sieve: Pigeonhole version 0.5.8 (b7b03ba2) initializing
sieve-test(root): Debug: sieve: include: sieve_global is not set; it is currently not possible to include :global' scripts. sieve-test(root): Debug: sieve: Sieve Extprograms plugin for Pigeonhole version 0.5.8 (b7b03ba2) loaded debug: file storage: Using Sieve script path: /var/lib/dovecot-sieve/default.sieve. debug: file script: Opened script
default' from `/var/lib/dovecot-sieve/default.sieve'.
debug: Script binary /var/lib/dovecot-sieve/default.svbin successfully loaded.
debug: binary save: not saving binary /var/lib/dovecot-sieve/default.svbin, because it is already stored.
Performed actions:
- send vacation message: => seconds : 604800 => subject : AutoReply: Test1 => handle : ${vnd.dovecot.mail_auto_reply_text}AutoReply: ${1}<default-from><NO-MIME>
START MESSAGE
END MESSAGE
Implicit keep:
- store message in folder: INBOX
sieve-test(root): Info: final result: success
The variable “vnd.dovecot.mail_auto_reply_text” is the trouble - it’s not being resolved, and I have no idea what the format of the variable should be.
Regards, Graham —
On 24. Sep 2020, at 22.50, Graham Leggett <minfrin@sharp.fm> wrote:
On 24 Sep 2020, at 20:45, Sami Ketola <sami.ketola@dovecot.fi <mailto:sami.ketola@dovecot.fi>> wrote:
can you link your doveconf -n and the sieve script?
[root@gatekeeper ~]# cat /var/lib/dovecot-sieve/default.sieve #
require ["fileinto", "mailbox"]; require ["vacation", "variables"]; require ["vnd.dovecot.environment"];
I think this should be
require ["environment"];
instead.
Sami
On 24 Sep 2020, at 22:07, Sami Ketola <sami.ketola@dovecot.fi> wrote:
I think this should be
require ["environment"];
instead.
I eventually stumbled on a syntax that worked. Putting all of this in one place:
You need to turn on the sieve_extprograms plugin:
sieve_plugins = sieve_extprograms
Then you need to enable vnd.dovecot.environment:
sieve_global_extensions = +vnd.dovecot.environment
Then you need to pull the extra fields you want out of the userdb, and those fields must be prefixed with “sieve_env_”, like this example for LDAP:
user_attrs = mailMessageStore=home=%$,=sieve_env_mail_auto_reply_mode=%{ldap:mailAutoReplyMode},=sieve_env_mail_auto_reply_text=%{ldap:mailAutoReplyText}
Then you need to add a requirement on “vnd.dovecot.environment” to the sieve script.
Then, to access the variables in the sieve script, you need to drop the “sieve_env_” part, and add the prefix “env.vnd.dovecot.config.”. There are various docs floating around that reference the above variable without the leading “env.” - this must be there too.
The resulting sieve looks like this:
require ["fileinto", "mailbox"]; require ["vacation", "variables"]; require ["vnd.dovecot.environment"];
# fileinto: for putting mail into a imap folder # mailbox: for creating imap folder if not exists # if header :contains "X-Spam-Flag" "YES" { # move mail into folder Junk, create folder if not exists fileinto :create "Junk"; stop; }
if string :matches "${env.vnd.dovecot.config.mail_auto_reply_mode}" "reply" { if header :matches "subject" "*" { vacation :subject "AutoReply: ${1}" "${env.vnd.dovecot.config.mail_auto_reply_text}"; } }
- The output of sieve-test looks like this. The handle is weird, but I’m assuming there is method in the madness somehow:
sieve-test(root): Debug: sieve: Pigeonhole version 0.5.8 (b7b03ba2) initializing
sieve-test(root): Debug: sieve: include: sieve_global is not set; it is currently not possible to include :global' scripts. sieve-test(root): Debug: sieve: Sieve Extprograms plugin for Pigeonhole version 0.5.8 (b7b03ba2) loaded debug: file storage: Using Sieve script path: /var/lib/dovecot-sieve/default.sieve. debug: file script: Opened script
default' from `/var/lib/dovecot-sieve/default.sieve'.
debug: Script binary /var/lib/dovecot-sieve/default.svbin successfully loaded.
debug: binary save: not saving binary /var/lib/dovecot-sieve/default.svbin, because it is already stored.
Performed actions:
- send vacation message: => seconds : 604800 => subject : AutoReply: Test1 => handle : ${env.vnd.dovecot.config.mail_auto_reply_text}AutoReply: ${1}<default-from><NO-MIME>
START MESSAGE I am truly away... END MESSAGE
Implicit keep:
- store message in folder: INBOX
sieve-test(root): Info: final result: success
Regards, Graham —
On 25/09/2020 11:33, Graham Leggett wrote:
On 24 Sep 2020, at 22:07, Sami Ketola <sami.ketola@dovecot.fi <mailto:sami.ketola@dovecot.fi>> wrote:
I think this should be
require ["environment"];
instead.
I eventually stumbled on a syntax that worked. Putting all of this in one place:
- You need to turn on the sieve_extprograms plugin:
sieve_plugins = sieve_extprograms
This step is not needed for vnd.dovecot.environment. I don't see anything else in your Sieve script that makes this a requirement, so you should be able to remove it.
- Then you need to enable vnd.dovecot.environment:
sieve_global_extensions = +vnd.dovecot.environment
- Then you need to pull the extra fields you want out of the userdb, and those fields must be prefixed with “sieve_env_”, like this example for LDAP:
user_attrs = mailMessageStore=home=%$,=sieve_env_mail_auto_reply_mode=%{ldap:mailAutoReplyMode},=sieve_env_mail_auto_reply_text=%{ldap:mailAutoReplyText}
Then you need to add a requirement on “vnd.dovecot.environment” to the sieve script.
Then, to access the variables in the sieve script, you need to drop the “sieve_env_” part, and add the prefix “env.vnd.dovecot.config.”. There are various docs floating around that reference the above variable without the leading “env.” - this must be there too.
Where are those erroneous docs?
- The resulting sieve looks like this:
require ["fileinto", "mailbox"]; require ["vacation", "variables"]; require ["vnd.dovecot.environment"];
# fileinto: for putting mail into a imap folder # mailbox: for creating imap folder if not exists # if header :contains "X-Spam-Flag" "YES" { # move mail into folder Junk, create folder if not exists fileinto :create "Junk"; stop; }
if string :matches "${env.vnd.dovecot.config.mail_auto_reply_mode}" "reply" { if header :matches "subject" "*" { vacation :subject "AutoReply: ${1}" "${env.vnd.dovecot.config.mail_auto_reply_text}"; } }
- The output of sieve-test looks like this. The handle is weird, but I’m assuming there is method in the madness somehow:
sieve-test(root): Debug: sieve: Pigeonhole version 0.5.8 (b7b03ba2) initializing sieve-test(root): Debug: sieve: include: sieve_global is not set; it is currently not possible to include
:global' scripts. sieve-test(root): Debug: sieve: Sieve Extprograms plugin for Pigeonhole version 0.5.8 (b7b03ba2) loaded debug: file storage: Using Sieve script path: /var/lib/dovecot-sieve/default.sieve. debug: file script: Opened script
default' from `/var/lib/dovecot-sieve/default.sieve'. debug: Script binary /var/lib/dovecot-sieve/default.svbin successfully loaded. debug: binary save: not saving binary /var/lib/dovecot-sieve/default.svbin, because it is already stored.Performed actions:
* send vacation message: => seconds : 604800 => subject : AutoReply: Test1 => handle : ${env.vnd.dovecot.config.mail_auto_reply_text}AutoReply: ${1}<default-from><NO-MIME>
START MESSAGE I am truly away... END MESSAGE
Implicit keep:
* store message in folder: INBOX
sieve-test(root): Info: final result: success
The handle is created implicitly and makes sure vacation avoids sending multiple identical responses within the :days (or :seconds) period. If you change the vacation command in the Sieve script, the handle changes, making sure that contacts get to see a new vacation message even when they've contacted the recipient within the :days period.
Regards,
Stephan.
Regards, Graham —
participants (3)
-
Graham Leggett
-
Sami Ketola
-
Stephan Bosch