mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-03 20:17:36 +03:00
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:
parent
b7691e8126
commit
65b9e15fc2
34 changed files with 2269 additions and 2303 deletions
|
@ -936,21 +936,20 @@ func testResumption(t *testing.T, version uint16) {
|
|||
testResumeState("Handshake", false)
|
||||
ticket := getTicket()
|
||||
testResumeState("Resume", true)
|
||||
if !bytes.Equal(ticket, getTicket()) && version != VersionTLS13 {
|
||||
t.Fatal("first ticket doesn't match ticket after resumption")
|
||||
}
|
||||
if bytes.Equal(ticket, getTicket()) && version == VersionTLS13 {
|
||||
if bytes.Equal(ticket, getTicket()) {
|
||||
t.Fatal("ticket didn't change after resumption")
|
||||
}
|
||||
|
||||
// An old session ticket can resume, but the server will provide a ticket encrypted with a fresh key.
|
||||
// An old session ticket is replaced with a ticket encrypted with a fresh key.
|
||||
ticket = getTicket()
|
||||
serverConfig.Time = func() time.Time { return time.Now().Add(24*time.Hour + time.Minute) }
|
||||
testResumeState("ResumeWithOldTicket", true)
|
||||
if bytes.Equal(ticket[:ticketKeyNameLen], getTicket()[:ticketKeyNameLen]) {
|
||||
if bytes.Equal(ticket, getTicket()) {
|
||||
t.Fatal("old first ticket matches the fresh one")
|
||||
}
|
||||
|
||||
// Now the session tickey key is expired, so a full handshake should occur.
|
||||
// Once the session master secret is expired, a full handshake should occur.
|
||||
ticket = getTicket()
|
||||
serverConfig.Time = func() time.Time { return time.Now().Add(24*8*time.Hour + time.Minute) }
|
||||
testResumeState("ResumeWithExpiredTicket", false)
|
||||
if bytes.Equal(ticket, getTicket()) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue