Package io.netty.channel.sctp.nio
Class NioSctpChannel
- java.lang.Object
-
- io.netty.util.DefaultAttributeMap
-
- io.netty.channel.AbstractChannel
-
- io.netty.channel.nio.AbstractNioChannel
-
- io.netty.channel.nio.AbstractNioMessageChannel
-
- io.netty.channel.sctp.nio.NioSctpChannel
-
- All Implemented Interfaces:
Channel,ChannelOutboundInvoker,SctpChannel,AttributeMap,java.lang.Comparable<Channel>
public class NioSctpChannel extends AbstractNioMessageChannel implements SctpChannel
SctpChannelimplementation which use non-blocking mode and allows to read / writeSctpMessages to the underlyingSctpChannel. Be aware that not all operations systems support SCTP. Please refer to the documentation of your operation system, to understand what you need to do to use it. Also this feature is only supported on Java 7+.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class io.netty.channel.nio.AbstractNioChannel
AbstractNioChannel.AbstractNioUnsafe, AbstractNioChannel.NioUnsafe
-
Nested classes/interfaces inherited from class io.netty.channel.AbstractChannel
AbstractChannel.AbstractUnsafe
-
Nested classes/interfaces inherited from interface io.netty.channel.Channel
Channel.Unsafe
-
-
Field Summary
-
Fields inherited from class io.netty.channel.nio.AbstractNioChannel
readInterestOp, readOps
-
-
Constructor Summary
Constructors Constructor Description NioSctpChannel()Create a new instanceNioSctpChannel(com.sun.nio.sctp.SctpChannel sctpChannel)Create a new instance usingSctpChannelNioSctpChannel(Channel parent, com.sun.nio.sctp.SctpChannel sctpChannel)Create a new instance
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.util.Set<java.net.InetSocketAddress>allLocalAddresses()Return all local addresses of the SCTP channel.java.util.Set<java.net.InetSocketAddress>allRemoteAddresses()Return all remote addresses of the SCTP server channel.com.sun.nio.sctp.Associationassociation()Returns the underlying SCTP association.ChannelFuturebindAddress(java.net.InetAddress localAddress)Bind a address to the already bound channel to enable multi-homing.ChannelFuturebindAddress(java.net.InetAddress localAddress, ChannelPromise promise)Bind a address to the already bound channel to enable multi-homing.SctpChannelConfigconfig()Returns theSctpChannelConfigconfiguration of the channel.protected voiddoBind(java.net.SocketAddress localAddress)Bind theChannelto theSocketAddressprotected voiddoClose()Close theChannelprotected booleandoConnect(java.net.SocketAddress remoteAddress, java.net.SocketAddress localAddress)Connect to the remote peerprotected voiddoDisconnect()Disconnect thisChannelfrom its remote peerprotected voiddoFinishConnect()Finish the connectprotected intdoReadMessages(java.util.List<java.lang.Object> buf)Read messages into the given array and return the amount which was read.protected booleandoWriteMessage(java.lang.Object msg, ChannelOutboundBuffer in)Write a message to the underlyingChannel.protected java.lang.ObjectfilterOutboundMessage(java.lang.Object msg)Invoked when a new message is added to aChannelOutboundBufferof thisAbstractChannel, so that theChannelimplementation converts the message to another.booleanisActive()Returntrueif theChannelis active and so connected.protected com.sun.nio.sctp.SctpChanneljavaChannel()java.net.InetSocketAddresslocalAddress()Returns the local address where this channel is bound to.protected java.net.SocketAddresslocalAddress0()Returns theSocketAddresswhich is bound locally.ChannelMetadatametadata()SctpServerChannelparent()Returns the parent of this channel.java.net.InetSocketAddressremoteAddress()Returns the remote address where this channel is connected to.protected java.net.SocketAddressremoteAddress0()Return theSocketAddresswhich theChannelis connected to.ChannelFutureunbindAddress(java.net.InetAddress localAddress)Unbind the address from channel's multi-homing address list.ChannelFutureunbindAddress(java.net.InetAddress localAddress, ChannelPromise promise)Unbind the address from channel's multi-homing address list.-
Methods inherited from class io.netty.channel.nio.AbstractNioMessageChannel
closeOnReadError, continueOnWriteError, continueReading, doBeginRead, doWrite, newUnsafe
-
Methods inherited from class io.netty.channel.nio.AbstractNioChannel
addAndSubmit, clearReadPending, doDeregister, doRegister, isCompatible, isOpen, isReadPending, newDirectBuffer, newDirectBuffer, registration, removeAndSubmit, selectionKey, setReadPending, unsafe
-
Methods inherited from class io.netty.channel.AbstractChannel
closeFuture, compareTo, doRegister, doShutdownOutput, equals, eventLoop, hashCode, id, invalidateLocalAddress, invalidateRemoteAddress, isRegistered, maxMessagesPerWrite, newChannelPipeline, newId, pipeline, toString, validateFileRegion, voidPromise
-
Methods inherited from class io.netty.util.DefaultAttributeMap
attr, hasAttr
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface io.netty.util.AttributeMap
attr, hasAttr
-
Methods inherited from interface io.netty.channel.Channel
alloc, bind, bind, bytesBeforeUnwritable, bytesBeforeWritable, close, close, closeFuture, connect, connect, connect, connect, deregister, deregister, disconnect, disconnect, eventLoop, flush, getOption, id, isOpen, isRegistered, isWritable, newFailedFuture, newProgressivePromise, newPromise, newSucceededFuture, pipeline, read, setOption, unsafe, voidPromise, write, write, writeAndFlush, writeAndFlush
-
-
-
-
Constructor Detail
-
NioSctpChannel
public NioSctpChannel()
Create a new instance
-
NioSctpChannel
public NioSctpChannel(com.sun.nio.sctp.SctpChannel sctpChannel)
Create a new instance usingSctpChannel
-
NioSctpChannel
public NioSctpChannel(Channel parent, com.sun.nio.sctp.SctpChannel sctpChannel)
Create a new instance- Parameters:
parent- theChannelwhich is the parent of thisNioSctpChannelornull.sctpChannel- the underlyingSctpChannel
-
-
Method Detail
-
localAddress
public java.net.InetSocketAddress localAddress()
Description copied from interface:ChannelReturns the local address where this channel is bound to. The returnedSocketAddressis supposed to be down-cast into more concrete type such asInetSocketAddressto retrieve the detailed information.- Specified by:
localAddressin interfaceChannel- Specified by:
localAddressin interfaceSctpChannel- Overrides:
localAddressin classAbstractChannel- Returns:
- the local address of this channel.
nullif this channel is not bound.
-
remoteAddress
public java.net.InetSocketAddress remoteAddress()
Description copied from interface:ChannelReturns the remote address where this channel is connected to. The returnedSocketAddressis supposed to be down-cast into more concrete type such asInetSocketAddressto retrieve the detailed information.- Specified by:
remoteAddressin interfaceChannel- Specified by:
remoteAddressin interfaceSctpChannel- Overrides:
remoteAddressin classAbstractChannel- Returns:
- the remote address of this channel.
nullif this channel is not connected. If this channel is not connected but it can receive messages from arbitrary remote addresses (e.g.DatagramChannel, useDefaultAddressedEnvelope.recipient()to determine the origination of the received message as this method will returnnull.
-
parent
public SctpServerChannel parent()
Description copied from interface:ChannelReturns the parent of this channel.- Specified by:
parentin interfaceChannel- Specified by:
parentin interfaceSctpChannel- Overrides:
parentin classAbstractChannel- Returns:
- the parent channel.
nullif this channel does not have a parent channel.
-
metadata
public ChannelMetadata metadata()
Description copied from interface:Channel
-
association
public com.sun.nio.sctp.Association association()
Description copied from interface:SctpChannelReturns the underlying SCTP association.- Specified by:
associationin interfaceSctpChannel
-
allLocalAddresses
public java.util.Set<java.net.InetSocketAddress> allLocalAddresses()
Description copied from interface:SctpChannelReturn all local addresses of the SCTP channel. Please note that, it will return more than one address if this channel is using multi-homing- Specified by:
allLocalAddressesin interfaceSctpChannel
-
config
public SctpChannelConfig config()
Description copied from interface:SctpChannelReturns theSctpChannelConfigconfiguration of the channel.- Specified by:
configin interfaceChannel- Specified by:
configin interfaceSctpChannel
-
allRemoteAddresses
public java.util.Set<java.net.InetSocketAddress> allRemoteAddresses()
Description copied from interface:SctpChannelReturn all remote addresses of the SCTP server channel. Please note that, it will return more than one address if the remote is using multi-homing.- Specified by:
allRemoteAddressesin interfaceSctpChannel
-
javaChannel
protected com.sun.nio.sctp.SctpChannel javaChannel()
- Overrides:
javaChannelin classAbstractNioChannel
-
isActive
public boolean isActive()
Description copied from interface:ChannelReturntrueif theChannelis active and so connected.
-
localAddress0
protected java.net.SocketAddress localAddress0()
Description copied from class:AbstractChannelReturns theSocketAddresswhich is bound locally.- Specified by:
localAddress0in classAbstractChannel
-
remoteAddress0
protected java.net.SocketAddress remoteAddress0()
Description copied from class:AbstractChannelReturn theSocketAddresswhich theChannelis connected to.- Specified by:
remoteAddress0in classAbstractChannel
-
doBind
protected void doBind(java.net.SocketAddress localAddress) throws java.lang.ExceptionDescription copied from class:AbstractChannelBind theChannelto theSocketAddress- Specified by:
doBindin classAbstractChannel- Throws:
java.lang.Exception
-
doConnect
protected boolean doConnect(java.net.SocketAddress remoteAddress, java.net.SocketAddress localAddress) throws java.lang.ExceptionDescription copied from class:AbstractNioChannelConnect to the remote peer- Specified by:
doConnectin classAbstractNioChannel- Throws:
java.lang.Exception
-
doFinishConnect
protected void doFinishConnect() throws java.lang.ExceptionDescription copied from class:AbstractNioChannelFinish the connect- Specified by:
doFinishConnectin classAbstractNioChannel- Throws:
java.lang.Exception
-
doDisconnect
protected void doDisconnect() throws java.lang.ExceptionDescription copied from class:AbstractChannelDisconnect thisChannelfrom its remote peer- Specified by:
doDisconnectin classAbstractChannel- Throws:
java.lang.Exception
-
doClose
protected void doClose() throws java.lang.ExceptionDescription copied from class:AbstractChannelClose theChannel- Overrides:
doClosein classAbstractNioChannel- Throws:
java.lang.Exception
-
doReadMessages
protected int doReadMessages(java.util.List<java.lang.Object> buf) throws java.lang.ExceptionDescription copied from class:AbstractNioMessageChannelRead messages into the given array and return the amount which was read.- Specified by:
doReadMessagesin classAbstractNioMessageChannel- Throws:
java.lang.Exception
-
doWriteMessage
protected boolean doWriteMessage(java.lang.Object msg, ChannelOutboundBuffer in) throws java.lang.ExceptionDescription copied from class:AbstractNioMessageChannelWrite a message to the underlyingChannel.- Specified by:
doWriteMessagein classAbstractNioMessageChannel- Returns:
trueif and only if the message has been written- Throws:
java.lang.Exception
-
filterOutboundMessage
protected final java.lang.Object filterOutboundMessage(java.lang.Object msg) throws java.lang.ExceptionDescription copied from class:AbstractChannelInvoked when a new message is added to aChannelOutboundBufferof thisAbstractChannel, so that theChannelimplementation converts the message to another. (e.g. heap buffer -> direct buffer)- Overrides:
filterOutboundMessagein classAbstractChannel- Throws:
java.lang.Exception
-
bindAddress
public ChannelFuture bindAddress(java.net.InetAddress localAddress)
Description copied from interface:SctpChannelBind a address to the already bound channel to enable multi-homing. The Channel bust be bound and yet to be connected.- Specified by:
bindAddressin interfaceSctpChannel
-
bindAddress
public ChannelFuture bindAddress(java.net.InetAddress localAddress, ChannelPromise promise)
Description copied from interface:SctpChannelBind a address to the already bound channel to enable multi-homing. The Channel bust be bound and yet to be connected. Will notify the givenChannelPromiseand return aChannelFuture- Specified by:
bindAddressin interfaceSctpChannel
-
unbindAddress
public ChannelFuture unbindAddress(java.net.InetAddress localAddress)
Description copied from interface:SctpChannelUnbind the address from channel's multi-homing address list. The address should be added already in multi-homing address list.- Specified by:
unbindAddressin interfaceSctpChannel
-
unbindAddress
public ChannelFuture unbindAddress(java.net.InetAddress localAddress, ChannelPromise promise)
Description copied from interface:SctpChannelUnbind the address from channel's multi-homing address list. The address should be added already in multi-homing address list. Will notify the givenChannelPromiseand return aChannelFuture- Specified by:
unbindAddressin interfaceSctpChannel
-
-