Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
Openfire
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
Openfire
Commits
736b76f1
Commit
736b76f1
authored
Jan 05, 2016
by
Dave Cridland
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #480 from guusdk/random
Improve quality of random data generation.
parents
c58efa58
579a8247
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
38 additions
and
21 deletions
+38
-21
SocketReader.java
src/java/org/jivesoftware/openfire/net/SocketReader.java
+10
-3
StanzaHandler.java
src/java/org/jivesoftware/openfire/net/StanzaHandler.java
+8
-1
BasicStreamIDFactory.java
...a/org/jivesoftware/openfire/spi/BasicStreamIDFactory.java
+12
-5
Blowfish.java
src/java/org/jivesoftware/util/Blowfish.java
+3
-4
StringUtils.java
src/java/org/jivesoftware/util/StringUtils.java
+5
-8
No files found.
src/java/org/jivesoftware/openfire/net/SocketReader.java
View file @
736b76f1
...
@@ -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\">"
);
...
...
src/java/org/jivesoftware/openfire/net/StanzaHandler.java
View file @
736b76f1
...
@@ -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
(
S
tringUtils
.
randomString
(
5
)).
append
(
"\" "
);
sb
.
append
(
"id=\""
).
append
(
S
TREAM_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\">"
);
...
...
src/java/org/jivesoftware/openfire/spi/BasicStreamIDFactory.java
View file @
736b76f1
...
@@ -22,24 +22,31 @@ package org.jivesoftware.openfire.spi;
...
@@ -22,24 +22,31 @@ package org.jivesoftware.openfire.spi;
import
org.jivesoftware.openfire.StreamID
;
import
org.jivesoftware.openfire.StreamID
;
import
org.jivesoftware.openfire.StreamIDFactory
;
import
org.jivesoftware.openfire.StreamIDFactory
;
import
java.math.BigInteger
;
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
*/
*/
public
class
BasicStreamIDFactory
implements
StreamIDFactory
{
public
class
BasicStreamIDFactory
implements
StreamIDFactory
{
/**
/**
* The random number to use, someone with Java can predict stream IDs if they can guess the current seed *
* The maximum amount of characters in a stream ID that's generated by this implementation.
*/
private
static
final
int
MAX_STRING_SIZE
=
10
;
/**
* The random number to use, someone with Java can predict stream IDs if they can guess the current seed
*/
*/
Random
random
=
new
Random
();
Random
random
=
new
Secure
Random
();
@Override
@Override
public
StreamID
createStreamID
()
{
public
StreamID
createStreamID
()
{
return
new
BasicStreamID
(
Integer
.
toHexString
(
random
.
nextInt
()
));
return
new
BasicStreamID
(
new
BigInteger
(
MAX_STRING_SIZE
*
5
,
random
).
toString
(
36
));
}
}
public
StreamID
createStreamID
(
String
name
)
{
public
StreamID
createStreamID
(
String
name
)
{
...
...
src/java/org/jivesoftware/util/Blowfish.java
View file @
736b76f1
...
@@ -15,6 +15,7 @@
...
@@ -15,6 +15,7 @@
package
org
.
jivesoftware
.
util
;
package
org
.
jivesoftware
.
util
;
import
java.security.MessageDigest
;
import
java.security.MessageDigest
;
import
java.security.SecureRandom
;
import
java.util.Random
;
import
java.util.Random
;
import
org.slf4j.Logger
;
import
org.slf4j.Logger
;
...
@@ -31,7 +32,7 @@ public class Blowfish implements Encryptor {
...
@@ -31,7 +32,7 @@ public class Blowfish implements Encryptor {
private
static
final
Logger
Log
=
LoggerFactory
.
getLogger
(
Blowfish
.
class
);
private
static
final
Logger
Log
=
LoggerFactory
.
getLogger
(
Blowfish
.
class
);
private
BlowfishCBC
m_bfish
;
private
BlowfishCBC
m_bfish
;
private
static
Random
m_rndGen
=
new
Random
();
private
static
Random
m_rndGen
=
new
Secure
Random
();
private
static
final
String
DEFAULT_KEY
=
"Blowfish-CBC"
;
private
static
final
String
DEFAULT_KEY
=
"Blowfish-CBC"
;
/**
/**
...
@@ -52,9 +53,7 @@ public class Blowfish implements Encryptor {
...
@@ -52,9 +53,7 @@ public class Blowfish implements Encryptor {
}
}
/**
/**
* Encrypts a string (treated in UNICODE) using the
* Encrypts a string (treated in UNICODE).
* standard Java random generator, which isn't that
* great for creating IVs
*
*
* @param sPlainText string to encrypt
* @param sPlainText string to encrypt
* @return encrypted string in binhex format
* @return encrypted string in binhex format
...
...
src/java/org/jivesoftware/util/StringUtils.java
View file @
736b76f1
...
@@ -30,6 +30,7 @@ import java.net.IDN;
...
@@ -30,6 +30,7 @@ import java.net.IDN;
import
java.nio.charset.StandardCharsets
;
import
java.nio.charset.StandardCharsets
;
import
java.security.MessageDigest
;
import
java.security.MessageDigest
;
import
java.security.NoSuchAlgorithmException
;
import
java.security.NoSuchAlgorithmException
;
import
java.security.SecureRandom
;
import
java.text.BreakIterator
;
import
java.text.BreakIterator
;
import
java.text.MessageFormat
;
import
java.text.MessageFormat
;
import
java.util.ArrayList
;
import
java.util.ArrayList
;
...
@@ -515,11 +516,9 @@ public final class StringUtils {
...
@@ -515,11 +516,9 @@ public final class StringUtils {
}
}
/**
/**
* Pseudo-random number generator object for use with randomString().
* A cryptographically strong random number generator object for use with randomString().
* The Random class is not considered to be cryptographically secure, so
* only use these random Strings for low to medium security applications.
*/
*/
private
static
Random
randGen
=
new
Random
();
private
static
Random
randGen
=
new
Secure
Random
();
/**
/**
* Array of numbers and letters of mixed case. Numbers appear in the list
* Array of numbers and letters of mixed case. Numbers appear in the list
...
@@ -532,10 +531,8 @@ public final class StringUtils {
...
@@ -532,10 +531,8 @@ public final class StringUtils {
/**
/**
* Returns a random String of numbers and letters (lower and upper case)
* Returns a random String of numbers and letters (lower and upper case)
* of the specified length. The method uses the Random class that is
* of the specified length. The method uses a cryptographically strong
* built-in to Java which is suitable for low to medium grade security uses.
* random number generator as provided by {@link SecureRandom}
* This means that the output is only pseudo random, i.e., each number is
* mathematically generated so is not truly random.
* <p>
* <p>
* The specified length must be at least one. If not, the method will return
* The specified length must be at least one. If not, the method will return
* null.</p>
* null.</p>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment