Fix s_client early data indicator
authorMatt Caswell <matt@openssl.org>
Thu, 30 Mar 2017 15:06:29 +0000 (16:06 +0100)
committerMatt Caswell <matt@openssl.org>
Thu, 30 Mar 2017 15:16:38 +0000 (16:16 +0100)
s_client was always saying that early_data was rejected even when it was
accepted. This was because it was using the wrong test to detect the end
of the handshake. It was using SSL_in_init() which only tells you whether
it is currently processing/sending/expecting handshake messages. It should
use SSL_is_init_finished() which tells you that no handshake messages are
being processed/sent/expected AND we have completed the handshake. In the
early data case we are not processing/sending handshake messages and we
are expecting early data (not a handshake message) - but the handshake has
not yet completed.

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

apps/s_client.c

index 67e9a925726ec89aa035c7f11af747a15d25dd00..fc18da282c67f854380a03d85b2dcd32b432cd8a 100644 (file)
@@ -2403,7 +2403,7 @@ int s_client_main(int argc, char **argv)
         else
             timeoutp = NULL;
 
-        if (SSL_in_init(con) && !SSL_total_renegotiations(con)
+        if (!SSL_is_init_finished(con) && SSL_total_renegotiations(con) == 0
                 && SSL_get_key_update_type(con) == SSL_KEY_UPDATE_NONE) {
             in_init = 1;
             tty_on = 0;