oracular (8) tlsproxy.8postfix.gz

Provided by: postfix_3.9.0-3_amd64 bug

NAME

       tlsproxy - Postfix TLS proxy

SYNOPSIS

       tlsproxy [generic Postfix daemon options]

DESCRIPTION

       The  tlsproxy(8)  server  implements  a two-way TLS proxy. It is used by the postscreen(8) server to talk
       SMTP-over-TLS with remote SMTP clients that are not allowlisted (including clients whose allowlist status
       has  expired),  and  by  the  smtp(8) client to support TLS connection reuse, but it should also work for
       non-SMTP protocols.

       Although one tlsproxy(8) process can serve multiple sessions at the same time, it is a good idea to allow
       the number of processes to increase with load, so that the service remains responsive.

PROTOCOL EXAMPLE

       The  example below concerns postscreen(8). However, the tlsproxy(8) server is agnostic of the application
       protocol, and the example is easily adapted to other applications.

       After receiving a valid remote SMTP client STARTTLS command, the postscreen(8) server  sends  the  remote
       SMTP  client  endpoint  string,  the  requested  role (server), and the requested timeout to tlsproxy(8).
       postscreen(8) then receives a "TLS available"  indication  from  tlsproxy(8).   If  the  TLS  service  is
       available,  postscreen(8)  sends  the  remote  SMTP  client file descriptor to tlsproxy(8), and sends the
       plaintext 220 greeting to the remote SMTP client.  This triggers TLS negotiations between the remote SMTP
       client  and  tlsproxy(8).   Upon  completion  of  the TLS-level handshake, tlsproxy(8) translates between
       plaintext from/to postscreen(8) and ciphertext to/from the remote SMTP client.

SECURITY

       The tlsproxy(8) server is moderately security-sensitive.  It talks to untrusted clients on  the  network.
       The process can be run chrooted at fixed low privilege.

DIAGNOSTICS

       Problems and transactions are logged to syslogd(8) or postlogd(8).

CONFIGURATION PARAMETERS

       Changes  to  main.cf  are  not  picked up automatically, as tlsproxy(8) processes may run for a long time
       depending on mail server load.  Use the command "postfix reload" to speed up a change.

       The text below provides only a parameter summary. See postconf(5) for more details including examples.

STARTTLS GLOBAL CONTROLS

       The following settings are global and therefore  cannot  be  overruled  by  information  specified  in  a
       tlsproxy(8) client request.

       tls_append_default_CA (no)
              Append the system-supplied default Certification Authority certificates to the ones specified with
              *_tls_CApath or *_tls_CAfile.

       tls_daemon_random_bytes (32)
              The number of pseudo-random bytes that an smtp(8) or smtpd(8) process requests from the  tlsmgr(8)
              server in order to seed its internal pseudo random number generator (PRNG).

       tls_high_cipherlist (see 'postconf -d' output)
              The OpenSSL cipherlist for "high" grade ciphers.

       tls_medium_cipherlist (see 'postconf -d' output)
              The OpenSSL cipherlist for "medium" or higher grade ciphers.

       tls_null_cipherlist (eNULL:!aNULL)
              The OpenSSL cipherlist for "NULL" grade ciphers that provide authentication without encryption.

       tls_eecdh_strong_curve (prime256v1)
              The  elliptic  curve  used  by  the  Postfix  SMTP  server  for sensibly strong ephemeral ECDH key
              exchange.

       tls_eecdh_ultra_curve (secp384r1)
              The elliptic curve used by the Postfix  SMTP  server  for  maximally  strong  ephemeral  ECDH  key
              exchange.

       tls_disable_workarounds (see 'postconf -d' output)
              List or bit-mask of OpenSSL bug work-arounds to disable.

       tls_preempt_cipherlist (no)
              With  SSLv3 and later, use the Postfix SMTP server's cipher preference order instead of the remote
              client's cipher preference order.

       Available in Postfix version 2.8..3.7:

       tls_low_cipherlist (see 'postconf -d' output)
              The OpenSSL cipherlist for "low" or higher grade ciphers.

       tls_export_cipherlist (see 'postconf -d' output)
              The OpenSSL cipherlist for "export" or higher grade ciphers.

       Available in Postfix version 2.9 and later:

       tls_legacy_public_key_fingerprints (no)
              A temporary migration aid for sites that use  certificate  public-key  fingerprints  with  Postfix
              2.9.0..2.9.5, which use an incorrect algorithm.

       Available in Postfix version 2.11-3.1:

       tls_dane_digest_agility (on)
              Configure RFC7671 DANE TLSA digest algorithm agility.

       tls_dane_trust_anchor_digest_enable (yes)
              Enable  support  for  RFC  6698 (DANE TLSA) DNS records that contain digests of trust-anchors with
              certificate usage "2".

       Available in Postfix version 2.11 and later:

       tlsmgr_service_name (tlsmgr)
              The name of the tlsmgr(8) service entry in master.cf.

       Available in Postfix version 3.0 and later:

       tls_session_ticket_cipher (Postfix >= 3.0: aes-256-cbc, Postfix < 3.0: aes-128-cbc)
              Algorithm used to encrypt RFC5077 TLS session tickets.

       openssl_path (openssl)
              The location of the OpenSSL command line program openssl(1).

       Available in Postfix version 3.2 and later:

       tls_eecdh_auto_curves (see 'postconf -d' output)
              The prioritized list of elliptic curves supported by the Postfix SMTP client and server.

       Available in Postfix version 3.4 and later:

       tls_server_sni_maps (empty)
              Optional lookup tables that map names received from remote SMTP clients via the  TLS  Server  Name
              Indication (SNI) extension to the appropriate keys and certificate chains.

       Available in Postfix 3.5, 3.4.6, 3.3.5, 3.2.10, 3.1.13 and later:

       tls_fast_shutdown_enable (yes)
              A  workaround  for  implementations  that  hang  Postfix  while shutting down a TLS session, until
              Postfix times out.

       Available in Postfix version 3.8 and later:

       tls_ffdhe_auto_groups (see 'postconf -d' output)
              The prioritized  list  of  finite-field  Diffie-Hellman  ephemeral  (FFDHE)  key  exchange  groups
              supported by the Postfix SMTP client and server.

       Available in Postfix 3.9, 3.8.1, 3.7.6, 3.6.10, 3.5.20 and later:

       tls_config_file (default)
              Optional configuration file with baseline OpenSSL settings.

       tls_config_name (empty)
              The application name passed by Postfix to OpenSSL library initialization functions.

