Allow a missing sig algs extension if resuming
authorMatt Caswell <matt@openssl.org>
Tue, 16 May 2017 11:04:00 +0000 (12:04 +0100)
committerMatt Caswell <matt@openssl.org>
Wed, 17 May 2017 14:33:42 +0000 (15:33 +0100)
The current TLSv1.3 spec says:

'If a server is authenticating via a certificate and the client has not
sent a "signature_algorithms" extension, then the server MUST abort the
handshake with a "missing_extension" alert (see Section 8.2).'

If we are resuming then we are not "authenticating via a certificate" but
we were still aborting with the missing_extension alert if sig algs was
missing.

This commit ensures that we only send the alert if we are not resuming.

Reviewed-by: Rich Salz <rsalz@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/3478)

ssl/statem/extensions.c

index fd76337564024f16f49efb615f2f6bfa8db42af7..68d8cea0bdd58f4e8fcbd061c966f1b36c7c4476 100644 (file)
@@ -1081,7 +1081,7 @@ static int init_srtp(SSL *s, unsigned int context)
 
 static int final_sig_algs(SSL *s, unsigned int context, int sent, int *al)
 {
-    if (!sent && SSL_IS_TLS13(s)) {
+    if (!sent && SSL_IS_TLS13(s) && !s->hit) {
         *al = TLS13_AD_MISSING_EXTENSION;
         SSLerr(SSL_F_FINAL_SIG_ALGS, SSL_R_MISSING_SIGALGS_EXTENSION);
         return 0;