mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 20:57:36 +03:00
Application data is now retrieved and restored via two callbacks on the qtls.Config. This allows us the get rid of the rather complex wrapping of the qtls.ClientSessionCache. Furthermore, it makes sure that we only restore the application data when qtls decides to actually use the ticket.
44 lines
1.4 KiB
Go
44 lines
1.4 KiB
Go
package handshake
|
|
|
|
// This package uses unsafe to convert between:
|
|
// * qtls.Certificate and tls.Certificate
|
|
// * qtls.CertificateRequestInfo and tls.CertificateRequestInfo
|
|
// * qtls.ClientHelloInfo and tls.ClientHelloInfo
|
|
// * qtls.ConnectionState and tls.ConnectionState
|
|
// * qtls.ClientSessionState and tls.ClientSessionState
|
|
// We check in init() that this conversion actually is safe.
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"reflect"
|
|
|
|
"github.com/marten-seemann/qtls"
|
|
)
|
|
|
|
func init() {
|
|
if !structsEqual(&tls.Certificate{}, &qtls.Certificate{}) {
|
|
panic("qtls.Certificate not compatible with tls.Certificate")
|
|
}
|
|
if !structsEqual(&tls.CertificateRequestInfo{}, &qtls.CertificateRequestInfo{}) {
|
|
panic("qtls.CertificateRequestInfo not compatible with tls.CertificateRequestInfo")
|
|
}
|
|
if !structsEqual(&tls.ClientSessionState{}, &qtls.ClientSessionState{}) {
|
|
panic("qtls.ClientSessionState not compatible with tls.ClientSessionState")
|
|
}
|
|
}
|
|
|
|
func structsEqual(a, b interface{}) bool {
|
|
sa := reflect.ValueOf(a).Elem()
|
|
sb := reflect.ValueOf(b).Elem()
|
|
if sa.NumField() != sb.NumField() {
|
|
return false
|
|
}
|
|
for i := 0; i < sa.NumField(); i++ {
|
|
fa := sa.Type().Field(i)
|
|
fb := sb.Type().Field(i)
|
|
if !reflect.DeepEqual(fa.Index, fb.Index) || fa.Name != fb.Name || fa.Anonymous != fb.Anonymous || fa.Offset != fb.Offset || !reflect.DeepEqual(fa.Type, fb.Type) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|