From ef2cf4625d78d35a956ec8f18d80fb3c2e63cbd7 Mon Sep 17 00:00:00 2001 From: Norman Maurer Date: Mon, 18 Jan 2016 20:42:37 +0100 Subject: [PATCH] [#4725] Ensure correct cause of handshake error is included in the SSLHandshakeException when using OpenSslEngine. Motivation: We need to ensure we add the correct handshake error to the SSLHandshakeException before throwing it when failing the handshake. Modifications: Use the correct error string when creating the SSLHandshakeException. Result: Correct SSLHandshakeException message included. --- .../src/main/java/io/netty/handler/ssl/OpenSslEngine.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/handler/src/main/java/io/netty/handler/ssl/OpenSslEngine.java b/handler/src/main/java/io/netty/handler/ssl/OpenSslEngine.java index 1570c75db2..91469ab0c1 100644 --- a/handler/src/main/java/io/netty/handler/ssl/OpenSslEngine.java +++ b/handler/src/main/java/io/netty/handler/ssl/OpenSslEngine.java @@ -750,6 +750,8 @@ public final class OpenSslEngine extends SSLEngine { } private SSLEngineResult sslReadErrorResult(int err, int bytesConsumed, int bytesProduced) throws SSLException { + String errStr = SSL.getErrorString(err); + // Check if we have a pending handshakeException and if so see if we need to consume all pending data from the // BIO first or can just shutdown and throw it now. // This is needed so we ensure close_notify etc is correctly send to the remote peer. @@ -758,11 +760,11 @@ public final class OpenSslEngine extends SSLEngine { if (handshakeException == null && handshakeState != HandshakeState.FINISHED) { // we seems to have data left that needs to be transfered and so the user needs // call wrap(...). Store the error so we can pick it up later. - handshakeException = new SSLHandshakeException(SSL.getLastError()); + handshakeException = new SSLHandshakeException(errStr); } return new SSLEngineResult(OK, NEED_WRAP, bytesConsumed, bytesProduced); } - throw shutdownWithError("SSL_read", SSL.getErrorString(err)); + throw shutdownWithError("SSL_read", errStr); } private int pendingAppData() {