Package org.acplt.oncrpc.server
Class OncRpcTcpServerTransport
java.lang.Object
org.acplt.oncrpc.server.OncRpcServerTransport
org.acplt.oncrpc.server.OncRpcTcpServerTransport
Instances of class
OncRpcTcpServerTransport encapsulate
TCP/IP-based XDR streams of ONC/RPC servers. This server transport class
is responsible for accepting new ONC/RPC connections over TCP/IP.- Version:
- $Revision: 1.3 $ $Date: 2008/01/02 15:13:35 $ $State: Exp $ $Locker: $
- Author:
- Harald Albrecht
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected intTimeout during the phase where data is received within calls, or data is sent within replies.Fields inherited from class org.acplt.oncrpc.server.OncRpcServerTransport
dispatcher, info, port -
Constructor Summary
ConstructorsConstructorDescriptionOncRpcTcpServerTransport(OncRpcDispatchable dispatcher, int port, int program, int version, int bufferSize) Create a new instance of aOncRpcTcpServerTransportwhich encapsulates TCP/IP-based XDR streams of an ONC/RPC server.OncRpcTcpServerTransport(OncRpcDispatchable dispatcher, int port, OncRpcServerTransportRegistrationInfo[] info, int bufferSize) Create a new instance of aOncRpcTcpServerTransportwhich encapsulates TCP/IP-based XDR streams of an ONC/RPC server.OncRpcTcpServerTransport(OncRpcDispatchable dispatcher, InetAddress bindAddr, int port, OncRpcServerTransportRegistrationInfo[] info, int bufferSize) Create a new instance of aOncRpcTcpServerTransportwhich encapsulates TCP/IP-based XDR streams of an ONC/RPC server. -
Method Summary
Modifier and TypeMethodDescriptionprotected voidbeginEncoding(OncRpcCallInformation callInfo, OncRpcServerReplyMessage state) Do not call.voidclose()Close the server transport and free any resources associated with it.protected voidDo not call.protected voidDo not call.Get the character encoding for (de-)serializing strings.intRetrieve the current timeout used during transmission phases (call and reply phases).protected XdrDecodingStreamDo not call.protected XdrEncodingStreamDo not call.voidlisten()Creates a new thread and uses this thread to listen to incoming ONC/RPC requests, then dispatches them and finally sends back the appropriate reply messages.voidregister()Register the TCP/IP port where this server transport waits for incoming requests with the ONC/RPC portmapper.protected voidRemoves a TCP/IP server transport from the list of currently open transports.protected voidreply(OncRpcCallInformation callInfo, OncRpcServerReplyMessage state, XdrAble reply) Do not call.voidretrieveCall(XdrAble call) Do not call.voidsetCharacterEncoding(String characterEncoding) Set the character encoding for (de-)serializing strings.voidsetTransmissionTimeout(int milliseconds) Set the timeout used during transmission of data.Methods inherited from class org.acplt.oncrpc.server.OncRpcServerTransport
getPort, unregister
-
Field Details
-
transmissionTimeout
protected int transmissionTimeoutTimeout during the phase where data is received within calls, or data is sent within replies.
-
-
Constructor Details
-
OncRpcTcpServerTransport
public OncRpcTcpServerTransport(OncRpcDispatchable dispatcher, int port, int program, int version, int bufferSize) throws OncRpcException, IOException Create a new instance of aOncRpcTcpServerTransportwhich encapsulates TCP/IP-based XDR streams of an ONC/RPC server. This particular server transport only waits for incoming connection requests and then createsOncRpcTcpConnectionServerTransportserver transports to handle individual connections. This constructor is a convenience constructor for those transports handling only a single ONC/RPC program and version number.- Parameters:
dispatcher- Reference to interface of an object capable of dispatching (handling) ONC/RPC calls.port- Number of port where the server will wait for incoming calls.program- Number of ONC/RPC program handled by this server transport.version- Version number of ONC/RPC program handled.bufferSize- Size of buffer used when receiving and sending chunks of XDR fragments over TCP/IP. The fragments built up to form ONC/RPC call and reply messages.- Throws:
OncRpcException- if an RPC error occurs.IOException- if an IO error occurs.
-
OncRpcTcpServerTransport
public OncRpcTcpServerTransport(OncRpcDispatchable dispatcher, int port, OncRpcServerTransportRegistrationInfo[] info, int bufferSize) throws OncRpcException, IOException Create a new instance of aOncRpcTcpServerTransportwhich encapsulates TCP/IP-based XDR streams of an ONC/RPC server. This particular server transport only waits for incoming connection requests and then createsOncRpcTcpConnectionServerTransportserver transports to handle individual connections.- Parameters:
dispatcher- Reference to interface of an object capable of dispatching (handling) ONC/RPC calls.port- Number of port where the server will wait for incoming calls.info- Array of program and version number tuples of the ONC/RPC programs and versions handled by this transport.bufferSize- Size of buffer used when receiving and sending chunks of XDR fragments over TCP/IP. The fragments built up to form ONC/RPC call and reply messages.- Throws:
OncRpcException- if an RPC error occurs.IOException- if an IO error occurs.
-
OncRpcTcpServerTransport
public OncRpcTcpServerTransport(OncRpcDispatchable dispatcher, InetAddress bindAddr, int port, OncRpcServerTransportRegistrationInfo[] info, int bufferSize) throws OncRpcException, IOException Create a new instance of aOncRpcTcpServerTransportwhich encapsulates TCP/IP-based XDR streams of an ONC/RPC server. This particular server transport only waits for incoming connection requests and then createsOncRpcTcpConnectionServerTransportserver transports to handle individual connections.- Parameters:
dispatcher- Reference to interface of an object capable of dispatching (handling) ONC/RPC calls.bindAddr- The local Internet Address the server will bind to.port- Number of port where the server will wait for incoming calls.info- Array of program and version number tuples of the ONC/RPC programs and versions handled by this transport.bufferSize- Size of buffer used when receiving and sending chunks of XDR fragments over TCP/IP. The fragments built up to form ONC/RPC call and reply messages.- Throws:
OncRpcException- if an RPC error occurs.IOException- if an IO error occurs.
-
-
Method Details
-
close
public void close()Close the server transport and free any resources associated with it.Note that the server transport is not deregistered. You'll have to do it manually if you need to do so. The reason for this behaviour is, that the portmapper removes all entries regardless of the protocol (TCP/IP or UDP/IP) for a given ONC/RPC program number and version.
Calling this method on a
OncRpcTcpServerTransportresults in the listening TCP network socket immediately being closed. In addition, all server transports handling the individual TCP/IP connections will also be closed. The handler threads will therefore either terminate directly or when they try to sent back replies.- Specified by:
closein classOncRpcServerTransport
-
removeTransport
Removes a TCP/IP server transport from the list of currently open transports.- Parameters:
transport- Server transport to remove from the list of currently open transports for this listening transport.
-
register
Register the TCP/IP port where this server transport waits for incoming requests with the ONC/RPC portmapper.- Specified by:
registerin classOncRpcServerTransport- Throws:
OncRpcException- if the portmapper could not be contacted successfully of if the portmapper rejected port registration(s).
-
retrieveCall
Do not call.- Specified by:
retrieveCallin classOncRpcServerTransport- Parameters:
call- An XDR able object instance, where to decode the call information in.- Throws:
Error- because this method must not be called for a listening server transport.OncRpcException- if an ONC/RPC exception occurs, like the data could not be successfully deserialized.IOException- if an I/O exception occurs, like transmission failures over the network, etc.
-
getXdrDecodingStream
Do not call.- Specified by:
getXdrDecodingStreamin classOncRpcServerTransport- Returns:
- Reference to decoding XDR stream.
- Throws:
Error- because this method must not be called for a listening server transport.
-
endDecoding
Do not call.- Specified by:
endDecodingin classOncRpcServerTransport- Throws:
Error- because this method must not be called for a listening server transport.OncRpcException- if an ONC/RPC exception occurs, like the data could not be successfully deserialized.IOException- if an I/O exception occurs, like transmission failures over the network, etc.
-
getXdrEncodingStream
Do not call.- Specified by:
getXdrEncodingStreamin classOncRpcServerTransport- Returns:
- Reference to enecoding XDR stream.
- Throws:
Error- because this method must not be called for a listening server transport.
-
beginEncoding
protected void beginEncoding(OncRpcCallInformation callInfo, OncRpcServerReplyMessage state) throws OncRpcException, IOException Do not call.- Specified by:
beginEncodingin classOncRpcServerTransport- Parameters:
callInfo- Information about ONC/RPC call for which we are about to send back the reply.state- ONC/RPC reply header indicating success or failure.- Throws:
Error- because this method must not be called for a listening server transport.OncRpcException- if an ONC/RPC exception occurs, like the data could not be successfully serialized.IOException- if an I/O exception occurs, like transmission
-
endEncoding
Do not call.- Specified by:
endEncodingin classOncRpcServerTransport- Throws:
Error- because this method must not be called for a listening server transport.OncRpcException- if an ONC/RPC exception occurs, like the data could not be successfully serialized.IOException- if an I/O exception occurs, like transmission failures over the network, etc.
-
reply
protected void reply(OncRpcCallInformation callInfo, OncRpcServerReplyMessage state, XdrAble reply) throws OncRpcException, IOException Do not call.- Specified by:
replyin classOncRpcServerTransport- Parameters:
callInfo- information about the original call, which are necessary to send back the reply to the appropriate caller.state- ONC/RPC reply message header indicating success or failure and containing associated state information.reply- If notnull, then this parameter references the reply to be serialized after the reply message header.- Throws:
Error- because this method must not be called for a listening server transport.OncRpcException- if an ONC/RPC exception occurs, like the data could not be successfully serialized.IOException- if an I/O exception occurs, like transmission failures over the network, etc.- See Also:
-
listen
public void listen()Creates a new thread and uses this thread to listen to incoming ONC/RPC requests, then dispatches them and finally sends back the appropriate reply messages. Control in the calling thread immediately returns after the handler thread has been created.For every incomming TCP/IP connection a handler thread is created to handle ONC/RPC calls on this particular connection.
- Specified by:
listenin classOncRpcServerTransport
-
setTransmissionTimeout
public void setTransmissionTimeout(int milliseconds) Set the timeout used during transmission of data. If the flow of data when sending calls or receiving replies blocks longer than the given timeout, an exception is thrown. The timeout must be > 0.- Parameters:
milliseconds- Transmission timeout in milliseconds.
-
getTransmissionTimeout
public int getTransmissionTimeout()Retrieve the current timeout used during transmission phases (call and reply phases).- Returns:
- Current transmission timeout.
-
setCharacterEncoding
Set the character encoding for (de-)serializing strings.- Specified by:
setCharacterEncodingin classOncRpcServerTransport- Parameters:
characterEncoding- the encoding to use for (de-)serializing strings. Ifnull, the system's default encoding is to be used.
-
getCharacterEncoding
Get the character encoding for (de-)serializing strings.- Specified by:
getCharacterEncodingin classOncRpcServerTransport- Returns:
- the encoding currently used for (de-)serializing strings.
If
null, then the system's default encoding is used.
-