Commit 843b6623 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Added try/catch when processing disco packet of external component.

git-svn-id: http://svn.igniterealtime.org/svn/repos/wildfire/trunk@3640 b35dd754-fafc-0310-a699-88a17e54d16e
parent ca008069
...@@ -12,12 +12,12 @@ ...@@ -12,12 +12,12 @@
package org.jivesoftware.wildfire.component; package org.jivesoftware.wildfire.component;
import org.dom4j.Element; import org.dom4j.Element;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import org.jivesoftware.wildfire.PacketException; import org.jivesoftware.wildfire.PacketException;
import org.jivesoftware.wildfire.PacketRouter; import org.jivesoftware.wildfire.PacketRouter;
import org.jivesoftware.wildfire.RoutableChannelHandler; import org.jivesoftware.wildfire.RoutableChannelHandler;
import org.jivesoftware.wildfire.XMPPServer; import org.jivesoftware.wildfire.XMPPServer;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import org.xmpp.component.Component; import org.xmpp.component.Component;
import org.xmpp.component.ComponentException; import org.xmpp.component.ComponentException;
import org.xmpp.component.ComponentManager; import org.xmpp.component.ComponentManager;
...@@ -311,15 +311,21 @@ public class InternalComponentManager implements ComponentManager, RoutableChann ...@@ -311,15 +311,21 @@ public class InternalComponentManager implements ComponentManager, RoutableChann
if ("http://jabber.org/protocol/disco#info".equals(namespace)) { if ("http://jabber.org/protocol/disco#info".equals(namespace)) {
// Add a disco item to the server for the component that supports disco // Add a disco item to the server for the component that supports disco
Element identity = childElement.element("identity"); Element identity = childElement.element("identity");
XMPPServer.getInstance().getIQDiscoItemsHandler().addComponentItem(packet.getFrom() try {
.toBareJID(), XMPPServer.getInstance().getIQDiscoItemsHandler().addComponentItem(packet.getFrom()
identity.attributeValue("name")); .toBareJID(),
if (component instanceof ComponentSession.ExternalComponent) { identity.attributeValue("name"));
ComponentSession.ExternalComponent externalComponent = if (component instanceof ComponentSession.ExternalComponent) {
(ComponentSession.ExternalComponent) component; ComponentSession.ExternalComponent externalComponent =
externalComponent.setName(identity.attributeValue("name")); (ComponentSession.ExternalComponent) component;
externalComponent.setType(identity.attributeValue("type")); externalComponent.setName(identity.attributeValue("name"));
externalComponent.setCategory(identity.attributeValue("category")); externalComponent.setType(identity.attributeValue("type"));
externalComponent.setCategory(identity.attributeValue("category"));
}
}
catch (Exception e) {
Log.error("Error processing disco packet of external component: " +
packet.toXML(), e);
} }
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment