mirror of
https://github.com/vanitasvitae/Smack.git
synced 2025-09-11 01:59:38 +02:00
JET is close to working
This commit is contained in:
parent
177ed6ea0d
commit
d2f979ed15
17 changed files with 242 additions and 208 deletions
|
@ -130,30 +130,6 @@ public final class JingleManager extends Manager {
|
|||
return manager;
|
||||
}
|
||||
|
||||
public static void registerDescriptionProvider(JingleContentDescriptionProvider<?> provider) {
|
||||
descriptionProviders.put(provider.getNamespace(), provider);
|
||||
}
|
||||
|
||||
public static JingleContentDescriptionProvider<?> getDescriptionProvider(String namespace) {
|
||||
return descriptionProviders.get(namespace);
|
||||
}
|
||||
|
||||
public static void registerTransportProvider(JingleContentTransportProvider<?> provider) {
|
||||
transportProviders.put(provider.getNamespace(), provider);
|
||||
}
|
||||
|
||||
public static JingleContentTransportProvider<?> getTransportProvider(String namespace) {
|
||||
return transportProviders.get(namespace);
|
||||
}
|
||||
|
||||
public static void registerSecurityProvider(JingleContentSecurityProvider<?> provider) {
|
||||
securityProviders.put(provider.getNamespace(), provider);
|
||||
}
|
||||
|
||||
public static JingleContentSecurityProvider<?> getSecurityProvider(String namespace) {
|
||||
return securityProviders.get(namespace);
|
||||
}
|
||||
|
||||
public static void addJingleDescriptionAdapter(JingleDescriptionAdapter<?> adapter) {
|
||||
descriptionAdapters.put(adapter.getNamespace(), adapter);
|
||||
}
|
||||
|
@ -178,6 +154,42 @@ public final class JingleManager extends Manager {
|
|||
return securityAdapters.get(namespace);
|
||||
}
|
||||
|
||||
public static void addJingleDescriptionProvider(JingleContentDescriptionProvider<?> provider) {
|
||||
descriptionProviders.put(provider.getNamespace(), provider);
|
||||
}
|
||||
|
||||
public static void removeJingleDescriptionProvider(String namespace) {
|
||||
descriptionProviders.remove(namespace);
|
||||
}
|
||||
|
||||
public static JingleContentDescriptionProvider<?> getJingleDescriptionProvider(String namespace) {
|
||||
return descriptionProviders.get(namespace);
|
||||
}
|
||||
|
||||
public static void addJingleTransportProvider(JingleContentTransportProvider<?> provider) {
|
||||
transportProviders.put(provider.getNamespace(), provider);
|
||||
}
|
||||
|
||||
public static void removeJingleTransportProvider(String namespace) {
|
||||
transportProviders.remove(namespace);
|
||||
}
|
||||
|
||||
public static JingleContentTransportProvider<?> getJingleTransportProvider(String namespace) {
|
||||
return transportProviders.get(namespace);
|
||||
}
|
||||
|
||||
public static void addJingleSecurityProvider(JingleContentSecurityProvider<?> provider) {
|
||||
securityProviders.put(provider.getNamespace(), provider);
|
||||
}
|
||||
|
||||
public static void removeJingleSecurityProvider(String namespace) {
|
||||
securityProviders.remove(namespace);
|
||||
}
|
||||
|
||||
public static JingleContentSecurityProvider<?> getJingleSecurityProvider(String namespace) {
|
||||
return securityProviders.get(namespace);
|
||||
}
|
||||
|
||||
public void addJingleDescriptionManager(JingleDescriptionManager manager) {
|
||||
descriptionManagers.put(manager.getNamespace(), manager);
|
||||
}
|
||||
|
|
|
@ -306,6 +306,9 @@ public class JingleContent implements JingleTransportCallback, JingleSecurityCal
|
|||
}
|
||||
|
||||
public void onAccept(final XMPPConnection connection) {
|
||||
if (security != null) {
|
||||
security.prepare(connection, getParent().getPeer());
|
||||
}
|
||||
//Establish transport
|
||||
Async.go(new Runnable() {
|
||||
@Override
|
||||
|
|
|
@ -16,12 +16,15 @@
|
|||
*/
|
||||
package org.jivesoftware.smackx.jingle.components;
|
||||
|
||||
import org.jivesoftware.smack.XMPPConnection;
|
||||
import org.jivesoftware.smackx.bytestreams.BytestreamSession;
|
||||
import org.jivesoftware.smackx.jingle.callbacks.JingleSecurityCallback;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentSecurityElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentSecurityInfoElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleElement;
|
||||
|
||||
import org.jxmpp.jid.FullJid;
|
||||
|
||||
/**
|
||||
* Class that represents a contents security component.
|
||||
*/
|
||||
|
@ -46,4 +49,8 @@ public abstract class JingleSecurity<D extends JingleContentSecurityElement> {
|
|||
public abstract void decryptIncomingBytestream(BytestreamSession bytestreamSession, JingleSecurityCallback callback);
|
||||
|
||||
public abstract void encryptOutgoingBytestream(BytestreamSession bytestreamSession, JingleSecurityCallback callbacks);
|
||||
|
||||
public abstract String getNamespace();
|
||||
|
||||
public abstract void prepare(XMPPConnection connection, FullJid sender);
|
||||
}
|
||||
|
|
|
@ -1,53 +0,0 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2017 Florian Schmaus
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.jivesoftware.smackx.jingle.provider;
|
||||
|
||||
import java.util.Map;
|
||||
import java.util.concurrent.ConcurrentHashMap;
|
||||
|
||||
public class JingleContentProviderManager {
|
||||
|
||||
private static final Map<String, JingleContentDescriptionProvider<?>> jingleContentDescriptionProviders = new ConcurrentHashMap<>();
|
||||
|
||||
private static final Map<String, JingleContentTransportProvider<?>> jingleContentTransportProviders = new ConcurrentHashMap<>();
|
||||
|
||||
public static void removeJingleContentTransportProvider(String namespace) {
|
||||
jingleContentTransportProviders.remove(namespace);
|
||||
}
|
||||
|
||||
public static void removeJingleContentDescriptionProvider(String namespace) {
|
||||
jingleContentDescriptionProviders.remove(namespace);
|
||||
}
|
||||
|
||||
public static JingleContentDescriptionProvider<?> addJingleContentDescriptionProvider(String namespace,
|
||||
JingleContentDescriptionProvider<?> provider) {
|
||||
return jingleContentDescriptionProviders.put(namespace, provider);
|
||||
}
|
||||
|
||||
public static JingleContentDescriptionProvider<?> getJingleContentDescriptionProvider(String namespace) {
|
||||
return jingleContentDescriptionProviders.get(namespace);
|
||||
}
|
||||
|
||||
public static JingleContentTransportProvider<?> addJingleContentTransportProvider(String namespace,
|
||||
JingleContentTransportProvider<?> provider) {
|
||||
return jingleContentTransportProviders.put(namespace, provider);
|
||||
}
|
||||
|
||||
public static JingleContentTransportProvider<?> getJingleContentTransportProvider(String namespace) {
|
||||
return jingleContentTransportProviders.get(namespace);
|
||||
}
|
||||
}
|
|
@ -20,9 +20,11 @@ import java.util.logging.Logger;
|
|||
|
||||
import org.jivesoftware.smack.provider.IQProvider;
|
||||
import org.jivesoftware.smack.util.ParserUtils;
|
||||
import org.jivesoftware.smackx.jingle.JingleManager;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleAction;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentSecurityElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentTransportElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleReasonElement;
|
||||
|
@ -57,35 +59,35 @@ public class JingleProvider extends IQProvider<JingleElement> {
|
|||
outerloop: while (true) {
|
||||
int eventType = parser.next();
|
||||
switch (eventType) {
|
||||
case XmlPullParser.START_TAG:
|
||||
String tagName = parser.getName();
|
||||
switch (tagName) {
|
||||
case JingleContentElement.ELEMENT:
|
||||
JingleContentElement content = parseJingleContent(parser, parser.getDepth());
|
||||
builder.addJingleContent(content);
|
||||
break;
|
||||
case JingleReasonElement.ELEMENT:
|
||||
parser.next();
|
||||
String reasonString = parser.getName();
|
||||
JingleReasonElement reason;
|
||||
if (reasonString.equals("alternative-session")) {
|
||||
parser.next();
|
||||
String sid = parser.nextText();
|
||||
reason = new JingleReasonElement.AlternativeSession(sid);
|
||||
} else {
|
||||
reason = new JingleReasonElement(JingleReasonElement.Reason.fromString(reasonString));
|
||||
case XmlPullParser.START_TAG:
|
||||
String tagName = parser.getName();
|
||||
switch (tagName) {
|
||||
case JingleContentElement.ELEMENT:
|
||||
JingleContentElement content = parseJingleContent(parser, parser.getDepth());
|
||||
builder.addJingleContent(content);
|
||||
break;
|
||||
case JingleReasonElement.ELEMENT:
|
||||
parser.next();
|
||||
String reasonString = parser.getName();
|
||||
JingleReasonElement reason;
|
||||
if (reasonString.equals("alternative-session")) {
|
||||
parser.next();
|
||||
String sid = parser.nextText();
|
||||
reason = new JingleReasonElement.AlternativeSession(sid);
|
||||
} else {
|
||||
reason = new JingleReasonElement(JingleReasonElement.Reason.fromString(reasonString));
|
||||
}
|
||||
builder.setReason(reason);
|
||||
break;
|
||||
default:
|
||||
LOGGER.severe("Unknown Jingle element: " + tagName);
|
||||
break;
|
||||
}
|
||||
builder.setReason(reason);
|
||||
break;
|
||||
default:
|
||||
LOGGER.severe("Unknown Jingle element: " + tagName);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case XmlPullParser.END_TAG:
|
||||
if (parser.getDepth() == initialDepth) {
|
||||
break outerloop;
|
||||
}
|
||||
case XmlPullParser.END_TAG:
|
||||
if (parser.getDepth() == initialDepth) {
|
||||
break outerloop;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -93,7 +95,7 @@ public class JingleProvider extends IQProvider<JingleElement> {
|
|||
}
|
||||
|
||||
public static JingleContentElement parseJingleContent(XmlPullParser parser, final int initialDepth)
|
||||
throws Exception {
|
||||
throws Exception {
|
||||
JingleContentElement.Builder builder = JingleContentElement.getBuilder();
|
||||
|
||||
String creatorString = parser.getAttributeValue("", JingleContentElement.CREATOR_ATTRIBUTE_NAME);
|
||||
|
@ -115,39 +117,48 @@ public class JingleProvider extends IQProvider<JingleElement> {
|
|||
outerloop: while (true) {
|
||||
int eventType = parser.next();
|
||||
switch (eventType) {
|
||||
case XmlPullParser.START_TAG:
|
||||
String tagName = parser.getName();
|
||||
String namespace = parser.getNamespace();
|
||||
switch (tagName) {
|
||||
case JingleContentDescriptionElement.ELEMENT: {
|
||||
JingleContentDescriptionProvider<?> provider = JingleContentProviderManager.getJingleContentDescriptionProvider(namespace);
|
||||
if (provider == null) {
|
||||
// TODO handle this case (DefaultExtensionElement wrapped in something?)
|
||||
break;
|
||||
case XmlPullParser.START_TAG:
|
||||
String tagName = parser.getName();
|
||||
String namespace = parser.getNamespace();
|
||||
switch (tagName) {
|
||||
case JingleContentDescriptionElement.ELEMENT: {
|
||||
JingleContentDescriptionProvider<?> provider = JingleManager.getJingleDescriptionProvider(namespace);
|
||||
if (provider == null) {
|
||||
// TODO handle this case (DefaultExtensionElement wrapped in something?)
|
||||
break;
|
||||
}
|
||||
JingleContentDescriptionElement description = provider.parse(parser);
|
||||
builder.setDescription(description);
|
||||
break;
|
||||
}
|
||||
case JingleContentTransportElement.ELEMENT: {
|
||||
JingleContentTransportProvider<?> provider = JingleManager.getJingleTransportProvider(namespace);
|
||||
if (provider == null) {
|
||||
// TODO handle this case (DefaultExtensionElement wrapped in something?)
|
||||
break;
|
||||
}
|
||||
JingleContentTransportElement transport = provider.parse(parser);
|
||||
builder.setTransport(transport);
|
||||
break;
|
||||
}
|
||||
case JingleContentSecurityElement.ELEMENT: {
|
||||
JingleContentSecurityProvider<?> provider = JingleManager.getJingleSecurityProvider(namespace);
|
||||
if (provider == null) {
|
||||
//TODO: handle this case (see above)
|
||||
}
|
||||
JingleContentSecurityElement security = provider.parse(parser);
|
||||
builder.setSecurity(security);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
LOGGER.severe("Unknown Jingle content element: " + tagName);
|
||||
break;
|
||||
}
|
||||
JingleContentDescriptionElement description = provider.parse(parser);
|
||||
builder.setDescription(description);
|
||||
break;
|
||||
}
|
||||
case JingleContentTransportElement.ELEMENT: {
|
||||
JingleContentTransportProvider<?> provider = JingleContentProviderManager.getJingleContentTransportProvider(namespace);
|
||||
if (provider == null) {
|
||||
// TODO handle this case (DefaultExtensionElement wrapped in something?)
|
||||
break;
|
||||
case XmlPullParser.END_TAG:
|
||||
if (parser.getDepth() == initialDepth) {
|
||||
break outerloop;
|
||||
}
|
||||
JingleContentTransportElement transport = provider.parse(parser);
|
||||
builder.setTransport(transport);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
LOGGER.severe("Unknown Jingle content element: " + tagName);
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case XmlPullParser.END_TAG:
|
||||
if (parser.getDepth() == initialDepth) {
|
||||
break outerloop;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -25,7 +25,6 @@ import org.jivesoftware.smackx.jingle.JingleManager;
|
|||
import org.jivesoftware.smackx.jingle.JingleTransportManager;
|
||||
import org.jivesoftware.smackx.jingle.components.JingleContent;
|
||||
import org.jivesoftware.smackx.jingle.components.JingleTransport;
|
||||
import org.jivesoftware.smackx.jingle.provider.JingleContentProviderManager;
|
||||
import org.jivesoftware.smackx.jingle.transport.jingle_ibb.provider.JingleIBBTransportProvider;
|
||||
|
||||
/**
|
||||
|
@ -39,6 +38,7 @@ public final class JingleIBBTransportManager extends Manager implements JingleTr
|
|||
|
||||
static {
|
||||
JingleManager.addJingleTransportAdapter(new JingleIBBTransportAdapter());
|
||||
JingleManager.addJingleTransportProvider(new JingleIBBTransportProvider());
|
||||
}
|
||||
|
||||
private JingleIBBTransportManager(XMPPConnection connection) {
|
||||
|
@ -46,7 +46,6 @@ public final class JingleIBBTransportManager extends Manager implements JingleTr
|
|||
ServiceDiscoveryManager.getInstanceFor(connection).addFeature(getNamespace());
|
||||
JingleManager jingleManager = JingleManager.getInstanceFor(connection);
|
||||
jingleManager.addJingleTransportManager(this);
|
||||
JingleContentProviderManager.addJingleContentTransportProvider(getNamespace(), new JingleIBBTransportProvider());
|
||||
}
|
||||
|
||||
public static JingleIBBTransportManager getInstanceFor(XMPPConnection connection) {
|
||||
|
|
|
@ -44,7 +44,6 @@ import org.jivesoftware.smackx.jingle.components.JingleTransportCandidate;
|
|||
import org.jivesoftware.smackx.jingle.element.JingleAction;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleContentElement;
|
||||
import org.jivesoftware.smackx.jingle.element.JingleElement;
|
||||
import org.jivesoftware.smackx.jingle.provider.JingleContentProviderManager;
|
||||
import org.jivesoftware.smackx.jingle.transport.jingle_s5b.element.JingleS5BTransportCandidateElement;
|
||||
import org.jivesoftware.smackx.jingle.transport.jingle_s5b.element.JingleS5BTransportElement;
|
||||
import org.jivesoftware.smackx.jingle.transport.jingle_s5b.element.JingleS5BTransportInfoElement;
|
||||
|
@ -70,6 +69,7 @@ public final class JingleS5BTransportManager extends Manager implements JingleTr
|
|||
|
||||
static {
|
||||
JingleManager.addJingleTransportAdapter(new JingleS5BTransportAdapter());
|
||||
JingleManager.addJingleTransportProvider(new JingleS5BTransportProvider());
|
||||
}
|
||||
|
||||
private JingleS5BTransportManager(XMPPConnection connection) {
|
||||
|
@ -77,7 +77,6 @@ public final class JingleS5BTransportManager extends Manager implements JingleTr
|
|||
ServiceDiscoveryManager.getInstanceFor(connection).addFeature(getNamespace());
|
||||
JingleManager jingleManager = JingleManager.getInstanceFor(connection);
|
||||
jingleManager.addJingleTransportManager(this);
|
||||
JingleContentProviderManager.addJingleContentTransportProvider(getNamespace(), new JingleS5BTransportProvider());
|
||||
|
||||
connection.addConnectionListener(connectionListener);
|
||||
}
|
||||
|
|
|
@ -20,7 +20,6 @@ import static junit.framework.TestCase.assertEquals;
|
|||
import static junit.framework.TestCase.assertNull;
|
||||
|
||||
import org.jivesoftware.smack.test.util.SmackTestSuite;
|
||||
import org.jivesoftware.smackx.jingle.provider.JingleContentProviderManager;
|
||||
import org.jivesoftware.smackx.jingle.transport.jingle_ibb.JingleIBBTransport;
|
||||
import org.jivesoftware.smackx.jingle.transport.jingle_ibb.provider.JingleIBBTransportProvider;
|
||||
import org.jivesoftware.smackx.jingle.transport.jingle_s5b.JingleS5BTransport;
|
||||
|
@ -35,19 +34,19 @@ public class JingleContentProviderManagerTest extends SmackTestSuite {
|
|||
|
||||
@Test
|
||||
public void transportProviderTest() {
|
||||
JingleContentProviderManager.removeJingleContentTransportProvider(JingleIBBTransport.NAMESPACE_V1);
|
||||
JingleContentProviderManager.removeJingleContentTransportProvider(JingleS5BTransport.NAMESPACE_V1);
|
||||
JingleManager.removeJingleTransportProvider(JingleIBBTransport.NAMESPACE_V1);
|
||||
JingleManager.removeJingleTransportProvider(JingleS5BTransport.NAMESPACE_V1);
|
||||
|
||||
assertNull(JingleContentProviderManager.getJingleContentTransportProvider(JingleIBBTransport.NAMESPACE_V1));
|
||||
assertNull(JingleContentProviderManager.getJingleContentTransportProvider(JingleS5BTransport.NAMESPACE_V1));
|
||||
assertNull(JingleManager.getJingleTransportProvider(JingleIBBTransport.NAMESPACE_V1));
|
||||
assertNull(JingleManager.getJingleTransportProvider(JingleS5BTransport.NAMESPACE_V1));
|
||||
|
||||
JingleIBBTransportProvider ibbProvider = new JingleIBBTransportProvider();
|
||||
JingleContentProviderManager.addJingleContentTransportProvider(JingleIBBTransport.NAMESPACE_V1, ibbProvider);
|
||||
assertEquals(ibbProvider, JingleContentProviderManager.getJingleContentTransportProvider(JingleIBBTransport.NAMESPACE_V1));
|
||||
JingleManager.addJingleTransportProvider(ibbProvider);
|
||||
assertEquals(ibbProvider, JingleManager.getJingleTransportProvider(JingleIBBTransport.NAMESPACE_V1));
|
||||
|
||||
assertNull(JingleContentProviderManager.getJingleContentTransportProvider(JingleS5BTransport.NAMESPACE_V1));
|
||||
assertNull(JingleManager.getJingleTransportProvider(JingleS5BTransport.NAMESPACE_V1));
|
||||
JingleS5BTransportProvider s5bProvider = new JingleS5BTransportProvider();
|
||||
JingleContentProviderManager.addJingleContentTransportProvider(JingleS5BTransport.NAMESPACE_V1, s5bProvider);
|
||||
assertEquals(s5bProvider, JingleContentProviderManager.getJingleContentTransportProvider(JingleS5BTransport.NAMESPACE_V1));
|
||||
JingleManager.addJingleTransportProvider(s5bProvider);
|
||||
assertEquals(s5bProvider, JingleManager.getJingleTransportProvider(JingleS5BTransport.NAMESPACE_V1));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue