From: Dr. Stephen Henson Date: Sat, 12 Sep 2015 01:37:48 +0000 (+0100) Subject: Make SRP work with -www X-Git-Tag: OpenSSL_1_0_1q~62 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=34a0eade7ffea9c73b59e0fdffd4e1148b47b5ee;p=oweals%2Fopenssl.git Make SRP work with -www PR#3817 Reviewed-by: Rich Salz (cherry picked from commit 4e7e623012e1604d985e2ef362c2957d464f3f01) Conflicts: apps/s_server.c --- diff --git a/apps/s_server.c b/apps/s_server.c index b58e5e07c4..a8aee77a6e 100644 --- a/apps/s_server.c +++ b/apps/s_server.c @@ -2654,6 +2654,21 @@ static int www_body(char *hostname, int s, unsigned char *context) goto err; } else { BIO_printf(bio_s_out, "read R BLOCK\n"); +#ifndef OPENSSL_NO_SRP + if (BIO_should_io_special(io) + && BIO_get_retry_reason(io) == BIO_RR_SSL_X509_LOOKUP) { + BIO_printf(bio_s_out, "LOOKUP renego during read\n"); + srp_callback_parm.user = + SRP_VBASE_get_by_user(srp_callback_parm.vb, + srp_callback_parm.login); + if (srp_callback_parm.user) + BIO_printf(bio_s_out, "LOOKUP done %s\n", + srp_callback_parm.user->info); + else + BIO_printf(bio_s_out, "LOOKUP not successful\n"); + continue; + } +#endif #if defined(OPENSSL_SYS_NETWARE) delay(1000); #elif !defined(OPENSSL_SYS_MSDOS) && !defined(__DJGPP__)