s5b createTransport

This commit is contained in:
vanitasvitae 2017-06-21 15:42:00 +02:00
parent 4c1ee37ea7
commit ecd29a1ea8
Signed by: vanitasvitae
GPG Key ID: 62BEE9264BF17311
6 changed files with 48 additions and 9 deletions

View File

@ -87,7 +87,7 @@ public class IncomingJingleFileOffer extends JingleFileTransferSession implement
return jutil.createAck(initiate);
}
transport = transportManager.createTransport();
transport = transportManager.createTransport(getInitiator());
jutil.sendTransportReplace(initiate.getFrom().asFullJidOrThrow(), initiate.getInitiator(),
initiate.getSid(), creator, name, transport);
state = State.sent_transport_replace;

View File

@ -75,7 +75,7 @@ public class OutgoingJingleFileOffer extends JingleFileTransferSession {
throw new IllegalStateException("There must be at least one workable transport method.");
}
transport = transportManager.createTransport();
transport = transportManager.createTransport(getResponder());
jutil.sendSessionInitiateFileOffer(getResponder(), getSessionId(), creator, name, file, transport);
state = State.pending;
@ -130,7 +130,7 @@ public class OutgoingJingleFileOffer extends JingleFileTransferSession {
if (replacementManager != null) {
jutil.sendTransportAccept(transportReplace.getFrom().asFullJidOrThrow(),
transportReplace.getInitiator(), transportReplace.getSid(), creator, name,
replacementManager.createTransport());
replacementManager.createTransport(getResponder()));
}
return jutil.createAck(transportReplace);

View File

@ -29,7 +29,7 @@ import org.jxmpp.jid.Jid;
*
* @author Henning Staib
*/
class Socks5Utils {
public class Socks5Utils {
/**
* Returns a SHA-1 digest of the given parameters as specified in <a

View File

@ -40,7 +40,7 @@ public abstract class JingleTransportManager<D extends JingleContentTransport> {
public abstract String getNamespace();
public abstract D createTransport();
public abstract D createTransport(FullJid recipient);
public abstract D createTransport(Jingle request);

View File

@ -59,7 +59,7 @@ public final class JingleIBBTransportManager extends JingleTransportManager<Jing
}
@Override
public JingleIBBTransport createTransport() {
public JingleIBBTransport createTransport(FullJid recipient) {
return new JingleIBBTransport();
}

View File

@ -17,21 +17,27 @@
package org.jivesoftware.smackx.jingle.transports.jingle_s5b;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
import java.util.WeakHashMap;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.jivesoftware.smack.SmackException;
import org.jivesoftware.smack.XMPPConnection;
import org.jivesoftware.smack.XMPPException;
import org.jivesoftware.smack.packet.IQ;
import org.jivesoftware.smackx.bytestreams.socks5.Socks5BytestreamManager;
import org.jivesoftware.smackx.bytestreams.socks5.Socks5Utils;
import org.jivesoftware.smackx.bytestreams.socks5.packet.Bytestream;
import org.jivesoftware.smackx.jingle.JingleManager;
import org.jivesoftware.smackx.jingle.element.Jingle;
import org.jivesoftware.smackx.jingle.element.JingleContentTransport;
import org.jivesoftware.smackx.jingle.transports.JingleTransportInitiationCallback;
import org.jivesoftware.smackx.jingle.transports.JingleTransportManager;
import org.jivesoftware.smackx.jingle.transports.jingle_s5b.elements.JingleS5BTransport;
import org.jivesoftware.smackx.jingle.transports.jingle_s5b.elements.JingleS5BTransportCandidate;
import org.jxmpp.jid.FullJid;
import org.jxmpp.jid.Jid;
@ -41,6 +47,8 @@ import org.jxmpp.jid.Jid;
*/
public final class JingleS5BTransportManager extends JingleTransportManager<JingleS5BTransport> {
private static final Logger LOGGER = Logger.getLogger(JingleS5BTransportManager.class.getName());
private static final WeakHashMap<XMPPConnection, JingleS5BTransportManager> INSTANCES = new WeakHashMap<>();
private JingleS5BTransportManager(XMPPConnection connection) {
@ -62,15 +70,46 @@ public final class JingleS5BTransportManager extends JingleTransportManager<Jing
}
@Override
public JingleS5BTransport createTransport() {
return null;
public JingleS5BTransport createTransport(FullJid recipient) {
return createTransport(recipient, JingleManager.randomSid(), Bytestream.Mode.tcp);
}
@Override
public JingleS5BTransport createTransport(Jingle request) {
return null;
FullJid remote = request.getFrom().asFullJidIfPossible();
JingleS5BTransport received = (JingleS5BTransport) request.getContents().get(0).getJingleTransport();
return createTransport(remote, received.getStreamId(), received.getMode());
}
private JingleS5BTransport createTransport(FullJid remote, String sid, Bytestream.Mode mode) {
JingleS5BTransport.Builder builder = JingleS5BTransport.getBuilder();
List<Bytestream.StreamHost> localStreams = getLocalStreamHosts();
List<Bytestream.StreamHost> availableStreams;
try {
availableStreams = getAvailableStreamHosts();
} catch (XMPPException.XMPPErrorException | SmackException.NoResponseException | InterruptedException | SmackException.NotConnectedException e) {
LOGGER.log(Level.WARNING, "Could not determine available StreamHosts: ", e);
availableStreams = Collections.emptyList();
}
for (Bytestream.StreamHost host : localStreams) {
JingleS5BTransportCandidate candidate = new JingleS5BTransportCandidate(host, 100);
builder.addTransportCandidate(candidate);
}
for (Bytestream.StreamHost host : availableStreams) {
JingleS5BTransportCandidate candidate = new JingleS5BTransportCandidate(host, 0);
builder.addTransportCandidate(candidate);
}
builder.setStreamId(sid);
builder.setMode(mode);
builder.setDestinationAddress(Socks5Utils.createDigest(sid, getConnection().getUser().asFullJidOrThrow(), remote));
return builder.build();
}
@Override
public void initiateOutgoingSession(FullJid remote, JingleContentTransport transport, JingleTransportInitiationCallback callback) {