KEYCLOAK-3969 Allow use of ScriptAuthenticator without user

Previously ScriptAuthenticator required a user to be authenticated
before it could be used as an additional authentication step which
limited the scenarios the authenticator could be used.

We now allow ScriptAuthenticators to be used without requiring an
user to be authenticated before.
Adapted the authenticator-template.js with a null safe username check.

Note that existing custom ScriptAuthenticators might need some additional
null checks since the user can now be undefined.
This commit is contained in:
Thomas Darimont 2016-12-04 23:15:53 +01:00
parent d7df86d6d0
commit 8610a02d72
2 changed files with 10 additions and 4 deletions

View file

@ -52,6 +52,10 @@ import java.util.Map;
* </ol> * </ol>
* </p> * </p>
* <p> * <p>
* Note that the {@code user} variable is only defined when the user was identified by a preceeding
* authentication step, e.g. by the {@link UsernamePasswordForm} authenticator.
* </p>
* <p>
* Additional context information can be extracted from the {@code context} argument passed to the {@code authenticate(context)} * Additional context information can be extracted from the {@code context} argument passed to the {@code authenticate(context)}
* or {@code action(context)} function. * or {@code action(context)} function.
* <p> * <p>
@ -63,9 +67,10 @@ import java.util.Map;
* *
* function authenticate(context) { * function authenticate(context) {
* *
* LOG.info(script.name + " --> trace auth for: " + user.username); * var username = user ? user.username : "anonymous";
* LOG.info(script.name + " --> trace auth for: " + username);
* *
* if ( user.username === "tester" * if ( username === "tester"
* && user.getAttribute("someAttribute") * && user.getAttribute("someAttribute")
* && user.getAttribute("someAttribute").contains("someValue")) { * && user.getAttribute("someAttribute").contains("someValue")) {
* *
@ -160,7 +165,7 @@ public class ScriptBasedAuthenticator implements Authenticator {
@Override @Override
public boolean requiresUser() { public boolean requiresUser() {
return true; return false;
} }
@Override @Override

View file

@ -24,7 +24,8 @@ AuthenticationFlowError = Java.type("org.keycloak.authentication.AuthenticationF
*/ */
function authenticate(context) { function authenticate(context) {
LOG.info(script.name + " trace auth for: " + user.username); var username = user ? user.username : "anonymous";
LOG.info(script.name + " trace auth for: " + username);
var authShouldFail = false; var authShouldFail = false;
if (authShouldFail) { if (authShouldFail) {