public class org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider extends java.lang.Object implements org.springframework.security.authentication.AuthenticationProvider, org.springframework.beans.factory.InitializingBean, org.springframework.context.MessageSourceAware
{
private static final org.slf4j.Logger LOG;
protected org.springframework.context.support.MessageSourceAccessor messages;
private org.springframework.security.core.userdetails.AuthenticationUserDetailsService authenticationUserDetailsService;
private org.apache.cxf.fediz.spring.FederationConfig federationConfig;
private final org.springframework.security.core.userdetails.UserDetailsChecker userDetailsChecker;
private org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper authoritiesMapper;
public void <init>()
{
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
org.springframework.context.support.MessageSourceAccessor v;
org.springframework.security.authentication.AccountStatusUserDetailsChecker v;
org.springframework.security.core.authority.mapping.NullAuthoritiesMapper v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <org.apache.cxf.fediz.spring.SpringFedizMessageSource: org.springframework.context.support.MessageSourceAccessor getAccessor()>();
v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.context.support.MessageSourceAccessor messages> = v;
v = new org.springframework.security.authentication.AccountStatusUserDetailsChecker;
specialinvoke v.<org.springframework.security.authentication.AccountStatusUserDetailsChecker: void <init>()>();
v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.userdetails.UserDetailsChecker userDetailsChecker> = v;
v = new org.springframework.security.core.authority.mapping.NullAuthoritiesMapper;
specialinvoke v.<org.springframework.security.core.authority.mapping.NullAuthoritiesMapper: void <init>()>();
v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper authoritiesMapper> = v;
return;
}
public org.springframework.security.core.userdetails.AuthenticationUserDetailsService getAuthenticationUserDetailsService()
{
org.springframework.security.core.userdetails.AuthenticationUserDetailsService v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.userdetails.AuthenticationUserDetailsService authenticationUserDetailsService>;
return v;
}
public void setAuthenticationUserDetailsService(org.springframework.security.core.userdetails.AuthenticationUserDetailsService)
{
org.springframework.security.core.userdetails.AuthenticationUserDetailsService v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v := @parameter: org.springframework.security.core.userdetails.AuthenticationUserDetailsService;
v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.userdetails.AuthenticationUserDetailsService authenticationUserDetailsService> = v;
return;
}
public org.apache.cxf.fediz.spring.FederationConfig getFederationConfig()
{
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
org.apache.cxf.fediz.spring.FederationConfig v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.apache.cxf.fediz.spring.FederationConfig federationConfig>;
return v;
}
public void setFederationConfig(org.apache.cxf.fediz.spring.FederationConfig)
{
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
org.apache.cxf.fediz.spring.FederationConfig v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v := @parameter: org.apache.cxf.fediz.spring.FederationConfig;
v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.apache.cxf.fediz.spring.FederationConfig federationConfig> = v;
return;
}
public void afterPropertiesSet() throws java.lang.Exception
{
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
org.apache.cxf.fediz.spring.FederationConfig v;
org.springframework.context.support.MessageSourceAccessor v;
org.springframework.security.core.userdetails.AuthenticationUserDetailsService v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.userdetails.AuthenticationUserDetailsService authenticationUserDetailsService>;
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "An authenticationUserDetailsService must be set");
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.context.support.MessageSourceAccessor messages>;
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "A message source must be set");
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.apache.cxf.fediz.spring.FederationConfig federationConfig>;
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "FederationConfig cannot be null.");
return;
}
public org.springframework.security.core.Authentication authenticate(org.springframework.security.core.Authentication)
{
org.springframework.security.authentication.BadCredentialsException v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationToken v;
org.springframework.context.support.MessageSourceAccessor v;
java.lang.Class v;
java.lang.Object v, v, v;
java.lang.String v, v;
org.springframework.security.core.Authentication v;
boolean v, v, v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v := @parameter: org.springframework.security.core.Authentication;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: boolean supports(java.lang.Class)>(v);
if v != 0 goto label;
return null;
label:
v = v instanceof org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
if v != 0 goto label;
return null;
label:
v = interfaceinvoke v.<org.springframework.security.core.Authentication: java.lang.Object getCredentials()>();
if v == null goto label;
v = "";
v = interfaceinvoke v.<org.springframework.security.core.Authentication: java.lang.Object getCredentials()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
v = new org.springframework.security.authentication.BadCredentialsException;
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.context.support.MessageSourceAccessor messages>;
v = virtualinvoke v.<org.springframework.context.support.MessageSourceAccessor: java.lang.String getMessage(java.lang.String,java.lang.String)>("FederationAuthenticationProvider.noSignInRequest", "Failed to get SignIn request");
specialinvoke v.<org.springframework.security.authentication.BadCredentialsException: void <init>(java.lang.String)>(v);
throw v;
label:
v = specialinvoke v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationToken authenticateNow(org.springframework.security.core.Authentication)>(v);
v = interfaceinvoke v.<org.springframework.security.core.Authentication: java.lang.Object getDetails()>();
virtualinvoke v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationToken: void setDetails(java.lang.Object)>(v);
return v;
}
private org.apache.cxf.fediz.spring.authentication.FederationAuthenticationToken authenticateNow(org.springframework.security.core.Authentication)
{
org.springframework.security.authentication.BadCredentialsException v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
org.springframework.security.core.userdetails.UserDetailsChecker v;
org.apache.cxf.fediz.core.processor.FedizResponse v;
org.apache.cxf.fediz.spring.FederationConfig v;
org.apache.cxf.fediz.core.processor.FedizProcessor v;
org.springframework.security.core.userdetails.UserDetails v;
java.lang.String v;
org.apache.cxf.fediz.core.config.FedizContext v;
org.slf4j.Logger v;
java.util.Collection v, v;
java.lang.Exception v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationToken v;
org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper v;
java.lang.Object v, v;
org.springframework.security.core.Authentication v;
org.apache.cxf.fediz.core.config.Protocol v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v := @parameter: org.springframework.security.core.Authentication;
label:
v = interfaceinvoke v.<org.springframework.security.core.Authentication: java.lang.Object getCredentials()>();
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.apache.cxf.fediz.spring.FederationConfig federationConfig>;
v = interfaceinvoke v.<org.apache.cxf.fediz.spring.FederationConfig: org.apache.cxf.fediz.core.config.FedizContext getFedizContext()>();
v = virtualinvoke v.<org.apache.cxf.fediz.core.config.FedizContext: org.apache.cxf.fediz.core.config.Protocol getProtocol()>();
v = staticinvoke <org.apache.cxf.fediz.core.processor.FedizProcessorFactory: org.apache.cxf.fediz.core.processor.FedizProcessor newFedizProcessor(org.apache.cxf.fediz.core.config.Protocol)>(v);
v = interfaceinvoke v.<org.apache.cxf.fediz.core.processor.FedizProcessor: org.apache.cxf.fediz.core.processor.FedizResponse processRequest(org.apache.cxf.fediz.core.processor.FedizRequest,org.apache.cxf.fediz.core.config.FedizContext)>(v, v);
v = virtualinvoke v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.userdetails.UserDetails loadUserByFederationResponse(org.apache.cxf.fediz.core.processor.FedizResponse)>(v);
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.userdetails.UserDetailsChecker userDetailsChecker>;
interfaceinvoke v.<org.springframework.security.core.userdetails.UserDetailsChecker: void check(org.springframework.security.core.userdetails.UserDetails)>(v);
v = new org.apache.cxf.fediz.spring.authentication.FederationAuthenticationToken;
v = interfaceinvoke v.<org.springframework.security.core.Authentication: java.lang.Object getCredentials()>();
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper authoritiesMapper>;
v = interfaceinvoke v.<org.springframework.security.core.userdetails.UserDetails: java.util.Collection getAuthorities()>();
v = interfaceinvoke v.<org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper: java.util.Collection mapAuthorities(java.util.Collection)>(v);
specialinvoke v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationToken: void <init>(java.lang.Object,java.lang.Object,java.util.Collection,org.springframework.security.core.userdetails.UserDetails,org.apache.cxf.fediz.core.processor.FedizResponse)>(v, v, v, v, v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Failed to validate SignIn request", v);
v = new org.springframework.security.authentication.BadCredentialsException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
specialinvoke v.<org.springframework.security.authentication.BadCredentialsException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Exception from label to label with label;
}
protected org.springframework.security.core.userdetails.UserDetails loadUserByFederationResponse(org.apache.cxf.fediz.core.processor.FedizResponse)
{
org.apache.cxf.fediz.core.processor.FedizResponse v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
org.springframework.security.core.userdetails.AuthenticationUserDetailsService v;
org.springframework.security.core.userdetails.UserDetails v;
org.apache.cxf.fediz.spring.authentication.FederationResponseAuthenticationToken v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v := @parameter: org.apache.cxf.fediz.core.processor.FedizResponse;
v = new org.apache.cxf.fediz.spring.authentication.FederationResponseAuthenticationToken;
specialinvoke v.<org.apache.cxf.fediz.spring.authentication.FederationResponseAuthenticationToken: void <init>(org.apache.cxf.fediz.core.processor.FedizResponse)>(v);
v = v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.userdetails.AuthenticationUserDetailsService authenticationUserDetailsService>;
v = interfaceinvoke v.<org.springframework.security.core.userdetails.AuthenticationUserDetailsService: org.springframework.security.core.userdetails.UserDetails loadUserDetails(org.springframework.security.core.Authentication)>(v);
return v;
}
public void setMessageSource(org.springframework.context.MessageSource)
{
org.springframework.context.support.MessageSourceAccessor v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
org.springframework.context.MessageSource v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v := @parameter: org.springframework.context.MessageSource;
v = new org.springframework.context.support.MessageSourceAccessor;
specialinvoke v.<org.springframework.context.support.MessageSourceAccessor: void <init>(org.springframework.context.MessageSource)>(v);
v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.context.support.MessageSourceAccessor messages> = v;
return;
}
public void setAuthoritiesMapper(org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper)
{
org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper v;
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v := @parameter: org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper;
v.<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.springframework.security.core.authority.mapping.GrantedAuthoritiesMapper authoritiesMapper> = v;
return;
}
public boolean supports(java.lang.Class)
{
org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider v;
java.lang.Class v, v, v;
boolean v, v, v;
v := @this: org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider;
v := @parameter: java.lang.Class;
v = class "Lorg/springframework/security/authentication/UsernamePasswordAuthenticationToken;";
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
if v != 0 goto label;
v = class "Lorg/apache/cxf/fediz/spring/authentication/FederationAuthenticationToken;";
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/cxf/fediz/spring/authentication/FederationAuthenticationProvider;");
<org.apache.cxf.fediz.spring.authentication.FederationAuthenticationProvider: org.slf4j.Logger LOG> = v;
return;
}
}