crypto/tls: reduce session ticket linkability

Ever since session ticket key rotation was introduced in CL 9072, we've
been including a prefix in every ticket to identify what key it's
encrypted with. It's a small privacy gain, but the cost of trial
decryptions is also small, especially since the first key is probably
the most frequently used.

Also reissue tickets on every resumption so that the next connection
can't be linked to all the previous ones. Again the privacy gain is
small but the performance cost is small and it comes with a reduction in
complexity.

For #60105

Change-Id: I852f297162d2b79a3d9bf61f6171e8ce94b2537a
Reviewed-on: https://go-review.googlesource.com/c/go/+/496817
Reviewed-by: Damien Neil <dneil@google.com>
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
Run-TryBot: Damien Neil <dneil@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
This commit is contained in:
Filippo Valsorda 2023-05-19 23:28:43 +02:00
parent b7691e8126
commit 65b9e15fc2
34 changed files with 2269 additions and 2303 deletions

View file

@ -275,7 +275,7 @@ func (hs *serverHandshakeStateTLS13) checkForResumption() error {
break
}
plaintext, _ := c.decryptTicket(identity.label)
plaintext := c.decryptTicket(identity.label)
if plaintext == nil {
continue
}