|
@@ -1,351 +1,34 @@
|
|
|
-# --------------------------------------------------------------------------
|
|
|
-# Please create a file "extra.conf" for persistent overrides to dovecot.conf
|
|
|
-# --------------------------------------------------------------------------
|
|
|
-# LDAP example:
|
|
|
-#passdb {
|
|
|
-# args = /etc/dovecot/ldap/passdb.conf
|
|
|
-# driver = ldap
|
|
|
-#}
|
|
|
-
|
|
|
+# /etc/dovecot/dovecot.conf
|
|
|
+# Base file kept minimal. All real config lives under conf.d/.
|
|
|
dovecot_config_version = 2.4.0
|
|
|
dovecot_storage_version = 2.4.0
|
|
|
|
|
|
listen = *,[::]
|
|
|
-
|
|
|
-auth_mechanisms = plain login
|
|
|
-#mail_debug = yes
|
|
|
-#auth_debug = yes
|
|
|
-#log_debug = category=fts-flatcurve # Activate Logging for Flatcurve FTS Searchings
|
|
|
-log_path = syslog
|
|
|
-auth_allow_cleartext = 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_driver = maildir
|
|
|
-mail_path = ~/
|
|
|
-mail_index_path = /var/vmail_index/${user}
|
|
|
-mail_plugins = </etc/dovecot/mail_plugins
|
|
|
-
|
|
|
-fs mail_ext_attachment {
|
|
|
- fs_driver = posix
|
|
|
- mail_ext_attachment_path = /var/attachments
|
|
|
- mail_ext_attachment_min_size = 128k
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-# Significantly speeds up very large mailboxes, but is only safe to enable if
|
|
|
-# you do not manually modify the files in the `cur` directories in
|
|
|
-# mailcowdockerized_vmail-vol-1.
|
|
|
-# https://docs.mailcow.email/manual-guides/Dovecot/u_e-dovecot-performance/
|
|
|
-maildir_very_dirty_syncs = yes
|
|
|
-
|
|
|
-ssl_min_protocol = TLSv1.2
|
|
|
-
|
|
|
-ssl_server {
|
|
|
- prefer_ciphers = server
|
|
|
- dh_file = /etc/ssl/mail/dhparams.pem
|
|
|
- cert_file = /etc/ssl/mail/cert.pem
|
|
|
- key_file = /etc/ssl/mail/key.pem
|
|
|
-}
|
|
|
-
|
|
|
-ssl_cipher_list = ALL:!ADH:!LOW:!SSLv2:!SSLv3:!EXP:!aNULL:!eNULL:!3DES:!MD5:!PSK:!DSS:!RC4:!SEED:!IDEA:+HIGH:+MEDIUM
|
|
|
-ssl_options = no_compression no_ticket
|
|
|
-
|
|
|
-# Dovecot 2.2
|
|
|
-#ssl_dh_parameters_length = 2048
|
|
|
-log_timestamp = "%Y-%m-%d %H:%M:%S "
|
|
|
-recipient_delimiter = +
|
|
|
-auth_master_user_separator = *
|
|
|
-mail_shared_explicit_inbox = yes
|
|
|
-mail_prefetch_count = 30
|
|
|
-passdb lua {
|
|
|
- fields {
|
|
|
- driver = lua
|
|
|
- args = file=/etc/dovecot/auth/passwd-verify.lua blocking=yes cache_key=%s:%u:%w
|
|
|
- result_success = return-ok
|
|
|
- result_failure = continue
|
|
|
- result_internalfail = continue
|
|
|
- }
|
|
|
-}
|
|
|
-# try a master passwd
|
|
|
-passdb master {
|
|
|
- fields {
|
|
|
- driver = passwd-file
|
|
|
- args = /etc/dovecot/dovecot-master.passwd
|
|
|
- master = yes
|
|
|
- skip = authenticated
|
|
|
- }
|
|
|
-}
|
|
|
-# 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
|
|
|
-passdb empty-lua {
|
|
|
- fields {
|
|
|
- driver = lua
|
|
|
- args = file=/etc/dovecot/auth/passwd-verify.lua blocking=yes
|
|
|
- }
|
|
|
-}
|
|
|
-# Set doveadm_password=your-secret-password in data/conf/dovecot/extra.conf (create if missing)
|
|
|
-service doveadm {
|
|
|
- inet_listener doveadm {
|
|
|
- port = 12345
|
|
|
- }
|
|
|
- vsz_limit=2048 MB
|
|
|
-}
|
|
|
-!include /etc/dovecot/dovecot.folders.conf
|
|
|
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
|
|
|
- }
|
|
|
-}
|
|
|
-service auth {
|
|
|
- inet_listener auth-inet {
|
|
|
- port = 10001
|
|
|
- }
|
|
|
- unix_listener auth-master {
|
|
|
- mode = 0600
|
|
|
- user = vmail
|
|
|
- }
|
|
|
- unix_listener auth-userdb {
|
|
|
- mode = 0600
|
|
|
- user = vmail
|
|
|
- }
|
|
|
- vsz_limit = 2G
|
|
|
-}
|
|
|
-service managesieve-login {
|
|
|
- inet_listener sieve {
|
|
|
- port = 4190
|
|
|
- }
|
|
|
- inet_listener sieve_haproxy {
|
|
|
- port = 14190
|
|
|
- haproxy = yes
|
|
|
- }
|
|
|
- service_restart_request_count = 1
|
|
|
- process_min_avail = 2
|
|
|
- vsz_limit = 1G
|
|
|
-}
|
|
|
-service imap-login {
|
|
|
- service_restart_request_count = 1
|
|
|
- process_min_avail = 2
|
|
|
- process_limit = 10000
|
|
|
- vsz_limit = 1G
|
|
|
- user = dovenull
|
|
|
- inet_listener imap_haproxy {
|
|
|
- port = 10143
|
|
|
- haproxy = yes
|
|
|
- }
|
|
|
- inet_listener imaps_haproxy {
|
|
|
- port = 10993
|
|
|
- ssl = yes
|
|
|
- haproxy = yes
|
|
|
- }
|
|
|
-}
|
|
|
-service pop3-login {
|
|
|
- service_restart_request_count = 1
|
|
|
- process_min_avail = 1
|
|
|
- vsz_limit = 1G
|
|
|
- inet_listener pop3_haproxy {
|
|
|
- port = 10110
|
|
|
- haproxy = yes
|
|
|
- }
|
|
|
- inet_listener pop3s_haproxy {
|
|
|
- port = 10995
|
|
|
- ssl = yes
|
|
|
- haproxy = yes
|
|
|
- }
|
|
|
-}
|
|
|
-service imap {
|
|
|
- executable = imap
|
|
|
- user = vmail
|
|
|
- vsz_limit = 1G
|
|
|
-}
|
|
|
-service managesieve {
|
|
|
- process_limit = 256
|
|
|
-}
|
|
|
-service lmtp {
|
|
|
- inet_listener lmtp-inet {
|
|
|
- port = 24
|
|
|
- }
|
|
|
- user = vmail
|
|
|
-}
|
|
|
-
|
|
|
-userdb master-userdb {
|
|
|
- fields {
|
|
|
- driver = passwd-file
|
|
|
- args = /etc/dovecot/dovecot-master.userdb
|
|
|
- }
|
|
|
-}
|
|
|
-userdb sql-userdb {
|
|
|
- fields {
|
|
|
- driver = sql
|
|
|
- args = /etc/dovecot/sql/dovecot-dict-sql-userdb.conf
|
|
|
- skip = found
|
|
|
- }
|
|
|
-}
|
|
|
-protocol imap {
|
|
|
- mail_plugins = </etc/dovecot/mail_plugins_imap
|
|
|
- imap_metadata = yes
|
|
|
-}
|
|
|
-
|
|
|
-mail_attribute {
|
|
|
- dict file {
|
|
|
- path = /etc/dovecot/dovecot-attributes
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-protocol lmtp {
|
|
|
- mail_plugins = </etc/dovecot/mail_plugins_lmtp
|
|
|
- auth_socket_path = /var/run/dovecot/auth-master
|
|
|
-}
|
|
|
-protocol sieve {
|
|
|
- managesieve_logout_format = bytes=%i/%o
|
|
|
-}
|
|
|
-
|
|
|
-# Allow "any" or "authenticated" to be used in ACLs
|
|
|
-imap_acl_allow_anyone = </etc/dovecot/acl_anyone
|
|
|
-
|
|
|
-
|
|
|
-acl_sharing_map {
|
|
|
- dict file {
|
|
|
- path = /var/vmail/shared-mailboxes.db
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-acl_driver = vfile
|
|
|
-acl_user = %u
|
|
|
-
|
|
|
-quota "User quota" {
|
|
|
- dict sqlquota {
|
|
|
- driver = sql
|
|
|
- args = /etc/dovecot/sql/dovecot-dict-sql-quota.conf
|
|
|
- }
|
|
|
- quota_rule = *:storage=+100M
|
|
|
- quota_rule2 = Trash:storage=+100%%
|
|
|
- quota_warning = storage=95%% quota-warning 95 %u
|
|
|
- quota_warning2 = storage=80%% quota-warning 80 %u
|
|
|
-}
|
|
|
-
|
|
|
-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
|
|
|
-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
|
|
|
-imapsieve_mailbox2_before = file:/usr/lib/dovecot/sieve/report-ham.sieve
|
|
|
-# END
|
|
|
-master_user = %u
|
|
|
-sieve_pipe_bin_dir = /usr/lib/dovecot/sieve
|
|
|
-sieve_global_extensions = +vnd.dovecot.pipe +vnd.dovecot.execute
|
|
|
-sieve_extensions = +notify +imapflags +vacation-seconds +editheader
|
|
|
-sieve_max_script_size = 1M
|
|
|
-sieve_max_redirects = 100
|
|
|
-sieve_max_actions = 101
|
|
|
-sieve_quota_max_scripts = 0
|
|
|
-sieve_quota_max_storage = 0
|
|
|
-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
|
|
|
-sieve_duplicate_default_period = 1m
|
|
|
-sieve_duplicate_max_period = 7d
|
|
|
-
|
|
|
-# -- 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.3.17+
|
|
|
-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
|
|
|
-
|
|
|
-# Try set mail_replica
|
|
|
-!include_try /etc/dovecot/mail_replica.conf
|
|
|
|
|
|
-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
|
|
|
- }
|
|
|
-}
|
|
|
-dict {
|
|
|
- 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
|
|
|
-}
|
|
|
-remote 127.0.0.1 {
|
|
|
- disable_plaintext_auth = no
|
|
|
-}
|
|
|
-submission_host = postfix:588
|
|
|
-mail_max_userip_connections = 500
|
|
|
-service stats {
|
|
|
- unix_listener stats-writer {
|
|
|
- mode = 0660
|
|
|
- user = vmail
|
|
|
- }
|
|
|
-}
|
|
|
-imap_max_line_length = 2 M
|
|
|
-auth_cache_verify_password_with_worker = yes
|
|
|
-auth_cache_negative_ttl = 60s
|
|
|
-auth_cache_ttl = 300s
|
|
|
-auth_cache_size = 10M
|
|
|
-auth_verbose_passwords = sha1:6
|
|
|
-service replicator {
|
|
|
- process_min_avail = 1
|
|
|
-}
|
|
|
-service aggregator {
|
|
|
- fifo_listener replication-notify-fifo {
|
|
|
- user = vmail
|
|
|
- }
|
|
|
- unix_listener replication-notify {
|
|
|
- user = vmail
|
|
|
- }
|
|
|
-}
|
|
|
-service replicator {
|
|
|
- unix_listener replicator-doveadm {
|
|
|
- mode = 0666
|
|
|
- }
|
|
|
-}
|
|
|
-replication_max_conns = 10
|
|
|
-doveadm_port = 12345
|
|
|
-replication_dsync_parameters = -d -l 30 -U -n INBOX
|
|
|
-# <Includes>
|
|
|
-!include_try /etc/dovecot/sni.conf
|
|
|
-!include_try /etc/dovecot/sogo_trusted_ip.conf
|
|
|
-!include_try /etc/dovecot/extra.conf
|
|
|
-!include_try /etc/dovecot/shared_namespace.conf
|
|
|
-!include_try /etc/dovecot/conf.d/fts.conf
|
|
|
-# </Includes>
|
|
|
-default_client_limit = 10400
|
|
|
-default_vsz_limit = 1024 M
|
|
|
+!include_try /etc/dovecot/conf.d/05-core.conf
|
|
|
+!include_try /etc/dovecot/conf.d/10-logging.conf
|
|
|
+!include_try /etc/dovecot/conf.d/10-mail.conf
|
|
|
+!include_try /etc/dovecot/conf.d/10-ssl.conf
|
|
|
+!include_try /etc/dovecot/conf.d/11-sql.conf
|
|
|
+!include_try /etc/dovecot/conf.d/12-mysql.conf
|
|
|
+!include_try /etc/dovecot/conf.d/12-storage-attachments.conf
|
|
|
+!include_try /etc/dovecot/conf.d/15-performance.conf
|
|
|
+!include_try /etc/dovecot/conf.d/20-auth.conf
|
|
|
+!include_try /etc/dovecot/conf.d/20-userdb.conf
|
|
|
+!include_try /etc/dovecot/conf.d/25-services.conf
|
|
|
+!include_try /etc/dovecot/conf.d/30-protocols.conf
|
|
|
+!include_try /etc/dovecot/conf.d/35-fts.conf
|
|
|
+!include_try /etc/dovecot/conf.d/40-acl.conf
|
|
|
+!include_try /etc/dovecot/conf.d/40-attributes.conf
|
|
|
+!include_try /etc/dovecot/conf.d/50-quota.conf
|
|
|
+!include_try /etc/dovecot/conf.d/60-sieve-pipeline.conf
|
|
|
+!include_try /etc/dovecot/conf.d/70-crypto.conf
|
|
|
+!include_try /etc/dovecot/conf.d/80-compress.conf
|
|
|
+!include_try /etc/dovecot/conf.d/80-mail-logging.conf
|
|
|
+!include_try /etc/dovecot/conf.d/90-limits.conf
|
|
|
+!include_try /etc/dovecot/conf.d/90-dict.conf
|
|
|
+!include_try /etc/dovecot/conf.d/99-includes.conf
|
|
|
+
|
|
|
+# Last: local overrides
|
|
|
+!include_try /etc/dovecot/extra.conf
|