mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 12:47:36 +03:00
* handshake: simplify method signature of cryptoSetup.handleEvent * use the new crypto/tls 0-RTT API
72 lines
1.7 KiB
Go
72 lines
1.7 KiB
Go
package handshake
|
|
|
|
import (
|
|
"bytes"
|
|
"errors"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/quic-go/quic-go/internal/wire"
|
|
"github.com/quic-go/quic-go/quicvarint"
|
|
)
|
|
|
|
const sessionTicketRevision = 4
|
|
|
|
type sessionTicket struct {
|
|
Parameters *wire.TransportParameters
|
|
RTT time.Duration // to be encoded in mus
|
|
}
|
|
|
|
func (t *sessionTicket) Marshal() []byte {
|
|
b := make([]byte, 0, 256)
|
|
b = quicvarint.Append(b, sessionTicketRevision)
|
|
b = quicvarint.Append(b, uint64(t.RTT.Microseconds()))
|
|
if t.Parameters == nil {
|
|
return b
|
|
}
|
|
return t.Parameters.MarshalForSessionTicket(b)
|
|
}
|
|
|
|
func (t *sessionTicket) Unmarshal(b []byte, using0RTT bool) error {
|
|
rev, l, err := quicvarint.Parse(b)
|
|
if err != nil {
|
|
return errors.New("failed to read session ticket revision")
|
|
}
|
|
b = b[l:]
|
|
if rev != sessionTicketRevision {
|
|
return fmt.Errorf("unknown session ticket revision: %d", rev)
|
|
}
|
|
rtt, l, err := quicvarint.Parse(b)
|
|
if err != nil {
|
|
return errors.New("failed to read RTT")
|
|
}
|
|
b = b[l:]
|
|
if using0RTT {
|
|
var tp wire.TransportParameters
|
|
if err := tp.UnmarshalFromSessionTicket(b); err != nil {
|
|
return fmt.Errorf("unmarshaling transport parameters from session ticket failed: %s", err.Error())
|
|
}
|
|
t.Parameters = &tp
|
|
} else if len(b) > 0 {
|
|
return fmt.Errorf("the session ticket has more bytes than expected")
|
|
}
|
|
t.RTT = time.Duration(rtt) * time.Microsecond
|
|
return nil
|
|
}
|
|
|
|
const extraPrefix = "quic-go1"
|
|
|
|
func addSessionStateExtraPrefix(b []byte) []byte {
|
|
return append([]byte(extraPrefix), b...)
|
|
}
|
|
|
|
func findSessionStateExtraData(extras [][]byte) []byte {
|
|
prefix := []byte(extraPrefix)
|
|
for _, extra := range extras {
|
|
if len(extra) < len(prefix) || !bytes.Equal(prefix, extra[:len(prefix)]) {
|
|
continue
|
|
}
|
|
return extra[len(prefix):]
|
|
}
|
|
return nil
|
|
}
|