mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-04 12:37:35 +03:00
crypto/tls: implement TLS 1.3 version-specific messages
Note that there is significant code duplication due to extensions with the same format appearing in different messages in TLS 1.3. This will be cleaned up in a future refactor once CL 145317 is merged. Enforcing the presence/absence of each extension in each message is left to the upper layer, based on both protocol version and extensions advertised in CH and CR. Duplicated extensions and unknown extensions in SH, EE, HRR, and CT will be tightened up in a future CL. The TLS 1.2 CertificateStatus message was restricted to accepting only type OCSP as any other type (none of which are specified so far) would have to be negotiated. Updates #9671 Change-Id: I7c42394c5cc0af01faa84b9b9f25fdc6e7cfbb9e Reviewed-on: https://go-review.googlesource.com/c/145477 Reviewed-by: Adam Langley <agl@golang.org>
This commit is contained in:
parent
3fdae13d6a
commit
d4e9432552
6 changed files with 613 additions and 65 deletions
26
conn.go
26
conn.go
|
@ -990,12 +990,24 @@ func (c *Conn) readHandshake() (interface{}, error) {
|
|||
case typeServerHello:
|
||||
m = new(serverHelloMsg)
|
||||
case typeNewSessionTicket:
|
||||
m = new(newSessionTicketMsg)
|
||||
if c.vers == VersionTLS13 {
|
||||
m = new(newSessionTicketMsgTLS13)
|
||||
} else {
|
||||
m = new(newSessionTicketMsg)
|
||||
}
|
||||
case typeCertificate:
|
||||
m = new(certificateMsg)
|
||||
if c.vers == VersionTLS13 {
|
||||
m = new(certificateMsgTLS13)
|
||||
} else {
|
||||
m = new(certificateMsg)
|
||||
}
|
||||
case typeCertificateRequest:
|
||||
m = &certificateRequestMsg{
|
||||
hasSignatureAlgorithm: c.vers >= VersionTLS12,
|
||||
if c.vers == VersionTLS13 {
|
||||
m = new(certificateRequestMsgTLS13)
|
||||
} else {
|
||||
m = &certificateRequestMsg{
|
||||
hasSignatureAlgorithm: c.vers >= VersionTLS12,
|
||||
}
|
||||
}
|
||||
case typeCertificateStatus:
|
||||
m = new(certificateStatusMsg)
|
||||
|
@ -1013,6 +1025,12 @@ func (c *Conn) readHandshake() (interface{}, error) {
|
|||
m = new(nextProtoMsg)
|
||||
case typeFinished:
|
||||
m = new(finishedMsg)
|
||||
case typeEncryptedExtensions:
|
||||
m = new(encryptedExtensionsMsg)
|
||||
case typeEndOfEarlyData:
|
||||
m = new(endOfEarlyDataMsg)
|
||||
case typeKeyUpdate:
|
||||
m = new(keyUpdateMsg)
|
||||
default:
|
||||
return nil, c.in.setErrorLocked(c.sendAlert(alertUnexpectedMessage))
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue