Package io.netty.handler.ssl
Class OptionalSslHandler
- java.lang.Object
-
- io.netty.channel.ChannelHandlerAdapter
-
- io.netty.channel.ChannelInboundHandlerAdapter
-
- io.netty.handler.codec.ByteToMessageDecoder
-
- io.netty.handler.ssl.OptionalSslHandler
-
- All Implemented Interfaces:
ChannelHandler,ChannelInboundHandler
public class OptionalSslHandler extends ByteToMessageDecoder
OptionalSslHandleris a utility decoder to support both SSL and non-SSL handlers based on the first message received.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class io.netty.handler.codec.ByteToMessageDecoder
ByteToMessageDecoder.Cumulator
-
Nested classes/interfaces inherited from interface io.netty.channel.ChannelHandler
ChannelHandler.Sharable
-
-
Field Summary
-
Fields inherited from class io.netty.handler.codec.ByteToMessageDecoder
COMPOSITE_CUMULATOR, MERGE_CUMULATOR
-
-
Constructor Summary
Constructors Constructor Description OptionalSslHandler(SslContext sslContext)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voiddecode(ChannelHandlerContext context, ByteBuf in, java.util.List<java.lang.Object> out)Decode the from oneByteBufto an other.protected ChannelHandlernewNonSslHandler(ChannelHandlerContext context)Override to configure the ChannelHandler.protected java.lang.StringnewNonSslHandlerName()Optionally specify the non-SSL handler name, this method may returnnull.protected SslHandlernewSslHandler(ChannelHandlerContext context, SslContext sslContext)Override to configure the SslHandler eg.protected java.lang.StringnewSslHandlerName()Optionally specify the SSL handler name, this method may returnnull.-
Methods inherited from class io.netty.handler.codec.ByteToMessageDecoder
actualReadableBytes, callDecode, channelInactive, channelRead, channelReadComplete, decodeLast, discardSomeReadBytes, handlerRemoved, handlerRemoved0, internalBuffer, isSingleDecode, setCumulator, setDiscardAfterReads, setSingleDecode, userEventTriggered
-
Methods inherited from class io.netty.channel.ChannelInboundHandlerAdapter
channelActive, channelRegistered, channelUnregistered, channelWritabilityChanged, exceptionCaught
-
Methods inherited from class io.netty.channel.ChannelHandlerAdapter
ensureNotSharable, handlerAdded, isSharable
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface io.netty.channel.ChannelHandler
handlerAdded
-
-
-
-
Constructor Detail
-
OptionalSslHandler
public OptionalSslHandler(SslContext sslContext)
-
-
Method Detail
-
decode
protected void decode(ChannelHandlerContext context, ByteBuf in, java.util.List<java.lang.Object> out) throws java.lang.Exception
Description copied from class:ByteToMessageDecoderDecode the from oneByteBufto an other. This method will be called till either the inputByteBufhas nothing to read when return from this method or till nothing was read from the inputByteBuf.- Specified by:
decodein classByteToMessageDecoder- Parameters:
context- theChannelHandlerContextwhich thisByteToMessageDecoderbelongs toin- theByteBuffrom which to read dataout- theListto which decoded messages should be added- Throws:
java.lang.Exception- is thrown if an error occurs
-
newSslHandlerName
protected java.lang.String newSslHandlerName()
Optionally specify the SSL handler name, this method may returnnull.- Returns:
- the name of the SSL handler.
-
newSslHandler
protected SslHandler newSslHandler(ChannelHandlerContext context, SslContext sslContext)
Override to configure the SslHandler eg.SSLParameters.setEndpointIdentificationAlgorithm(String). The hostname and port is not known by this method so servers may want to override this method and use theSslContext.newHandler(ByteBufAllocator, String, int)variant.- Parameters:
context- theChannelHandlerContextto use.sslContext- theSSLContextto use.- Returns:
- the
SslHandlerwhich will replace theOptionalSslHandlerin the pipeline if the traffic is SSL.
-
newNonSslHandlerName
protected java.lang.String newNonSslHandlerName()
Optionally specify the non-SSL handler name, this method may returnnull.- Returns:
- the name of the non-SSL handler.
-
newNonSslHandler
protected ChannelHandler newNonSslHandler(ChannelHandlerContext context)
Override to configure the ChannelHandler.- Parameters:
context- theChannelHandlerContextto use.- Returns:
- the
ChannelHandlerwhich will replace theOptionalSslHandlerin the pipeline ornullto simply remove theOptionalSslHandlerif the traffic is non-SSL.
-
-