The OTP configuration is failing when LDAP is configured to don't import users (read-only) in RH-SSO 7.4

Solution Verified - Updated -

Issue

OTP can't be configured when LDAP Import Users is false and read-only. RH-SSO 7.4.7 doesn't show any message and goes directly to the application. Testing on 7.4.8 we get the following error:

13:07:01,223 WARN [org.keycloak.services] (default task-6) KC-SERVICES0013: Failed authentication: org.keycloak.models.ModelException: Not possible to write 'required action CONFIGURE_TOTP' when updating user 'bwilson'
 at org.keycloak.keycloak-server-spi-private@9.0.14.redhat-00001//org.keycloak.models.utils.ReadOnlyUserModelDelegate.readOnlyException(ReadOnlyUserModelDelegate.java:146)
 at org.keycloak.keycloak-server-spi-private@9.0.14.redhat-00001//org.keycloak.models.utils.ReadOnlyUserModelDelegate.addRequiredAction(ReadOnlyUserModelDelegate.java:71)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-ldap-federation@9.0.14.redhat-00001//org.keycloak.storage.ldap.LDAPWritesOnlyUserModelDelegate.addRequiredAction(LDAPWritesOnlyUserModelDelegate.java:86)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-server-spi@9.0.14.redhat-00001//org.keycloak.models.utils.UserModelDelegate.addRequiredAction(UserModelDelegate.java:104)
 at org.keycloak.keycloak-server-spi-private@9.0.14.redhat-00001//org.keycloak.storage.adapter.UpdateOnlyChangeUserModelDelegate.addRequiredAction(UpdateOnlyChangeUserModelDelegate.java:80)
 at org.keycloak.keycloak-model-infinispan@9.0.14.redhat-00001//org.keycloak.models.cache.infinispan.UserAdapter.addRequiredAction(UserAdapter.java:232)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.authenticators.browser.OTPFormAuthenticator.setRequiredActions(OTPFormAuthenticator.java:133)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.DefaultAuthenticationFlow.processSingleFlowExecutionModel(DefaultAuthenticationFlow.java:430)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.DefaultAuthenticationFlow.processFlow(DefaultAuthenticationFlow.java:247)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.DefaultAuthenticationFlow.processSingleFlowExecutionModel(DefaultAuthenticationFlow.java:381)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.DefaultAuthenticationFlow.processFlow(DefaultAuthenticationFlow.java:247)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.DefaultAuthenticationFlow.processSingleFlowExecutionModel(DefaultAuthenticationFlow.java:381)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.DefaultAuthenticationFlow.continueAuthenticationAfterSuccessfulAction(DefaultAuthenticationFlow.java:180)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.DefaultAuthenticationFlow.processAction(DefaultAuthenticationFlow.java:158)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.authentication.AuthenticationProcessor.authenticationAction(AuthenticationProcessor.java:949)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.services.resources.LoginActionsService.processFlow(LoginActionsService.java:311)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.services.resources.LoginActionsService.processAuthentication(LoginActionsService.java:282)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.services.resources.LoginActionsService.authenticate(LoginActionsService.java:266)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.services.resources.LoginActionsService.authenticateForm(LoginActionsService.java:339)
 at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.base/java.lang.reflect.Method.invoke(Method.java:566)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.MethodInjectorImpl.invoke(MethodInjectorImpl.java:138)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.ResourceMethodInvoker.internalInvokeOnTarget(ResourceMethodInvoker.java:535)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.ResourceMethodInvoker.invokeOnTargetAfterFilter(ResourceMethodInvoker.java:424)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.ResourceMethodInvoker.lambda$invokeOnTarget$0(ResourceMethodInvoker.java:385)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.interception.PreMatchContainerRequestContext.filter(PreMatchContainerRequestContext.java:356)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.ResourceMethodInvoker.invokeOnTarget(ResourceMethodInvoker.java:387)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:356)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.ResourceLocatorInvoker.invokeOnTargetObject(ResourceLocatorInvoker.java:150)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.ResourceLocatorInvoker.invoke(ResourceLocatorInvoker.java:104)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:440)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.SynchronousDispatcher.lambda$invoke$4(SynchronousDispatcher.java:229)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.SynchronousDispatcher.lambda$preprocess$0(SynchronousDispatcher.java:135)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.interception.PreMatchContainerRequestContext.filter(PreMatchContainerRequestContext.java:356)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.SynchronousDispatcher.preprocess(SynchronousDispatcher.java:138)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:215)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.plugins.server.servlet.ServletContainerDispatcher.service(ServletContainerDispatcher.java:227)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:56)
 at org.jboss.resteasy.resteasy-jaxrs@3.11.4.Final-redhat-00001//org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:51)
 at javax.servlet.api@2.0.0.Final-redhat-00001//javax.servlet.http.HttpServlet.service(HttpServlet.java:590)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:74)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.FilterHandler$FilterChainImpl.doFilter(FilterHandler.java:129)
 at org.keycloak.keycloak-services@9.0.14.redhat-00001//org.keycloak.services.filters.KeycloakSessionServletFilter.doFilter(KeycloakSessionServletFilter.java:91)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.core.ManagedFilter.doFilter(ManagedFilter.java:61)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.FilterHandler$FilterChainImpl.doFilter(FilterHandler.java:131)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.FilterHandler.handleRequest(FilterHandler.java:84)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:62)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletChain$1.handleRequest(ServletChain.java:68)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36)
 at org.wildfly.extension.undertow@7.3.8.GA-redhat-00001//org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.RedirectDirHandler.handleRequest(RedirectDirHandler.java:68)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:111)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:57)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:46)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:64)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:60)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:77)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.security.handlers.NotificationReceiverHandler.handleRequest(NotificationReceiverHandler.java:50)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.security.handlers.AbstractSecurityContextAssociationHandler.handleRequest(AbstractSecurityContextAssociationHandler.java:43)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
 at org.wildfly.extension.undertow@7.3.8.GA-redhat-00001//org.wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
 at org.wildfly.extension.undertow@7.3.8.GA-redhat-00001//org.wildfly.extension.undertow.deployment.GlobalRequestControllerHandler.handleRequest(GlobalRequestControllerHandler.java:68)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:269)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletInitialHandler.access$100(ServletInitialHandler.java:78)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletInitialHandler$2.call(ServletInitialHandler.java:133)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletInitialHandler$2.call(ServletInitialHandler.java:130)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.core.ServletRequestContextThreadSetupAction$1.call(ServletRequestContextThreadSetupAction.java:48)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.core.ContextClassLoaderSetupAction$1.call(ContextClassLoaderSetupAction.java:43)
 at org.wildfly.extension.undertow@7.3.8.GA-redhat-00001//org.wildfly.extension.undertow.security.SecurityContextThreadSetupAction.lambda$create$0(SecurityContextThreadSetupAction.java:105)
 at org.wildfly.extension.undertow@7.3.8.GA-redhat-00001//org.wildfly.extension.undertow.deployment.UndertowDeploymentInfoService$UndertowThreadSetupAction.lambda$create$0(UndertowDeploymentInfoService.java:1530)
 at org.wildfly.extension.undertow@7.3.8.GA-redhat-00001//org.wildfly.extension.undertow.deployment.UndertowDeploymentInfoService$UndertowThreadSetupAction.lambda$create$0(UndertowDeploymentInfoService.java:1530)
 at org.wildfly.extension.undertow@7.3.8.GA-redhat-00001//org.wildfly.extension.undertow.deployment.UndertowDeploymentInfoService$UndertowThreadSetupAction.lambda$create$0(UndertowDeploymentInfoService.java:1530)
 at org.wildfly.extension.undertow@7.3.8.GA-redhat-00001//org.wildfly.extension.undertow.deployment.UndertowDeploymentInfoService$UndertowThreadSetupAction.lambda$create$0(UndertowDeploymentInfoService.java:1530)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:249)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletInitialHandler.access$000(ServletInitialHandler.java:78)
 at io.undertow.servlet@2.0.38.SP1-redhat-00001//io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:99)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.server.Connectors.executeRootHandler(Connectors.java:390)
 at io.undertow.core@2.0.38.SP1-redhat-00001//io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:830)
 at org.jboss.threads@2.3.3.Final-redhat-00001//org.jboss.threads.ContextClassLoaderSavingRunnable.run(ContextClassLoaderSavingRunnable.java:35)
 at org.jboss.threads@2.3.3.Final-redhat-00001//org.jboss.threads.EnhancedQueueExecutor.safeRun(EnhancedQueueExecutor.java:1982)
 at org.jboss.threads@2.3.3.Final-redhat-00001//org.jboss.threads.EnhancedQueueExecutor$ThreadBody.doRunTask(EnhancedQueueExecutor.java:1486)
 at org.jboss.threads@2.3.3.Final-redhat-00001//org.jboss.threads.EnhancedQueueExecutor$ThreadBody.run(EnhancedQueueExecutor.java:1377)
 at org.jboss.xnio@3.7.12.Final-redhat-00001//org.xnio.XnioWorker$WorkerThreadFactory$1$1.run(XnioWorker.java:1280)
 at java.base/java.lang.Thread.run(Thread.java:834)

Environment

  • Red Hat Single Sign-On (RH-SSO ) - 7.4.x

Subscriber exclusive content

A Red Hat subscription provides unlimited access to our knowledgebase, tools, and much more.

Current Customers and Partners

Log in for full access

Log In

New to Red Hat?

Learn more about Red Hat subscriptions

Using a Red Hat product through a public cloud?

How to access this content