Java Code Examples for javax.net.ssl.SSLEngine#getDelegatedTask()
The following examples show how to use
javax.net.ssl.SSLEngine#getDelegatedTask() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: TestTLS12.java From dragonwell8_jdk with GNU General Public License v2.0 | 5 votes |
private static void runDelegatedTasks(SSLEngineResult result, SSLEngine engine) throws Exception { if (result.getHandshakeStatus() == HandshakeStatus.NEED_TASK) { Runnable runnable; while ((runnable = engine.getDelegatedTask()) != null) { runnable.run(); } HandshakeStatus hsStatus = engine.getHandshakeStatus(); if (hsStatus == HandshakeStatus.NEED_TASK) { throw new Exception( "handshake shouldn't need additional tasks"); } } }
Example 2
Source File: AbstractSslEngineBenchmark.java From netty-4.1.22 with Apache License 2.0 | 5 votes |
private static void runDelegatedTasks(SSLEngineResult result, SSLEngine engine) { if (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_TASK) { for (;;) { Runnable task = engine.getDelegatedTask(); if (task == null) { break; } task.run(); } } }
Example 3
Source File: SSLEngineTest.java From netty-4.1.22 with Apache License 2.0 | 5 votes |
private static void runDelegatedTasks(SSLEngineResult result, SSLEngine engine) { if (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_TASK) { for (;;) { Runnable task = engine.getDelegatedTask(); if (task == null) { break; } task.run(); } } }
Example 4
Source File: TestTLS12.java From TencentKona-8 with GNU General Public License v2.0 | 5 votes |
private static void runDelegatedTasks(SSLEngineResult result, SSLEngine engine) throws Exception { if (result.getHandshakeStatus() == HandshakeStatus.NEED_TASK) { Runnable runnable; while ((runnable = engine.getDelegatedTask()) != null) { runnable.run(); } HandshakeStatus hsStatus = engine.getHandshakeStatus(); if (hsStatus == HandshakeStatus.NEED_TASK) { throw new Exception( "handshake shouldn't need additional tasks"); } } }
Example 5
Source File: TestTLS12.java From openjdk-jdk8u with GNU General Public License v2.0 | 5 votes |
private static void runDelegatedTasks(SSLEngineResult result, SSLEngine engine) throws Exception { if (result.getHandshakeStatus() == HandshakeStatus.NEED_TASK) { Runnable runnable; while ((runnable = engine.getDelegatedTask()) != null) { runnable.run(); } HandshakeStatus hsStatus = engine.getHandshakeStatus(); if (hsStatus == HandshakeStatus.NEED_TASK) { throw new Exception( "handshake shouldn't need additional tasks"); } } }
Example 6
Source File: DiameterFirewall.java From SigFW with GNU Affero General Public License v3.0 | 5 votes |
/** * DTLS run delegated tasks */ void dtls_runDelegatedTasks(SSLEngine engine) throws Exception { Runnable runnable; while ((runnable = engine.getDelegatedTask()) != null) { runnable.run(); } SSLEngineResult.HandshakeStatus hs = engine.getHandshakeStatus(); if (hs == SSLEngineResult.HandshakeStatus.NEED_TASK) { throw new Exception("handshake shouldn't need additional tasks"); } }
Example 7
Source File: SSLEngineTestCase.java From openjdk-jdk9 with GNU General Public License v2.0 | 5 votes |
private static void runDelegatedTasks(SSLEngine engine) { Runnable runnable; System.out.println("Running delegated tasks..."); while ((runnable = engine.getDelegatedTask()) != null) { runnable.run(); } HandshakeStatus hs = engine.getHandshakeStatus(); if (hs == HandshakeStatus.NEED_TASK) { throw new Error("Handshake shouldn't need additional tasks."); } }
Example 8
Source File: TestTLS12.java From jdk8u_jdk with GNU General Public License v2.0 | 5 votes |
private static void runDelegatedTasks(SSLEngineResult result, SSLEngine engine) throws Exception { if (result.getHandshakeStatus() == HandshakeStatus.NEED_TASK) { Runnable runnable; while ((runnable = engine.getDelegatedTask()) != null) { runnable.run(); } HandshakeStatus hsStatus = engine.getHandshakeStatus(); if (hsStatus == HandshakeStatus.NEED_TASK) { throw new Exception( "handshake shouldn't need additional tasks"); } } }
Example 9
Source File: SSLCodec.java From NetBare with MIT License | 4 votes |
private void runDelegatedTasks(SSLEngine engine) { while (true) { final Runnable task = engine.getDelegatedTask(); if (task == null) { break; } task.run(); } }
Example 10
Source File: GelfTCPSSLSender.java From xian with Apache License 2.0 | 4 votes |
private void doHandshake(SocketChannel socketChannel, SSLEngine sslEngine, ByteBuffer myNetData, ByteBuffer peerNetData) throws IOException { // Create byte buffers to use for holding application data int appBufferSize = sslEngine.getSession().getApplicationBufferSize(); ByteBuffer myAppData = ByteBuffer.allocate(appBufferSize); ByteBuffer peerAppData = ByteBuffer.allocate(appBufferSize); SSLEngineResult.HandshakeStatus hs = sslEngine.getHandshakeStatus(); // Process handshaking message while (hs != SSLEngineResult.HandshakeStatus.FINISHED && hs != SSLEngineResult.HandshakeStatus.NOT_HANDSHAKING) { switch (hs) { case NEED_UNWRAP: // Receive handshaking data from peer if (socketChannel.read(peerNetData) < 0) { throw new SocketException("Channel closed"); } // Process incoming handshaking data peerNetData.flip(); SSLEngineResult res = sslEngine.unwrap(peerNetData, peerAppData); peerNetData.compact(); hs = res.getHandshakeStatus(); // Check status switch (res.getStatus()) { case OK: // Handle OK status break; case BUFFER_OVERFLOW: peerAppData = enlargeBuffer(peerNetData, peerAppData); break; case BUFFER_UNDERFLOW: break; } break; case NEED_WRAP: // Empty the local network packet buffer. myNetData.clear(); // Generate handshaking data res = sslEngine.wrap(myAppData, myNetData); hs = res.getHandshakeStatus(); // Check status switch (res.getStatus()) { case OK: myNetData.flip(); // Send the handshaking data to peer while (myNetData.hasRemaining()) { if (socketChannel.write(myNetData) < 0) { // Handle closed channel } } break; case BUFFER_OVERFLOW: myNetData = enlargeBuffer(myAppData, myNetData); break; case BUFFER_UNDERFLOW: break; case CLOSED: if (sslEngine.isOutboundDone()) { return; } else { sslEngine.closeOutbound(); hs = sslEngine.getHandshakeStatus(); break; } default: throw new IOException("Cannot wrap data: " + res.getStatus()); } break; case NEED_TASK: Runnable task; while ((task = sslEngine.getDelegatedTask()) != null) { task.run(); } hs = sslEngine.getHandshakeStatus(); break; case FINISHED: return; } } }
Example 11
Source File: TlsHelper.java From an2linuxclient with GNU General Public License v3.0 | 4 votes |
public static SSLEngineResult.HandshakeStatus doHandshake(SSLEngine tlsEngine, ByteBuffer netDataBuf, OutputStream out, InputStream in){ try { ByteBuffer empty; /*Apparently on Android 4.4 (API_19) SSLEngine whines about BUFFER_OVERFLOW for this buffer even though nothing ever gets written to it*/ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT_WATCH){ empty = ByteBuffer.allocate(0); } else { empty = ByteBuffer.allocate(tlsEngine.getSession().getApplicationBufferSize()); } // ClientHello -> netDataBuf tlsEngine.wrap(empty, netDataBuf); netDataBuf.flip(); byte[] clientHello = new byte[netDataBuf.limit()]; netDataBuf.get(clientHello); out.write(ConnectionHelper.intToByteArray(clientHello.length)); out.write(clientHello); // netDataBuf <- ServerHello..ServerHelloDone int serverHelloSize = ByteBuffer.wrap(ConnectionHelper.readAll(4, in)).getInt(); byte[] serverHello = ConnectionHelper.readAll(serverHelloSize, in); netDataBuf.clear(); netDataBuf.put(serverHello); netDataBuf.flip(); SSLEngineResult result = tlsEngine.unwrap(netDataBuf, empty); while (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_UNWRAP){ result = tlsEngine.unwrap(netDataBuf, empty); } Runnable task = tlsEngine.getDelegatedTask(); while (task != null){ task.run(); task = tlsEngine.getDelegatedTask(); } // [client]Certificate*..ClientKeyExchange..Finished -> netDataBuf netDataBuf.clear(); result = tlsEngine.wrap(empty, netDataBuf); while (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_WRAP){ result = tlsEngine.wrap(empty, netDataBuf); } netDataBuf.flip(); byte[] clientKeyExchange = new byte[netDataBuf.limit()]; netDataBuf.get(clientKeyExchange); out.write(ConnectionHelper.intToByteArray(clientKeyExchange.length)); out.write(clientKeyExchange); // netDataBuf <- ChangeCipherSpec..Finished int serverChangeCipherSpecSize = ByteBuffer.wrap(ConnectionHelper.readAll(4, in)).getInt(); byte[] serverChangeCipherSpec = ConnectionHelper.readAll(serverChangeCipherSpecSize, in); netDataBuf.clear(); netDataBuf.put(serverChangeCipherSpec); netDataBuf.flip(); result = tlsEngine.unwrap(netDataBuf, empty); while (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_UNWRAP){ result = tlsEngine.unwrap(netDataBuf, empty); } /*On Android 8.1 (LineageOS 15.1) on a Xiaomi device (not sure about others) the SSL_ENGINE may return NEED_WRAP here, so we do that even though no data gets written by the SSL_ENGINE ???*/ if (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_WRAP) { netDataBuf.clear(); result = tlsEngine.wrap(empty, netDataBuf); // netDataBuf still empty here... } /*Apparently on Android 4.4 (API_19) with SSLEngine the latest call tlsEngine.unwrap(..) that finishes the handshake returns NOT_HANDSHAKING instead of FINISHED as the result*/ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT_WATCH){ return result.getHandshakeStatus(); } else { if (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NOT_HANDSHAKING){ return SSLEngineResult.HandshakeStatus.FINISHED; } else if (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.FINISHED) { // just in case return result.getHandshakeStatus(); } else { return null; } } } catch (IOException e){ return null; } }
Example 12
Source File: TlsHelper.java From an2linuxclient with GNU General Public License v3.0 | 4 votes |
public static SSLEngineResult.HandshakeStatus doHandshake(SSLEngine tlsEngine, ByteBuffer netDataBuf, OutputStream out, InputStream in){ try { ByteBuffer empty; /*Apparently on Android 4.4 (API_19) SSLEngine whines about BUFFER_OVERFLOW for this buffer even though nothing ever gets written to it*/ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT_WATCH){ empty = ByteBuffer.allocate(0); } else { empty = ByteBuffer.allocate(tlsEngine.getSession().getApplicationBufferSize()); } // ClientHello -> netDataBuf tlsEngine.wrap(empty, netDataBuf); netDataBuf.flip(); byte[] clientHello = new byte[netDataBuf.limit()]; netDataBuf.get(clientHello); out.write(ConnectionHelper.intToByteArray(clientHello.length)); out.write(clientHello); // netDataBuf <- ServerHello..ServerHelloDone int serverHelloSize = ByteBuffer.wrap(ConnectionHelper.readAll(4, in)).getInt(); byte[] serverHello = ConnectionHelper.readAll(serverHelloSize, in); netDataBuf.clear(); netDataBuf.put(serverHello); netDataBuf.flip(); SSLEngineResult result = tlsEngine.unwrap(netDataBuf, empty); while (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_UNWRAP){ result = tlsEngine.unwrap(netDataBuf, empty); } Runnable task = tlsEngine.getDelegatedTask(); while (task != null){ task.run(); task = tlsEngine.getDelegatedTask(); } // [client]Certificate*..ClientKeyExchange..Finished -> netDataBuf netDataBuf.clear(); result = tlsEngine.wrap(empty, netDataBuf); while (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_WRAP){ result = tlsEngine.wrap(empty, netDataBuf); } netDataBuf.flip(); byte[] clientKeyExchange = new byte[netDataBuf.limit()]; netDataBuf.get(clientKeyExchange); out.write(ConnectionHelper.intToByteArray(clientKeyExchange.length)); out.write(clientKeyExchange); // netDataBuf <- ChangeCipherSpec..Finished int serverChangeCipherSpecSize = ByteBuffer.wrap(ConnectionHelper.readAll(4, in)).getInt(); byte[] serverChangeCipherSpec = ConnectionHelper.readAll(serverChangeCipherSpecSize, in); netDataBuf.clear(); netDataBuf.put(serverChangeCipherSpec); netDataBuf.flip(); result = tlsEngine.unwrap(netDataBuf, empty); while (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_UNWRAP){ result = tlsEngine.unwrap(netDataBuf, empty); } /*On Android 8.1 (LineageOS 15.1) on a Xiaomi device (not sure about others) the SSL_ENGINE may return NEED_WRAP here, so we do that even though no data gets written by the SSL_ENGINE ???*/ if (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NEED_WRAP) { netDataBuf.clear(); result = tlsEngine.wrap(empty, netDataBuf); // netDataBuf still empty here... } /*Apparently on Android 4.4 (API_19) with SSLEngine the latest call tlsEngine.unwrap(..) that finishes the handshake returns NOT_HANDSHAKING instead of FINISHED as the result*/ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT_WATCH){ return result.getHandshakeStatus(); } else { if (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.NOT_HANDSHAKING){ return SSLEngineResult.HandshakeStatus.FINISHED; } else if (result.getHandshakeStatus() == SSLEngineResult.HandshakeStatus.FINISHED) { // just in case return result.getHandshakeStatus(); } else { return null; } } } catch (IOException e){ return null; } }
Example 13
Source File: SSLSocket.java From whiskey with Apache License 2.0 | 4 votes |
private static void runDelegatedTasks(SSLEngine engine) { Runnable task; while ((task = engine.getDelegatedTask()) != null) { task.run(); } }
Example 14
Source File: Link.java From cloudstack with Apache License 2.0 | 4 votes |
public static boolean doHandshake(final SocketChannel socketChannel, final SSLEngine sslEngine) throws IOException { if (socketChannel == null || sslEngine == null) { return false; } final int appBufferSize = sslEngine.getSession().getApplicationBufferSize(); final int netBufferSize = sslEngine.getSession().getPacketBufferSize(); ByteBuffer myAppData = ByteBuffer.allocate(appBufferSize); ByteBuffer peerAppData = ByteBuffer.allocate(appBufferSize); ByteBuffer myNetData = ByteBuffer.allocate(netBufferSize); ByteBuffer peerNetData = ByteBuffer.allocate(netBufferSize); final Executor executor = Executors.newSingleThreadExecutor(); final long startTimeMills = System.currentTimeMillis(); HandshakeStatus handshakeStatus = sslEngine.getHandshakeStatus(); while (handshakeStatus != SSLEngineResult.HandshakeStatus.FINISHED && handshakeStatus != SSLEngineResult.HandshakeStatus.NOT_HANDSHAKING) { final long timeTaken = System.currentTimeMillis() - startTimeMills; if (timeTaken > 30000L) { s_logger.warn("SSL Handshake has taken more than 30s to connect to: " + socketChannel.getRemoteAddress() + ". Please investigate this connection."); return false; } switch (handshakeStatus) { case NEED_UNWRAP: final HandshakeHolder unwrapResult = doHandshakeUnwrap(socketChannel, sslEngine, peerAppData, peerNetData, appBufferSize); peerAppData = unwrapResult.getAppDataBuffer(); peerNetData = unwrapResult.getNetDataBuffer(); if (!unwrapResult.isSuccess()) { return false; } break; case NEED_WRAP: final HandshakeHolder wrapResult = doHandshakeWrap(socketChannel, sslEngine, myAppData, myNetData, peerNetData, netBufferSize); myNetData = wrapResult.getNetDataBuffer(); if (!wrapResult.isSuccess()) { return false; } break; case NEED_TASK: Runnable task; while ((task = sslEngine.getDelegatedTask()) != null) { if (s_logger.isTraceEnabled()) { s_logger.trace("SSL: Running delegated task!"); } executor.execute(task); } break; case FINISHED: break; case NOT_HANDSHAKING: break; default: throw new IllegalStateException("Invalid SSL status: " + handshakeStatus); } handshakeStatus = sslEngine.getHandshakeStatus(); } return true; }