Class NettyConnection
- java.lang.Object
-
- org.jivesoftware.openfire.nio.NettyConnection
-
- All Implemented Interfaces:
Closeable,AutoCloseable,Connection
public class NettyConnection extends Object implements Connection
Implementation ofConnectioninterface specific for Netty connections.- Author:
- Matthew Vivian, Alex Gidman
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.jivesoftware.openfire.Connection
Connection.ClientAuth, Connection.CompressionPolicy, Connection.State, Connection.TLSPolicy
-
-
Field Summary
Fields Modifier and Type Field Description static StringCHARSETThe utf-8 charset for decoding and encoding XMPP packet streams.LocalSessionsessionstatic StringSSL_HANDLER_NAME-
Fields inherited from interface org.jivesoftware.openfire.Connection
additionalNamespaces
-
-
Constructor Summary
Constructors Constructor Description NettyConnection(io.netty.channel.ChannelHandlerContext channelHandlerContext, PacketDeliverer packetDeliverer, ConnectionConfiguration configuration)
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddCompression()Adds the compression filter to the connection but only filter incoming traffic.voidclose()Close this session including associated socket connection.voidclose(org.xmpp.packet.StreamError error)Close this session including associated socket connection, optionally citing a stream error.voiddeliver(org.xmpp.packet.Packet packet)Delivers the packet to this connection without checking the recipient.voiddeliverRawText(String text)Delivers raw text to this connection.byte[]getAddress()Returns the raw IP address of thisInetAddressobject.Optional<String>getCipherSuiteName()Returns the TLS cipher suite name used by the connection of the session, if any.ConnectionConfigurationgetConfiguration()Returns a representation of the desired state for this connection.StringgetHostAddress()Returns the IP address string in textual presentation.StringgetHostName()Gets the host name for this IP address.Certificate[]getLocalCertificates()Returns the local underlyingX509Certificatechain for the connection.intgetMajorXMPPVersion()Returns the major version of XMPP being used by this connection (major_version.minor_version.intgetMinorXMPPVersion()Returns the minor version of XMPP being used by this connection (major_version.minor_version.PacketDeliverergetPacketDeliverer()Returns the packet deliverer to use when delivering a packet over the socket fails.Certificate[]getPeerCertificates()Returns the underlyingX509Certificatefor the connection of the peer.Optional<String>getTLSProtocolName()Returns the TLS protocol name used by the connection of the session, if any.voidinit(LocalSession owner)Initializes the connection with it's owning session.booleanisClosed()Returns true if the connection/session is closed.booleanisCompressed()Returns true if the connection is using compression.booleanisEncrypted()Returns true if this connection is encrypted.booleanisInitialized()Checks if the connection has finished initialization.booleanisSecure()Deprecated.booleanisUsingSelfSignedCertificate()Returns true if the other peer of this session presented a self-signed certificate.voidregisterCloseListener(ConnectionCloseListener listener, Object callback)Registers a listener for close event notification.voidreinit(LocalSession owner)Reinitializes the connection to switch to a different session.voidremoveCloseListener(ConnectionCloseListener listener)Removes a registered close event listener.voidsetEncrypted(boolean encrypted)voidsetUsingSelfSignedCertificate(boolean isSelfSigned)Keeps track if the other peer of this session presented a self-signed certificate.voidsetXMPPVersion(int majorVersion, int minorVersion)Sets the XMPP version information.voidstartCompression()Start compressing outgoing traffic for this connection.voidstartTLS(boolean clientMode, boolean directTLS)Encrypts the plain connection by negotiating TLS with the other peer.voidsystemShutdown()Notification message indicating that the server is being shutdown.StringtoString()booleanvalidate()Verifies that the connection is still live.-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.jivesoftware.openfire.Connection
getAdditionalNamespaces, setAdditionalNamespaces
-
-
-
-
Field Detail
-
SSL_HANDLER_NAME
public static final String SSL_HANDLER_NAME
- See Also:
- Constant Field Values
-
CHARSET
public static final String CHARSET
The utf-8 charset for decoding and encoding XMPP packet streams.- See Also:
- Constant Field Values
-
session
public LocalSession session
-
-
Constructor Detail
-
NettyConnection
public NettyConnection(io.netty.channel.ChannelHandlerContext channelHandlerContext, @Nullable PacketDeliverer packetDeliverer, ConnectionConfiguration configuration)
-
-
Method Detail
-
validate
public boolean validate()
Description copied from interface:ConnectionVerifies that the connection is still live. Typically this is done by sending a whitespace character between packets.- Specified by:
validatein interfaceConnection- Returns:
- true if the socket remains valid, false otherwise.
-
registerCloseListener
public void registerCloseListener(ConnectionCloseListener listener, Object callback)
Description copied from interface:ConnectionRegisters a listener for close event notification. Registrations after the Session is closed will be immediately notified before the registration call returns (within the context of the registration call). An optional handback object can be associated with the registration if the same listener is registered to listen for multiple connection closures.- Specified by:
registerCloseListenerin interfaceConnection- Parameters:
listener- the listener to register for events.callback- the object to send in the event notification.
-
removeCloseListener
public void removeCloseListener(ConnectionCloseListener listener)
Description copied from interface:ConnectionRemoves a registered close event listener. Registered listeners must be able to receive close events up until the time this method returns. (i.e. it is possible to call unregister, receive a close event registration, and then have the unregister call return.)- Specified by:
removeCloseListenerin interfaceConnection- Parameters:
listener- the listener to deregister for close events.
-
getAddress
public byte[] getAddress() throws UnknownHostExceptionDescription copied from interface:ConnectionReturns the raw IP address of thisInetAddressobject. The result is in network byte order: the highest order byte of the address is ingetAddress()[0].- Specified by:
getAddressin interfaceConnection- Returns:
- the raw IP address of this object.
- Throws:
UnknownHostException- if IP address of host could not be determined.
-
getHostAddress
public String getHostAddress() throws UnknownHostException
Description copied from interface:ConnectionReturns the IP address string in textual presentation.- Specified by:
getHostAddressin interfaceConnection- Returns:
- the raw IP address in a string format.
- Throws:
UnknownHostException- if IP address of host could not be determined.
-
getHostName
public String getHostName() throws UnknownHostException
Description copied from interface:ConnectionGets the host name for this IP address.If this InetAddress was created with a host name, this host name will be remembered and returned; otherwise, a reverse name lookup will be performed and the result will be returned based on the system configured name lookup service. If a lookup of the name service is required, call
getCanonicalHostName.If there is a security manager, its
checkConnectmethod is first called with the hostname and-1as its arguments to see if the operation is allowed. If the operation is not allowed, it will return the textual representation of the IP address.- Specified by:
getHostNamein interfaceConnection- Returns:
- the host name for this IP address, or if the operation is not allowed by the security check, the textual representation of the IP address.
- Throws:
UnknownHostException- if IP address of host could not be determined.- See Also:
InetAddress.getCanonicalHostName(),SecurityManager.checkConnect(java.lang.String, int)
-
getLocalCertificates
public Certificate[] getLocalCertificates()
Description copied from interface:ConnectionReturns the local underlyingX509Certificatechain for the connection.- Specified by:
getLocalCertificatesin interfaceConnection- Returns:
- an ordered array of certificates, with the local certificate
first followed by any certificate authorities. If no certificates
is present for the connection, then
nullis returned.
-
getPeerCertificates
public Certificate[] getPeerCertificates()
Description copied from interface:ConnectionReturns the underlyingX509Certificatefor the connection of the peer.- Specified by:
getPeerCertificatesin interfaceConnection- Returns:
- an ordered array of peer certificates, with the peer's own certificate first followed by any certificate authorities.
-
getTLSProtocolName
public Optional<String> getTLSProtocolName()
Description copied from interface:ConnectionReturns the TLS protocol name used by the connection of the session, if any.- Specified by:
getTLSProtocolNamein interfaceConnection- Returns:
- a TLS protocol (version) name.
-
getCipherSuiteName
public Optional<String> getCipherSuiteName()
Description copied from interface:ConnectionReturns the TLS cipher suite name used by the connection of the session, if any.- Specified by:
getCipherSuiteNamein interfaceConnection- Returns:
- cipher suite name.
-
setUsingSelfSignedCertificate
public void setUsingSelfSignedCertificate(boolean isSelfSigned)
Description copied from interface:ConnectionKeeps track if the other peer of this session presented a self-signed certificate. When using self-signed certificate for server-2-server sessions then SASL EXTERNAL will not be used and instead server-dialback will be preferred for vcerifying the identify of the remote server.- Specified by:
setUsingSelfSignedCertificatein interfaceConnection- Parameters:
isSelfSigned- true if the other peer presented a self-signed certificate.
-
isUsingSelfSignedCertificate
public boolean isUsingSelfSignedCertificate()
Description copied from interface:ConnectionReturns true if the other peer of this session presented a self-signed certificate. When using self-signed certificate for server-2-server sessions then SASL EXTERNAL will not be used and instead server-dialback will be preferred for vcerifying the identify of the remote server.- Specified by:
isUsingSelfSignedCertificatein interfaceConnection- Returns:
- true if the other peer of this session presented a self-signed certificate.
-
getPacketDeliverer
@Nullable public PacketDeliverer getPacketDeliverer()
Description copied from interface:ConnectionReturns the packet deliverer to use when delivering a packet over the socket fails. The packet deliverer will retry to send the packet using some other connection or will store the packet offline for later retrieval. When null, packets will just be dropped.- Specified by:
getPacketDelivererin interfaceConnection- Returns:
- the packet deliverer to use when delivering a packet over the socket fails.
-
close
public void close()
Description copied from interface:ConnectionClose this session including associated socket connection. The order of events for closing the session is:- Set closing flag to prevent redundant shutdowns.
- Call notifyEvent all listeners that the channel is shutting down.
- Close the socket.
Closeable.close()contract (idempotent, try-with-resources, etc.)- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Specified by:
closein interfaceConnection
-
close
public void close(@Nullable org.xmpp.packet.StreamError error)Description copied from interface:ConnectionClose this session including associated socket connection, optionally citing a stream error. The events for closing the session are:- Set closing flag to prevent redundant shutdowns.
- Close the socket.
- Notify all listeners that the channel is shut down.
- Specified by:
closein interfaceConnection- Parameters:
error- If non-null, the end-stream tag will be preceded with this error.
-
systemShutdown
public void systemShutdown()
Description copied from interface:ConnectionNotification message indicating that the server is being shutdown. Implementors should send a stream error whose condition is system-shutdown before closing the connection.- Specified by:
systemShutdownin interfaceConnection
-
init
public void init(LocalSession owner)
Description copied from interface:ConnectionInitializes the connection with it's owning session. Allows the connection class to configure itself with session related information (e.g. stream ID).- Specified by:
initin interfaceConnection- Parameters:
owner- the session that owns this connection
-
reinit
public void reinit(LocalSession owner)
Description copied from interface:ConnectionReinitializes the connection to switch to a different session. This allows for XEP-0198 resumption and transport-switching.- Specified by:
reinitin interfaceConnection- Parameters:
owner- The new session now owning the connection.
-
isInitialized
public boolean isInitialized()
Description copied from interface:ConnectionChecks if the connection has finished initialization.- Specified by:
isInitializedin interfaceConnection- Returns:
- true if connection has finished initialization.
-
isClosed
public boolean isClosed()
Description copied from interface:ConnectionReturns true if the connection/session is closed.- Specified by:
isClosedin interfaceConnection- Returns:
- true if the connection is closed.
-
isSecure
@Deprecated public boolean isSecure()
Deprecated.Description copied from interface:ConnectionReturns true if this connection is secure.- Specified by:
isSecurein interfaceConnection- Returns:
- true if the connection is secure (e.g. SSL/TLS)
-
isEncrypted
public boolean isEncrypted()
Description copied from interface:ConnectionReturns true if this connection is encrypted.- Specified by:
isEncryptedin interfaceConnection- Returns:
- true if the connection is encrypted (e.g. uses SSL/TLS)
-
setEncrypted
public void setEncrypted(boolean encrypted)
-
deliver
public void deliver(org.xmpp.packet.Packet packet) throws UnauthorizedExceptionDescription copied from interface:ConnectionDelivers the packet to this connection without checking the recipient. The method essentially callssocket.send(packet.getWriteBuffer()). Use with caution! This code is unlikely to be called directly. Instead, ensure that data sent to the entities is sent through the appropriate LocalSession object. For clients, this prevents, for example, synchronisation issues with stanza counts related to Stream Management (XEP-0198).- Specified by:
deliverin interfaceConnection- Parameters:
packet- the packet to deliver.- Throws:
UnauthorizedException- if a permission error was detected.
-
deliverRawText
public void deliverRawText(String text)
Description copied from interface:ConnectionDelivers raw text to this connection. This is a very low level way for sending XML stanzas to the client. This method should not be used unless you have very good reasons for not usingConnection.deliver(org.xmpp.packet.Packet).This method avoids having to get the writer of this connection and mess directly with the writer. Therefore, this method ensures a correct delivery of the stanza even if other threads were sending data concurrently.
- Specified by:
deliverRawTextin interfaceConnection- Parameters:
text- the XML stanzas represented kept in a String.
-
startTLS
public void startTLS(boolean clientMode, boolean directTLS) throws ExceptionDescription copied from interface:ConnectionEncrypts the plain connection by negotiating TLS with the other peer. In a server-2-server connection the server requesting the TLS negotiation will be the client and the other server will be the server during the TLS negotiation. Therefore, the server requesting the TLS negotiation must passtruein theclientModeparameter and the server receiving the TLS request must passfalsein theclientModeparameter.In the case of client-2-server the XMPP server must pass
falsein theclientModeparameter since it will behave as the server in the TLS negotiation.- Specified by:
startTLSin interfaceConnection- Parameters:
clientMode- boolean indicating if this entity is a client or a server in the TLS negotiation.directTLS- boolean indicating if the negotiation is directTLS (true) or startTLS (false).- Throws:
Exception- if an error occurred while encrypting the connection.
-
addCompression
public void addCompression()
Description copied from interface:ConnectionAdds the compression filter to the connection but only filter incoming traffic. Do not filter outgoing traffic since we still need to send an uncompressed stanza to the client indicating that he can start compressing the traffic. After we sent the uncompresses stanza we can start compression outgoing traffic as well.- Specified by:
addCompressionin interfaceConnection
-
startCompression
public void startCompression()
Description copied from interface:ConnectionStart compressing outgoing traffic for this connection. Compression will only be available after TLS has been negotiated. This means that a connection can never be using compression before TLS. However, it is possible to use compression without TLS.- Specified by:
startCompressionin interfaceConnection
-
getConfiguration
public ConnectionConfiguration getConfiguration()
Description copied from interface:ConnectionReturns a representation of the desired state for this connection. Note that this is different from the current state of the connection. For example, TLS can be required by configuration, but while the connection has yet to be fully initialized, the current state might not be TLS-encrypted.- Specified by:
getConfigurationin interfaceConnection- Returns:
- The desired configuration for the connection (never null).
-
getMajorXMPPVersion
public int getMajorXMPPVersion()
Description copied from interface:ConnectionReturns the major version of XMPP being used by this connection (major_version.minor_version. In most cases, the version should be "1.0". However, older clients using the "Jabber" protocol do not set a version. In that case, the version is "0.0".- Specified by:
getMajorXMPPVersionin interfaceConnection- Returns:
- the major XMPP version being used by this connection.
-
getMinorXMPPVersion
public int getMinorXMPPVersion()
Description copied from interface:ConnectionReturns the minor version of XMPP being used by this connection (major_version.minor_version. In most cases, the version should be "1.0". However, older clients using the "Jabber" protocol do not set a version. In that case, the version is "0.0".- Specified by:
getMinorXMPPVersionin interfaceConnection- Returns:
- the minor XMPP version being used by this connection.
-
setXMPPVersion
public void setXMPPVersion(int majorVersion, int minorVersion)Description copied from interface:ConnectionSets the XMPP version information. In most cases, the version should be "1.0". However, older clients using the "Jabber" protocol do not set a version. In that case, the version is "0.0".- Specified by:
setXMPPVersionin interfaceConnection- Parameters:
majorVersion- the major version.minorVersion- the minor version.
-
isCompressed
public boolean isCompressed()
Description copied from interface:ConnectionReturns true if the connection is using compression.- Specified by:
isCompressedin interfaceConnection- Returns:
- true if the connection is using compression.
-
-