Commit 579a8247 authored by Guus der Kinderen's avatar Guus der Kinderen

Use StreamIDFactory when generating Stream IDs

StreamIDFactory is designed to generate stream IDs. It's silly to use
something else when generating stream IDs.
parent 8073bab7
...@@ -28,11 +28,12 @@ import org.dom4j.io.XMPPPacketReader; ...@@ -28,11 +28,12 @@ import org.dom4j.io.XMPPPacketReader;
import org.jivesoftware.openfire.Connection; import org.jivesoftware.openfire.Connection;
import org.jivesoftware.openfire.PacketRouter; import org.jivesoftware.openfire.PacketRouter;
import org.jivesoftware.openfire.RoutingTable; import org.jivesoftware.openfire.RoutingTable;
import org.jivesoftware.openfire.StreamIDFactory;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.session.LocalSession; import org.jivesoftware.openfire.session.LocalSession;
import org.jivesoftware.openfire.session.Session; import org.jivesoftware.openfire.session.Session;
import org.jivesoftware.openfire.spi.BasicStreamIDFactory;
import org.jivesoftware.util.LocaleUtils; import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.xmlpull.v1.XmlPullParser; import org.xmlpull.v1.XmlPullParser;
...@@ -60,6 +61,12 @@ public abstract class SocketReader implements Runnable { ...@@ -60,6 +61,12 @@ public abstract class SocketReader implements Runnable {
* The utf-8 charset for decoding and encoding Jabber packet streams. * The utf-8 charset for decoding and encoding Jabber packet streams.
*/ */
private static String CHARSET = "UTF-8"; private static String CHARSET = "UTF-8";
/**
* A factory that generates random stream IDs
*/
private static final StreamIDFactory STREAM_ID_FACTORY = new BasicStreamIDFactory();
/** /**
* Reuse the same factory for all the connections. * Reuse the same factory for all the connections.
*/ */
...@@ -394,7 +401,7 @@ public abstract class SocketReader implements Runnable { ...@@ -394,7 +401,7 @@ public abstract class SocketReader implements Runnable {
// Append stream header // Append stream header
sb.append("<stream:stream "); sb.append("<stream:stream ");
sb.append("from=\"").append(serverName).append("\" "); sb.append("from=\"").append(serverName).append("\" ");
sb.append("id=\"").append(StringUtils.randomString(5)).append("\" "); sb.append("id=\"").append( STREAM_ID_FACTORY.createStreamID() ).append( "\" " );
sb.append("xmlns=\"").append(xpp.getNamespace(null)).append("\" "); sb.append("xmlns=\"").append(xpp.getNamespace(null)).append("\" ");
sb.append("xmlns:stream=\"").append(xpp.getNamespace("stream")).append("\" "); sb.append("xmlns:stream=\"").append(xpp.getNamespace("stream")).append("\" ");
sb.append("version=\"1.0\">"); sb.append("version=\"1.0\">");
...@@ -423,7 +430,7 @@ public abstract class SocketReader implements Runnable { ...@@ -423,7 +430,7 @@ public abstract class SocketReader implements Runnable {
// Append stream header // Append stream header
sb.append("<stream:stream "); sb.append("<stream:stream ");
sb.append("from=\"").append(serverName).append("\" "); sb.append("from=\"").append(serverName).append("\" ");
sb.append("id=\"").append(StringUtils.randomString(5)).append("\" "); sb.append("id=\"").append( STREAM_ID_FACTORY.createStreamID() ).append( "\" " );
sb.append("xmlns=\"").append(xpp.getNamespace(null)).append("\" "); sb.append("xmlns=\"").append(xpp.getNamespace(null)).append("\" ");
sb.append("xmlns:stream=\"").append(xpp.getNamespace("stream")).append("\" "); sb.append("xmlns:stream=\"").append(xpp.getNamespace("stream")).append("\" ");
sb.append("version=\"1.0\">"); sb.append("version=\"1.0\">");
......
...@@ -23,11 +23,13 @@ import org.dom4j.Element; ...@@ -23,11 +23,13 @@ import org.dom4j.Element;
import org.dom4j.io.XMPPPacketReader; import org.dom4j.io.XMPPPacketReader;
import org.jivesoftware.openfire.Connection; import org.jivesoftware.openfire.Connection;
import org.jivesoftware.openfire.PacketRouter; import org.jivesoftware.openfire.PacketRouter;
import org.jivesoftware.openfire.StreamIDFactory;
import org.jivesoftware.openfire.XMPPServer; import org.jivesoftware.openfire.XMPPServer;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.http.FlashCrossDomainServlet; import org.jivesoftware.openfire.http.FlashCrossDomainServlet;
import org.jivesoftware.openfire.session.LocalSession; import org.jivesoftware.openfire.session.LocalSession;
import org.jivesoftware.openfire.session.Session; import org.jivesoftware.openfire.session.Session;
import org.jivesoftware.openfire.spi.BasicStreamIDFactory;
import org.jivesoftware.openfire.streammanagement.StreamManager; import org.jivesoftware.openfire.streammanagement.StreamManager;
import org.jivesoftware.util.JiveGlobals; import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.LocaleUtils; import org.jivesoftware.util.LocaleUtils;
...@@ -51,6 +53,11 @@ public abstract class StanzaHandler { ...@@ -51,6 +53,11 @@ public abstract class StanzaHandler {
private static final Logger Log = LoggerFactory.getLogger(StanzaHandler.class); private static final Logger Log = LoggerFactory.getLogger(StanzaHandler.class);
/**
* A factory that generates random stream IDs
*/
private static final StreamIDFactory STREAM_ID_FACTORY = new BasicStreamIDFactory();
/** /**
* The utf-8 charset for decoding and encoding Jabber packet streams. * The utf-8 charset for decoding and encoding Jabber packet streams.
*/ */
...@@ -659,7 +666,7 @@ public abstract class StanzaHandler { ...@@ -659,7 +666,7 @@ public abstract class StanzaHandler {
// Append stream header // Append stream header
sb.append("<stream:stream "); sb.append("<stream:stream ");
sb.append("from=\"").append(serverName).append("\" "); sb.append("from=\"").append(serverName).append("\" ");
sb.append("id=\"").append(StringUtils.randomString(5)).append("\" "); sb.append("id=\"").append(STREAM_ID_FACTORY.createStreamID()).append("\" ");
sb.append("xmlns=\"").append(xpp.getNamespace(null)).append("\" "); sb.append("xmlns=\"").append(xpp.getNamespace(null)).append("\" ");
sb.append("xmlns:stream=\"http://etherx.jabber.org/streams\" "); sb.append("xmlns:stream=\"http://etherx.jabber.org/streams\" ");
sb.append("version=\"1.0\">"); sb.append("version=\"1.0\">");
......
...@@ -28,8 +28,7 @@ import java.security.SecureRandom; ...@@ -28,8 +28,7 @@ import java.security.SecureRandom;
import java.util.Random; import java.util.Random;
/** /**
* A basic stream ID factory that produces id's using java.util.Random * A basic stream ID factory that produces IDs using a cryptographically strong random number generator.
* and a simple hex representation of a random int.
* *
* @author Iain Shigeoka * @author Iain Shigeoka
*/ */
......
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