STARTTLS SERVER CONTROLS

       These  settings  are  clones  of  Postfix  SMTP server settings.  They allow tlsproxy(8) to load the same
       certificate and private key information as the Postfix SMTP server, before dropping privileges,  so  that
       the  key  files  can  be  kept  read-only  for  root.  These  settings  can currently not be overruled by
       information in a tlsproxy(8) client request, but that limitation may be removed in a future version.

       tlsproxy_tls_CAfile ($smtpd_tls_CAfile)
              A file containing (PEM format) CA certificates of root CAs trusted  to  sign  either  remote  SMTP
              client certificates or intermediate CA certificates.

       tlsproxy_tls_CApath ($smtpd_tls_CApath)
              A directory containing (PEM format) CA certificates of root CAs trusted to sign either remote SMTP
              client certificates or intermediate CA certificates.

       tlsproxy_tls_always_issue_session_ids ($smtpd_tls_always_issue_session_ids)
              Force the Postfix tlsproxy(8) server to issue a TLS session id, even when TLS session  caching  is
              turned off.

       tlsproxy_tls_ask_ccert ($smtpd_tls_ask_ccert)
              Ask a remote SMTP client for a client certificate.

       tlsproxy_tls_ccert_verifydepth ($smtpd_tls_ccert_verifydepth)
              The verification depth for remote SMTP client certificates.

       tlsproxy_tls_cert_file ($smtpd_tls_cert_file)
              File with the Postfix tlsproxy(8) server RSA certificate in PEM format.

       tlsproxy_tls_ciphers ($smtpd_tls_ciphers)
              The  minimum  TLS cipher grade that the Postfix tlsproxy(8) server will use with opportunistic TLS
              encryption.

       tlsproxy_tls_dcert_file ($smtpd_tls_dcert_file)
              File with the Postfix tlsproxy(8) server DSA certificate in PEM format.

       tlsproxy_tls_dh1024_param_file ($smtpd_tls_dh1024_param_file)
              File with DH parameters that the  Postfix  tlsproxy(8)  server  should  use  with  non-export  EDH
              ciphers.

       tlsproxy_tls_dh512_param_file ($smtpd_tls_dh512_param_file)
              File  with  DH  parameters  that  the  Postfix tlsproxy(8) server should use with export-grade EDH
              ciphers.

       tlsproxy_tls_dkey_file ($smtpd_tls_dkey_file)
              File with the Postfix tlsproxy(8) server DSA private key in PEM format.

       tlsproxy_tls_eccert_file ($smtpd_tls_eccert_file)
              File with the Postfix tlsproxy(8) server ECDSA certificate in PEM format.

       tlsproxy_tls_eckey_file ($smtpd_tls_eckey_file)
              File with the Postfix tlsproxy(8) server ECDSA private key in PEM format.

       tlsproxy_tls_eecdh_grade ($smtpd_tls_eecdh_grade)
              The Postfix tlsproxy(8) server security grade for ephemeral elliptic-curve Diffie-Hellman  (EECDH)
              key exchange.

       tlsproxy_tls_exclude_ciphers ($smtpd_tls_exclude_ciphers)
              List  of  ciphers  or  cipher  types to exclude from the tlsproxy(8) server cipher list at all TLS
              security levels.

       tlsproxy_tls_fingerprint_digest ($smtpd_tls_fingerprint_digest)
              The message digest algorithm to construct remote SMTP client-certificate fingerprints.

       tlsproxy_tls_key_file ($smtpd_tls_key_file)
              File with the Postfix tlsproxy(8) server RSA private key in PEM format.

       tlsproxy_tls_loglevel ($smtpd_tls_loglevel)
              Enable additional Postfix tlsproxy(8) server logging of TLS activity.

       tlsproxy_tls_mandatory_ciphers ($smtpd_tls_mandatory_ciphers)
              The minimum TLS cipher grade that the Postfix tlsproxy(8)  server  will  use  with  mandatory  TLS
              encryption.

       tlsproxy_tls_mandatory_exclude_ciphers ($smtpd_tls_mandatory_exclude_ciphers)
              Additional  list  of ciphers or cipher types to exclude from the tlsproxy(8) server cipher list at
              mandatory TLS security levels.

       tlsproxy_tls_mandatory_protocols ($smtpd_tls_mandatory_protocols)
              The SSL/TLS protocols accepted by the Postfix tlsproxy(8) server with mandatory TLS encryption.

       tlsproxy_tls_protocols ($smtpd_tls_protocols)
              List of  TLS  protocols  that  the  Postfix  tlsproxy(8)  server  will  exclude  or  include  with
              opportunistic TLS encryption.

       tlsproxy_tls_req_ccert ($smtpd_tls_req_ccert)
              With  mandatory TLS encryption, require a trusted remote SMTP client certificate in order to allow
              TLS connections to proceed.

       tlsproxy_tls_security_level ($smtpd_tls_security_level)
              The SMTP TLS security level for  the  Postfix  tlsproxy(8)  server;  when  a  non-empty  value  is
              specified, this overrides the obsolete parameters smtpd_use_tls and smtpd_enforce_tls.

       tlsproxy_tls_chain_files ($smtpd_tls_chain_files)
              Files with the Postfix tlsproxy(8) server keys and certificate chains in PEM format.

       Available in Postfix version 3.9 and later:

       tlsproxy_tls_enable_rpk ($smtpd_tls_enable_rpk)
              Request  that  remote SMTP clients send an RFC7250 raw public key instead of an X.509 certificate,
              when asking or requiring client authentication.

