@Override
public AuthenticationResult authenticate( final Credential credential, final SecurityContext securityContext )
throws AuthenticationException {
if ( !supportsCredential( credential ) ) {
return new AuthenticationResult() {
@Override
public List<String> getMessages() {
return new ArrayList<String>( 1 ) {{
add( "Credential not supported by " + DefaultAuthenticationProvider.class.getName() );
}};
}
@Override
public AuthenticationStatus getStatus() {
return AuthenticationStatus.NONE;
}
@Override
public Principal getPrincipal() {
return null;
}
};
}
final UserNameCredential realCredential = UserNameCredential.class.cast( credential );
if ( !authenticationSource.authenticate( realCredential, securityContext ) ) {
return new AuthenticationResult() {
@Override
public List<String> getMessages() {
return new ArrayList<String>( 1 ) {{
add( "Invalid credentials." );
}};
}
@Override
public AuthenticationStatus getStatus() {
return AuthenticationStatus.FAILED;
}
@Override
public Principal getPrincipal() {
return null;
}
};
}
return new AuthenticationResult() {
@Override
public List<String> getMessages() {
return emptyList();
}