Class Socks5TransferNegotiator
java.lang.Object
org.jivesoftware.smack.Manager
org.jivesoftware.smackx.filetransfer.StreamNegotiator
org.jivesoftware.smackx.filetransfer.Socks5TransferNegotiator
Negotiates a SOCKS5 Bytestream to be used for file transfers. The implementation is based on the
Socks5BytestreamManager
and the Socks5BytestreamRequest
.- See Also:
-
Field Summary
Fields inherited from class org.jivesoftware.smackx.filetransfer.StreamNegotiator
initationSetEvents
-
Method Summary
Modifier and TypeMethodDescriptioncreateIncomingStream
(StreamInitiation initiation) This method handles the file stream download negotiation process.createOutgoingStream
(String streamID, Jid initiator, Jid target) This method handles the file upload stream negotiation process.Returns the XMPP namespace reserved for this particular type of file transfer.void
newStreamInitiation
(Jid from, String streamID) Signal that a new stream initiation arrived.Methods inherited from class org.jivesoftware.smackx.filetransfer.StreamNegotiator
createInitiationAccept, initiateIncomingStream, signal
Methods inherited from class org.jivesoftware.smack.Manager
connection, getAuthenticatedConnectionOrThrow, schedule, schedule, scheduleBlocking
-
Method Details
-
createOutgoingStream
public OutputStream createOutgoingStream(String streamID, Jid initiator, Jid target) throws SmackException, XMPPException Description copied from class:StreamNegotiator
This method handles the file upload stream negotiation process. The particular stream negotiator is determined during the file transfer negotiation process. This method returns the OutputStream to transmit the file to the remote user.- Specified by:
createOutgoingStream
in classStreamNegotiator
- Parameters:
streamID
- The streamID that uniquely identifies the file transfer.initiator
- The fully-qualified JID of the initiator of the file transfer.target
- The fully-qualified JID of the target or receiver of the file transfer.- Returns:
- The negotiated stream ready for data.
- Throws:
SmackException
- if Smack detected an exceptional situation.XMPPException
- if an XMPP protocol error was received.
-
createIncomingStream
public InputStream createIncomingStream(StreamInitiation initiation) throws XMPPException.XMPPErrorException, InterruptedException, SmackException Description copied from class:StreamNegotiator
This method handles the file stream download negotiation process. The appropriate stream negotiator's initiate incoming stream is called after an appropriate file transfer method is selected. The manager will respond to the initiator with the selected means of transfer, then it will handle any negotiation specific to the particular transfer method. This method returns the InputStream, ready to transfer the file.- Specified by:
createIncomingStream
in classStreamNegotiator
- Parameters:
initiation
- The initiation that triggered this download.- Returns:
- After the negotiation process is complete, the InputStream to write a file to is returned.
- Throws:
XMPPException.XMPPErrorException
- If an error occurs during this process an XMPPException is thrown.InterruptedException
- If thread is interrupted.SmackException
- if Smack detected an exceptional situation.
-
newStreamInitiation
Description copied from class:StreamNegotiator
Signal that a new stream initiation arrived. The negotiator may needs to prepare for it.- Specified by:
newStreamInitiation
in classStreamNegotiator
- Parameters:
from
- The initiator of the file transfer.streamID
- The stream ID related to the transfer.
-
getNamespace
Description copied from class:StreamNegotiator
Returns the XMPP namespace reserved for this particular type of file transfer.- Specified by:
getNamespace
in classStreamNegotiator
- Returns:
- Returns the XMPP namespace reserved for this particular type of file transfer.
-