Commit 23573051 authored by Matt Caswell's avatar Matt Caswell
Browse files

Stop server from expecting Certificate message when not requested



In a non client-auth renegotiation where the original handshake *was*
client auth, then the server will expect the client to send a Certificate
message anyway resulting in a connection failure.

Reviewed-by: default avatarRichard Levitte <levitte@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/1982)
parent 10305baf
Loading
Loading
Loading
Loading
+2 −1
Original line number Diff line number Diff line
@@ -347,6 +347,8 @@ static int state_machine(SSL *s, int server)
                 */
                s->ctx->stats.sess_accept_renegotiate++;
            }

            s->s3->tmp.cert_request = 0;
        } else {
            s->ctx->stats.sess_connect++;

@@ -354,7 +356,6 @@ static int state_machine(SSL *s, int server)
            memset(s->s3->client_random, 0, sizeof(s->s3->client_random));
            s->hit = 0;

            s->s3->tmp.cert_request = 0;
            s->s3->tmp.cert_req = 0;

            if (SSL_IS_DTLS(s)) {