Commit 467d682f authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Added stream header before sending stream error. JM-457

git-svn-id: http://svn.igniterealtime.org/svn/repos/messenger/trunk@3040 b35dd754-fafc-0310-a699-88a17e54d16e
parent d83b87a5
...@@ -20,6 +20,7 @@ import org.jivesoftware.messenger.interceptor.PacketRejectedException; ...@@ -20,6 +20,7 @@ import org.jivesoftware.messenger.interceptor.PacketRejectedException;
import org.jivesoftware.messenger.server.OutgoingSessionPromise; import org.jivesoftware.messenger.server.OutgoingSessionPromise;
import org.jivesoftware.util.LocaleUtils; import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log; import org.jivesoftware.util.Log;
import org.jivesoftware.util.StringUtils;
import org.xmlpull.v1.XmlPullParser; import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException; import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlPullParserFactory; import org.xmlpull.v1.XmlPullParserFactory;
...@@ -447,16 +448,22 @@ public abstract class SocketReader implements Runnable { ...@@ -447,16 +448,22 @@ public abstract class SocketReader implements Runnable {
// error and close the underlying connection. // error and close the underlying connection.
String host = reader.getXPPParser().getAttributeValue("", "to"); String host = reader.getXPPParser().getAttributeValue("", "to");
if (validateHost() && isHostUnknown(host)) { if (validateHost() && isHostUnknown(host)) {
Writer writer = connection.getWriter();
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
sb.append("<?xml version='1.0' encoding='"); sb.append("<?xml version='1.0' encoding='");
sb.append(CHARSET); sb.append(CHARSET);
sb.append("'?>"); sb.append("'?>");
// Append stream header
sb.append("<stream:stream ");
sb.append("from=\"").append(serverName).append("\" ");
sb.append("id=\"").append(StringUtils.randomString(5)).append("\" ");
sb.append("xmlns=\"").append(xpp.getNamespace(null)).append("\" ");
sb.append("xmlns:stream=\"").append(xpp.getNamespace("stream")).append("\" ");
sb.append("version=\"1.0\">");
// Set the host_unknown error // Set the host_unknown error
StreamError error = new StreamError(StreamError.Condition.host_unknown); StreamError error = new StreamError(StreamError.Condition.host_unknown);
sb.append(error.toXML()); sb.append(error.toXML());
writer.write(sb.toString()); // Deliver stanza
writer.flush(); connection.deliverRawText(sb.toString());
// Close the underlying connection // Close the underlying connection
connection.close(); connection.close();
// Log a warning so that admins can track this cases from the server side // Log a warning so that admins can track this cases from the server side
...@@ -470,16 +477,21 @@ public abstract class SocketReader implements Runnable { ...@@ -470,16 +477,21 @@ public abstract class SocketReader implements Runnable {
else if (!createSession(xpp.getNamespace(null))) { else if (!createSession(xpp.getNamespace(null))) {
// No session was created because of an invalid namespace prefix so answer a stream // No session was created because of an invalid namespace prefix so answer a stream
// error and close the underlying connection // error and close the underlying connection
Writer writer = connection.getWriter();
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
sb.append("<?xml version='1.0' encoding='"); sb.append("<?xml version='1.0' encoding='");
sb.append(CHARSET); sb.append(CHARSET);
sb.append("'?>"); sb.append("'?>");
// Append stream header
sb.append("<stream:stream ");
sb.append("from=\"").append(serverName).append("\" ");
sb.append("id=\"").append(StringUtils.randomString(5)).append("\" ");
sb.append("xmlns=\"").append(xpp.getNamespace(null)).append("\" ");
sb.append("xmlns:stream=\"").append(xpp.getNamespace("stream")).append("\" ");
sb.append("version=\"1.0\">");
// Include the bad-namespace-prefix in the response // Include the bad-namespace-prefix in the response
StreamError error = new StreamError(StreamError.Condition.bad_namespace_prefix); StreamError error = new StreamError(StreamError.Condition.bad_namespace_prefix);
sb.append(error.toXML()); sb.append(error.toXML());
writer.write(sb.toString()); connection.deliverRawText(sb.toString());
writer.flush();
// Close the underlying connection // Close the underlying connection
connection.close(); connection.close();
// Log a warning so that admins can track this cases from the server side // Log a warning so that admins can track this cases from the server side
......
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