UserDetails now indicates locked accounts.

This commit is contained in:
Ben Alex 2005-03-21 03:22:59 +00:00
parent c34db326f8
commit 6f31ecb04b
31 changed files with 405 additions and 163 deletions

View File

@ -23,11 +23,13 @@ import net.sf.acegisecurity.BadCredentialsException;
import net.sf.acegisecurity.CredentialsExpiredException; import net.sf.acegisecurity.CredentialsExpiredException;
import net.sf.acegisecurity.DisabledException; import net.sf.acegisecurity.DisabledException;
import net.sf.acegisecurity.GrantedAuthority; import net.sf.acegisecurity.GrantedAuthority;
import net.sf.acegisecurity.LockedException;
import net.sf.acegisecurity.UserDetails; import net.sf.acegisecurity.UserDetails;
import net.sf.acegisecurity.providers.AuthenticationProvider; import net.sf.acegisecurity.providers.AuthenticationProvider;
import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken; import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken;
import net.sf.acegisecurity.providers.dao.cache.NullUserCache; import net.sf.acegisecurity.providers.dao.cache.NullUserCache;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureAccountExpiredEvent; import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureAccountExpiredEvent;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureAccountLockedEvent;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureCredentialsExpiredEvent; import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureCredentialsExpiredEvent;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureDisabledEvent; import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureDisabledEvent;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailurePasswordEvent; import net.sf.acegisecurity.providers.dao.event.AuthenticationFailurePasswordEvent;
@ -232,7 +234,8 @@ public class DaoAuthenticationProvider implements AuthenticationProvider,
authentication, authentication,
new User("".equals(username) new User("".equals(username)
? "EMPTY_STRING_PROVIDED" : username, "*****", ? "EMPTY_STRING_PROVIDED" : username, "*****",
false, false, false, new GrantedAuthority[0]))); false, false, false, false,
new GrantedAuthority[0])));
} }
throw ex; throw ex;
@ -257,6 +260,15 @@ public class DaoAuthenticationProvider implements AuthenticationProvider,
throw new AccountExpiredException("User account has expired"); throw new AccountExpiredException("User account has expired");
} }
if (!user.isAccountNonLocked()) {
if (this.context != null) {
context.publishEvent(new AuthenticationFailureAccountLockedEvent(
authentication, user));
}
throw new LockedException("User account is locked");
}
if (!user.isCredentialsNonExpired()) { if (!user.isCredentialsNonExpired()) {
if (this.context != null) { if (this.context != null) {
context.publishEvent(new AuthenticationFailureCredentialsExpiredEvent( context.publishEvent(new AuthenticationFailureCredentialsExpiredEvent(

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -23,11 +23,13 @@ import net.sf.acegisecurity.BadCredentialsException;
import net.sf.acegisecurity.CredentialsExpiredException; import net.sf.acegisecurity.CredentialsExpiredException;
import net.sf.acegisecurity.DisabledException; import net.sf.acegisecurity.DisabledException;
import net.sf.acegisecurity.GrantedAuthority; import net.sf.acegisecurity.GrantedAuthority;
import net.sf.acegisecurity.LockedException;
import net.sf.acegisecurity.UserDetails; import net.sf.acegisecurity.UserDetails;
import net.sf.acegisecurity.providers.AuthenticationProvider; import net.sf.acegisecurity.providers.AuthenticationProvider;
import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken; import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken;
import net.sf.acegisecurity.providers.dao.cache.NullUserCache; import net.sf.acegisecurity.providers.dao.cache.NullUserCache;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureAccountExpiredEvent; import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureAccountExpiredEvent;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureAccountLockedEvent;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureCredentialsExpiredEvent; import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureCredentialsExpiredEvent;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureDisabledEvent; import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureDisabledEvent;
import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureUsernameOrPasswordEvent; import net.sf.acegisecurity.providers.dao.event.AuthenticationFailureUsernameOrPasswordEvent;
@ -184,7 +186,7 @@ public class PasswordDaoAuthenticationProvider implements AuthenticationProvider
context.publishEvent(new AuthenticationFailureUsernameOrPasswordEvent( context.publishEvent(new AuthenticationFailureUsernameOrPasswordEvent(
authentication, authentication,
new User(username, "*****", false, false, false, new User(username, "*****", false, false, false,
new GrantedAuthority[0]))); false, new GrantedAuthority[0])));
} }
throw ex; throw ex;
@ -209,6 +211,15 @@ public class PasswordDaoAuthenticationProvider implements AuthenticationProvider
throw new AccountExpiredException("User account has expired"); throw new AccountExpiredException("User account has expired");
} }
if (!user.isAccountNonLocked()) {
if (this.context != null) {
context.publishEvent(new AuthenticationFailureAccountLockedEvent(
authentication, user));
}
throw new LockedException("User account is locked");
}
if (!user.isCredentialsNonExpired()) { if (!user.isCredentialsNonExpired()) {
if (this.context != null) { if (this.context != null) {
context.publishEvent(new AuthenticationFailureCredentialsExpiredEvent( context.publishEvent(new AuthenticationFailureCredentialsExpiredEvent(

View File

@ -0,0 +1,36 @@
/* Copyright 2004, 2005 Acegi Technology Pty Limited
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.sf.acegisecurity.providers.dao.event;
import net.sf.acegisecurity.Authentication;
import net.sf.acegisecurity.UserDetails;
/**
* Application event which indicates authentication failure due to the user's
* account having been locked.
*
* @author Ben Alex
* @version $Id$
*/
public class AuthenticationFailureAccountLockedEvent extends AuthenticationEvent {
//~ Constructors ===========================================================
public AuthenticationFailureAccountLockedEvent(
Authentication authentication, UserDetails user) {
super(authentication, user);
}
}

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -63,6 +63,17 @@ public class LoggerListener implements ApplicationListener {
} }
} }
if (event instanceof AuthenticationFailureAccountLockedEvent) {
AuthenticationFailureAccountLockedEvent authEvent = (AuthenticationFailureAccountLockedEvent) event;
if (logger.isWarnEnabled()) {
logger.warn(
"Authentication failed due to account being locked for user: "
+ authEvent.getUser().getUsername() + "; details: "
+ authEvent.getAuthentication().getDetails());
}
}
if (event instanceof AuthenticationFailureCredentialsExpiredEvent) { if (event instanceof AuthenticationFailureCredentialsExpiredEvent) {
AuthenticationFailureCredentialsExpiredEvent authEvent = (AuthenticationFailureCredentialsExpiredEvent) event; AuthenticationFailureCredentialsExpiredEvent authEvent = (AuthenticationFailureCredentialsExpiredEvent) event;

View File

@ -38,6 +38,7 @@ public class User implements UserDetails {
private String username; private String username;
private GrantedAuthority[] authorities; private GrantedAuthority[] authorities;
private boolean accountNonExpired; private boolean accountNonExpired;
private boolean accountNonLocked;
private boolean credentialsNonExpired; private boolean credentialsNonExpired;
private boolean enabled; private boolean enabled;
@ -88,10 +89,44 @@ public class User implements UserDetails {
* @throws IllegalArgumentException if a <code>null</code> value was passed * @throws IllegalArgumentException if a <code>null</code> value was passed
* either as a parameter or as an element in the * either as a parameter or as an element in the
* <code>GrantedAuthority[]</code> array * <code>GrantedAuthority[]</code> array
*
* @deprecated use new constructor with extended properties (this
* constructor will be removed from release 1.0.0)
*/ */
public User(String username, String password, boolean enabled, public User(String username, String password, boolean enabled,
boolean accountNonExpired, boolean credentialsNonExpired, boolean accountNonExpired, boolean credentialsNonExpired,
GrantedAuthority[] authorities) throws IllegalArgumentException { GrantedAuthority[] authorities) throws IllegalArgumentException {
this(username, password, enabled, accountNonExpired,
credentialsNonExpired, true, authorities);
}
/**
* Construct the <code>User</code> with the details required by {@link
* DaoAuthenticationProvider}.
*
* @param username the username presented to the
* <code>DaoAuthenticationProvider</code>
* @param password the password that should be presented to the
* <code>DaoAuthenticationProvider</code>
* @param enabled set to <code>true</code> if the user is enabled
* @param accountNonExpired set to <code>true</code> if the account has not
* expired
* @param credentialsNonExpired set to <code>true</code> if the credentials
* have not expired
* @param accountNonLocked set to <code>true</code> if the account is not
* locked
* @param authorities the authorities that should be granted to the caller
* if they presented the correct username and password and the user
* is enabled
*
* @throws IllegalArgumentException if a <code>null</code> value was passed
* either as a parameter or as an element in the
* <code>GrantedAuthority[]</code> array
*/
public User(String username, String password, boolean enabled,
boolean accountNonExpired, boolean credentialsNonExpired,
boolean accountNonLocked, GrantedAuthority[] authorities)
throws IllegalArgumentException {
if (((username == null) || "".equals(username)) || (password == null) if (((username == null) || "".equals(username)) || (password == null)
|| (authorities == null)) { || (authorities == null)) {
throw new IllegalArgumentException( throw new IllegalArgumentException(
@ -112,6 +147,7 @@ public class User implements UserDetails {
this.authorities = authorities; this.authorities = authorities;
this.accountNonExpired = accountNonExpired; this.accountNonExpired = accountNonExpired;
this.credentialsNonExpired = credentialsNonExpired; this.credentialsNonExpired = credentialsNonExpired;
this.accountNonLocked = accountNonLocked;
} }
protected User() { protected User() {
@ -124,6 +160,10 @@ public class User implements UserDetails {
return accountNonExpired; return accountNonExpired;
} }
public boolean isAccountNonLocked() {
return this.accountNonLocked;
}
public GrantedAuthority[] getAuthorities() { public GrantedAuthority[] getAuthorities() {
return authorities; return authorities;
} }

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -53,6 +53,15 @@ public interface UserDetails extends Serializable {
*/ */
public boolean isAccountNonExpired(); public boolean isAccountNonExpired();
/**
* Indicates whether the user is locked or unlocked. A locked user cannot
* be authenticated.
*
* @return <code>true</code> if the user is not locked, <code>false</code>
* otherwise
*/
public boolean isAccountNonLocked();
/** /**
* Returns the authorities granted to the user. Cannot return * Returns the authorities granted to the user. Cannot return
* <code>null</code>. * <code>null</code>.

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -192,7 +192,7 @@ public class JdbcDaoImpl extends JdbcDaoSupport implements AuthenticationDao {
arrayAuths = (GrantedAuthority[]) dbAuths.toArray(arrayAuths); arrayAuths = (GrantedAuthority[]) dbAuths.toArray(arrayAuths);
return new User(user.getUsername(), user.getPassword(), return new User(user.getUsername(), user.getPassword(),
user.isEnabled(), true, true, arrayAuths); user.isEnabled(), true, true, true, arrayAuths);
} }
/** /**
@ -256,7 +256,7 @@ public class JdbcDaoImpl extends JdbcDaoSupport implements AuthenticationDao {
String password = rs.getString(2); String password = rs.getString(2);
boolean enabled = rs.getBoolean(3); boolean enabled = rs.getBoolean(3);
UserDetails user = new User(username, password, enabled, true, UserDetails user = new User(username, password, enabled, true,
true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("HOLDER")}); new GrantedAuthority[] {new GrantedAuthorityImpl("HOLDER")});
return user; return user;

View File

@ -96,7 +96,8 @@ public class UserMapEditor extends PropertyEditorSupport {
// Make a user object, assuming the properties were properly provided // Make a user object, assuming the properties were properly provided
if (attr != null) { if (attr != null) {
UserDetails user = new User(username, attr.getPassword(), UserDetails user = new User(username, attr.getPassword(),
attr.isEnabled(), true, true, attr.getAuthorities()); attr.isEnabled(), true, true, true,
attr.getAuthorities());
userMap.addUser(user); userMap.addUser(user);
} }
} }

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -55,7 +55,7 @@ public class GrantedAuthorityEffectiveAclsResolverTests extends TestCase {
.getPrincipal(), new NamedEntityObjectIdentity("OBJECT", "100"), .getPrincipal(), new NamedEntityObjectIdentity("OBJECT", "100"),
null, 2); null, 2);
private UsernamePasswordAuthenticationToken scottWithUserDetails = new UsernamePasswordAuthenticationToken(new User( private UsernamePasswordAuthenticationToken scottWithUserDetails = new UsernamePasswordAuthenticationToken(new User(
"scott", "NOT_USED", true, true, true, "scott", "NOT_USED", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl(
"ROLE_EVERYBODY")}), "not used", "ROLE_EVERYBODY")}), "not used",
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_EVERYBODY"), new GrantedAuthorityImpl("ROLE_TWO")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_EVERYBODY"), new GrantedAuthorityImpl("ROLE_TWO")});

View File

@ -16,12 +16,14 @@
package net.sf.acegisecurity.providers; package net.sf.acegisecurity.providers;
import junit.framework.TestCase; import junit.framework.TestCase;
import net.sf.acegisecurity.*; import net.sf.acegisecurity.*;
import net.sf.acegisecurity.providers.anonymous.AnonymousAuthenticationToken; import net.sf.acegisecurity.providers.anonymous.AnonymousAuthenticationToken;
import net.sf.acegisecurity.providers.dao.User; import net.sf.acegisecurity.providers.dao.User;
import net.sf.acegisecurity.ui.WebAuthenticationDetails; import net.sf.acegisecurity.ui.WebAuthenticationDetails;
import net.sf.acegisecurity.ui.session.HttpSessionCreatedEvent; import net.sf.acegisecurity.ui.session.HttpSessionCreatedEvent;
import net.sf.acegisecurity.ui.session.HttpSessionDestroyedEvent; import net.sf.acegisecurity.ui.session.HttpSessionDestroyedEvent;
import org.springframework.context.ApplicationListener; import org.springframework.context.ApplicationListener;
import java.security.Principal; import java.security.Principal;
@ -39,8 +41,17 @@ public class ConcurrentSessionControllerImplTests extends TestCase {
//~ Methods ================================================================ //~ Methods ================================================================
public void testAnonymous() throws Exception {
AnonymousAuthenticationToken auth = new AnonymousAuthenticationToken("blah",
"anon",
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ANON")});
target.beforeAuthentication(auth);
target.afterAuthentication(auth, auth);
}
public void testBumpCoverage() throws Exception { public void testBumpCoverage() throws Exception {
target.onApplicationEvent(new HttpSessionCreatedEvent(new MockHttpSession())); target.onApplicationEvent(new HttpSessionCreatedEvent(
new MockHttpSession()));
} }
public void testEnforcementKnownGood() throws Exception { public void testEnforcementKnownGood() throws Exception {
@ -63,7 +74,8 @@ public class ConcurrentSessionControllerImplTests extends TestCase {
try { try {
auth = createAuthentication("user", "password", "lastsession"); auth = createAuthentication("user", "password", "lastsession");
target.beforeAuthentication(auth); target.beforeAuthentication(auth);
fail("Only allowed 5 sessions, this should have thrown a ConcurrentLoginException"); fail(
"Only allowed 5 sessions, this should have thrown a ConcurrentLoginException");
} catch (ConcurrentLoginException e) { } catch (ConcurrentLoginException e) {
assertTrue(e.getMessage().startsWith(auth.getPrincipal().toString())); assertTrue(e.getMessage().startsWith(auth.getPrincipal().toString()));
} }
@ -81,9 +93,9 @@ public class ConcurrentSessionControllerImplTests extends TestCase {
try { try {
target.beforeAuthentication(createAuthentication("user", target.beforeAuthentication(createAuthentication("user",
"password", "session2")); "password", "session2"));
fail("Only allowed 1 session, this should have thrown a ConcurrentLoginException"); fail(
} catch (ConcurrentLoginException e) { "Only allowed 1 session, this should have thrown a ConcurrentLoginException");
} } catch (ConcurrentLoginException e) {}
} }
public void testEnforcementUnlimitedSameSession() throws Exception { public void testEnforcementUnlimitedSameSession() throws Exception {
@ -129,6 +141,11 @@ public class ConcurrentSessionControllerImplTests extends TestCase {
target.afterAuthentication(different, different); target.afterAuthentication(different, different);
} }
public void testImplementsApplicationListener() throws Exception {
assertTrue("This class must implement ApplicationListener, and at one point it didn't.",
target instanceof ApplicationListener);
}
public void testNonWebDetails() throws Exception { public void testNonWebDetails() throws Exception {
UsernamePasswordAuthenticationToken auth = new UsernamePasswordAuthenticationToken("asdf", UsernamePasswordAuthenticationToken auth = new UsernamePasswordAuthenticationToken("asdf",
"asdf"); "asdf");
@ -141,7 +158,7 @@ public class ConcurrentSessionControllerImplTests extends TestCase {
target.setMaxSessions(1); target.setMaxSessions(1);
final UserDetails user = new User("user", "password", true, true, true, final UserDetails user = new User("user", "password", true, true, true,
new GrantedAuthority[0]); true, new GrantedAuthority[0]);
final UsernamePasswordAuthenticationToken auth = new UsernamePasswordAuthenticationToken(user, final UsernamePasswordAuthenticationToken auth = new UsernamePasswordAuthenticationToken(user,
"password", user.getAuthorities()); "password", user.getAuthorities());
auth.setDetails(createWebDetails(auth, "session1")); auth.setDetails(createWebDetails(auth, "session1"));
@ -162,9 +179,9 @@ public class ConcurrentSessionControllerImplTests extends TestCase {
otherAuth.setDetails(createWebDetails(otherAuth, "session2")); otherAuth.setDetails(createWebDetails(otherAuth, "session2"));
target.beforeAuthentication(otherAuth); target.beforeAuthentication(otherAuth);
fail("Same principal, different principal type, different session should have thrown ConcurrentLoginException"); fail(
} catch (ConcurrentLoginException e) { "Same principal, different principal type, different session should have thrown ConcurrentLoginException");
} } catch (ConcurrentLoginException e) {}
} }
public void testSetMax() throws Exception { public void testSetMax() throws Exception {
@ -236,14 +253,4 @@ public class ConcurrentSessionControllerImplTests extends TestCase {
return new WebAuthenticationDetails(request); return new WebAuthenticationDetails(request);
} }
public void testAnonymous() throws Exception {
AnonymousAuthenticationToken auth = new AnonymousAuthenticationToken("blah", "anon", new GrantedAuthority[]{new GrantedAuthorityImpl("ROLE_ANON")});
target.beforeAuthentication(auth);
target.afterAuthentication(auth, auth);
}
public void testImplementsApplicationListener() throws Exception {
assertTrue("This class must implement ApplicationListener, and at one point it didn't.", target instanceof ApplicationListener);
}
} }

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -327,7 +327,7 @@ public class CasAuthenticationProviderTests extends TestCase {
} }
private UserDetails makeUserDetails() { private UserDetails makeUserDetails() {
return new User("user", "password", true, true, true, return new User("user", "password", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} }
@ -337,7 +337,7 @@ public class CasAuthenticationProviderTests extends TestCase {
private class MockAuthoritiesPopulator implements CasAuthoritiesPopulator { private class MockAuthoritiesPopulator implements CasAuthoritiesPopulator {
public UserDetails getUserDetails(String casUserId) public UserDetails getUserDetails(String casUserId)
throws AuthenticationException { throws AuthenticationException {
return new User("user", "password", true, true, true, return new User("user", "password", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_A"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_A"), new GrantedAuthorityImpl(
"ROLE_B")}); "ROLE_B")});
} }

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -319,7 +319,7 @@ public class CasAuthenticationTokenTests extends TestCase {
} }
private UserDetails makeUserDetails() { private UserDetails makeUserDetails() {
return new User("user", "password", true, true, true, return new User("user", "password", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} }

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -102,7 +102,7 @@ public class EhCacheBasedTicketCacheTests extends TestCase {
List proxyList = new Vector(); List proxyList = new Vector();
proxyList.add("https://localhost/newPortal/j_acegi_cas_security_check"); proxyList.add("https://localhost/newPortal/j_acegi_cas_security_check");
User user = new User("marissa", "password", true, true, true, User user = new User("marissa", "password", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -139,7 +139,7 @@ public class DaoCasAuthoritiesPopulatorTests extends TestCase {
public UserDetails loadUserByUsername(String username) public UserDetails loadUserByUsername(String username)
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("marissa".equals(username)) { if ("marissa".equals(username)) {
return new User("marissa", "koala", true, true, true, return new User("marissa", "koala", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -25,6 +25,7 @@ import net.sf.acegisecurity.CredentialsExpiredException;
import net.sf.acegisecurity.DisabledException; import net.sf.acegisecurity.DisabledException;
import net.sf.acegisecurity.GrantedAuthority; import net.sf.acegisecurity.GrantedAuthority;
import net.sf.acegisecurity.GrantedAuthorityImpl; import net.sf.acegisecurity.GrantedAuthorityImpl;
import net.sf.acegisecurity.LockedException;
import net.sf.acegisecurity.UserDetails; import net.sf.acegisecurity.UserDetails;
import net.sf.acegisecurity.providers.TestingAuthenticationToken; import net.sf.acegisecurity.providers.TestingAuthenticationToken;
import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken; import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken;
@ -103,6 +104,32 @@ public class DaoAuthenticationProviderTests extends TestCase {
} }
} }
public void testAuthenticateFailsIfAccountLocked() {
UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken("peter",
"opal");
DaoAuthenticationProvider provider = new DaoAuthenticationProvider();
provider.setAuthenticationDao(new MockAuthenticationDaoUserPeterAccountLocked());
provider.setUserCache(new MockUserCache());
try {
provider.authenticate(token);
fail("Should have thrown LockedException");
} catch (LockedException expected) {
assertTrue(true);
}
provider.setApplicationContext(new ClassPathXmlApplicationContext(
"net/sf/acegisecurity/util/filtertest-valid.xml"));
try {
provider.authenticate(token);
fail("Should have thrown CredentialsExpiredException");
} catch (LockedException expected) {
assertTrue(true);
}
}
public void testAuthenticateFailsIfCredentialsExpired() { public void testAuthenticateFailsIfCredentialsExpired() {
UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken("peter", UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken("peter",
"opal"); "opal");
@ -492,7 +519,7 @@ public class DaoAuthenticationProviderTests extends TestCase {
public UserDetails loadUserByUsername(String username) public UserDetails loadUserByUsername(String username)
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("marissa".equals(username)) { if ("marissa".equals(username)) {
return new User("marissa", password, true, true, true, return new User("marissa", password, true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {
@ -508,7 +535,7 @@ public class DaoAuthenticationProviderTests extends TestCase {
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("marissa".equals(username)) { if ("marissa".equals(username)) {
return new User("marissa", "koala{SYSTEM_SALT_VALUE}", true, return new User("marissa", "koala{SYSTEM_SALT_VALUE}", true,
true, true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {
@ -522,7 +549,7 @@ public class DaoAuthenticationProviderTests extends TestCase {
public UserDetails loadUserByUsername(String username) public UserDetails loadUserByUsername(String username)
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("peter".equals(username)) { if ("peter".equals(username)) {
return new User("peter", "opal", false, true, true, return new User("peter", "opal", false, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {
@ -537,7 +564,22 @@ public class DaoAuthenticationProviderTests extends TestCase {
public UserDetails loadUserByUsername(String username) public UserDetails loadUserByUsername(String username)
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("peter".equals(username)) { if ("peter".equals(username)) {
return new User("peter", "opal", true, false, true, return new User("peter", "opal", true, false, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")});
} else {
throw new UsernameNotFoundException("Could not find: "
+ username);
}
}
}
private class MockAuthenticationDaoUserPeterAccountLocked
implements AuthenticationDao {
public UserDetails loadUserByUsername(String username)
throws UsernameNotFoundException, DataAccessException {
if ("peter".equals(username)) {
return new User("peter", "opal", true, true, true, false,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {
@ -552,7 +594,7 @@ public class DaoAuthenticationProviderTests extends TestCase {
public UserDetails loadUserByUsername(String username) public UserDetails loadUserByUsername(String username)
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("peter".equals(username)) { if ("peter".equals(username)) {
return new User("peter", "opal", true, true, false, return new User("peter", "opal", true, true, false, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -25,6 +25,7 @@ import net.sf.acegisecurity.CredentialsExpiredException;
import net.sf.acegisecurity.DisabledException; import net.sf.acegisecurity.DisabledException;
import net.sf.acegisecurity.GrantedAuthority; import net.sf.acegisecurity.GrantedAuthority;
import net.sf.acegisecurity.GrantedAuthorityImpl; import net.sf.acegisecurity.GrantedAuthorityImpl;
import net.sf.acegisecurity.LockedException;
import net.sf.acegisecurity.UserDetails; import net.sf.acegisecurity.UserDetails;
import net.sf.acegisecurity.providers.TestingAuthenticationToken; import net.sf.acegisecurity.providers.TestingAuthenticationToken;
import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken; import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken;
@ -98,6 +99,32 @@ public class PasswordDaoAuthenticationProviderTests extends TestCase {
} }
} }
public void testAuthenticateFailsIfAccountLocked() {
UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken("peter",
"opal");
PasswordDaoAuthenticationProvider provider = new PasswordDaoAuthenticationProvider();
provider.setPasswordAuthenticationDao(new MockAuthenticationDaoUserPeterAccountLocked());
provider.setUserCache(new MockUserCache());
try {
provider.authenticate(token);
fail("Should have thrown AccountExpiredException");
} catch (LockedException expected) {
assertTrue(true);
}
provider.setApplicationContext(new ClassPathXmlApplicationContext(
"net/sf/acegisecurity/util/filtertest-valid.xml"));
try {
provider.authenticate(token);
fail("Should have thrown AccountExpiredException");
} catch (LockedException expected) {
assertTrue(true);
}
}
public void testAuthenticateFailsIfCredentialsExpired() { public void testAuthenticateFailsIfCredentialsExpired() {
UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken("peter", UsernamePasswordAuthenticationToken token = new UsernamePasswordAuthenticationToken("peter",
"opal"); "opal");
@ -346,7 +373,7 @@ public class PasswordDaoAuthenticationProviderTests extends TestCase {
String password) String password)
throws BadCredentialsException, DataAccessException { throws BadCredentialsException, DataAccessException {
if ("marissa".equals(username) && "koala".equals(password)) { if ("marissa".equals(username) && "koala".equals(password)) {
return new User("marissa", "koala", true, true, true, return new User("marissa", "koala", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {
@ -361,7 +388,7 @@ public class PasswordDaoAuthenticationProviderTests extends TestCase {
String password) String password)
throws BadCredentialsException, DataAccessException { throws BadCredentialsException, DataAccessException {
if ("peter".equals(username) && "opal".equals(password)) { if ("peter".equals(username) && "opal".equals(password)) {
return new User("peter", "opal", false, true, true, return new User("peter", "opal", false, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {
@ -376,7 +403,23 @@ public class PasswordDaoAuthenticationProviderTests extends TestCase {
String password) String password)
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("peter".equals(username)) { if ("peter".equals(username)) {
return new User("peter", "opal", true, false, true, return new User("peter", "opal", true, false, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")});
} else {
throw new UsernameNotFoundException("Could not find: "
+ username);
}
}
}
private class MockAuthenticationDaoUserPeterAccountLocked
implements PasswordAuthenticationDao {
public UserDetails loadUserByUsernameAndPassword(String username,
String password)
throws UsernameNotFoundException, DataAccessException {
if ("peter".equals(username)) {
return new User("peter", "opal", true, true, true, false,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {
@ -392,7 +435,7 @@ public class PasswordDaoAuthenticationProviderTests extends TestCase {
String password) String password)
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("peter".equals(username)) { if ("peter".equals(username)) {
return new User("peter", "opal", true, true, false, return new User("peter", "opal", true, true, false, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} else { } else {

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -60,7 +60,7 @@ public class UserTests extends TestCase {
public void testNullValuesRejected() throws Exception { public void testNullValuesRejected() throws Exception {
try { try {
UserDetails user = new User(null, "koala", true, true, true, UserDetails user = new User(null, "koala", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
fail("Should have thrown IllegalArgumentException"); fail("Should have thrown IllegalArgumentException");
@ -70,6 +70,7 @@ public class UserTests extends TestCase {
try { try {
UserDetails user = new User("marissa", null, true, true, true, UserDetails user = new User("marissa", null, true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
fail("Should have thrown IllegalArgumentException"); fail("Should have thrown IllegalArgumentException");
@ -79,7 +80,7 @@ public class UserTests extends TestCase {
try { try {
UserDetails user = new User("marissa", "koala", true, true, true, UserDetails user = new User("marissa", "koala", true, true, true,
null); true, null);
fail("Should have thrown IllegalArgumentException"); fail("Should have thrown IllegalArgumentException");
} catch (IllegalArgumentException expected) { } catch (IllegalArgumentException expected) {
assertTrue(true); assertTrue(true);
@ -87,6 +88,7 @@ public class UserTests extends TestCase {
try { try {
UserDetails user = new User("marissa", "koala", true, true, true, UserDetails user = new User("marissa", "koala", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), null}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), null});
fail("Should have thrown IllegalArgumentException"); fail("Should have thrown IllegalArgumentException");
} catch (IllegalArgumentException expected) { } catch (IllegalArgumentException expected) {
@ -97,7 +99,7 @@ public class UserTests extends TestCase {
public void testNullWithinGrantedAuthorityElementIsRejected() public void testNullWithinGrantedAuthorityElementIsRejected()
throws Exception { throws Exception {
try { try {
UserDetails user = new User(null, "koala", true, true, true, UserDetails user = new User(null, "koala", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO"), null, new GrantedAuthorityImpl( "ROLE_TWO"), null, new GrantedAuthorityImpl(
"ROLE_THREE")}); "ROLE_THREE")});
@ -108,7 +110,7 @@ public class UserTests extends TestCase {
} }
public void testUserGettersSetter() throws Exception { public void testUserGettersSetter() throws Exception {
UserDetails user = new User("marissa", "koala", true, true, true, UserDetails user = new User("marissa", "koala", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
assertEquals("marissa", user.getUsername()); assertEquals("marissa", user.getUsername());
@ -122,6 +124,7 @@ public class UserTests extends TestCase {
public void testUserIsEnabled() throws Exception { public void testUserIsEnabled() throws Exception {
UserDetails user = new User("marissa", "koala", false, true, true, UserDetails user = new User("marissa", "koala", false, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
assertTrue(!user.isEnabled()); assertTrue(!user.isEnabled());

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -95,7 +95,7 @@ public class EhCacheBasedUserCacheTests extends TestCase {
} }
private User getUser() { private User getUser() {
return new User("john", "password", true, true, true, return new User("john", "password", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} }

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -57,7 +57,7 @@ public class NullUserCacheTests extends TestCase {
} }
private User getUser() { private User getUser() {
return new User("john", "password", true, true, true, return new User("john", "password", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
} }

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -97,7 +97,7 @@ public class AuthenticationEventTests extends TestCase {
} }
private User getUser() { private User getUser() {
User user = new User("foo", "bar", true, true, true, User user = new User("foo", "bar", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_FOOBAR")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_FOOBAR")});
return user; return user;

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -90,7 +90,7 @@ public class LoggerListenerTests extends TestCase {
} }
private User getUser() { private User getUser() {
User user = new User("foo", "bar", true, true, true, User user = new User("foo", "bar", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_FOOBAR")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_FOOBAR")});
return user; return user;

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -53,12 +53,13 @@ public class UserMapTests extends TestCase {
public void testAddAndRetrieveUser() { public void testAddAndRetrieveUser() {
UserDetails marissa = new User("marissa", "koala", true, true, true, UserDetails marissa = new User("marissa", "koala", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
UserDetails scott = new User("scott", "wombat", true, true, true, UserDetails scott = new User("scott", "wombat", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_THREE")}); "ROLE_THREE")});
UserDetails peter = new User("peter", "opal", true, true, true, UserDetails peter = new User("peter", "opal", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_FOUR")}); "ROLE_FOUR")});
UserMap map = new UserMap(); UserMap map = new UserMap();
@ -86,6 +87,7 @@ public class UserMapTests extends TestCase {
public void testUnknownUserIsNotRetrieved() { public void testUnknownUserIsNotRetrieved() {
UserDetails marissa = new User("marissa", "koala", true, true, true, UserDetails marissa = new User("marissa", "koala", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE"), new GrantedAuthorityImpl(
"ROLE_TWO")}); "ROLE_TWO")});
UserMap map = new UserMap(); UserMap map = new UserMap();

View File

@ -1,4 +1,4 @@
/* Copyright 2004 Acegi Technology Pty Limited /* Copyright 2004, 2005 Acegi Technology Pty Limited
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -67,7 +67,7 @@ public class ReflectionSaltSourceTests extends TestCase {
ReflectionSaltSource saltSource = new ReflectionSaltSource(); ReflectionSaltSource saltSource = new ReflectionSaltSource();
saltSource.setUserPropertyToUse("getDoesNotExist"); saltSource.setUserPropertyToUse("getDoesNotExist");
UserDetails user = new User("scott", "wombat", true, true, true, UserDetails user = new User("scott", "wombat", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("HOLDER")}); new GrantedAuthority[] {new GrantedAuthorityImpl("HOLDER")});
try { try {
@ -89,7 +89,7 @@ public class ReflectionSaltSourceTests extends TestCase {
saltSource.setUserPropertyToUse("getUsername"); saltSource.setUserPropertyToUse("getUsername");
saltSource.afterPropertiesSet(); saltSource.afterPropertiesSet();
UserDetails user = new User("scott", "wombat", true, true, true, UserDetails user = new User("scott", "wombat", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("HOLDER")}); new GrantedAuthority[] {new GrantedAuthorityImpl("HOLDER")});
assertEquals("scott", saltSource.getSalt(user)); assertEquals("scott", saltSource.getSalt(user));
} }

View File

@ -16,12 +16,14 @@
package net.sf.acegisecurity.providers.x509; package net.sf.acegisecurity.providers.x509;
import junit.framework.TestCase; import junit.framework.TestCase;
import net.sf.acegisecurity.*; import net.sf.acegisecurity.*;
import net.sf.acegisecurity.providers.dao.User;
import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken; import net.sf.acegisecurity.providers.UsernamePasswordAuthenticationToken;
import net.sf.acegisecurity.providers.dao.User;
import java.security.cert.X509Certificate; import java.security.cert.X509Certificate;
/** /**
* Tests {@link net.sf.acegisecurity.providers.x509.X509AuthenticationProvider} * Tests {@link net.sf.acegisecurity.providers.x509.X509AuthenticationProvider}
* *
@ -45,17 +47,28 @@ public class X509AuthenticationProviderTests extends TestCase {
super.setUp(); super.setUp();
} }
public void testRequiresPopulator() throws Exception { public void testAuthenticationIsNullWithUnsupportedToken() {
X509AuthenticationProvider provider = new X509AuthenticationProvider(); X509AuthenticationProvider provider = new X509AuthenticationProvider();
Authentication request = new UsernamePasswordAuthenticationToken("dummy",
"dummy");
Authentication result = provider.authenticate(request);
assertNull(result);
}
public void testFailsWithNullCertificate() {
X509AuthenticationProvider provider = new X509AuthenticationProvider();
provider.setX509AuthoritiesPopulator(new MockAuthoritiesPopulator(false));
try { try {
provider.afterPropertiesSet(); provider.authenticate(new X509AuthenticationToken(null));
fail("Should have thrown IllegalArgumentException"); fail("Should have thrown BadCredentialsException");
} catch (IllegalArgumentException failed) { } catch (BadCredentialsException e) {
//ignored //ignore
} }
} }
public void testNormalOperation () throws Exception { public void testNormalOperation() throws Exception {
X509AuthenticationProvider provider = new X509AuthenticationProvider(); X509AuthenticationProvider provider = new X509AuthenticationProvider();
provider.setX509AuthoritiesPopulator(new MockAuthoritiesPopulator(false)); provider.setX509AuthoritiesPopulator(new MockAuthoritiesPopulator(false));
@ -67,56 +80,48 @@ public class X509AuthenticationProviderTests extends TestCase {
assertNotNull(result.getAuthorities()); assertNotNull(result.getAuthorities());
} }
public void testFailsWithNullCertificate() {
X509AuthenticationProvider provider = new X509AuthenticationProvider();
provider.setX509AuthoritiesPopulator(new MockAuthoritiesPopulator(false));
try {
provider.authenticate(new X509AuthenticationToken(null));
fail("Should have thrown BadCredentialsException");
} catch(BadCredentialsException e) {
//ignore
}
}
public void testPopulatorRejectionCausesFailure() throws Exception { public void testPopulatorRejectionCausesFailure() throws Exception {
X509AuthenticationProvider provider = new X509AuthenticationProvider(); X509AuthenticationProvider provider = new X509AuthenticationProvider();
provider.setX509AuthoritiesPopulator(new MockAuthoritiesPopulator(true)); provider.setX509AuthoritiesPopulator(new MockAuthoritiesPopulator(true));
try { try {
provider.authenticate(X509TestUtils.createToken()); provider.authenticate(X509TestUtils.createToken());
fail("Should have thrown BadCredentialsException"); fail("Should have thrown BadCredentialsException");
} catch(BadCredentialsException e) { } catch (BadCredentialsException e) {
//ignore //ignore
} }
} }
public void testAuthenticationIsNullWithUnsupportedToken() { public void testRequiresPopulator() throws Exception {
X509AuthenticationProvider provider = new X509AuthenticationProvider(); X509AuthenticationProvider provider = new X509AuthenticationProvider();
Authentication request = new UsernamePasswordAuthenticationToken("dummy","dummy");
Authentication result = provider.authenticate(request); try {
assertNull(result); provider.afterPropertiesSet();
fail("Should have thrown IllegalArgumentException");
} catch (IllegalArgumentException failed) {
//ignored
}
} }
//~ Inner Classes ========================================================== //~ Inner Classes ==========================================================
public static class MockAuthoritiesPopulator implements X509AuthoritiesPopulator { public static class MockAuthoritiesPopulator
implements X509AuthoritiesPopulator {
private boolean rejectCertificate; private boolean rejectCertificate;
public MockAuthoritiesPopulator(boolean rejectCertificate) { public MockAuthoritiesPopulator(boolean rejectCertificate) {
this.rejectCertificate = rejectCertificate; this.rejectCertificate = rejectCertificate;
} }
public UserDetails getUserDetails(X509Certificate userCertificate) throws AuthenticationException { public UserDetails getUserDetails(X509Certificate userCertificate)
if(rejectCertificate) { throws AuthenticationException {
if (rejectCertificate) {
throw new BadCredentialsException("Invalid Certificate"); throw new BadCredentialsException("Invalid Certificate");
} }
return new User ("user", "password", true, true, true, return new User("user", "password", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_A"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_A"), new GrantedAuthorityImpl(
"ROLE_B")}); "ROLE_B")});
} }
} }
} }

View File

@ -17,22 +17,23 @@ package net.sf.acegisecurity.providers.x509;
import junit.framework.TestCase; import junit.framework.TestCase;
import java.security.cert.X509Certificate;
import java.security.cert.CertificateFactory;
import java.io.ByteArrayInputStream;
/** /**
* DOCUMENT ME!
*
* @author Luke Taylor * @author Luke Taylor
*/ */
public class X509AuthenticationTokenTests extends TestCase { public class X509AuthenticationTokenTests extends TestCase {
//~ Constructors ===========================================================
public X509AuthenticationTokenTests() { public X509AuthenticationTokenTests() {}
}
public X509AuthenticationTokenTests(String s) { public X509AuthenticationTokenTests(String s) {
super(s); super(s);
} }
//~ Methods ================================================================
public void setUp() throws Exception { public void setUp() throws Exception {
super.setUp(); super.setUp();
} }
@ -44,4 +45,3 @@ public class X509AuthenticationTokenTests extends TestCase {
assertTrue(token.isAuthenticated()); assertTrue(token.isAuthenticated());
} }
} }

View File

@ -16,19 +16,24 @@
package net.sf.acegisecurity.providers.x509.populator; package net.sf.acegisecurity.providers.x509.populator;
import junit.framework.TestCase; import junit.framework.TestCase;
import net.sf.acegisecurity.providers.dao.AuthenticationDao;
import net.sf.acegisecurity.providers.dao.UsernameNotFoundException; import net.sf.acegisecurity.BadCredentialsException;
import net.sf.acegisecurity.providers.dao.User;
import net.sf.acegisecurity.providers.x509.X509TestUtils;
import net.sf.acegisecurity.UserDetails;
import net.sf.acegisecurity.GrantedAuthority; import net.sf.acegisecurity.GrantedAuthority;
import net.sf.acegisecurity.GrantedAuthorityImpl; import net.sf.acegisecurity.GrantedAuthorityImpl;
import net.sf.acegisecurity.BadCredentialsException; import net.sf.acegisecurity.UserDetails;
import net.sf.acegisecurity.providers.dao.AuthenticationDao;
import net.sf.acegisecurity.providers.dao.User;
import net.sf.acegisecurity.providers.dao.UsernameNotFoundException;
import net.sf.acegisecurity.providers.x509.X509TestUtils;
import org.springframework.dao.DataAccessException; import org.springframework.dao.DataAccessException;
import java.security.cert.X509Certificate; import java.security.cert.X509Certificate;
/** /**
* DOCUMENT ME!
*
* @author Luke Taylor * @author Luke Taylor
*/ */
public class DaoX509AuthoritiesPopulatorTests extends TestCase { public class DaoX509AuthoritiesPopulatorTests extends TestCase {
@ -48,29 +53,7 @@ public class DaoX509AuthoritiesPopulatorTests extends TestCase {
super.setUp(); super.setUp();
} }
public void testRequiresDao() throws Exception { public void testDefaultCNPatternMatch() throws Exception {
DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator();
try {
populator.afterPropertiesSet();
fail("Should have thrown IllegalArgumentException");
} catch(IllegalArgumentException failed) {
// ignored
}
}
public void testInvalidRegexFails() throws Exception {
DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator();
populator.setAuthenticationDao(new MockAuthenticationDaoMatchesNameOrEmail());
populator.setSubjectDNRegex("CN=(.*?,"); // missing closing bracket on group
try {
populator.afterPropertiesSet();
fail("Should have thrown IllegalArgumentException");
} catch(IllegalArgumentException failed) {
// ignored
}
}
public void testDefaultCNPatternMatch() throws Exception{
X509Certificate cert = X509TestUtils.buildTestCertificate(); X509Certificate cert = X509TestUtils.buildTestCertificate();
DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator(); DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator();
@ -79,7 +62,7 @@ public class DaoX509AuthoritiesPopulatorTests extends TestCase {
populator.getUserDetails(cert); populator.getUserDetails(cert);
} }
public void testEmailPatternMatch() throws Exception{ public void testEmailPatternMatch() throws Exception {
X509Certificate cert = X509TestUtils.buildTestCertificate(); X509Certificate cert = X509TestUtils.buildTestCertificate();
DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator(); DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator();
@ -89,17 +72,15 @@ public class DaoX509AuthoritiesPopulatorTests extends TestCase {
populator.getUserDetails(cert); populator.getUserDetails(cert);
} }
public void testPatternWithNoGroupFails() throws Exception { public void testInvalidRegexFails() throws Exception {
X509Certificate cert = X509TestUtils.buildTestCertificate();
DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator(); DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator();
populator.setAuthenticationDao(new MockAuthenticationDaoMatchesNameOrEmail()); populator.setAuthenticationDao(new MockAuthenticationDaoMatchesNameOrEmail());
populator.setSubjectDNRegex("CN=.*?,"); populator.setSubjectDNRegex("CN=(.*?,"); // missing closing bracket on group
populator.afterPropertiesSet();
try { try {
populator.getUserDetails(cert); populator.afterPropertiesSet();
fail("Should have thrown IllegalArgumentException for regexp without group"); fail("Should have thrown IllegalArgumentException");
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException failed) {
// ignored // ignored
} }
} }
@ -111,6 +92,7 @@ public class DaoX509AuthoritiesPopulatorTests extends TestCase {
populator.setAuthenticationDao(new MockAuthenticationDaoMatchesNameOrEmail()); populator.setAuthenticationDao(new MockAuthenticationDaoMatchesNameOrEmail());
populator.setSubjectDNRegex("shoeSize=(.*?),"); populator.setSubjectDNRegex("shoeSize=(.*?),");
populator.afterPropertiesSet(); populator.afterPropertiesSet();
try { try {
populator.getUserDetails(cert); populator.getUserDetails(cert);
fail("Should have thrown BadCredentialsException."); fail("Should have thrown BadCredentialsException.");
@ -119,13 +101,43 @@ public class DaoX509AuthoritiesPopulatorTests extends TestCase {
} }
} }
//~ Inner Classes ========================================================== public void testPatternWithNoGroupFails() throws Exception {
private class MockAuthenticationDaoMatchesNameOrEmail implements AuthenticationDao { X509Certificate cert = X509TestUtils.buildTestCertificate();
DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator();
populator.setAuthenticationDao(new MockAuthenticationDaoMatchesNameOrEmail());
populator.setSubjectDNRegex("CN=.*?,");
populator.afterPropertiesSet();
try {
populator.getUserDetails(cert);
fail(
"Should have thrown IllegalArgumentException for regexp without group");
} catch (IllegalArgumentException e) {
// ignored
}
}
public void testRequiresDao() throws Exception {
DaoX509AuthoritiesPopulator populator = new DaoX509AuthoritiesPopulator();
try {
populator.afterPropertiesSet();
fail("Should have thrown IllegalArgumentException");
} catch (IllegalArgumentException failed) {
// ignored
}
}
//~ Inner Classes ==========================================================
private class MockAuthenticationDaoMatchesNameOrEmail
implements AuthenticationDao {
public UserDetails loadUserByUsername(String username) public UserDetails loadUserByUsername(String username)
throws UsernameNotFoundException, DataAccessException { throws UsernameNotFoundException, DataAccessException {
if ("Luke Taylor".equals(username) || "luke@monkeymachine".equals(username)) { if ("Luke Taylor".equals(username)
return new User("luke", "monkey", true, true, true, || "luke@monkeymachine".equals(username)) {
return new User("luke", "monkey", true, true, true, true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ONE")});
} else { } else {
throw new UsernameNotFoundException("Could not find: " throw new UsernameNotFoundException("Could not find: "

View File

@ -77,7 +77,7 @@ public class AuthenticationTagTests extends TestCase {
public void testOperationWhenPrincipalIsAUserDetailsInstance() public void testOperationWhenPrincipalIsAUserDetailsInstance()
throws JspException { throws JspException {
Authentication auth = new TestingAuthenticationToken(new User( Authentication auth = new TestingAuthenticationToken(new User(
"marissaUserDetails", "koala", true, true, true, "marissaUserDetails", "koala", true, true, true, true,
new GrantedAuthority[] {}), "koala", new GrantedAuthority[] {}), "koala",
new GrantedAuthority[] {}); new GrantedAuthority[] {});
SecureContext sc = new SecureContextImpl(); SecureContext sc = new SecureContextImpl();

View File

@ -104,6 +104,7 @@ public class TokenBasedRememberMeServicesTests extends TestCase {
public void testAutoLoginIfExpired() throws Exception { public void testAutoLoginIfExpired() throws Exception {
UserDetails user = new User("someone", "password", true, true, true, UserDetails user = new User("someone", "password", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")});
TokenBasedRememberMeServices services = new TokenBasedRememberMeServices(); TokenBasedRememberMeServices services = new TokenBasedRememberMeServices();
@ -130,6 +131,7 @@ public class TokenBasedRememberMeServicesTests extends TestCase {
public void testAutoLoginIfMissingThreeTokensInCookieValue() public void testAutoLoginIfMissingThreeTokensInCookieValue()
throws Exception { throws Exception {
UserDetails user = new User("someone", "password", true, true, true, UserDetails user = new User("someone", "password", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")});
TokenBasedRememberMeServices services = new TokenBasedRememberMeServices(); TokenBasedRememberMeServices services = new TokenBasedRememberMeServices();
@ -154,6 +156,7 @@ public class TokenBasedRememberMeServicesTests extends TestCase {
public void testAutoLoginIfNotBase64Encoded() throws Exception { public void testAutoLoginIfNotBase64Encoded() throws Exception {
UserDetails user = new User("someone", "password", true, true, true, UserDetails user = new User("someone", "password", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")});
TokenBasedRememberMeServices services = new TokenBasedRememberMeServices(); TokenBasedRememberMeServices services = new TokenBasedRememberMeServices();
@ -179,6 +182,7 @@ public class TokenBasedRememberMeServicesTests extends TestCase {
public void testAutoLoginIfSignatureBlocksDoesNotMatchExpectedValue() public void testAutoLoginIfSignatureBlocksDoesNotMatchExpectedValue()
throws Exception { throws Exception {
UserDetails user = new User("someone", "password", true, true, true, UserDetails user = new User("someone", "password", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")});
TokenBasedRememberMeServices services = new TokenBasedRememberMeServices(); TokenBasedRememberMeServices services = new TokenBasedRememberMeServices();
@ -205,6 +209,7 @@ public class TokenBasedRememberMeServicesTests extends TestCase {
public void testAutoLoginIfTokenDoesNotContainANumberInCookieValue() public void testAutoLoginIfTokenDoesNotContainANumberInCookieValue()
throws Exception { throws Exception {
UserDetails user = new User("someone", "password", true, true, true, UserDetails user = new User("someone", "password", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")});
TokenBasedRememberMeServices services = new TokenBasedRememberMeServices(); TokenBasedRememberMeServices services = new TokenBasedRememberMeServices();
@ -252,6 +257,7 @@ public class TokenBasedRememberMeServicesTests extends TestCase {
public void testAutoLoginWithValidToken() throws Exception { public void testAutoLoginWithValidToken() throws Exception {
UserDetails user = new User("someone", "password", true, true, true, UserDetails user = new User("someone", "password", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")});
TokenBasedRememberMeServices services = new TokenBasedRememberMeServices(); TokenBasedRememberMeServices services = new TokenBasedRememberMeServices();
@ -346,6 +352,7 @@ public class TokenBasedRememberMeServicesTests extends TestCase {
MockHttpServletResponse response = new MockHttpServletResponse(); MockHttpServletResponse response = new MockHttpServletResponse();
UserDetails user = new User("someone", "password", true, true, true, UserDetails user = new User("someone", "password", true, true, true,
true,
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")}); new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_ABC")});
services.loginSuccess(request, response, services.loginSuccess(request, response,
new TestingAuthenticationToken(user, "ignored", new TestingAuthenticationToken(user, "ignored",

View File

@ -80,7 +80,7 @@ public class ContextHolderAwareRequestWrapperTests extends TestCase {
throws Exception { throws Exception {
SecureContext sc = new SecureContextImpl(); SecureContext sc = new SecureContextImpl();
Authentication auth = new TestingAuthenticationToken(new User( Authentication auth = new TestingAuthenticationToken(new User(
"marissaAsUserDetails", "koala", true, true, true, "marissaAsUserDetails", "koala", true, true, true, true,
new GrantedAuthority[] {}), "koala", new GrantedAuthority[] {}), "koala",
new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_HELLO"), new GrantedAuthorityImpl( new GrantedAuthority[] {new GrantedAuthorityImpl("ROLE_HELLO"), new GrantedAuthorityImpl(
"ROLE_FOOBAR")}); "ROLE_FOOBAR")});

View File

@ -26,12 +26,13 @@
</properties> </properties>
<body> <body>
<release version="0.8.1" date="In CVS"> <release version="0.8.1" date="In CVS">
<action dev="benalex" type="add">X509 (certificate-based) authentication support</action> <action dev="luke_t" type="add">X509 (certificate-based) authentication support</action>
<action dev="benalex" type="update">UserDetails now advises locked accounts, with corresponding DaoAuthenticationProvider events and enforcement</action>
<action dev="benalex" type="update">ContextHolderAwareRequestWrapper methods returns null if user is anonymous</action> <action dev="benalex" type="update">ContextHolderAwareRequestWrapper methods returns null if user is anonymous</action>
<action dev="benalex" type="update">AbstractBasicAclEntry improved compatibility with Hibernate</action> <action dev="benalex" type="update">AbstractBasicAclEntry improved compatibility with Hibernate</action>
<action dev="benalex" type="fix">SecurityEnforcementFilter caused NullPointerException when anonymous authentication used with BasicProcessingFilterEntryPoint</action> <action dev="benalex" type="fix">SecurityEnforcementFilter caused NullPointerException when anonymous authentication used with BasicProcessingFilterEntryPoint</action>
<action dev="benalex" type="fix">FilterChainProxy now supports replacement of ServletRequest and ServetResponse by Filter beans</action> <action dev="benalex" type="fix">FilterChainProxy now supports replacement of ServletRequest and ServetResponse by Filter beans</action>
<action dev="benalex" type="fix">Corrected Authz parsing of whitespace in GrantedAuthoritys</action> <action dev="fbos" type="fix">Corrected Authz parsing of whitespace in GrantedAuthoritys</action>
<action dev="benalex" type="fix">TokenBasedRememberMeServices now respects expired users, expired credentials and disabled users</action> <action dev="benalex" type="fix">TokenBasedRememberMeServices now respects expired users, expired credentials and disabled users</action>
<action dev="benalex" type="fix">HttpSessionContextIntegrationFilter now handles HttpSession invalidation without redirection</action> <action dev="benalex" type="fix">HttpSessionContextIntegrationFilter now handles HttpSession invalidation without redirection</action>
</release> </release>

View File

@ -721,7 +721,7 @@ public class LdapPasswordAuthenticationDao implements PasswordAuthenticationDao
String[] ldapRoles = (String[]) roles.toArray(new String[] {}); String[] ldapRoles = (String[]) roles.toArray(new String[] {});
return new User(username, password, true, true, true, return new User(username, password, true, true, true, true,
getGrantedAuthorities(ldapRoles)); getGrantedAuthorities(ldapRoles));
} catch (AuthenticationException ex) { } catch (AuthenticationException ex) {
throw new BadCredentialsException( throw new BadCredentialsException(