public class org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman extends java.lang.Object implements org.apache.isis.core.security.authentication.Authenticator
{
private static final org.apache.logging.log4j.Logger log;
private final org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository applicationUserRepository;
private final org.springframework.security.crypto.password.PasswordEncoder passwordEncoder;
public void <init>(org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository, org.springframework.security.crypto.password.PasswordEncoder)
{
org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman v;
org.springframework.security.crypto.password.PasswordEncoder v;
org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository v;
v := @this: org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman;
v := @parameter: org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository;
v := @parameter: org.springframework.security.crypto.password.PasswordEncoder;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman: org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository applicationUserRepository> = v;
v.<org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman: org.springframework.security.crypto.password.PasswordEncoder passwordEncoder> = v;
return;
}
public final boolean canAuthenticate(java.lang.Class)
{
java.lang.Class v, v;
org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman v;
boolean v;
v := @this: org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman;
v := @parameter: java.lang.Class;
v = class "Lorg/apache/isis/core/security/authentication/AuthenticationRequestPassword;";
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
return v;
}
public org.apache.isis.applib.services.iactnlayer.InteractionContext authenticate(org.apache.isis.core.security.authentication.AuthenticationRequest, java.lang.String)
{
java.util.function.Predicate v;
java.util.function.Function v;
org.apache.logging.log4j.Logger v;
java.util.Optional v, v, v;
java.lang.Object v;
java.lang.String v, v, v;
org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman v;
org.apache.isis.core.security.authentication.AuthenticationRequest v;
org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository v;
v := @this: org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman;
v := @parameter: org.apache.isis.core.security.authentication.AuthenticationRequest;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.isis.core.security.authentication.AuthenticationRequestPassword: java.lang.String getName()>();
v = virtualinvoke v.<org.apache.isis.core.security.authentication.AuthenticationRequestPassword: java.lang.String getPassword()>();
if v != null goto label;
v = <org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman: org.apache.logging.log4j.Logger log>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String)>("login failed: username is null");
return null;
label:
v = v.<org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman: org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository applicationUserRepository>;
v = interfaceinvoke v.<org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository: java.util.Optional findByUsername(java.lang.String)>(v);
v = staticinvoke <org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman$lambda_authenticate_0__1: java.util.function.Predicate bootstrap$(org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman,java.lang.String)>(v, v);
v = virtualinvoke v.<java.util.Optional: java.util.Optional filter(java.util.function.Predicate)>(v);
v = staticinvoke <org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman$lambda_authenticate_1__2: java.util.function.Function bootstrap$(org.apache.isis.core.security.authentication.AuthenticationRequest,java.lang.String,java.lang.String)>(v, v, v);
v = virtualinvoke v.<java.util.Optional: java.util.Optional map(java.util.function.Function)>(v);
v = virtualinvoke v.<java.util.Optional: java.lang.Object orElse(java.lang.Object)>(null);
return v;
}
public void logout(org.apache.isis.applib.services.iactnlayer.InteractionContext)
{
org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman v;
org.apache.isis.applib.services.iactnlayer.InteractionContext v;
v := @this: org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman;
v := @parameter: org.apache.isis.applib.services.iactnlayer.InteractionContext;
return;
}
static void <clinit>()
{
org.apache.logging.log4j.Logger v;
v = staticinvoke <org.apache.logging.log4j.LogManager: org.apache.logging.log4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/isis/extensions/secman/integration/authenticator/AuthenticatorSecman;");
<org.apache.isis.extensions.secman.integration.authenticator.AuthenticatorSecman: org.apache.logging.log4j.Logger log> = v;
return;
}
}