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
bd4d07bc
Commit
bd4d07bc
authored
Dec 13, 2016
by
Dave Cridland
Committed by
GitHub
Dec 13, 2016
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #671 from surevine/of-1104
OF-1104 Ensure SCRAM uses AuthProvider API
parents
2249ae78
121db7f2
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
271 additions
and
8 deletions
+271
-8
AuthFactory.java
src/java/org/jivesoftware/openfire/auth/AuthFactory.java
+13
-0
AuthProvider.java
src/java/org/jivesoftware/openfire/auth/AuthProvider.java
+4
-0
DefaultAuthProvider.java
...a/org/jivesoftware/openfire/auth/DefaultAuthProvider.java
+84
-1
HybridAuthProvider.java
...va/org/jivesoftware/openfire/auth/HybridAuthProvider.java
+20
-0
JDBCAuthProvider.java
...java/org/jivesoftware/openfire/auth/JDBCAuthProvider.java
+21
-1
MappedAuthProvider.java
...va/org/jivesoftware/openfire/auth/MappedAuthProvider.java
+44
-0
NativeAuthProvider.java
...va/org/jivesoftware/openfire/auth/NativeAuthProvider.java
+20
-0
POP3AuthProvider.java
...java/org/jivesoftware/openfire/auth/POP3AuthProvider.java
+20
-0
CrowdAuthProvider.java
...va/org/jivesoftware/openfire/crowd/CrowdAuthProvider.java
+20
-0
LdapAuthProvider.java
...java/org/jivesoftware/openfire/ldap/LdapAuthProvider.java
+20
-0
ScramSha1SaslServer.java
...a/org/jivesoftware/openfire/sasl/ScramSha1SaslServer.java
+5
-6
No files found.
src/java/org/jivesoftware/openfire/auth/AuthFactory.java
View file @
bd4d07bc
...
...
@@ -293,4 +293,17 @@ public class AuthFactory {
// TODO Auto-generated method stub
return
authProvider
.
isScramSupported
();
}
public
static
String
getSalt
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
return
authProvider
.
getSalt
(
username
);
}
public
static
int
getIterations
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
return
authProvider
.
getIterations
(
username
);
}
public
static
String
getServerKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
return
authProvider
.
getServerKey
(
username
);
}
public
static
String
getStoredKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
return
authProvider
.
getStoredKey
(
username
);
}
}
\ No newline at end of file
src/java/org/jivesoftware/openfire/auth/AuthProvider.java
View file @
bd4d07bc
...
...
@@ -90,4 +90,8 @@ public interface AuthProvider {
public
boolean
supportsPasswordRetrieval
();
boolean
isScramSupported
();
String
getSalt
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
;
int
getIterations
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
;
String
getServerKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
;
String
getStoredKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
;
}
\ No newline at end of file
src/java/org/jivesoftware/openfire/auth/DefaultAuthProvider.java
View file @
bd4d07bc
...
...
@@ -55,7 +55,7 @@ public class DefaultAuthProvider implements AuthProvider {
private
static
final
String
LOAD_PASSWORD
=
"SELECT plainPassword,encryptedPassword FROM ofUser WHERE username=?"
;
private
static
final
String
TEST_PASSWORD
=
"SELECT plainPassword,encryptedPassword,iterations,salt,storedKey FROM ofUser WHERE username=?"
;
"SELECT plainPassword,encryptedPassword,iterations,salt,storedKey
,serverKey
FROM ofUser WHERE username=?"
;
private
static
final
String
UPDATE_PASSWORD
=
"UPDATE ofUser SET plainPassword=?, encryptedPassword=?, storedKey=?, serverKey=?, salt=?, iterations=? WHERE username=?"
;
...
...
@@ -68,6 +68,89 @@ public class DefaultAuthProvider implements AuthProvider {
}
private
class
UserInfo
{
String
plainText
;
String
encrypted
;
int
iterations
;
String
salt
;
String
storedKey
;
String
serverKey
;
}
private
UserInfo
getUserInfo
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
if
(!
isScramSupported
())
{
// Reject the operation since the provider does not support SCRAM
throw
new
UnsupportedOperationException
();
}
Connection
con
=
null
;
PreparedStatement
pstmt
=
null
;
ResultSet
rs
=
null
;
try
{
con
=
DbConnectionManager
.
getConnection
();
pstmt
=
con
.
prepareStatement
(
TEST_PASSWORD
);
pstmt
.
setString
(
1
,
username
);
rs
=
pstmt
.
executeQuery
();
if
(!
rs
.
next
())
{
throw
new
UserNotFoundException
(
username
);
}
UserInfo
userInfo
=
new
UserInfo
();
userInfo
.
plainText
=
rs
.
getString
(
1
);
userInfo
.
encrypted
=
rs
.
getString
(
2
);
userInfo
.
iterations
=
rs
.
getInt
(
3
);
userInfo
.
salt
=
rs
.
getString
(
4
);
userInfo
.
storedKey
=
rs
.
getString
(
5
);
userInfo
.
serverKey
=
rs
.
getString
(
6
);
if
(
userInfo
.
encrypted
!=
null
)
{
try
{
userInfo
.
plainText
=
AuthFactory
.
decryptPassword
(
userInfo
.
encrypted
);
}
catch
(
UnsupportedOperationException
uoe
)
{
// Ignore and return plain password instead.
}
}
if
(
userInfo
.
plainText
!=
null
)
{
boolean
scramOnly
=
JiveGlobals
.
getBooleanProperty
(
"user.scramHashedPasswordOnly"
);
if
(
scramOnly
)
{
// If we have a password here, but we're meant to be scramOnly, we should reset it.
setPassword
(
username
,
userInfo
.
plainText
);
}
if
(
userInfo
.
salt
==
null
)
{
// RECURSE
return
getUserInfo
(
username
);
}
}
// Good to go.
return
userInfo
;
}
catch
(
SQLException
sqle
)
{
Log
.
error
(
"User SQL failure:"
,
sqle
);
throw
new
UserNotFoundException
(
sqle
);
}
finally
{
DbConnectionManager
.
closeConnection
(
rs
,
pstmt
,
con
);
}
}
@Override
public
String
getSalt
(
String
username
)
throws
UserNotFoundException
{
return
getUserInfo
(
username
).
salt
;
}
@Override
public
int
getIterations
(
String
username
)
throws
UserNotFoundException
{
return
getUserInfo
(
username
).
iterations
;
}
@Override
public
String
getStoredKey
(
String
username
)
throws
UserNotFoundException
{
return
getUserInfo
(
username
).
storedKey
;
}
@Override
public
String
getServerKey
(
String
username
)
throws
UserNotFoundException
{
return
getUserInfo
(
username
).
serverKey
;
}
@Override
public
void
authenticate
(
String
username
,
String
password
)
throws
UnauthorizedException
{
if
(
username
==
null
||
password
==
null
)
{
...
...
src/java/org/jivesoftware/openfire/auth/HybridAuthProvider.java
View file @
bd4d07bc
...
...
@@ -232,4 +232,24 @@ public class HybridAuthProvider implements AuthProvider {
// TODO Auto-generated method stub
return
false
;
}
@Override
public
String
getSalt
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
int
getIterations
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getServerKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getStoredKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
}
\ No newline at end of file
src/java/org/jivesoftware/openfire/auth/JDBCAuthProvider.java
View file @
bd4d07bc
...
...
@@ -449,6 +449,26 @@ public class JDBCAuthProvider implements AuthProvider, PropertyEventListener {
return
false
;
}
@Override
public
String
getSalt
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
int
getIterations
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getServerKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getStoredKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
/**
* Support a subset of JDBCAuthProvider properties when updated via REST,
* web GUI, or other sources. Provider strings (and related settings) must
...
...
src/java/org/jivesoftware/openfire/auth/MappedAuthProvider.java
View file @
bd4d07bc
...
...
@@ -139,4 +139,48 @@ public class MappedAuthProvider implements AuthProvider
return
false
;
}
@Override
public
String
getSalt
(
String
username
)
throws
UserNotFoundException
{
final
AuthProvider
provider
=
mapper
.
getAuthProvider
(
username
);
if
(
provider
==
null
)
{
throw
new
UserNotFoundException
();
}
return
provider
.
getSalt
(
username
);
}
@Override
public
int
getIterations
(
String
username
)
throws
UserNotFoundException
{
final
AuthProvider
provider
=
mapper
.
getAuthProvider
(
username
);
if
(
provider
==
null
)
{
throw
new
UserNotFoundException
();
}
return
provider
.
getIterations
(
username
);
}
@Override
public
String
getServerKey
(
String
username
)
throws
UserNotFoundException
{
final
AuthProvider
provider
=
mapper
.
getAuthProvider
(
username
);
if
(
provider
==
null
)
{
throw
new
UserNotFoundException
();
}
return
provider
.
getServerKey
(
username
);
}
@Override
public
String
getStoredKey
(
String
username
)
throws
UserNotFoundException
{
final
AuthProvider
provider
=
mapper
.
getAuthProvider
(
username
);
if
(
provider
==
null
)
{
throw
new
UserNotFoundException
();
}
return
provider
.
getStoredKey
(
username
);
}
}
src/java/org/jivesoftware/openfire/auth/NativeAuthProvider.java
View file @
bd4d07bc
...
...
@@ -204,4 +204,24 @@ public class NativeAuthProvider implements AuthProvider {
// TODO Auto-generated method stub
return
false
;
}
@Override
public
String
getSalt
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
int
getIterations
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getServerKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getStoredKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
}
src/java/org/jivesoftware/openfire/auth/POP3AuthProvider.java
View file @
bd4d07bc
...
...
@@ -240,4 +240,24 @@ public class POP3AuthProvider implements AuthProvider {
public
boolean
isScramSupported
()
{
return
false
;
}
@Override
public
String
getSalt
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
int
getIterations
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getServerKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getStoredKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
}
\ No newline at end of file
src/java/org/jivesoftware/openfire/crowd/CrowdAuthProvider.java
View file @
bd4d07bc
...
...
@@ -107,4 +107,24 @@ public class CrowdAuthProvider implements AuthProvider {
return
false
;
}
@Override
public
String
getSalt
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
int
getIterations
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getServerKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getStoredKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
}
src/java/org/jivesoftware/openfire/ldap/LdapAuthProvider.java
View file @
bd4d07bc
...
...
@@ -157,4 +157,24 @@ public class LdapAuthProvider implements AuthProvider {
public
boolean
isScramSupported
()
{
return
false
;
}
@Override
public
String
getSalt
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
int
getIterations
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getServerKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
@Override
public
String
getStoredKey
(
String
username
)
throws
UnsupportedOperationException
,
UserNotFoundException
{
throw
new
UnsupportedOperationException
();
}
}
\ No newline at end of file
src/java/org/jivesoftware/openfire/sasl/ScramSha1SaslServer.java
View file @
bd4d07bc
...
...
@@ -38,7 +38,6 @@ import org.jivesoftware.openfire.auth.AuthFactory;
import
org.jivesoftware.openfire.auth.ConnectionException
;
import
org.jivesoftware.openfire.auth.InternalUnauthenticatedException
;
import
org.jivesoftware.openfire.auth.ScramUtils
;
import
org.jivesoftware.openfire.user.UserManager
;
import
org.jivesoftware.openfire.user.UserNotFoundException
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
...
...
@@ -315,13 +314,13 @@ public class ScramSha1SaslServer implements SaslServer {
*/
private
byte
[]
getSalt
(
final
String
username
)
{
try
{
String
saltshaker
=
UserManager
.
getUserProvider
().
loadUser
(
username
).
getSalt
(
);
String
saltshaker
=
AuthFactory
.
getSalt
(
username
);
byte
[]
salt
;
if
(
saltshaker
==
null
)
{
Log
.
debug
(
"No salt found, so resetting password."
);
String
password
=
AuthFactory
.
getPassword
(
username
);
AuthFactory
.
setPassword
(
username
,
password
);
salt
=
DatatypeConverter
.
parseBase64Binary
(
UserManager
.
getUserProvider
().
loadUser
(
username
).
getSalt
(
));
salt
=
DatatypeConverter
.
parseBase64Binary
(
AuthFactory
.
getSalt
(
username
));
}
else
{
salt
=
DatatypeConverter
.
parseBase64Binary
(
saltshaker
);
}
...
...
@@ -338,14 +337,14 @@ public class ScramSha1SaslServer implements SaslServer {
* Retrieve the iteration count from the database for a given username.
*/
private
int
getIterations
(
final
String
username
)
throws
UserNotFoundException
{
return
UserManager
.
getUserProvider
().
loadUser
(
username
).
getIterations
(
);
return
AuthFactory
.
getIterations
(
username
);
}
/**
* Retrieve the server key from the database for a given username.
*/
private
byte
[]
getServerKey
(
final
String
username
)
throws
UserNotFoundException
{
final
String
serverKey
=
UserManager
.
getUserProvider
().
loadUser
(
username
).
getServerKey
(
);
final
String
serverKey
=
AuthFactory
.
getServerKey
(
username
);
if
(
serverKey
==
null
)
{
return
null
;
}
else
{
...
...
@@ -357,7 +356,7 @@ public class ScramSha1SaslServer implements SaslServer {
* Retrieve the stored key from the database for a given username.
*/
private
byte
[]
getStoredKey
(
final
String
username
)
throws
UserNotFoundException
{
final
String
storedKey
=
UserManager
.
getUserProvider
().
loadUser
(
username
).
getStoredKey
(
);
final
String
storedKey
=
AuthFactory
.
getStoredKey
(
username
);
if
(
storedKey
==
null
)
{
return
null
;
}
else
{
...
...
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