Package org.java_websocket
Class SSLSocketChannel2
java.lang.Object
org.java_websocket.SSLSocketChannel2
- All Implemented Interfaces:
Closeable,AutoCloseable,ByteChannel,Channel,ReadableByteChannel,WritableByteChannel,ISSLChannel,WrappedByteChannel
public class SSLSocketChannel2
extends Object
implements ByteChannel, WrappedByteChannel, ISSLChannel
Implements the relevant portions of the SocketChannel interface with the SSLEngine wrapper.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected intShould be used to count the buffer allocations.protected static ByteBufferThis object is used to feed theSSLEngine's wrap and unwrap methods during the handshake phase.protected ExecutorServiceprotected ByteBufferencrypted data incomingprotected ByteBufferraw payload incomingprotected ByteBufferencrypted data outgoingprotected SSLEngineResultprotected SelectionKeyused to set interestOP SelectionKey.OP_WRITE for the underlying channelprotected SocketChannelthe underlying channelprotected SSLEngineprotected SSLEngineResult -
Constructor Summary
ConstructorsConstructorDescriptionSSLSocketChannel2(SocketChannel channel, SSLEngine sslEngine, ExecutorService exec, SelectionKey key) -
Method Summary
Modifier and TypeMethodDescriptionvoidclose()configureBlocking(boolean b) booleanconnect(SocketAddress remote) protected voidprotected voidcreateBuffers(SSLSession session) booleanGet the ssl engine used for the de- and encryption of the communication.booleanThis function returns the blocking state of the channelbooleanbooleanbooleanreturns whether readMore should be called to fetch data which has been decoded but not yet been returned.booleanreturns whether writeMore should be called write additional data.booleanisOpen()intread(ByteBuffer dst) Blocks when in blocking mode until at least one byte has been decoded.
When not in blocking mode 0 may be returned.intreadMore(ByteBuffer dst) This function does not read data from the underlying channel at all.socket()intwrite(ByteBuffer src) voidGets called whenWrappedByteChannel.isNeedWrite()()} requires a additional rite
-
Field Details
-
emptybuffer
This object is used to feed theSSLEngine's wrap and unwrap methods during the handshake phase. -
exec
-
tasks
-
inData
raw payload incoming -
outCrypt
encrypted data outgoing -
inCrypt
encrypted data incoming -
socketChannel
the underlying channel -
selectionKey
used to set interestOP SelectionKey.OP_WRITE for the underlying channel -
sslEngine
-
readEngineResult
-
writeEngineResult
-
bufferallocations
protected int bufferallocationsShould be used to count the buffer allocations. But because of #190 where HandshakeStatus.FINISHED is not properly returned by nio wrap/unwrap this variable is used to check whethercreateBuffers(SSLSession)needs to be called.
-
-
Constructor Details
-
SSLSocketChannel2
public SSLSocketChannel2(SocketChannel channel, SSLEngine sslEngine, ExecutorService exec, SelectionKey key) throws IOException - Throws:
IOException
-
-
Method Details
-
consumeDelegatedTasks
protected void consumeDelegatedTasks() -
createBuffers
-
write
- Specified by:
writein interfaceWritableByteChannel- Throws:
IOException
-
read
Blocks when in blocking mode until at least one byte has been decoded.
When not in blocking mode 0 may be returned.- Specified by:
readin interfaceReadableByteChannel- Returns:
- the number of bytes read.
- Throws:
IOException
-
isConnected
public boolean isConnected() -
close
- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceChannel- Specified by:
closein interfaceCloseable- Throws:
IOException
-
configureBlocking
- Throws:
IOException
-
connect
- Throws:
IOException
-
finishConnect
- Throws:
IOException
-
socket
-
isInboundDone
public boolean isInboundDone() -
isOpen
public boolean isOpen() -
isNeedWrite
public boolean isNeedWrite()Description copied from interface:WrappedByteChannelreturns whether writeMore should be called write additional data.- Specified by:
isNeedWritein interfaceWrappedByteChannel- Returns:
- is a additional write needed
-
writeMore
Description copied from interface:WrappedByteChannelGets called whenWrappedByteChannel.isNeedWrite()()} requires a additional rite- Specified by:
writeMorein interfaceWrappedByteChannel- Throws:
IOException- may be thrown due to an error while writing
-
isNeedRead
public boolean isNeedRead()Description copied from interface:WrappedByteChannelreturns whether readMore should be called to fetch data which has been decoded but not yet been returned.- Specified by:
isNeedReadin interfaceWrappedByteChannel- Returns:
- is a additional read needed
- See Also:
-
readMore
Description copied from interface:WrappedByteChannelThis function does not read data from the underlying channel at all. It is just a way to fetch data which has already be received or decoded but was but was not yet returned to the user. This could be the case when the decoded data did not fit into the buffer the user passed toReadableByteChannel.read(ByteBuffer).- Specified by:
readMorein interfaceWrappedByteChannel- Parameters:
dst- the destiny of the read- Returns:
- the amount of remaining data
- Throws:
SSLException
-
isBlocking
public boolean isBlocking()Description copied from interface:WrappedByteChannelThis function returns the blocking state of the channel- Specified by:
isBlockingin interfaceWrappedByteChannel- Returns:
- is the channel blocking
-
getSSLEngine
Description copied from interface:ISSLChannelGet the ssl engine used for the de- and encryption of the communication.- Specified by:
getSSLEnginein interfaceISSLChannel- Returns:
- the ssl engine of this channel
-