Skip to content
Snippets Groups Projects
guix.texi 412 KiB
Newer Older
  • Learn to ignore specific revisions
  • Andy Wingo's avatar
    Andy Wingo committed
    8001 8002 8003 8004 8005 8006 8007 8008 8009 8010 8011 8012 8013 8014 8015 8016 8017 8018 8019 8020 8021 8022 8023 8024 8025 8026 8027 8028 8029 8030 8031 8032 8033 8034 8035 8036 8037 8038 8039 8040 8041 8042 8043 8044 8045 8046 8047 8048 8049 8050 8051 8052 8053 8054 8055 8056 8057 8058 8059 8060 8061 8062 8063 8064 8065 8066 8067 8068 8069 8070 8071 8072 8073 8074 8075 8076 8077 8078 8079 8080 8081 8082 8083 8084 8085 8086 8087 8088 8089 8090 8091 8092 8093 8094 8095 8096 8097 8098 8099 8100 8101 8102 8103 8104 8105 8106 8107 8108 8109 8110 8111 8112 8113 8114 8115 8116 8117 8118 8119 8120 8121 8122 8123 8124 8125 8126 8127 8128 8129 8130 8131 8132 8133 8134 8135 8136 8137 8138 8139 8140 8141 8142 8143 8144 8145 8146 8147 8148 8149 8150 8151 8152 8153 8154 8155 8156 8157 8158 8159 8160 8161 8162 8163 8164 8165 8166 8167 8168 8169 8170 8171 8172 8173 8174 8175 8176 8177 8178 8179 8180 8181 8182 8183 8184 8185 8186 8187 8188 8189 8190 8191 8192 8193 8194 8195 8196 8197 8198 8199 8200 8201 8202 8203 8204 8205 8206 8207 8208 8209 8210 8211 8212 8213 8214 8215 8216 8217 8218 8219 8220 8221 8222 8223 8224 8225 8226 8227 8228 8229 8230 8231 8232 8233 8234 8235 8236 8237 8238 8239 8240 8241 8242 8243 8244 8245 8246 8247 8248 8249 8250 8251 8252 8253 8254 8255 8256 8257 8258 8259 8260 8261 8262 8263 8264 8265 8266 8267 8268 8269 8270 8271 8272 8273 8274 8275 8276 8277 8278 8279 8280 8281 8282 8283 8284 8285 8286 8287 8288 8289 8290 8291 8292 8293 8294 8295 8296 8297 8298 8299 8300 8301 8302 8303 8304 8305 8306 8307 8308 8309 8310 8311 8312 8313 8314 8315 8316 8317 8318 8319 8320 8321 8322 8323 8324 8325 8326 8327 8328 8329 8330 8331 8332 8333 8334 8335 8336 8337 8338 8339 8340 8341 8342 8343 8344 8345 8346 8347 8348 8349 8350 8351 8352 8353 8354 8355 8356 8357 8358 8359 8360 8361 8362 8363 8364 8365 8366 8367 8368 8369 8370 8371 8372 8373 8374 8375 8376 8377 8378 8379 8380 8381 8382 8383 8384 8385 8386 8387 8388 8389 8390 8391 8392 8393 8394 8395 8396 8397 8398 8399 8400 8401 8402 8403 8404 8405 8406 8407 8408 8409 8410 8411 8412 8413 8414 8415 8416 8417 8418 8419 8420 8421 8422 8423 8424 8425 8426 8427 8428 8429 8430 8431 8432 8433 8434 8435 8436 8437 8438 8439 8440 8441 8442 8443 8444 8445 8446 8447 8448 8449 8450 8451 8452 8453 8454 8455 8456 8457 8458 8459 8460 8461 8462 8463 8464 8465 8466 8467 8468 8469 8470 8471 8472 8473 8474 8475 8476 8477 8478 8479 8480 8481 8482 8483 8484 8485 8486 8487 8488 8489 8490 8491 8492 8493 8494 8495 8496 8497 8498 8499 8500 8501 8502 8503 8504 8505 8506 8507 8508 8509 8510 8511 8512 8513 8514 8515 8516 8517 8518 8519 8520 8521 8522 8523 8524 8525 8526 8527 8528 8529 8530 8531 8532 8533 8534 8535 8536 8537 8538 8539 8540 8541 8542 8543 8544 8545 8546 8547 8548 8549 8550 8551 8552 8553 8554 8555 8556 8557 8558 8559 8560 8561 8562 8563 8564 8565 8566 8567 8568 8569 8570 8571 8572 8573 8574 8575 8576 8577 8578 8579 8580 8581 8582 8583 8584 8585 8586 8587 8588 8589 8590 8591 8592 8593 8594 8595 8596 8597 8598 8599 8600 8601 8602 8603 8604 8605 8606 8607 8608 8609 8610 8611 8612 8613 8614 8615 8616 8617 8618 8619 8620 8621 8622 8623 8624 8625 8626 8627 8628 8629 8630 8631 8632 8633 8634 8635 8636 8637 8638 8639 8640 8641 8642 8643 8644 8645 8646 8647 8648 8649 8650 8651 8652 8653 8654 8655 8656 8657 8658 8659 8660 8661 8662 8663 8664 8665 8666 8667 8668 8669 8670 8671 8672 8673 8674 8675 8676 8677 8678 8679 8680 8681 8682 8683 8684 8685 8686 8687 8688 8689 8690 8691 8692 8693 8694 8695 8696 8697 8698 8699 8700 8701 8702 8703 8704 8705 8706 8707 8708 8709 8710 8711 8712 8713 8714 8715 8716 8717 8718 8719 8720 8721 8722 8723 8724 8725 8726 8727 8728 8729 8730 8731 8732 8733 8734 8735 8736 8737 8738 8739 8740 8741 8742 8743 8744 8745 8746 8747 8748 8749 8750 8751 8752 8753 8754 8755 8756 8757 8758 8759 8760 8761 8762 8763 8764 8765 8766 8767 8768 8769 8770 8771 8772 8773 8774 8775 8776 8777 8778 8779 8780 8781 8782 8783 8784 8785 8786 8787 8788 8789 8790 8791 8792 8793 8794 8795 8796 8797 8798 8799 8800 8801 8802 8803 8804 8805 8806 8807 8808 8809 8810 8811 8812 8813 8814 8815 8816 8817 8818 8819 8820 8821 8822 8823 8824 8825 8826 8827 8828 8829 8830 8831 8832 8833 8834 8835 8836 8837 8838 8839 8840 8841 8842 8843 8844 8845 8846 8847 8848 8849 8850 8851 8852 8853 8854 8855 8856 8857 8858 8859 8860 8861 8862 8863 8864 8865 8866 8867 8868 8869 8870 8871 8872 8873 8874 8875 8876 8877 8878 8879 8880 8881 8882 8883 8884 8885 8886 8887 8888 8889 8890 8891 8892 8893 8894 8895 8896
    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 filesystem access to clients.  There's no access checks
    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 filesystems (NFS or clustered filesystem).
    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. 
    @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 filesystems (ext4, xfs).
    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
    Filesystem backend to use for saving attachments:
    @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.
    Default is postmaster@@<your domain>.  %d expands to recipient domain.
    Defaults to @samp{""}.
    @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
    Human readable error message for rejection mails.  You can use
    variables:
    
    @table @code
    @item %n
    CRLF
    @item %r
    reason
    @item %s
    original subject
    @item %t
    recipient
    @end table
    Defaults to @samp{"Your message to <%t> was automatically rejected:%n%r"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string recipient-delimiter
    Delimiter character between local-part and detail in email
    address.
    Defaults to @samp{"+"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string lda-original-recipient-header
    Header where the original recipient address (SMTP's RCPT TO:
    address) is taken from if not available elsewhere.  With dovecot-lda -a
    parameter overrides this.  A commonly used header for this is
    X-Original-To.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean lda-mailbox-autocreate?
    Should saving a mail to a nonexistent mailbox automatically create
    it?.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} boolean lda-mailbox-autosubscribe?
    Should automatically created mailboxes be also automatically
    subscribed?.
    Defaults to @samp{#f}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} non-negative-integer imap-max-line-length
    Maximum IMAP command line length.  Some clients generate very long
    command lines with huge mailboxes, so you may need to raise this if you
    get "Too long argument" or "IMAP command line too large" errors
    often.
    Defaults to @samp{64000}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string imap-logout-format
    IMAP logout format string:
    @table @code
    @item %i
    total number of bytes read from client
    @item %o
    total number of bytes sent to client.
    @end table
    Defaults to @samp{"in=%i out=%o"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string imap-capability
    Override the IMAP CAPABILITY response.  If the value begins with '+',
    add the given capabilities on top of the defaults (e.g. +XFOO XBAR).
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string imap-idle-notify-interval
    How long to wait between "OK Still here" notifications when client
    is IDLEing.
    Defaults to @samp{"2 mins"}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string imap-id-send
    ID field names and values to send to clients.  Using * as the value
    makes Dovecot use the default value.  The following fields have default
    values currently: name, version, os, os-version, support-url,
    support-email.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string imap-id-log
    ID fields sent by client to log.  * means everything.
    Defaults to @samp{""}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} space-separated-string-list imap-client-workarounds
    Workarounds for various client bugs:
    
    @table @code
    @item delay-newmail
    Send EXISTS/RECENT new mail notifications only when replying to NOOP and
    CHECK commands.  Some clients ignore them otherwise, for example OSX
    Mail (<v2.1).  Outlook Express breaks more badly though, without this it
    may show user "Message no longer in server" errors.  Note that OE6
    still breaks even with this workaround if synchronization is set to
    "Headers Only".
    
    @item tb-extra-mailbox-sep
    Thunderbird gets somehow confused with LAYOUT=fs (mbox and dbox) and
    adds extra @samp{/} suffixes to mailbox names.  This option causes Dovecot to
    ignore the extra @samp{/} instead of treating it as invalid mailbox name.
    
    @item tb-lsub-flags
    Show \Noselect flags for LSUB replies with LAYOUT=fs (e.g. mbox).
    This makes Thunderbird realize they aren't selectable and show them
    greyed out, instead of only later giving "not selectable" popup error.
    @end table
    Defaults to @samp{()}.
    @end deftypevr
    
    @deftypevr {@code{dovecot-configuration} parameter} string imap-urlauth-host
    Host allowed in URLAUTH URLs sent by client.  "*" allows all.
    Defaults to @samp{""}.
    @end deftypevr
    
    
    Whew!  Lots of configuration options.  The nice thing about it though is
    that GuixSD has a complete interface to Dovecot's configuration
    language.  This allows not only a nice way to declare configurations,
    but also offers reflective capabilities as well: users can write code to
    inspect and transform configurations from within Scheme.
    
    However, it could be that you just want to get a @code{dovecot.conf} up
    and running.  In that case, you can pass an
    @code{opaque-dovecot-configuration} as the @code{#:config} paramter to
    @code{dovecot-service}.  As its name indicates, an opaque configuration
    does not have easy reflective capabilities.
    
    Available @code{opaque-dovecot-configuration} fields are:
    
    @deftypevr {@code{opaque-dovecot-configuration} parameter} package dovecot
    The dovecot package.
    @end deftypevr
    
    @deftypevr {@code{opaque-dovecot-configuration} parameter} string string
    The contents of the @code{dovecot.conf}, as a string.
    @end deftypevr
    
    For example, if your @code{dovecot.conf} is just the empty string, you
    could instantiate a dovecot service like this:
    
    @example
    (dovecot-service #:config
                     (opaque-dovecot-configuration
                      (string "")))
    @end example
    
    
    @node Web Services
    @subsubsection Web Services
    
    The @code{(gnu services web)} module provides the following service:
    
    
    @deffn {Scheme Procedure} nginx-service [#:nginx nginx] @
    
           [#:log-directory ``/var/log/nginx''] @
           [#:run-directory ``/var/run/nginx''] @
           [#:config-file]
    
    Return a service that runs @var{nginx}, the nginx web server.
    
    The nginx daemon loads its runtime configuration from @var{config-file}.
    Log files are written to @var{log-directory} and temporary runtime data
    files are written to @var{run-directory}.  For proper operation, these
    arguments should match what is in @var{config-file} to ensure that the
    directories are created when the service is activated.
    
    @end deffn
    
    
    @node Various Services
    @subsubsection Various Services
    
    The @code{(gnu services lirc)} module provides the following service.
    
    
    @deffn {Scheme Procedure} lirc-service [#:lirc lirc] @
    
           [#:device #f] [#:driver #f] [#:config-file #f] @
           [#:extra-options '()]
    Return a service that runs @url{http://www.lirc.org,LIRC}, a daemon that
    decodes infrared signals from remote controls.
    
    Optionally, @var{device}, @var{driver} and @var{config-file}
    (configuration file name) may be specified.  See @command{lircd} manual
    for details.
    
    Finally, @var{extra-options} is a list of additional command-line options
    passed to @command{lircd}.
    @end deffn
    
    
    
    @node Setuid Programs
    @subsection Setuid Programs
    
    @cindex setuid programs
    Some programs need to run with ``root'' privileges, even when they are
    launched by unprivileged users.  A notorious example is the
    
    @command{passwd} program, which users can run to change their
    password, and which needs to access the @file{/etc/passwd} and
    
    @file{/etc/shadow} files---something normally restricted to root, for
    obvious security reasons.  To address that, these executables are
    @dfn{setuid-root}, meaning that they always run with root privileges
    (@pxref{How Change Persona,,, libc, The GNU C Library Reference Manual},
    
    for more info about the setuid mechanism.)
    
    
    The store itself @emph{cannot} contain setuid programs: that would be a
    security issue since any user on the system can write derivations that
    populate the store (@pxref{The Store}).  Thus, a different mechanism is
    used: instead of changing the setuid bit directly on files that are in
    the store, we let the system administrator @emph{declare} which programs
    should be setuid root.
    
    The @code{setuid-programs} field of an @code{operating-system}
    declaration contains a list of G-expressions denoting the names of
    programs to be setuid-root (@pxref{Using the Configuration System}).
    For instance, the @command{passwd} program, which is part of the Shadow
    package, can be designated by this G-expression (@pxref{G-Expressions}):
    
    @example
    #~(string-append #$shadow "/bin/passwd")
    @end example
    
    A default set of setuid programs is defined by the
    @code{%setuid-programs} variable of the @code{(gnu system)} module.
    
    @defvr {Scheme Variable} %setuid-programs
    A list of G-expressions denoting common programs that are setuid-root.
    
    The list includes commands such as @command{passwd}, @command{ping},
    @command{su}, and @command{sudo}.
    @end defvr
    
    Under the hood, the actual setuid programs are created in the
    @file{/run/setuid-programs} directory at system activation time.  The
    files in this directory refer to the ``real'' binaries, which are in the
    store.
    
    
    @node X.509 Certificates
    @subsection X.509 Certificates
    
    @cindex HTTPS, certificates
    @cindex X.509 certificates
    @cindex TLS
    Web servers available over HTTPS (that is, HTTP over the transport-layer
    security mechanism, TLS) send client programs an @dfn{X.509 certificate}
    that the client can then use to @emph{authenticate} the server.  To do
    that, clients verify that the server's certificate is signed by a
    so-called @dfn{certificate authority} (CA).  But to verify the CA's
    signature, clients must have first acquired the CA's certificate.
    
    Web browsers such as GNU@tie{}IceCat include their own set of CA
    certificates, such that they are able to verify CA signatures
    out-of-the-box.
    
    However, most other programs that can talk HTTPS---@command{wget},