Commit 374d97bf authored by guus's avatar guus

OF-443: Server Dialback should also be available to streams for which the...

OF-443: Server Dialback should also be available to streams for which the version identifier is equal to or higher than 1.0.

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@12233 b35dd754-fafc-0310-a699-88a17e54d16e
parent d3a723d8
...@@ -110,6 +110,20 @@ public class LocalIncomingServerSession extends LocalSession implements Incoming ...@@ -110,6 +110,20 @@ public class LocalIncomingServerSession extends LocalSession implements Incoming
public static LocalIncomingServerSession createSession(String serverName, XMPPPacketReader reader, public static LocalIncomingServerSession createSession(String serverName, XMPPPacketReader reader,
SocketConnection connection) throws XmlPullParserException, IOException { SocketConnection connection) throws XmlPullParserException, IOException {
XmlPullParser xpp = reader.getXPPParser(); XmlPullParser xpp = reader.getXPPParser();
if (xpp.getNamespace("db") != null) {
if (ServerDialback.isEnabled()) {
Log.debug("Server is trying to establish connection and authenticate using server dialback: " + connection);
ServerDialback method = new ServerDialback(connection, serverName);
return method.createIncomingSession(reader);
} else {
Log.debug("Server is trying to establish connection and authenticate using server dialback, " +
"but Server Dialback is disabled by configuration. Rejecting connection: " + connection);
connection.close();
return null;
}
}
String version = xpp.getAttributeValue("", "version"); String version = xpp.getAttributeValue("", "version");
int[] serverVersion = version != null ? decodeVersion(version) : new int[] {0,0}; int[] serverVersion = version != null ? decodeVersion(version) : new int[] {0,0};
if (serverVersion[0] >= 1) { if (serverVersion[0] >= 1) {
...@@ -118,19 +132,15 @@ public class LocalIncomingServerSession extends LocalSession implements Incoming ...@@ -118,19 +132,15 @@ public class LocalIncomingServerSession extends LocalSession implements Incoming
return createIncomingSession(connection, serverName); return createIncomingSession(connection, serverName);
} }
catch (Exception e) { catch (Exception e) {
Log.error("Error establishing connection from remote server", e); Log.error("Error establishing connection from remote server:" + connection, e);
} connection.close();
} return null;
else if (xpp.getNamespace("db") != null) {
// Server is trying to establish connection and authenticate using server dialback (pre XMPP 1.0)
if (ServerDialback.isEnabled()) {
ServerDialback method = new ServerDialback(connection, serverName);
return method.createIncomingSession(reader);
} }
Log.debug("LocalIncomingServerSession: Server dialback is disabled. Rejecting connection: " + connection);
} }
// Close the connection since remote server is not XMPP 1.0 compliant and is not
// using server dialback to establish and authenticate the connection Log.debug("Server is not 1.0 compliant and is not using dialback to establish and "
+ "authenticate the connection. Rejecting connection: "
+ connection);
connection.close(); connection.close();
return null; return null;
} }
......
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