crypto/tls: check that client cipher suite matches version

This commit is contained in:
Peter Wu 2017-09-12 19:52:05 +01:00
bovenliggende 998f77009e
commit 857c7243c9

Bestand weergeven

@ -186,6 +186,12 @@ NextCipherSuite:
c.sendAlert(alertHandshakeFailure)
return errors.New("tls: server chose an unconfigured cipher suite")
}
// Check that the chosen cipher suite matches the protocol version.
if c.vers >= VersionTLS13 && suite.flags&suiteTLS13 == 0 ||
c.vers < VersionTLS13 && suite.flags&suiteTLS13 != 0 {
c.sendAlert(alertHandshakeFailure)
return errors.New("tls: server chose an inappropriate cipher suite")
}
hs := &clientHandshakeState{
c: c,