STARTTLS CLIENT CONTROLS

       These settings are clones of Postfix SMTP client settings.  They  allow  tlsproxy(8)  to  load  the  same
       certificate  and  private key information as the Postfix SMTP client, before dropping privileges, so that
       the key files can be kept read-only for root.  Some  settings  may  be  overruled  by  information  in  a
       tlsproxy(8) client request.

       Available in Postfix version 3.4 and later:

       tlsproxy_client_CAfile ($smtp_tls_CAfile)
              A  file  containing  CA  certificates  of  root  CAs  trusted  to  sign  either  remote TLS server
              certificates or intermediate CA certificates.

       tlsproxy_client_CApath ($smtp_tls_CApath)
              Directory with PEM format Certification Authority certificates that the Postfix tlsproxy(8) client
              uses to verify a remote TLS server certificate.

       tlsproxy_client_chain_files ($smtp_tls_chain_files)
              Files with the Postfix tlsproxy(8) client keys and certificate chains in PEM format.

       tlsproxy_client_cert_file ($smtp_tls_cert_file)
              File with the Postfix tlsproxy(8) client RSA certificate in PEM format.

       tlsproxy_client_key_file ($smtp_tls_key_file)
              File with the Postfix tlsproxy(8) client RSA private key in PEM format.

       tlsproxy_client_dcert_file ($smtp_tls_dcert_file)
              File with the Postfix tlsproxy(8) client DSA certificate in PEM format.

       tlsproxy_client_dkey_file ($smtp_tls_dkey_file)
              File with the Postfix tlsproxy(8) client DSA private key in PEM format.

       tlsproxy_client_eccert_file ($smtp_tls_eccert_file)
              File with the Postfix tlsproxy(8) client ECDSA certificate in PEM format.

       tlsproxy_client_eckey_file ($smtp_tls_eckey_file)
              File with the Postfix tlsproxy(8) client ECDSA private key in PEM format.

       tlsproxy_client_fingerprint_digest ($smtp_tls_fingerprint_digest)
              The message digest algorithm used to construct remote TLS server certificate fingerprints.

       tlsproxy_client_loglevel ($smtp_tls_loglevel)
              Enable additional Postfix tlsproxy(8) client logging of TLS activity.

       tlsproxy_client_loglevel_parameter (smtp_tls_loglevel)
              The name of the parameter that provides the tlsproxy_client_loglevel value.

       tlsproxy_client_scert_verifydepth ($smtp_tls_scert_verifydepth)
              The verification depth for remote TLS server certificates.

       tlsproxy_client_use_tls ($smtp_use_tls)
              Opportunistic mode: use TLS when a remote server announces TLS support.

       tlsproxy_client_enforce_tls ($smtp_enforce_tls)
              Enforcement mode: require that SMTP servers use TLS encryption.

       tlsproxy_client_per_site ($smtp_tls_per_site)
              Optional  lookup  tables  with  the  Postfix  tlsproxy(8)  client  TLS  usage  policy  by next-hop
              destination and by remote TLS server hostname.

       Available in Postfix version 3.4-3.6:

       tlsproxy_client_level ($smtp_tls_security_level)
              The default TLS security level for the Postfix tlsproxy(8) client.

       tlsproxy_client_policy ($smtp_tls_policy_maps)
              Optional lookup tables with the  Postfix  tlsproxy(8)  client  TLS  security  policy  by  next-hop
              destination.

       Available in Postfix version 3.7 and later:

       tlsproxy_client_security_level ($smtp_tls_security_level)
              The default TLS security level for the Postfix tlsproxy(8) client.

       tlsproxy_client_policy_maps ($smtp_tls_policy_maps)
              Optional  lookup  tables  with  the  Postfix  tlsproxy(8)  client  TLS security policy by next-hop
              destination.

