A TLS termination proxy (or SSL termination proxy,[1] or SSL offloading[2]) is a proxy server that acts as an intermediary point between client and server applications, and is used to terminate and/or establish TLS (or DTLS) tunnels by decrypting and/or encrypting communications. This is different from TLS pass-through proxies that forward encrypted (D)TLS traffic between clients and servers without terminating the tunnel.

Incoming HTTPS traffic gets decrypted and forwarded to a web service in the private network.

Uses

edit

TLS termination proxies can be used to:

  • secure plaintext communications over untrusted networks by tunnelling them in (D)TLS,
  • allow inspection of encrypted traffic by an intrusion detection system to detect and block malicious activities,
  • allow network surveillance and analyze encrypted traffic,
  • enable otherwise unsupported integration with other applications that provide additional capabilities such as content filtering or Hardware security module,
  • enable (D)TLS protocol versions, extensions, or capabilities (e.g. OCSP stapling, ALPN, DANE, CT validation, etc.) unsupported by client or server applications to enhance their compatibility and/or security,
  • work around buggy/insecure (D)TLS implementations in client or server applications to improve their compatibility and/or security,
  • provide additional certificate-based authentication unsupported by server and/or client applications or protocols,
  • provide an additional defence-in-depth layer for centralised control and consistent management of (D)TLS configuration and associated security policies, and
  • reduce the load on the main servers by offloading the cryptographic processing to another machine.

Types

edit

TLS termination proxies can provide three connectivity patterns:[3]

  • TLS Offloading of inbound encrypted (D)TLS connection from a client and forwarding communications over a plain text connection to the server.
  • TLS Encryption of inbound plaintext connection from a client and forwarding communications over an encrypted (D)TLS connection to the server.
  • TLS Bridging of two encrypted (D)TLS connections to allow inspection and filtering of encrypted traffic by decrypting inbound (D)TLS connection from a client and re-encrypting it with another (D)TLS connection to the server.

Combining a TLS Encrypting proxy in front of a client with a TLS Offloading proxy in front of a server, can allow (D)TLS encryption and authentication for protocols and applications that don't otherwise support it, with two proxies maintaining a secure (D)TLS tunnel over untrusted network segments between client and server.

A proxy used by clients as an intermediary gateway for all outbound connections is typically called a Forward proxy, while a proxy used by servers as an intermediary gateway for all inbound connections is typically called a Reverse proxy. Forward TLS bridging proxies that allow intrusion detection system to analyse all client traffic are typically marketed as "SSL Forward Proxy".[4][5][6]

TLS Offloading and TLS Bridging proxies typically need to authenticate themselves to clients with a digital certificate using either PKIX or DANE authentication. Usually the server operator supplies to its reverse proxy a valid certificate for use during (D)TLS handshake with clients. A forward proxy operator, however would need to create their own private CA, install it into the trust store of all clients and have the proxy generate a new certificate signed by the private CA in real time for each server that a client tries to connect to.

When network traffic between client and server is routed via a proxy, it can operate in transparent mode by using the client's IP address instead of its own when connecting to the server and using the server's IP address when responding to the client. If a Transparent TLS Bridging Proxy has a valid server certificate, neither client nor server would be able to detect the proxy presence. An adversary that has compromised the private key of the server's digital certificate or is able to use a compromised/coerced PKIX CAs to issue a new valid certificate for the server, could perform a man-in-the-middle attack by routing TLS traffic between client and server through a Transparent TLS Bridging Proxy and would have the ability to copy decrypted communications, including logon credentials, and modify content of communications on the fly without being detected.

References

edit
  1. ^ "What is SSL Termination?". F5 Networks. Archived from the original on 2024-06-08. Retrieved 2024-06-08.
  2. ^ "Setup IIS with URL Rewrite as a reverse proxy". Microsoft. 25 August 2016. Archived from the original on 15 August 2022. Retrieved 8 June 2024.
  3. ^ "Infrastructure Layouts Involving TLS". HAProxy Technologies.
  4. ^ "SSL Forward Proxy Overview". Juniper Networks. 2023-10-16. Archived from the original on 2024-06-08. Retrieved 2024-06-08.
  5. ^ "SSL Forward Proxy". Palo Alto Networks. Archived from the original on 2017-12-01. Retrieved 2017-11-24.
  6. ^ "Overview: SSL forward proxy client and server authentication". F5 Networks. Archived from the original on 2024-06-08. Retrieved 2017-11-24.