mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-03 20:17:36 +03:00
crypto/tls: improved 0-RTT QUIC API
Add synchronous management of stored sessions to QUICConn. This adds QUICStoreSession and QUICResumeSession events, permitting a QUIC implementation to handle session resumption as part of its regular event loop processing. Fixes #63691 Change-Id: I9fe16207cc1986eac084869675bc36e227cbf3f0 Reviewed-on: https://go-review.googlesource.com/c/go/+/536935 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Marten Seemann <martenseemann@gmail.com> Reviewed-by: Roland Shoemaker <roland@golang.org>
This commit is contained in:
parent
a81de4f2e0
commit
833bba2d07
7 changed files with 254 additions and 30 deletions
|
@ -377,6 +377,12 @@ func (hs *serverHandshakeStateTLS13) checkForResumption() error {
|
|||
continue
|
||||
}
|
||||
|
||||
if c.quic != nil {
|
||||
if err := c.quicResumeSession(sessionState); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
hs.earlySecret = hs.suite.extract(sessionState.secret, nil)
|
||||
binderKey := hs.suite.deriveSecret(hs.earlySecret, resumptionBinderLabel, nil)
|
||||
// Clone the transcript in case a HelloRetryRequest was recorded.
|
||||
|
@ -856,10 +862,10 @@ func (hs *serverHandshakeStateTLS13) sendSessionTickets() error {
|
|||
if !hs.shouldSendSessionTickets() {
|
||||
return nil
|
||||
}
|
||||
return c.sendSessionTicket(false)
|
||||
return c.sendSessionTicket(false, nil)
|
||||
}
|
||||
|
||||
func (c *Conn) sendSessionTicket(earlyData bool) error {
|
||||
func (c *Conn) sendSessionTicket(earlyData bool, extra [][]byte) error {
|
||||
suite := cipherSuiteTLS13ByID(c.cipherSuite)
|
||||
if suite == nil {
|
||||
return errors.New("tls: internal error: unknown cipher suite")
|
||||
|
@ -874,6 +880,7 @@ func (c *Conn) sendSessionTicket(earlyData bool) error {
|
|||
state := c.sessionState()
|
||||
state.secret = psk
|
||||
state.EarlyData = earlyData
|
||||
state.Extra = extra
|
||||
if c.config.WrapSession != nil {
|
||||
var err error
|
||||
m.label, err = c.config.WrapSession(c.connectionStateLocked(), state)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue