TLSPROXY(8) TLSPROXY(8)
NAME
tlsproxy - Postfix TLS proxy
SYNOPSIStlsproxy [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 eas-
ily 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 plain-
text 220 greeting to the remote SMTP client. This triggers TLS negoti-
ations 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) pro-
cesses 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 cer-
tificates 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 pref-
erence 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 pub-lic-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 shut-
ting 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 ini-
tialization 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 inter-
mediate 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 inter-
mediate CA certificates.
tlsproxy_tls_always_issue_session_ids ($smtpd_tls_always_issue_ses-sion_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_manda-tory_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 cer-
tificates.
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 CONTROLStlsproxy_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 CONTROLSconfig_directory (see 'postconf -d' output)
The default location of the Postfix main.cf and master.cf con-
figuration 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 ALSOpostscreen(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(8)