mailcow/data/conf/dovecot/dovecot.conf

404 lines
9.4 KiB
Plaintext
Raw Normal View History

# --------------------------------------------------------------------------
# Please create a file "extra.conf" for persistent overrides to dovecot.conf
# --------------------------------------------------------------------------
# LDAP example:
#passdb {
2019-07-28 21:36:09 +02:00
# args = /etc/dovecot/ldap/passdb.conf
# driver = ldap
#}
2017-03-02 11:23:23 +01:00
auth_mechanisms = plain login
#mail_debug = yes
2018-02-27 20:54:46 +01:00
#auth_debug = yes
2017-05-06 23:42:07 +02:00
log_path = syslog
2017-03-02 11:23:23 +01:00
disable_plaintext_auth = yes
# Uncomment on NFS share
#mmap_disable = yes
#mail_fsync = always
#mail_nfs_index = yes
#mail_nfs_storage = yes
login_log_format_elements = "user=<%u> method=%m rip=%r lip=%l mpid=%e %c %k"
mail_home = /var/vmail/%d/%n
mail_location = maildir:~/
2019-07-28 21:36:09 +02:00
mail_plugins = </etc/dovecot/mail_plugins
mail_attachment_fs = crypt:set_prefix=mail_crypt_global:posix:
mail_attachment_dir = /var/attachments
mail_attachment_min_size = 128k
# Dovecot 2.2
#ssl_protocols = !SSLv3
# Dovecot 2.3
ssl_min_protocol = TLSv1
2017-03-02 11:23:23 +01:00
ssl_prefer_server_ciphers = yes
ssl_cipher_list = ALL:!ADH:!LOW:!SSLv2:!SSLv3:!EXP:!aNULL:!eNULL:!3DES:!MD5:!PSK:!DSS:!RC4:!SEED:!IDEA:+HIGH:+MEDIUM
# Default in Dovecot 2.3
ssl_options = no_compression no_ticket
# New in Dovecot 2.3
ssl_dh=</etc/ssl/mail/dhparams.pem
# Dovecot 2.2
#ssl_dh_parameters_length = 2048
2017-03-02 11:23:23 +01:00
log_timestamp = "%Y-%m-%d %H:%M:%S "
recipient_delimiter = +
auth_master_user_separator = *
mail_shared_explicit_inbox = yes
2017-03-02 11:23:23 +01:00
mail_prefetch_count = 30
# try a master passwd
2017-03-02 11:23:23 +01:00
passdb {
driver = passwd-file
2019-07-28 21:36:09 +02:00
args = /etc/dovecot/dovecot-master.passwd
2017-03-02 11:23:23 +01:00
master = yes
pass = yes
result_failure = continue
result_internalfail = continue
}
# try an app passwd
passdb {
driver = lua
args = file=/var/lib/dovecot/app-passdb.lua blocking=yes
pass = yes
result_failure = continue
result_internalfail = continue
2017-03-02 11:23:23 +01:00
}
# check for regular password - if empty (e.g. force-passwd-reset), previous pass=yes passdbs also fail
# a return of the following passdb is mandatory
2017-03-02 11:23:23 +01:00
passdb {
2019-07-28 21:36:09 +02:00
args = /etc/dovecot/sql/dovecot-dict-sql-passdb.conf
2017-03-02 11:23:23 +01:00
driver = sql
result_success = return-ok
result_failure = continue
result_internalfail = continue
2017-03-02 11:23:23 +01:00
}
passdb {
driver = passwd-file
2019-07-28 21:36:09 +02:00
args = /etc/dovecot/dovecot-master.passwd
skip = authenticated
}
2017-07-10 21:30:45 +02:00
# Set doveadm_password=your-secret-password in data/conf/dovecot/extra.conf (create if missing)
service doveadm {
inet_listener {
port = 12345
}
}
2017-03-02 11:23:23 +01:00
namespace inbox {
inbox = yes
location =
separator = /
mailbox "Trash" {
auto = subscribe
special_use = \Trash
}
mailbox "Deleted Messages" {
special_use = \Trash
}
mailbox "Deleted Items" {
special_use = \Trash
}
mailbox "Rubbish" {
special_use = \Trash
}
2017-03-02 11:23:23 +01:00
mailbox "Gelöschte Objekte" {
special_use = \Trash
}
2018-11-14 22:18:02 +01:00
mailbox "Gelöschte Elemente" {
special_use = \Trash
}
2017-03-02 11:23:23 +01:00
mailbox "Papierkorb" {
special_use = \Trash
}
mailbox "Itens Excluidos" {
special_use = \Trash
}
mailbox "Itens Excluídos" {
special_use = \Trash
}
mailbox "Lixeira" {
special_use = \Trash
}
mailbox "Prullenbak" {
special_use = \Trash
}
mailbox "Verwijderde items" {
special_use = \Trash
}
mailbox "Archive" {
auto = subscribe
special_use = \Archive
}
mailbox "Archiv" {
special_use = \Archive
}
mailbox "Archives" {
special_use = \Archive
}
mailbox "Arquivo" {
special_use = \Archive
}
mailbox "Arquivos" {
special_use = \Archive
}
mailbox "Archief" {
special_use = \Archive
}
mailbox "Sent" {
auto = subscribe
special_use = \Sent
}
mailbox "Sent Messages" {
special_use = \Sent
}
mailbox "Sent Items" {
special_use = \Sent
}
mailbox "Gesendet" {
special_use = \Sent
}
mailbox "Gesendete Objekte" {
special_use = \Sent
}
2018-11-14 22:18:02 +01:00
mailbox "Gesendete Elemente" {
special_use = \Sent
2017-03-02 11:23:23 +01:00
}
mailbox "Itens Enviados" {
special_use = \Sent
}
mailbox "Enviados" {
special_use = \Sent
}
mailbox "Verzonden items" {
special_use = \Sent
}
mailbox "Verzonden" {
special_use = \Sent
}
mailbox "Drafts" {
auto = subscribe
special_use = \Drafts
}
mailbox "Entwürfe" {
special_use = \Drafts
}
mailbox "Rascunhos" {
special_use = \Drafts
}
mailbox "Concepten" {
special_use = \Drafts
}
mailbox "Junk" {
auto = subscribe
special_use = \Junk
}
2017-06-25 11:32:21 +02:00
mailbox "Junk-E-Mail" {
2017-03-10 15:34:23 +01:00
special_use = \Junk
}
2017-06-25 11:32:21 +02:00
mailbox "Junk E-Mail" {
2017-03-02 11:23:23 +01:00
special_use = \Junk
}
mailbox "Spam" {
special_use = \Junk
}
mailbox "Lixo Eletrônico" {
special_use = \Junk
}
mailbox "Ongewenste e-mail" {
special_use = \Junk
}
mailbox "Koncepty" {
special_use = \Drafts
}
mailbox "Nevyžádaná pošta" {
special_use = \Junk
}
mailbox "Odstraněná pošta" {
special_use = \Trash
}
mailbox "Odeslaná pošta" {
special_use = \Sent
}
2017-03-02 11:23:23 +01:00
prefix =
}
protocols = imap sieve lmtp pop3
service dict {
unix_listener dict {
mode = 0660
user = vmail
group = vmail
}
}
service log {
user = dovenull
}
service config {
unix_listener config {
user = root
group = vmail
mode = 0660
}
}
2017-03-02 11:23:23 +01:00
service auth {
inet_listener auth-inet {
port = 10001
}
unix_listener auth-master {
mode = 0600
user = vmail
}
unix_listener auth-userdb {
mode = 0600
user = vmail
}
}
service managesieve-login {
inet_listener sieve {
port = 4190
}
service_count = 1
process_min_avail = 2
vsz_limit = 1G
}
service imap-login {
service_count = 1
process_limit = 10000
vsz_limit = 1G
user = dovenull
}
service pop3-login {
service_count = 1
vsz_limit = 1G
2017-03-02 11:23:23 +01:00
}
service imap {
executable = imap imap-postlogin
user = vmail
vsz_limit = 1G
2017-03-02 11:23:23 +01:00
}
service managesieve {
process_limit = 256
}
service lmtp {
inet_listener lmtp-inet {
port = 24
}
user = vmail
}
listen = *,[::]
ssl_cert = </etc/ssl/mail/cert.pem
ssl_key = </etc/ssl/mail/key.pem
!include_try /etc/dovecot/sni.conf
userdb {
driver = passwd-file
2019-07-28 21:36:09 +02:00
args = /etc/dovecot/dovecot-master.userdb
}
2017-03-02 11:23:23 +01:00
userdb {
2019-07-28 21:36:09 +02:00
args = /etc/dovecot/sql/dovecot-dict-sql-userdb.conf
2017-03-02 11:23:23 +01:00
driver = sql
skip = found
2017-03-02 11:23:23 +01:00
}
protocol imap {
2019-07-28 21:36:09 +02:00
mail_plugins = </etc/dovecot/mail_plugins_imap
2018-02-05 21:42:23 +01:00
imap_metadata = yes
2017-03-02 11:23:23 +01:00
}
2018-02-05 21:42:23 +01:00
mail_attribute_dict = file:%h/dovecot-attributes
2017-03-02 11:23:23 +01:00
protocol lmtp {
2019-07-28 21:36:09 +02:00
mail_plugins = </etc/dovecot/mail_plugins_lmtp
auth_socket_path = /var/run/dovecot/auth-master
2017-03-02 11:23:23 +01:00
}
protocol sieve {
managesieve_logout_format = bytes=%i/%o
}
plugin {
# Allow "any" or "authenticated" to be used in ACLs
2019-07-28 21:36:09 +02:00
acl_anyone = </etc/dovecot/acl_anyone
2017-03-02 11:23:23 +01:00
acl_shared_dict = file:/var/vmail/shared-mailboxes.db
acl = vfile
fts = solr
fts_autoindex = yes
2019-03-10 09:40:31 +01:00
fts_solr = url=http://solr:8983/solr/dovecot-fts/
2017-03-02 11:23:23 +01:00
quota = dict:Userquota::proxy::sqlquota
quota_rule2 = Trash:storage=+100%%
sieve = /var/vmail/sieve/%u.sieve
sieve_plugins = sieve_imapsieve sieve_extprograms
sieve_vacation_send_from_recipient = yes
sieve_redirect_envelope_from = recipient
# From elsewhere to Spam folder
imapsieve_mailbox1_name = Junk
imapsieve_mailbox1_causes = COPY
2019-07-28 21:36:09 +02:00
imapsieve_mailbox1_before = file:/usr/lib/dovecot/sieve/report-spam.sieve
# END
# From Spam folder to elsewhere
imapsieve_mailbox2_name = *
imapsieve_mailbox2_from = Junk
imapsieve_mailbox2_causes = COPY
2019-07-28 21:36:09 +02:00
imapsieve_mailbox2_before = file:/usr/lib/dovecot/sieve/report-ham.sieve
# END
2019-02-04 23:59:31 +01:00
quota_warning = storage=95%% quota-warning 95 %u
quota_warning2 = storage=80%% quota-warning 80 %u
2019-07-28 21:36:09 +02:00
sieve_pipe_bin_dir = /usr/lib/dovecot/sieve
sieve_global_extensions = +vnd.dovecot.pipe +vnd.dovecot.execute
sieve_extensions = +notify +imapflags +vacation-seconds
2017-03-02 11:23:23 +01:00
sieve_max_script_size = 1M
sieve_max_redirects = 30
2017-03-02 11:23:23 +01:00
sieve_quota_max_scripts = 0
sieve_quota_max_storage = 0
2017-07-31 12:41:18 +02:00
listescape_char = "\\"
sieve_vacation_min_period = 5s
sieve_vacation_max_period = 0
sieve_vacation_default_period = 60s
sieve_before = /var/vmail/sieve/global_sieve_before.sieve
sieve_before2 = dict:proxy::sieve_before;name=active;bindir=/var/vmail/sieve_before_bindir
sieve_after = dict:proxy::sieve_after;name=active;bindir=/var/vmail/sieve_after_bindir
sieve_after2 = /var/vmail/sieve/global_sieve_after.sieve
# -- Global keys
mail_crypt_global_private_key = </mail_crypt/ecprivkey.pem
mail_crypt_global_public_key = </mail_crypt/ecpubkey.pem
mail_crypt_save_version = 2
# Enable compression while saving, lz4 Dovecot v2.2.11+
zlib_save = lz4
mail_log_events = delete undelete expunge copy mailbox_delete mailbox_rename
mail_log_fields = uid box msgid size
mail_log_cached_only = yes
2017-03-02 11:23:23 +01:00
}
2019-02-04 23:59:31 +01:00
service quota-warning {
executable = script /usr/local/bin/quota_notify.py
# use some unprivileged user for executing the quota warnings
user = vmail
unix_listener quota-warning {
user = vmail
}
}
2017-03-02 11:23:23 +01:00
dict {
2019-07-28 21:36:09 +02:00
sqlquota = mysql:/etc/dovecot/sql/dovecot-dict-sql-quota.conf
sieve_after = mysql:/etc/dovecot/sql/dovecot-dict-sql-sieve_after.conf
sieve_before = mysql:/etc/dovecot/sql/dovecot-dict-sql-sieve_before.conf
2017-03-02 11:23:23 +01:00
}
remote 127.0.0.1 {
disable_plaintext_auth = no
}
submission_host = postfix:588
mail_max_userip_connections = 500
service imap-postlogin {
executable = script-login /usr/local/bin/postlogin.sh
unix_listener imap-postlogin {
}
}
service stats {
unix_listener stats-writer {
mode = 0660
user = vmail
}
}
imap_max_line_length = 2 M
2019-03-18 14:15:02 +01:00
#auth_cache_verify_password_with_worker = yes
#auth_cache_negative_ttl = 0
#auth_cache_ttl = 30 s
#auth_cache_size = 2 M
2019-07-28 21:36:09 +02:00
!include_try /etc/dovecot/extra.conf
!include_try /etc/dovecot/sogo-sso.conf
!include_try /etc/dovecot/shared_namespace.conf
default_client_limit = 10400
default_vsz_limit = 1024 M