OBSOLETE STARTTLS SUPPORT CONTROLS

       These parameters are supported for compatibility with smtpd(8) legacy parameters.

       tlsproxy_use_tls ($smtpd_use_tls)
              Opportunistic TLS: announce STARTTLS support to remote SMTP  clients,  but  do  not  require  that
              clients use TLS encryption.

       tlsproxy_enforce_tls ($smtpd_enforce_tls)
              Mandatory  TLS: announce STARTTLS support to remote SMTP clients, and require that clients use TLS
              encryption.

       tlsproxy_client_use_tls ($smtp_use_tls)
              Opportunistic mode: use TLS when a remote server announces TLS support.

       tlsproxy_client_enforce_tls ($smtp_enforce_tls)
              Enforcement mode: require that SMTP servers use TLS encryption.

RESOURCE CONTROLS

       tlsproxy_watchdog_timeout (10s)
              How much time a tlsproxy(8) process may  take  to  process  local  or  remote  I/O  before  it  is
              terminated by a built-in watchdog timer.

MISCELLANEOUS CONTROLS

       config_directory (see 'postconf -d' output)
              The default location of the Postfix main.cf and master.cf configuration files.

       process_id (read-only)
              The process ID of a Postfix command or daemon process.

       process_name (read-only)
              The process name of a Postfix command or daemon process.

       syslog_facility (mail)
              The syslog facility of Postfix logging.

       syslog_name (see 'postconf -d' output)
              A  prefix  that  is prepended to the process name in syslog records, so that, for example, "smtpd"
              becomes "prefix/smtpd".

       Available in Postfix 3.3 and later:

       service_name (read-only)
              The master.cf service name of a Postfix daemon process.

SEE ALSO

       postscreen(8), Postfix zombie blocker
       smtpd(8), Postfix SMTP server
       postconf(5), configuration parameters
       postlogd(8), Postfix logging
       syslogd(8), system logging

LICENSE

       The Secure Mailer license must be distributed with this software.

HISTORY

       This service was introduced with Postfix version 2.8.

AUTHOR(S)

       Wietse Venema
       IBM T.J. Watson Research
       P.O. Box 704
       Yorktown Heights, NY 10598, USA

       Wietse Venema
       Google, Inc.
       111 8th Avenue
       New York, NY 10011, USA

                                                                                              TLSPROXY(8postfix)