Commit 27887739 authored by huni's avatar huni

Fixed the issue where terminate, pause and xmpp:restart requests were considered polling.

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/branches@10711 b35dd754-fafc-0310-a699-88a17e54d16e
parent 2f1f8c4e
...@@ -649,7 +649,7 @@ public class HttpSession extends LocalClientSession { ...@@ -649,7 +649,7 @@ public class HttpSession extends LocalClientSession {
* protocol. * protocol.
*/ */
synchronized HttpConnection createConnection(long rid, Collection<Element> packetsToBeSent, synchronized HttpConnection createConnection(long rid, Collection<Element> packetsToBeSent,
boolean isSecure) boolean isSecure, boolean isPoll)
throws HttpConnectionClosedException, HttpBindException throws HttpConnectionClosedException, HttpBindException
{ {
HttpConnection connection = new HttpConnection(rid, isSecure, sslCertificates); HttpConnection connection = new HttpConnection(rid, isSecure, sslCertificates);
...@@ -672,7 +672,7 @@ public class HttpSession extends LocalClientSession { ...@@ -672,7 +672,7 @@ public class HttpSession extends LocalClientSession {
if (packetsToBeSent.size() > 0) { if (packetsToBeSent.size() > 0) {
packetsToSend.add(packetsToBeSent); packetsToSend.add(packetsToBeSent);
} }
addConnection(connection, packetsToBeSent.size() <= 0); addConnection(connection, isPoll);
return connection; return connection;
} }
...@@ -806,9 +806,9 @@ public class HttpSession extends LocalClientSession { ...@@ -806,9 +806,9 @@ public class HttpSession extends LocalClientSession {
overactivity = (pendingConnections >= maxRequests - 1); overactivity = (pendingConnections >= maxRequests - 1);
} }
} }
lastPoll = time;
errorMessage += ", minimum polling interval is " errorMessage += ", minimum polling interval is "
+ maxPollingInterval + ", current interval " + ((time - lastPoll) / 1000); + maxPollingInterval + ", current interval " + ((time - lastPoll) / 1000);
lastPoll = time;
} }
setLastResponseEmpty(false); setLastResponseEmpty(false);
......
...@@ -14,6 +14,7 @@ package org.jivesoftware.openfire.http; ...@@ -14,6 +14,7 @@ package org.jivesoftware.openfire.http;
import org.dom4j.DocumentException; import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper; import org.dom4j.DocumentHelper;
import org.dom4j.Element; import org.dom4j.Element;
import org.dom4j.QName;
import org.jivesoftware.openfire.SessionManager; import org.jivesoftware.openfire.SessionManager;
import org.jivesoftware.openfire.StreamID; import org.jivesoftware.openfire.StreamID;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
...@@ -266,7 +267,14 @@ public class HttpSessionManager { ...@@ -266,7 +267,14 @@ public class HttpSessionManager {
{ {
//noinspection unchecked //noinspection unchecked
List<Element> elements = rootNode.elements(); List<Element> elements = rootNode.elements();
HttpConnection connection = session.createConnection(rid, elements, isSecure); boolean isPoll = (elements.size() == 0);
if ("terminate".equals(rootNode.attributeValue("type")))
isPoll = false;
if ("true".equals(rootNode.attributeValue(new QName("restart", rootNode.getNamespaceForPrefix("xmpp")))))
isPoll = false;
if (rootNode.attributeValue("pause") != null)
isPoll = false;
HttpConnection connection = session.createConnection(rid, elements, isSecure, isPoll);
if (elements.size() > 0) { if (elements.size() > 0) {
// creates the runnable to forward the packets // creates the runnable to forward the packets
new HttpPacketSender(session).init(); new HttpPacketSender(session).init();
......
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