From b07b2a1b44a26909c9e89435ae417e0d30ca6951 Mon Sep 17 00:00:00 2001 From: Matt Caswell Date: Thu, 9 Feb 2017 13:33:09 +0000 Subject: [PATCH] Add the ability for s_client to send a KeyUpdate message Reviewed-by: Rich Salz (Merged from https://github.com/openssl/openssl/pull/2609) --- apps/s_client.c | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/apps/s_client.c b/apps/s_client.c index 2db985daf3..a2ededcf0c 100644 --- a/apps/s_client.c +++ b/apps/s_client.c @@ -2291,7 +2291,8 @@ int s_client_main(int argc, char **argv) else timeoutp = NULL; - if (SSL_in_init(con) && !SSL_total_renegotiations(con)) { + if (SSL_in_init(con) && !SSL_total_renegotiations(con) + && SSL_get_key_update_type(con) == SSL_KEY_UPDATE_NONE) { in_init = 1; tty_on = 0; } else { @@ -2606,6 +2607,15 @@ int s_client_main(int argc, char **argv) SSL_renegotiate(con); cbuf_len = 0; } + + if ((!c_ign_eof) && ((cbuf[0] == 'K' || cbuf[0] == 'k' ) + && cmdletters)) { + BIO_printf(bio_err, "KEYUPDATE\n"); + SSL_key_update(con, + cbuf[0] == 'K' ? SSL_KEY_UPDATE_REQUESTED + : SSL_KEY_UPDATE_NOT_REQUESTED); + cbuf_len = 0; + } #ifndef OPENSSL_NO_HEARTBEATS else if ((!c_ign_eof) && (cbuf[0] == 'B' && cmdletters)) { BIO_printf(bio_err, "HEARTBEATING\n"); -- 2.34.1