Class OTPFormAuthenticator
java.lang.Object
org.keycloak.authentication.AbstractFormAuthenticator
org.keycloak.authentication.authenticators.browser.AbstractUsernameFormAuthenticator
org.keycloak.authentication.authenticators.browser.OTPFormAuthenticator
- All Implemented Interfaces:
Authenticator,CredentialValidator<OTPCredentialProvider>,Provider
- Direct Known Subclasses:
ConditionalOtpFormAuthenticator
public class OTPFormAuthenticator
extends AbstractUsernameFormAuthenticator
implements Authenticator, CredentialValidator<OTPCredentialProvider>
- Version:
- $Revision: 1 $
- Author:
- Bill Burke
-
Field Summary
FieldsFields inherited from class org.keycloak.authentication.authenticators.browser.AbstractUsernameFormAuthenticator
ATTEMPTED_USERNAME, REGISTRATION_FORM_ACTION, SESSION_INVALID, USER_SET_BEFORE_USERNAME_PASSWORD_AUTH -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaction(AuthenticationFlowContext context) Called from a form action invocation.voidauthenticate(AuthenticationFlowContext context) Initial call for the authenticator.voidclose()booleanconfiguredFor(KeycloakSession session, RealmModel realm, UserModel user) Is this authenticator configured for this user.protected jakarta.ws.rs.core.Responseprotected StringdisabledByBruteForceError(String error) protected StringgetCredentialProvider(KeycloakSession session) getRequiredActions(KeycloakSession session) Overwrite this if the authenticator is associated withbooleanDoes this authenticator require that the user has already been identified? That AuthenticatorContext.getUser() is not null?voidsetRequiredActions(KeycloakSession session, RealmModel realm, UserModel user) Set actions to configure authenticatorvoidvalidateOTP(AuthenticationFlowContext context) Methods inherited from class org.keycloak.authentication.authenticators.browser.AbstractUsernameFormAuthenticator
challenge, challenge, enabledUser, getDefaultChallengeMessage, isDisabledByBruteForce, isUserAlreadySetBeforeUsernamePasswordAuth, setDuplicateUserChallenge, testInvalidUser, validatePassword, validateUser, validateUserAndPasswordMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.keycloak.authentication.Authenticator
areRequiredActionsEnabledMethods inherited from interface org.keycloak.authentication.CredentialValidator
getCredentials, getType
-
Field Details
-
SELECTED_OTP_CREDENTIAL_ID
- See Also:
-
UNNAMED
- See Also:
-
-
Constructor Details
-
OTPFormAuthenticator
public OTPFormAuthenticator()
-
-
Method Details
-
action
Description copied from interface:AuthenticatorCalled from a form action invocation.- Specified by:
actionin interfaceAuthenticator- Overrides:
actionin classAbstractUsernameFormAuthenticator
-
authenticate
Description copied from interface:AuthenticatorInitial call for the authenticator. This method should check the current HTTP request to determine if the request satisfies the Authenticator's requirements. If it doesn't, it should send back a challenge response by calling the AuthenticationFlowContext.challenge(Response). If this challenge is a authentication, the action URL of the form must point to /realms/{realm}/login-actions/authenticate?code={session-code}&execution={executionId} or /realms/{realm}/login-actions/registration?code={session-code}&execution={executionId} {session-code} pertains to the code generated from AuthenticationFlowContext.generateAccessCode(). The {executionId} pertains to the AuthenticationExecutionModel.getId() value obtained from AuthenticationFlowContext.getExecution(). The action URL will invoke the action() method described below.- Specified by:
authenticatein interfaceAuthenticator
-
validateOTP
-
requiresUser
public boolean requiresUser()Description copied from interface:AuthenticatorDoes this authenticator require that the user has already been identified? That AuthenticatorContext.getUser() is not null?- Specified by:
requiresUserin interfaceAuthenticator- Returns:
-
disabledByBruteForceError
- Overrides:
disabledByBruteForceErrorin classAbstractUsernameFormAuthenticator
-
disabledByBruteForceFieldError
- Overrides:
disabledByBruteForceFieldErrorin classAbstractUsernameFormAuthenticator
-
createLoginForm
- Overrides:
createLoginFormin classAbstractUsernameFormAuthenticator
-
configuredFor
Description copied from interface:AuthenticatorIs this authenticator configured for this user.- Specified by:
configuredForin interfaceAuthenticator- Returns:
-
setRequiredActions
Description copied from interface:AuthenticatorSet actions to configure authenticator- Specified by:
setRequiredActionsin interfaceAuthenticator
-
getRequiredActions
Description copied from interface:AuthenticatorOverwrite this if the authenticator is associated with- Specified by:
getRequiredActionsin interfaceAuthenticator- Returns:
-
close
public void close()- Specified by:
closein interfaceProvider- Overrides:
closein classAbstractFormAuthenticator
-
getCredentialProvider
- Specified by:
getCredentialProviderin interfaceCredentialValidator<OTPCredentialProvider>
-