TLS 1.3
Introduction
The Transport Layer Security (TLS) protocol ensures the security of network flows over an untrusted network. It operates at presentation layer, and secures several application layer protocols: HTTPS, but also FTPS, SMTPS, IMAPS, POP3S, DoT… It provides the following security properties:
- Confidentiality of application data
- Integrity of application data
- Anti-replay of application data
- Authentication of the server
- Authentication of the client (optional)
Note: TLS does not offer non-repudiation of exchanged data.
Let’s start with a brief overview of the TLS handshake process. For the sake of clarity, the TLS 1.2 handshake is represented below since the different steps are easier to understand.
data:image/s3,"s3://crabby-images/101b2/101b231952ac4185557bebc0e67c5997dfe65045" alt=""
Cryptographic fun
TLS 1.3 handshake
Let’s continue with a more detailed modelling, in order to identify the handshake crypto magic. The client initiates the TLS handshake by listing the supported cryptographic algorithms. The server answers with the selected protocols.
Note: The TLS 1.2 handshake consists in at least 5 packets sent back-and-forth. But TLS 1.3 speeds up the handshake by limiting it to 3.
data:image/s3,"s3://crabby-images/824a8/824a814d03c9dd3a406b20e062c04d75b89aa1df" alt=""
TLS 1.3 explanations
Parameter | Explanation |
---|---|
Random: 68a9ddc224… |
Random value used to prevent protocol version degradation attacks. |
Server Name: kartapuce.com |
With this Server Name Indication, the server specifies the desired domain name. It is useful when several domain names are hosted behind a single IP address. ![]() ![]() |
Supported Version: TLS 1.3 |
This is the latest TLS version, without known vulnerabilities. |
Cipher Suite: TLS_AES_256_GCM_SHA384 |
The AES_256_GCM cipher suite provides confidentiality and integrity of the application data. The SHA384 hash algorithm is used with HKDF in order to derivate the secret keys. ![]() |
PSK Key Exchange Modes: PSK_DHE_KE |
The key establishment relies on the Eliptic Curve Ephemeral Diffie-Hellman key establishment protocol. The Diffie-Hellman key exchange is ephemeral because a new session key is computed for each key exchange (based on random client and server parameters). The Diffie-Hellman also provides Perfect Forward Secrecy: if Kartapuce Private key is compromised in the future (long-term secret), it is still not possible to retrieve old session keys from captured traffic. ![]() ![]() |
Key Share Group: x25519 |
It uses the x25519 elliptic curve. |
Signature Algorithms: RSA_PSS_RSAE_SHA256 |
The server is authenticated during the key exchange, preventing man-in-the-middle attacks. ![]() |
Certificate | This contains the X.509 certificate of the server. ![]() |
Note: Wireshark permits to capture and analyse the TLS handshake.
Note: Based on original learning material from ANSSI documentation Recommandations de sécurité relatives à TLS.