public class oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler extends oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler implements oadd.org.apache.hadoop.security.authentication.server.CompositeAuthenticationHandler
{
public static final java.lang.String DELEGATION_TOKEN_SCHEMES_PROPERTY;
private static final oadd.com.google.common.base.Splitter STR_SPLITTER;
private java.util.Set delegationAuthSchemes;
public void <init>()
{
oadd.org.apache.hadoop.security.authentication.server.MultiSchemeAuthenticationHandler v;
oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler;
v = new 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-dt");
specialinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: void <init>(oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler)>(v);
v.<oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: java.util.Set delegationAuthSchemes> = null;
return;
}
public java.util.Collection getTokenTypes()
{
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler v;
oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler v;
java.util.Collection v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler getAuthHandler()>();
v = interfaceinvoke v.<oadd.org.apache.hadoop.security.authentication.server.CompositeAuthenticationHandler: java.util.Collection getTokenTypes()>();
return v;
}
public void init(java.util.Properties) throws javax.servlet.ServletException
{
java.lang.Iterable v, v;
java.util.HashSet v, v;
oadd.com.google.common.base.Splitter v, v;
java.lang.String v, v, v, v;
boolean v, v, v;
java.util.Properties v;
java.util.Iterator v, v;
java.util.Set v, v;
oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler v;
java.lang.Object v, v, v, v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler;
v := @parameter: java.util.Properties;
specialinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: void init(java.util.Properties)>(v);
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)>(v);
v = virtualinvoke v.<java.util.Properties: java.lang.String getProperty(java.lang.String)>("multi-scheme-auth-handler.delegation.schemes");
v = staticinvoke <oadd.com.google.common.base.Preconditions: java.lang.Object checkNotNull(java.lang.Object)>(v);
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v = <oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: 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);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v.<oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: java.util.Set delegationAuthSchemes> = v;
v = <oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: 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 = v.<oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: java.util.Set delegationAuthSchemes>;
v = staticinvoke <oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandlerUtil: java.lang.String checkAuthScheme(java.lang.String)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: java.util.Set delegationAuthSchemes>;
v = interfaceinvoke v.<java.util.Set: boolean containsAll(java.util.Collection)>(v);
staticinvoke <oadd.com.google.common.base.Preconditions: void checkArgument(boolean)>(v);
return;
}
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
{
javax.servlet.http.HttpServletRequest v;
java.lang.String v;
boolean v, v, v, v, 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;
oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler v;
java.lang.Object v, v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler;
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");
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: boolean isManagementOperation(javax.servlet.http.HttpServletRequest)>(v);
if v == 0 goto label;
v = 0;
if v == null goto label;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: java.util.Set delegationAuthSchemes>;
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 = 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 = 1;
label:
if v != 0 goto label;
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void setStatus(int)>(401);
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: java.util.Set delegationAuthSchemes>;
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;
label:
v = specialinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken authenticate(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)>(v, v);
return v;
}
static void <clinit>()
{
oadd.com.google.common.base.Splitter v, v, 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.token.delegation.web.MultiSchemeDelegationTokenAuthenticationHandler: oadd.com.google.common.base.Splitter STR_SPLITTER> = v;
return;
}
}