public class oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler extends java.lang.Object implements oadd.org.apache.hadoop.security.authentication.server.CompositeAuthenticationHandler
{
private static org.slf4j.Logger logger;
public static final java.lang.String SCHEMES_PROPERTY;
public static final java.lang.String AUTH_HANDLER_PROPERTY;
private static final oadd.com.google.common.base.Splitter STR_SPLITTER;
private final java.util.Map schemeToAuthHandlerMapping;
private final java.util.Collection types;
private final java.lang.String authType;
public static final java.lang.String TYPE;
public void <init>()
{
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: void <init>(java.lang.String)>("multi-scheme");
return;
}
public void <init>(java.lang.String)
{
java.util.HashSet v;
java.util.HashMap v;
java.lang.String v;
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
v := @parameter: java.lang.String;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Map schemeToAuthHandlerMapping> = v;
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Collection types> = v;
v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.lang.String authType> = v;
return;
}
public java.lang.String getType()
{
java.lang.String v;
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.lang.String authType>;
return v;
}
public java.util.Collection getTokenTypes()
{
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
java.util.Collection v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Collection types>;
return v;
}
public void init(java.util.Properties) throws javax.servlet.ServletException
{
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
oadd.com.google.common.base.Splitter v;
java.util.Map v, v;
boolean v, v, v;
java.util.Collection v, v;
java.util.Set v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler v;
java.lang.Object[] v;
java.lang.Iterable v;
java.lang.String v, v, v, v, v, v, v, v;
java.util.Properties v;
org.slf4j.Logger v, v;
java.util.Iterator v, v;
java.lang.IllegalArgumentException v;
java.lang.Object v, v, v, v, v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
v := @parameter: java.util.Properties;
v = virtualinvoke v.<java.util.Properties: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = <oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: org.slf4j.Logger logger>;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("{} : {}", v, v);
goto label;
label:
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Collection types>;
interfaceinvoke v.<java.util.Collection: void clear()>();
v = virtualinvoke v.<java.util.Properties: java.lang.String getProperty(java.lang.String)>("multi-scheme-auth-handler.schemes");
v = staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object,java.lang.String,java.lang.Object)>(v, "%s system property is not specified.", "multi-scheme-auth-handler.schemes");
v = <oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: oadd.com.google.common.base.Splitter STR_SPLITTER>;
v = virtualinvoke v.<oadd.com.google.common.base.Splitter: java.lang.Iterable split(java.lang.CharSequence)>(v);
v = interfaceinvoke v.<java.lang.Iterable: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandlerUtil: java.lang.String checkAuthScheme(java.lang.String)>(v);
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Map schemeToAuthHandlerMapping>;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = new java.lang.IllegalArgumentException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Handler is already specified for \u authentication scheme.");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = newarray (java.lang.Object)[1];
v[0] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("multi-scheme-auth-handler.schemes.%s.handler", v);
v = virtualinvoke v.<java.lang.String: java.lang.String toLowerCase()>();
v = virtualinvoke v.<java.util.Properties: java.lang.String getProperty(java.lang.String)>(v);
staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object,java.lang.String,java.lang.Object)>(v, "No auth handler configured for scheme %s.", v);
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandlerUtil: java.lang.String getAuthenticationHandlerClassName(java.lang.String)>(v);
v = virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler initializeAuthHandler(java.lang.String,java.util.Properties)>(v, v);
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Map schemeToAuthHandlerMapping>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Collection types>;
v = interfaceinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler: java.lang.String getType()>();
interfaceinvoke v.<java.util.Collection: boolean add(java.lang.Object)>(v);
goto label;
label:
v = <oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("Successfully initialized MultiSchemeAuthenticationHandler");
return;
}
protected oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler initializeAuthHandler(java.lang.String, java.util.Properties) throws javax.servlet.ServletException
{
java.util.Properties v;
org.slf4j.Logger v, v, v;
javax.servlet.ServletException v;
java.lang.ReflectiveOperationException v;
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
java.lang.Thread v;
java.lang.Class v;
java.lang.Object v;
java.lang.ClassLoader v;
java.lang.String v, v, v, v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
v := @parameter: java.lang.String;
v := @parameter: java.util.Properties;
label:
staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
v = <oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: org.slf4j.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Initializing Authentication handler of type \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.Class loadClass(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.Class: java.lang.Object newInstance()>();
interfaceinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler: void init(java.util.Properties)>(v);
v = <oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: org.slf4j.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Successfully initialized Authentication handler of type \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
label:
return v;
label:
v := @caughtexception;
v = <oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: org.slf4j.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Failed to initialize authentication handler \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
v = new javax.servlet.ServletException;
specialinvoke v.<javax.servlet.ServletException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.ClassNotFoundException from label to label with label;
catch java.lang.InstantiationException from label to label with label;
catch java.lang.IllegalAccessException from label to label with label;
}
public void destroy()
{
java.util.Iterator v;
java.util.Collection v;
java.util.Map v;
java.lang.Object v;
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Map schemeToAuthHandlerMapping>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = interfaceinvoke v.<java.util.Collection: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
interfaceinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler: void destroy()>();
goto label;
label:
return;
}
public boolean managementOperation(oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken, javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) throws java.io.IOException, oadd.org.apache.hadoop.security.authentication.client.AuthenticationException
{
javax.servlet.http.HttpServletRequest v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken v;
javax.servlet.http.HttpServletResponse v;
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
v := @parameter: oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken;
v := @parameter: javax.servlet.http.HttpServletRequest;
v := @parameter: javax.servlet.http.HttpServletResponse;
return 1;
}
public oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken authenticate(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) throws java.io.IOException, oadd.org.apache.hadoop.security.authentication.client.AuthenticationException
{
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
javax.servlet.http.HttpServletRequest v;
java.util.Map v, v;
java.lang.String v, v;
boolean v, v, v;
org.slf4j.Logger v;
java.util.Iterator v, v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken v;
javax.servlet.http.HttpServletResponse v;
java.util.Set v, v;
java.lang.Object v, v, v, v;
v := @this: oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler;
v := @parameter: javax.servlet.http.HttpServletRequest;
v := @parameter: javax.servlet.http.HttpServletResponse;
v = interfaceinvoke v.<javax.servlet.http.HttpServletRequest: java.lang.String getHeader(java.lang.String)>("Authorization");
if v == null goto label;
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Map schemeToAuthHandlerMapping>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandlerUtil: boolean matchAuthScheme(java.lang.String,java.lang.String)>(v, v);
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = interfaceinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken authenticate(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)>(v, v);
v = <oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: org.slf4j.Logger logger>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken: java.lang.String getType()>();
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Token generated with type {}", v);
return v;
label:
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void setStatus(int)>(401);
v = v.<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: java.util.Map schemeToAuthHandlerMapping>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void addHeader(java.lang.String,java.lang.String)>("WWW-Authenticate", v);
goto label;
label:
return null;
}
static void <clinit>()
{
org.slf4j.Logger v;
oadd.com.google.common.base.Splitter v, v, v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/hadoop/security/authentication/server/MultiSchemeAuthenticationHandler;");
<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: org.slf4j.Logger logger> = v;
v = staticinvoke <oadd.com.google.common.base.Splitter: oadd.com.google.common.base.Splitter on(char)>(44);
v = virtualinvoke v.<oadd.com.google.common.base.Splitter: oadd.com.google.common.base.Splitter trimResults()>();
v = virtualinvoke v.<oadd.com.google.common.base.Splitter: oadd.com.google.common.base.Splitter omitEmptyStrings()>();
<oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler: oadd.com.google.common.base.Splitter STR_SPLITTER> = v;
return;
}
}