Skip to content
Snippets Groups Projects
guix.texi 467 KiB
Newer Older
  • Learn to ignore specific revisions
  • Andy Wingo's avatar
    Andy Wingo committed
    The driver that the passdb should use.  Valid values include
    @samp{pam}, @samp{passwd}, @samp{shadow}, @samp{bsdauth}, and
    @samp{static}.
    Defaults to @samp{"pam"}.
    @end deftypevr
    
    @deftypevr {@code{passdb-configuration} parameter} free-form-args args
    A list of key-value args to the passdb driver.
    Defaults to @samp{()}.
    @end deftypevr
    
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} userdb-configuration-list userdbs
    List of userdb configurations, each one created by the
    @code{userdb-configuration} constructor.
    
    Available @code{userdb-configuration} fields are:
    
    @deftypevr {@code{userdb-configuration} parameter} string driver
    The driver that the userdb should use.  Valid values include
    @samp{passwd} and @samp{static}.
    Defaults to @samp{"passwd"}.
    @end deftypevr
    
    @deftypevr {@code{userdb-configuration} parameter} free-form-args args
    A list of key-value args to the userdb driver.
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{userdb-configuration} parameter} free-form-args override-fields
    Override fields from passwd.
    Defaults to @samp{()}.
    @end deftypevr
    
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} plugin-configuration plugin-configuration
    Plug-in configuration, created by the @code{plugin-configuration}
    constructor.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} list-of-namespace-configuration namespaces
    List of namespaces.  Each item in the list is created by the
    @code{namespace-configuration} constructor.
    
    Available @code{namespace-configuration} fields are:
    
    @deftypevr {@code{namespace-configuration} parameter} string name
    Name for this namespace.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} string type
    Namespace type: @samp{private}, @samp{shared} or @samp{public}.
    Defaults to @samp{"private"}.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} string separator
    Hierarchy separator to use. You should use the same separator for
    all namespaces or some clients get confused.  @samp{/} is usually a good
    one.  The default however depends on the underlying mail storage
    format.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} string prefix
    Prefix required to access this namespace.  This needs to be
    different for all namespaces. For example @samp{Public/}.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} string location
    
    Physical location of the mailbox. This is in the same format as
    
    Andy Wingo's avatar
    Andy Wingo committed
    mail_location, which is also the default for it.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} boolean inbox?
    There can be only one INBOX, and this setting defines which
    namespace has it.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} boolean hidden?
    If namespace is hidden, it's not advertised to clients via NAMESPACE
    extension. You'll most likely also want to set @samp{list? #f}.  This is mostly
    useful when converting from another server with different namespaces
    which you want to deprecate but still keep working.  For example you can
    create hidden namespaces with prefixes @samp{~/mail/}, @samp{~%u/mail/}
    and @samp{mail/}.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} boolean list?
    
    Show the mailboxes under this namespace with the LIST command. This
    makes the namespace visible for clients that do not support the NAMESPACE
    
    Andy Wingo's avatar
    Andy Wingo committed
    extension.  The special @code{children} value lists child mailboxes, but
    hides the namespace prefix.
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} boolean subscriptions?
    Namespace handles its own subscriptions.  If set to @code{#f}, the
    parent namespace handles them.  The empty prefix should always have this
    
    as @code{#t}).
    
    Andy Wingo's avatar
    Andy Wingo committed
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{namespace-configuration} parameter} mailbox-configuration-list mailboxes
    List of predefined mailboxes in this namespace.
    Defaults to @samp{()}.
    
    Available @code{mailbox-configuration} fields are:
    
    @deftypevr {@code{mailbox-configuration} parameter} string name
    Name for this mailbox.
    @end deftypevr
    
    @deftypevr {@code{mailbox-configuration} parameter} string auto
    @samp{create} will automatically create this mailbox.
    @samp{subscribe} will both create and subscribe to the mailbox.
    Defaults to @samp{"no"}.
    @end deftypevr
    
    @deftypevr {@code{mailbox-configuration} parameter} space-separated-string-list special-use
    List of IMAP @code{SPECIAL-USE} attributes as specified by RFC 6154.
    Valid values are @code{\All}, @code{\Archive}, @code{\Drafts},
    @code{\Flagged}, @code{\Junk}, @code{\Sent}, and @code{\Trash}.
    Defaults to @samp{()}.
    @end deftypevr
    
    @end deftypevr
    
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} file-name base-dir
    Base directory where to store runtime data.
    Defaults to @samp{"/var/run/dovecot/"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string login-greeting
    Greeting message for clients.
    Defaults to @samp{"Dovecot ready."}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list login-trusted-networks
    List of trusted network ranges.  Connections from these IPs are
    allowed to override their IP addresses and ports (for logging and for
    authentication checks).  @samp{disable-plaintext-auth} is also ignored
    
    for these networks.  Typically you would specify your IMAP proxy servers
    
    Andy Wingo's avatar
    Andy Wingo committed
    here.
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list login-access-sockets
    List of login access check sockets (e.g. tcpwrap).
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean verbose-proctitle?
    Show more verbose process titles (in ps).  Currently shows user name
    
    and IP address.  Useful for seeing who is actually using the IMAP
    processes (e.g. shared mailboxes or if the same uid is used for multiple
    
    Andy Wingo's avatar
    Andy Wingo committed
    accounts).
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean shutdown-clients?
    Should all processes be killed when Dovecot master process shuts down.
    Setting this to @code{#f} means that Dovecot can be upgraded without
    forcing existing client connections to close (although that could also
    
    be a problem if the upgrade is e.g. due to a security fix).
    
    Andy Wingo's avatar
    Andy Wingo committed
    9173 9174 9175 9176 9177 9178 9179 9180 9181 9182 9183 9184 9185 9186 9187 9188 9189 9190 9191 9192 9193 9194 9195 9196 9197 9198 9199 9200 9201 9202 9203 9204 9205 9206 9207 9208 9209 9210 9211 9212 9213 9214 9215 9216 9217 9218 9219 9220 9221 9222 9223 9224 9225 9226 9227 9228 9229 9230 9231 9232 9233 9234 9235 9236 9237 9238 9239 9240 9241 9242 9243 9244 9245 9246 9247 9248 9249 9250 9251 9252 9253 9254 9255 9256 9257 9258 9259 9260 9261 9262 9263 9264 9265 9266 9267 9268 9269 9270 9271 9272 9273 9274 9275 9276 9277 9278 9279 9280 9281 9282 9283 9284 9285 9286 9287 9288 9289 9290 9291 9292 9293 9294 9295 9296 9297 9298 9299 9300 9301 9302 9303 9304 9305 9306 9307 9308 9309 9310 9311 9312 9313 9314 9315 9316 9317 9318 9319 9320 9321 9322 9323 9324 9325 9326 9327 9328 9329 9330 9331 9332 9333 9334 9335 9336 9337 9338 9339 9340 9341 9342 9343 9344 9345 9346 9347 9348 9349 9350 9351 9352 9353 9354 9355 9356 9357 9358 9359 9360 9361 9362 9363 9364 9365 9366 9367 9368 9369 9370 9371 9372 9373 9374 9375 9376 9377 9378 9379 9380 9381 9382 9383 9384 9385 9386 9387 9388 9389 9390 9391 9392 9393 9394 9395 9396 9397 9398 9399 9400 9401 9402 9403 9404 9405 9406 9407 9408 9409 9410 9411 9412 9413 9414 9415 9416 9417 9418 9419 9420 9421 9422 9423 9424 9425 9426 9427 9428 9429 9430 9431 9432 9433 9434 9435 9436 9437 9438 9439 9440 9441 9442 9443 9444 9445 9446 9447 9448 9449 9450 9451 9452 9453 9454 9455 9456 9457 9458 9459 9460 9461 9462 9463 9464 9465 9466 9467 9468 9469 9470 9471 9472 9473 9474 9475 9476 9477 9478 9479 9480 9481 9482 9483 9484 9485 9486 9487 9488 9489 9490 9491 9492 9493 9494 9495 9496 9497 9498 9499 9500 9501 9502 9503 9504 9505 9506 9507 9508 9509 9510 9511 9512 9513 9514 9515 9516 9517 9518 9519 9520 9521 9522 9523 9524 9525 9526 9527 9528 9529 9530 9531 9532 9533 9534 9535 9536 9537 9538 9539 9540 9541 9542 9543 9544 9545 9546
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer doveadm-worker-count
    If non-zero, run mail commands via this many connections to doveadm
    server, instead of running them directly in the same process.
    Defaults to @samp{0}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string doveadm-socket-path
    UNIX socket or host:port used for connecting to doveadm server.
    Defaults to @samp{"doveadm-server"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list import-environment
    List of environment variables that are preserved on Dovecot startup
    and passed down to all of its child processes.  You can also give
    key=value pairs to always set specific settings.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean disable-plaintext-auth?
    Disable LOGIN command and all other plaintext authentications unless
    SSL/TLS is used (LOGINDISABLED capability).  Note that if the remote IP
    matches the local IP (i.e. you're connecting from the same computer),
    the connection is considered secure and plaintext authentication is
    allowed.  See also ssl=required setting.
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer auth-cache-size
    Authentication cache size (e.g. @samp{#e10e6}).  0 means it's disabled.
    Note that bsdauth, PAM and vpopmail require @samp{cache-key} to be set
    for caching to be used.
    Defaults to @samp{0}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-cache-ttl
    Time to live for cached data.  After TTL expires the cached record
    is no longer used, *except* if the main database lookup returns internal
    failure.  We also try to handle password changes automatically: If
    user's previous authentication was successful, but this one wasn't, the
    cache isn't used.  For now this works only with plaintext
    authentication.
    Defaults to @samp{"1 hour"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-cache-negative-ttl
    TTL for negative hits (user not found, password mismatch).
    0 disables caching them completely.
    Defaults to @samp{"1 hour"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list auth-realms
    List of realms for SASL authentication mechanisms that need them.
    You can leave it empty if you don't want to support multiple realms.
    Many clients simply use the first one listed here, so keep the default
    realm first.
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-default-realm
    Default realm/domain to use if none was specified.  This is used for
    both SASL realms and appending @@domain to username in plaintext
    logins.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-username-chars
    List of allowed characters in username.  If the user-given username
    contains a character not listed in here, the login automatically fails.
    This is just an extra check to make sure user can't exploit any
    potential quote escaping vulnerabilities with SQL/LDAP databases.  If
    you want to allow all characters, set this value to empty.
    Defaults to @samp{"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890.-_@@"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-username-translation
    Username character translations before it's looked up from
    databases.  The value contains series of from -> to characters.  For
    example @samp{#@@/@@} means that @samp{#} and @samp{/} characters are
    translated to @samp{@@}.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-username-format
    Username formatting before it's looked up from databases.  You can
    use the standard variables here, e.g. %Lu would lowercase the username,
    %n would drop away the domain if it was given, or @samp{%n-AT-%d} would
    change the @samp{@@} into @samp{-AT-}.  This translation is done after
    @samp{auth-username-translation} changes.
    Defaults to @samp{"%Lu"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-master-user-separator
    If you want to allow master users to log in by specifying the master
    username within the normal username string (i.e. not using SASL
    mechanism's support for it), you can specify the separator character
    here.  The format is then <username><separator><master username>.
    UW-IMAP uses @samp{*} as the separator, so that could be a good
    choice.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-anonymous-username
    Username to use for users logging in with ANONYMOUS SASL
    mechanism.
    Defaults to @samp{"anonymous"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer auth-worker-max-count
    Maximum number of dovecot-auth worker processes.  They're used to
    execute blocking passdb and userdb queries (e.g. MySQL and PAM).
    They're automatically created and destroyed as needed.
    Defaults to @samp{30}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-gssapi-hostname
    Host name to use in GSSAPI principal names.  The default is to use
    the name returned by gethostname().  Use @samp{$ALL} (with quotes) to
    allow all keytab entries.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-krb5-keytab
    Kerberos keytab to use for the GSSAPI mechanism.  Will use the
    system default (usually /etc/krb5.keytab) if not specified.  You may
    need to change the auth service to run as root to be able to read this
    file.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean auth-use-winbind?
    Do NTLM and GSS-SPNEGO authentication using Samba's winbind daemon
    and @samp{ntlm-auth} helper.
    <doc/wiki/Authentication/Mechanisms/Winbind.txt>.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} file-name auth-winbind-helper-path
    Path for Samba's @samp{ntlm-auth} helper binary.
    Defaults to @samp{"/usr/bin/ntlm_auth"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string auth-failure-delay
    Time to delay before replying to failed authentications.
    Defaults to @samp{"2 secs"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean auth-ssl-require-client-cert?
    Require a valid SSL client certificate or the authentication
    fails.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean auth-ssl-username-from-cert?
    Take the username from client's SSL certificate, using
    @code{X509_NAME_get_text_by_NID()} which returns the subject's DN's
    CommonName.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list auth-mechanisms
    List of wanted authentication mechanisms.  Supported mechanisms are:
    @samp{plain}, @samp{login}, @samp{digest-md5}, @samp{cram-md5},
    @samp{ntlm}, @samp{rpa}, @samp{apop}, @samp{anonymous}, @samp{gssapi},
    @samp{otp}, @samp{skey}, and @samp{gss-spnego}.  NOTE: See also
    @samp{disable-plaintext-auth} setting.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list director-servers
    List of IPs or hostnames to all director servers, including ourself.
    Ports can be specified as ip:port.  The default port is the same as what
    director service's @samp{inet-listener} is using.
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list director-mail-servers
    List of IPs or hostnames to all backend mail servers.  Ranges are
    allowed too, like 10.0.0.10-10.0.0.30.
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string director-user-expire
    How long to redirect users to a specific server after it no longer
    has any connections.
    Defaults to @samp{"15 min"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer director-doveadm-port
    TCP/IP port that accepts doveadm connections (instead of director
    connections) If you enable this, you'll also need to add
    @samp{inet-listener} for the port.
    Defaults to @samp{0}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string director-username-hash
    How the username is translated before being hashed.  Useful values
    include %Ln if user can log in with or without @@domain, %Ld if mailboxes
    are shared within domain.
    Defaults to @samp{"%Lu"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string log-path
    Log file to use for error messages.  @samp{syslog} logs to syslog,
    @samp{/dev/stderr} logs to stderr.
    Defaults to @samp{"syslog"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string info-log-path
    Log file to use for informational messages.  Defaults to
    @samp{log-path}.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string debug-log-path
    Log file to use for debug messages.  Defaults to
    @samp{info-log-path}.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string syslog-facility
    Syslog facility to use if you're logging to syslog.  Usually if you
    don't want to use @samp{mail}, you'll use local0..local7.  Also other
    standard facilities are supported.
    Defaults to @samp{"mail"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean auth-verbose?
    Log unsuccessful authentication attempts and the reasons why they
    failed.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean auth-verbose-passwords?
    In case of password mismatches, log the attempted password.  Valid
    values are no, plain and sha1.  sha1 can be useful for detecting brute
    force password attempts vs.  user simply trying the same password over
    and over again.  You can also truncate the value to n chars by appending
    ":n" (e.g. sha1:6).
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean auth-debug?
    Even more verbose logging for debugging purposes.  Shows for example
    SQL queries.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean auth-debug-passwords?
    In case of password mismatches, log the passwords and used scheme so
    the problem can be debugged.  Enabling this also enables
    @samp{auth-debug}.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mail-debug?
    Enable mail process debugging.  This can help you figure out why
    Dovecot isn't finding your mails.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean verbose-ssl?
    Show protocol level SSL errors.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string log-timestamp
    Prefix for each line written to log file.  % codes are in
    strftime(3) format.
    Defaults to @samp{"\"%b %d %H:%M:%S \""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list login-log-format-elements
    List of elements we want to log.  The elements which have a
    non-empty variable value are joined together to form a comma-separated
    string.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string login-log-format
    Login log format.  %s contains @samp{login-log-format-elements}
    string, %$ contains the data we want to log.
    Defaults to @samp{"%$: %s"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-log-prefix
    Log prefix for mail processes.  See doc/wiki/Variables.txt for list
    of possible variables you can use.
    Defaults to @samp{"\"%s(%u): \""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string deliver-log-format
    Format to use for logging mail deliveries.  You can use variables:
    @table @code
    @item %$
    Delivery status message (e.g. @samp{saved to INBOX})
    @item %m
    Message-ID
    @item %s
    Subject
    @item %f
    From address
    @item %p
    Physical size
    @item %w
    Virtual size.
    @end table
    Defaults to @samp{"msgid=%m: %$"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-location
    Location for users' mailboxes.  The default is empty, which means
    that Dovecot tries to find the mailboxes automatically.  This won't work
    if the user doesn't yet have any mail, so you should explicitly tell
    Dovecot the full location.
    
    If you're using mbox, giving a path to the INBOX
    file (e.g. /var/mail/%u) isn't enough.  You'll also need to tell Dovecot
    where the other mailboxes are kept.  This is called the "root mail
    directory", and it must be the first path given in the
    @samp{mail-location} setting.
    
    There are a few special variables you can use, eg.:
    
    @table @samp
    @item %u
    username
    @item %n
    user part in user@@domain, same as %u if there's no domain
    @item %d
    domain part in user@@domain, empty if there's no domain
    @item %h
    home director
    @end table
    
    See doc/wiki/Variables.txt for full list.  Some examples:
    @table @samp
    @item maildir:~/Maildir
    @item mbox:~/mail:INBOX=/var/mail/%u
    @item mbox:/var/mail/%d/%1n/%n:INDEX=/var/indexes/%d/%1n/%
    @end table
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-uid
    System user and group used to access mails.  If you use multiple,
    userdb can override these by returning uid or gid fields.  You can use
    either numbers or names.  <doc/wiki/UserIds.txt>.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-gid
    
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-privileged-group
    Group to enable temporarily for privileged operations.  Currently
    this is used only with INBOX when either its initial creation or
    dotlocking fails.  Typically this is set to "mail" to give access to
    /var/mail.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-access-groups
    Grant access to these supplementary groups for mail processes.
    Typically these are used to set up access to shared mailboxes.  Note
    that it may be dangerous to set these if users can create
    symlinks (e.g. if "mail" group is set here, ln -s /var/mail ~/mail/var
    could allow a user to delete others' mailboxes, or ln -s
    /secret/shared/box ~/mail/mybox would allow reading it).
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mail-full-filesystem-access?
    
    Allow full file system access to clients.  There's no access checks
    
    Andy Wingo's avatar
    Andy Wingo committed
    other than what the operating system does for the active UID/GID.  It
    works with both maildir and mboxes, allowing you to prefix mailboxes
    names with e.g. /path/ or ~user/.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mmap-disable?
    Don't use mmap() at all.  This is required if you store indexes to
    
    shared file systems (NFS or clustered file system).
    
    Andy Wingo's avatar
    Andy Wingo committed
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean dotlock-use-excl?
    Rely on @samp{O_EXCL} to work when creating dotlock files.  NFS
    supports @samp{O_EXCL} since version 3, so this should be safe to use
    nowadays by default.
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-fsync
    When to use fsync() or fdatasync() calls:
    @table @code
    @item optimized
    Whenever necessary to avoid losing important data
    @item always
    Useful with e.g. NFS when write()s are delayed
    @item never
    Never use it (best performance, but crashes can lose data).
    @end table
    Defaults to @samp{"optimized"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mail-nfs-storage?
    Mail storage exists in NFS.  Set this to yes to make Dovecot flush
    NFS caches whenever needed.  If you're using only a single mail server
    this isn't needed.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mail-nfs-index?
    Mail index files also exist in NFS.  Setting this to yes requires
    @samp{mmap-disable? #t} and @samp{fsync-disable? #f}.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string lock-method
    Locking method for index files.  Alternatives are fcntl, flock and
    dotlock.  Dotlocking uses some tricks which may create more disk I/O
    than other locking methods.  NFS users: flock doesn't work, remember to
    change @samp{mmap-disable}.
    Defaults to @samp{"fcntl"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} file-name mail-temp-dir
    Directory in which LDA/LMTP temporarily stores incoming mails >128
    kB.
    Defaults to @samp{"/tmp"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer first-valid-uid
    Valid UID range for users.  This is mostly to make sure that users can't
    log in as daemons or other system users.  Note that denying root logins is
    hardcoded to dovecot binary and can't be done even if @samp{first-valid-uid}
    is set to 0.
    Defaults to @samp{500}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer last-valid-uid
    
    Defaults to @samp{0}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer first-valid-gid
    Valid GID range for users.  Users having non-valid GID as primary group ID
    aren't allowed to log in.  If user belongs to supplementary groups with
    non-valid GIDs, those groups are not set.
    Defaults to @samp{1}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer last-valid-gid
    
    Defaults to @samp{0}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer mail-max-keyword-length
    Maximum allowed length for mail keyword name.  It's only forced when
    trying to create new keywords.
    Defaults to @samp{50}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} colon-separated-file-name-list valid-chroot-dirs
    List of directories under which chrooting is allowed for mail
    processes (i.e. /var/mail will allow chrooting to /var/mail/foo/bar
    too).  This setting doesn't affect @samp{login-chroot}
    @samp{mail-chroot} or auth chroot settings.  If this setting is empty,
    "/./" in home dirs are ignored.  WARNING: Never add directories here
    which local users can modify, that may lead to root exploit.  Usually
    this should be done only if you don't allow shell access for users.
    <doc/wiki/Chrooting.txt>.
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-chroot
    Default chroot directory for mail processes.  This can be overridden
    for specific users in user database by giving /./ in user's home
    directory (e.g. /home/./user chroots into /home).  Note that usually
    there is no real need to do chrooting, Dovecot doesn't allow users to
    access files outside their mail directory anyway.  If your home
    directories are prefixed with the chroot directory, append "/." to
    @samp{mail-chroot}.  <doc/wiki/Chrooting.txt>.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} file-name auth-socket-path
    UNIX socket path to master authentication server to find users.
    This is used by imap (for shared users) and lda.
    Defaults to @samp{"/var/run/dovecot/auth-userdb"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} file-name mail-plugin-dir
    Directory where to look up mail plugins.
    Defaults to @samp{"/usr/lib/dovecot"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list mail-plugins
    List of plugins to load for all services.  Plugins specific to IMAP,
    LDA, etc. are added to this list in their own .conf files.
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer mail-cache-min-mail-count
    The minimum number of mails in a mailbox before updates are done to
    cache file.  This allows optimizing Dovecot's behavior to do less disk
    writes at the cost of more disk reads.
    Defaults to @samp{0}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mailbox-idle-check-interval
    When IDLE command is running, mailbox is checked once in a while to
    see if there are any new mails or other changes.  This setting defines
    the minimum time to wait between those checks.  Dovecot can also use
    dnotify, inotify and kqueue to find out immediately when changes
    occur.
    Defaults to @samp{"30 secs"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mail-save-crlf?
    Save mails with CR+LF instead of plain LF.  This makes sending those
    mails take less CPU, especially with sendfile() syscall with Linux and
    FreeBSD.  But it also creates a bit more disk I/O which may just make it
    slower.  Also note that if other software reads the mboxes/maildirs,
    they may handle the extra CRs wrong and cause problems.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean maildir-stat-dirs?
    By default LIST command returns all entries in maildir beginning
    with a dot.  Enabling this option makes Dovecot return only entries
    which are directories.  This is done by stat()ing each entry, so it
    causes more disk I/O.
     (For systems setting struct @samp{dirent->d_type} this check is free
    and it's done always regardless of this setting).
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean maildir-copy-with-hardlinks?
    When copying a message, do it with hard links whenever possible.
    This makes the performance much better, and it's unlikely to have any
    side effects.
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean maildir-very-dirty-syncs?
    Assume Dovecot is the only MUA accessing Maildir: Scan cur/
    directory only when its mtime changes unexpectedly or when we can't find
    the mail otherwise.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list mbox-read-locks
    Which locking methods to use for locking mbox.  There are four
    available:
    
    @table @code
    @item dotlock
    Create <mailbox>.lock file.  This is the oldest and most NFS-safe
    solution.  If you want to use /var/mail/ like directory, the users will
    need write access to that directory.
    @item dotlock-try
    Same as dotlock, but if it fails because of permissions or because there
    isn't enough disk space, just skip it.
    @item fcntl
    Use this if possible.  Works with NFS too if lockd is used.
    @item flock
    
    May not exist in all systems.  Doesn't work with NFS.
    
    Andy Wingo's avatar
    Andy Wingo committed
    @item lockf
    May not exist in all systems.  Doesn't work with NFS.
    @end table
    
    You can use multiple locking methods; if you do the order they're declared
    in is important to avoid deadlocks if other MTAs/MUAs are using multiple
    locking methods as well.  Some operating systems don't allow using some of
    them simultaneously.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list mbox-write-locks
    
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mbox-lock-timeout
    Maximum time to wait for lock (all of them) before aborting.
    Defaults to @samp{"5 mins"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mbox-dotlock-change-timeout
    If dotlock exists but the mailbox isn't modified in any way,
    override the lock file after this much time.
    Defaults to @samp{"2 mins"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mbox-dirty-syncs?
    When mbox changes unexpectedly we have to fully read it to find out
    what changed.  If the mbox is large this can take a long time.  Since
    the change is usually just a newly appended mail, it'd be faster to
    simply read the new mails.  If this setting is enabled, Dovecot does
    this but still safely fallbacks to re-reading the whole mbox file
    whenever something in mbox isn't how it's expected to be.  The only real
    downside to this setting is that if some other MUA changes message
    flags, Dovecot doesn't notice it immediately.  Note that a full sync is
    done with SELECT, EXAMINE, EXPUNGE and CHECK commands.
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mbox-very-dirty-syncs?
    Like @samp{mbox-dirty-syncs}, but don't do full syncs even with SELECT,
    EXAMINE, EXPUNGE or CHECK commands.  If this is set,
    @samp{mbox-dirty-syncs} is ignored.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mbox-lazy-writes?
    Delay writing mbox headers until doing a full write sync (EXPUNGE
    and CHECK commands and when closing the mailbox).  This is especially
    useful for POP3 where clients often delete all mails.  The downside is
    that our changes aren't immediately visible to other MUAs.
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer mbox-min-index-size
    If mbox size is smaller than this (e.g. 100k), don't write index
    files.  If an index file already exists it's still read, just not
    updated.
    Defaults to @samp{0}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer mdbox-rotate-size
    Maximum dbox file size until it's rotated.
    Defaults to @samp{2000000}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mdbox-rotate-interval
    Maximum dbox file age until it's rotated.  Typically in days.  Day
    begins from midnight, so 1d = today, 2d = yesterday, etc.  0 = check
    disabled.
    Defaults to @samp{"1d"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean mdbox-preallocate-space?
    When creating new mdbox files, immediately preallocate their size to
    @samp{mdbox-rotate-size}.  This setting currently works only in Linux
    
    with some file systems (ext4, xfs).
    
    Andy Wingo's avatar
    Andy Wingo committed
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-attachment-dir
    sdbox and mdbox support saving mail attachments to external files,
    which also allows single instance storage for them.  Other backends
    don't support this for now.
    
    WARNING: This feature hasn't been tested much yet.  Use at your own risk.
    
    Directory root where to store mail attachments.  Disabled, if empty.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer mail-attachment-min-size
    Attachments smaller than this aren't saved externally.  It's also
    possible to write a plugin to disable saving specific attachments
    externally.
    Defaults to @samp{128000}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-attachment-fs
    
    File system backend to use for saving attachments:
    
    Andy Wingo's avatar
    Andy Wingo committed
    @table @code
    @item posix
    No SiS done by Dovecot (but this might help FS's own deduplication)
    @item sis posix
    SiS with immediate byte-by-byte comparison during saving
    @item sis-queue posix
    SiS with delayed comparison and deduplication.
    @end table
    Defaults to @samp{"sis posix"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string mail-attachment-hash
    Hash format to use in attachment filenames.  You can add any text and
    variables: @code{%@{md4@}}, @code{%@{md5@}}, @code{%@{sha1@}},
    @code{%@{sha256@}}, @code{%@{sha512@}}, @code{%@{size@}}.  Variables can be
    truncated, e.g. @code{%@{sha256:80@}} returns only first 80 bits.
    Defaults to @samp{"%@{sha1@}"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer default-process-limit
    
    Defaults to @samp{100}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer default-client-limit
    
    Defaults to @samp{1000}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer default-vsz-limit
    Default VSZ (virtual memory size) limit for service processes.
    This is mainly intended to catch and kill processes that leak memory
    before they eat up everything.
    Defaults to @samp{256000000}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string default-login-user
    Login user is internally used by login processes.  This is the most
    untrusted user in Dovecot system.  It shouldn't have access to anything
    at all.
    Defaults to @samp{"dovenull"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string default-internal-user
    Internal user is used by unprivileged processes.  It should be
    separate from login user, so that login processes can't disturb other
    processes.
    Defaults to @samp{"dovecot"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl?
    SSL/TLS support: yes, no, required.  <doc/wiki/SSL.txt>.
    Defaults to @samp{"required"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl-cert
    PEM encoded X.509 SSL/TLS certificate (public key).
    Defaults to @samp{"</etc/dovecot/default.pem"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl-key
    PEM encoded SSL/TLS private key.  The key is opened before
    dropping root privileges, so keep the key file unreadable by anyone but
    root.
    Defaults to @samp{"</etc/dovecot/private/default.pem"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl-key-password
    If key file is password protected, give the password here.
    Alternatively give it when starting dovecot with -p parameter.  Since
    this file is often world-readable, you may want to place this setting
    instead to a different.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl-ca
    PEM encoded trusted certificate authority.  Set this only if you
    intend to use @samp{ssl-verify-client-cert? #t}.  The file should
    contain the CA certificate(s) followed by the matching
    CRL(s).  (e.g. @samp{ssl-ca </etc/ssl/certs/ca.pem}).
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean ssl-require-crl?
    Require that CRL check succeeds for client certificates.
    Defaults to @samp{#t}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean ssl-verify-client-cert?
    Request client to send a certificate.  If you also want to require
    it, set @samp{auth-ssl-require-client-cert? #t} in auth section.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl-cert-username-field
    Which field from certificate to use for username.  commonName and
    x500UniqueIdentifier are the usual choices.  You'll also need to set
    @samp{auth-ssl-username-from-cert? #t}.
    Defaults to @samp{"commonName"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} hours ssl-parameters-regenerate
    How often to regenerate the SSL parameters file.  Generation is
    quite CPU intensive operation.  The value is in hours, 0 disables
    regeneration entirely.
    Defaults to @samp{168}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl-protocols
    SSL protocols to use.
    Defaults to @samp{"!SSLv2"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl-cipher-list
    SSL ciphers to use.
    Defaults to @samp{"ALL:!LOW:!SSLv2:!EXP:!aNULL"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string ssl-crypto-device
    SSL crypto device to use, for valid values run "openssl engine".
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string postmaster-address
    Address to use when sending rejection mails.
    
    %d expands to recipient domain.
    Defaults to @samp{"postmaster@@%d"}.
    
    Andy Wingo's avatar
    Andy Wingo committed
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string hostname
    Hostname to use in various parts of sent mails (e.g. in Message-Id)
    and in LMTP replies.  Default is the system's real hostname@@domain.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean quota-full-tempfail?
    If user is over quota, return with temporary failure instead of
    bouncing the mail.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} file-name sendmail-path
    Binary to use for sending mails.
    Defaults to @samp{"/usr/sbin/sendmail"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string submission-host
    If non-empty, send mails via this SMTP host[:port] instead of
    sendmail.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string rejection-subject
    Subject: header to use for rejection mails.  You can use the same
    variables as for @samp{rejection-reason} below.
    Defaults to @samp{"Rejected: %s"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string rejection-reason