- All Implemented Interfaces:
Closeable,AutoCloseable,AFSocketExtensions,AFSomeSocket,AFSomeSocketThing,FileDescriptorAccess,AFTIPCSocketExtensions
public final class AFTIPCSocket
extends AFSocket<AFTIPCSocketAddress>
implements AFTIPCSocketExtensions
Implementation of an
AF_TIPC socket.- Author:
- Christian Kohlschütter
-
Nested Class Summary
Nested classes/interfaces inherited from class org.newsclub.net.unix.AFSocket
AFSocket.Constructor<A extends AFSocketAddress> -
Method Summary
Modifier and TypeMethodDescriptionstatic AFTIPCSocketconnectTo(AFTIPCSocketAddress addr) Creates a newAFSocketand connects it to the givenAFTIPCSocketAddress.Returns the TIPC "DestName" information from the ancillary receive buffer (if any was set), ornullif no DestName was retrieved.Returns the TIPC "ErrInfo" information from the ancillary receive buffer (if any was set), ornullif no error was retrieved.static StringgetLinkName(int peerId, int bearerId) Retrieves the link name given a node hash and a bearer ID.static byte[]getNodeIdentity(int peerId) Retrieves the 16-byte node ID given a node hash.byte[]getNodeIdentity(AFTIPCSocketAddress address) Retrieves the TIPC node identity given the node hash of the given address.static StringgetNodeIdHexString(int peerId) Retrieves the node ID given a node hash, as a hexadecimal string.static booleanReturnstrueiffAFTIPCSockets (sockets of type "AF_TIPC") are supported by the current Java VM and the kernel.static voidVery basic self-test function.protected AFTIPCSocketChannelCreates a newAFSocketChannelfor this socket.static AFTIPCSocketCreates a new, unboundAFSocket.static AFTIPCSocketCreates a new, unbound, "strict"AFSocket.Methods inherited from class org.newsclub.net.unix.AFSocket
addCloseable, bind, checkConnectionClosed, close, connect, connect, connectHook, connectTo, connectTo, ensureAncillaryReceiveBufferSize, ensureSupported, ensureUnsafeSupported, forceConnectAddress, getAncillaryReceiveBufferSize, getFileDescriptor, getImplExtensions, getInputStream, getLoadedLibrary, getLocalSocketAddress, getOutputStream, getRemoteSocketAddress, getVersion, isBound, isClosed, isConnected, isRunningOnAndroid, newInstance, removeCloseable, setAncillaryReceiveBufferSize, setShutdownOnClose, socketAddressClass, supports, supports, toStringMethods inherited from class java.net.Socket
getInetAddress, getKeepAlive, getLocalAddress, getLocalPort, getOOBInline, getOption, getPort, getReceiveBufferSize, getReuseAddress, getSendBufferSize, getSoLinger, getSoTimeout, getTcpNoDelay, getTrafficClass, isInputShutdown, isOutputShutdown, sendUrgentData, setKeepAlive, setOOBInline, setOption, setPerformancePreferences, setReceiveBufferSize, setReuseAddress, setSendBufferSize, setSocketImplFactory, setSoLinger, setSoTimeout, setTcpNoDelay, setTrafficClass, shutdownInput, shutdownOutput, supportedOptionsMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.newsclub.net.unix.AFSocketExtensions
ensureAncillaryReceiveBufferSize, getAncillaryReceiveBufferSize, setAncillaryReceiveBufferSize
-
Method Details
-
isSupported
public static boolean isSupported()ReturnstrueiffAFTIPCSockets (sockets of type "AF_TIPC") are supported by the current Java VM and the kernel. To supportAFTIPCSockets, a custom JNI library must be loaded that is supplied with junixsocket, and the system must support AF_TIPC sockets. This call is equivalent to checkingAFSocket.isSupported()andAFSocket.supports(AFSocketCapability)withAFSocketCapability.CAPABILITY_TIPC.- Returns:
trueiff supported.
-
newChannel
Description copied from class:AFSocketCreates a newAFSocketChannelfor this socket.- Specified by:
newChannelin classAFSocket<AFTIPCSocketAddress>- Returns:
- The new instance.
-
newInstance
Creates a new, unboundAFSocket. This "default" implementation is a bit "lenient" with respect to the specification. In particular, we ignore calls toSocket.getTcpNoDelay()andSocket.setTcpNoDelay(boolean).- Returns:
- A new, unbound socket.
- Throws:
IOException- if the operation fails.
-
newStrictInstance
Creates a new, unbound, "strict"AFSocket. This call uses an implementation that tries to be closer to the specification thannewInstance(), at least for some cases.- Returns:
- A new, unbound socket.
- Throws:
IOException- if the operation fails.
-
connectTo
Creates a newAFSocketand connects it to the givenAFTIPCSocketAddress.- Parameters:
addr- The address to connect to.- Returns:
- A new, connected socket.
- Throws:
IOException- if the operation fails.
-
getChannel
- Overrides:
getChannelin classAFSocket<AFTIPCSocketAddress>
-
main
Very basic self-test function. Prints "supported" and "capabilities" status to System.out.- Parameters:
args- ignored.
-
getErrInfo
Description copied from interface:AFTIPCSocketExtensionsReturns the TIPC "ErrInfo" information from the ancillary receive buffer (if any was set), ornullif no error was retrieved.- Specified by:
getErrInfoin interfaceAFTIPCSocketExtensions- Returns:
- The ErrInfo.
-
getDestName
Description copied from interface:AFTIPCSocketExtensionsReturns the TIPC "DestName" information from the ancillary receive buffer (if any was set), ornullif no DestName was retrieved.- Specified by:
getDestNamein interfaceAFTIPCSocketExtensions- Returns:
- The service address or range (without scope) that was specified by the sender of the message.
-
getNodeIdentity
Retrieves the 16-byte node ID given a node hash.- Parameters:
peerId- The node hash.- Returns:
- The node ID, or
nullif unsupported. - Throws:
IOException- on error.
-
getNodeIdentity
Retrieves the TIPC node identity given the node hash of the given address.- Parameters:
address- The address.- Returns:
- The node identity, or
nullif unsupported. - Throws:
IOException- on error.
-
getNodeIdHexString
Retrieves the node ID given a node hash, as a hexadecimal string.- Parameters:
peerId- The node hash.- Returns:
- The node ID, or
nullif unsupported. - Throws:
IOException- on error.
-
getLinkName
Retrieves the link name given a node hash and a bearer ID.- Parameters:
peerId- The node hash.bearerId- The bearer Id.- Returns:
- The link name, or
nullif unsupported. - Throws:
IOException- on error.
-