public abstract class oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler extends java.lang.Object implements oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler
{
private static final org.slf4j.Logger LOG;
protected static final java.lang.String TYPE_POSTFIX;
public static final java.lang.String PREFIX;
public static final java.lang.String TOKEN_KIND;
private static final java.util.Set DELEGATION_TOKEN_OPS;
public static final java.lang.String DELEGATION_TOKEN_UGI_ATTRIBUTE;
public static final java.lang.String JSON_MAPPER_PREFIX;
private oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler authHandler;
private oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager;
private java.lang.String authType;
private oadd.com.fasterxml.jackson.core.JsonFactory jsonFactory;
private static final java.lang.String ENTER;
public void <init>(oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler)
{
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
java.lang.String v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler authHandler> = v;
v = interfaceinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler: java.lang.String getType()>();
v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.lang.String authType> = v;
return;
}
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager getTokenManager()
{
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager>;
return v;
}
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler getAuthHandler()
{
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler authHandler>;
return v;
}
public void init(java.util.Properties) throws javax.servlet.ServletException
{
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
java.util.Properties v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: java.util.Properties;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler authHandler>;
interfaceinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler: void init(java.util.Properties)>(v);
virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: void initTokenManager(java.util.Properties)>(v);
virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: void initJsonFactory(java.util.Properties)>(v);
return;
}
public void setExternalDelegationTokenSecretManager(oadd.org.apache.hadoop.security.token.delegation.AbstractDelegationTokenSecretManager)
{
oadd.org.apache.hadoop.security.token.delegation.AbstractDelegationTokenSecretManager v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: oadd.org.apache.hadoop.security.token.delegation.AbstractDelegationTokenSecretManager;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager>;
virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager: void setExternalDelegationTokenSecretManager(oadd.org.apache.hadoop.security.token.delegation.AbstractDelegationTokenSecretManager)>(v);
return;
}
public void initTokenManager(java.util.Properties)
{
java.util.Properties v;
java.util.Iterator v;
oadd.org.apache.hadoop.io.Text v;
java.util.Set v;
java.lang.IllegalArgumentException v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager v, v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
java.lang.Object v, v, v;
oadd.org.apache.hadoop.conf.Configuration v;
java.lang.String v, v;
boolean v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: java.util.Properties;
v = new oadd.org.apache.hadoop.conf.Configuration;
specialinvoke v.<oadd.org.apache.hadoop.conf.Configuration: void <init>(boolean)>(0);
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: void set(java.lang.String,java.lang.String)>(v, v);
goto label;
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.conf.Configuration: java.lang.String get(java.lang.String)>("delegation-token.token-kind");
if v != null goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("The configuration does not define the token kind");
throw v;
label:
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = new oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager;
v = new oadd.org.apache.hadoop.io.Text;
specialinvoke v.<oadd.org.apache.hadoop.io.Text: void <init>(java.lang.String)>(v);
specialinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager: void <init>(oadd.org.apache.hadoop.conf.Configuration,oadd.org.apache.hadoop.io.Text)>(v, v);
v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager> = v;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager>;
virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager: void init()>();
return;
}
public void initJsonFactory(java.util.Properties)
{
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
int v;
java.lang.String v, v;
boolean v, v, v, v;
java.util.Properties v;
java.util.Iterator v;
oadd.com.fasterxml.jackson.core.JsonFactory v;
java.util.Set v;
java.lang.Object v, v, v;
oadd.com.fasterxml.jackson.core.JsonGenerator$Feature v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: java.util.Properties;
v = 0;
v = new oadd.com.fasterxml.jackson.core.JsonFactory;
specialinvoke v.<oadd.com.fasterxml.jackson.core.JsonFactory: void <init>()>();
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("delegation-token.json-mapper.");
if v == 0 goto label;
v = "delegation-token.json-mapper.";
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = staticinvoke <oadd.com.fasterxml.jackson.core.JsonGenerator$Feature: oadd.com.fasterxml.jackson.core.JsonGenerator$Feature valueOf(java.lang.String)>(v);
if v == null goto label;
v = 1;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
virtualinvoke v.<oadd.com.fasterxml.jackson.core.JsonFactory: oadd.com.fasterxml.jackson.core.JsonFactory configure(oadd.com.fasterxml.jackson.core.JsonGenerator$Feature,boolean)>(v, v);
goto label;
label:
if v == 0 goto label;
v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.com.fasterxml.jackson.core.JsonFactory jsonFactory> = v;
label:
return;
}
public void destroy()
{
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager>;
virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager: void destroy()>();
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler authHandler>;
interfaceinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler: void destroy()>();
return;
}
public java.lang.String getType()
{
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
java.lang.String v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.lang.String authType>;
return v;
}
protected final boolean isManagementOperation(javax.servlet.http.HttpServletRequest) throws java.io.IOException
{
java.util.Set v;
javax.servlet.http.HttpServletRequest v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
java.lang.String v, v, v;
boolean v, v, v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: javax.servlet.http.HttpServletRequest;
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.ServletUtils: java.lang.String getParameter(javax.servlet.http.HttpServletRequest,java.lang.String)>(v, "op");
if v == null goto label;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String toUpperCase(java.lang.String)>(v);
goto label;
label:
v = null;
label:
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.util.Set DELEGATION_TOKEN_OPS>;
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<javax.servlet.http.HttpServletRequest: java.lang.String getMethod()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("OPTIONS");
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
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
{
java.lang.IllegalStateException v, v;
oadd.org.apache.hadoop.security.authentication.client.AuthenticationException v, v;
oadd.org.apache.hadoop.security.authorize.AuthorizationException v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
int[] v;
java.lang.Long v;
oadd.com.fasterxml.jackson.databind.ObjectMapper v;
java.util.Map v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation v;
boolean v, v, v, v, v;
java.io.PrintWriter v;
oadd.com.fasterxml.jackson.core.JsonFactory v;
oadd.org.apache.hadoop.security.token.Token v, v, v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager v, v, v;
java.lang.Object[] v, v, v;
java.util.HashMap v;
long v;
javax.servlet.http.HttpServletRequest v;
int v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
oadd.org.apache.hadoop.security.UserGroupInformation v, v;
org.slf4j.Logger v, v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken v;
javax.servlet.http.HttpServletResponse v;
java.io.IOException v, v, v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken;
v := @parameter: javax.servlet.http.HttpServletRequest;
v := @parameter: javax.servlet.http.HttpServletResponse;
v = 1;
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Processing operation for req=({}), token: {}", v, v);
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.ServletUtils: java.lang.String getParameter(javax.servlet.http.HttpServletRequest,java.lang.String)>(v, "op");
if v == null goto label;
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String toUpperCase(java.lang.String)>(v);
goto label;
label:
v = null;
label:
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: boolean isManagementOperation(javax.servlet.http.HttpServletRequest)>(v);
if v == 0 goto label;
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation valueOf(java.lang.String)>(v);
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: java.lang.String getHttpMethod()>();
v = interfaceinvoke v.<javax.servlet.http.HttpServletRequest: java.lang.String getMethod()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: boolean requiresKerberosCredentials()>();
if v == 0 goto label;
if v != null goto label;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler authHandler>;
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.token.delegation.web.DelegationTokenAuthenticationHandler: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Got token: {}.", v);
if v != null goto label;
v = 0;
v = 0;
goto label;
label:
v = 1;
goto label;
label:
v = 1;
label:
if v == 0 goto label;
if v == null goto label;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken: java.lang.String getUserName()>();
v = staticinvoke <oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.UserGroupInformation createRemoteUser(java.lang.String)>(v);
goto label;
label:
v = null;
label:
v = v;
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationFilter: java.lang.String getDoAs(javax.servlet.http.HttpServletRequest)>(v);
if v == null goto label;
if v == null goto label;
v = staticinvoke <oadd.org.apache.hadoop.security.UserGroupInformation: oadd.org.apache.hadoop.security.UserGroupInformation createProxyUser(java.lang.String,oadd.org.apache.hadoop.security.UserGroupInformation)>(v, v);
label:
v = interfaceinvoke v.<javax.servlet.http.HttpServletRequest: java.lang.String getRemoteAddr()>();
staticinvoke <oadd.org.apache.hadoop.security.authorize.ProxyUsers: void authorize(oadd.org.apache.hadoop.security.UserGroupInformation,java.lang.String)>(v, v);
label:
goto label;
label:
v := @caughtexception;
staticinvoke <oadd.org.apache.hadoop.util.HttpExceptionUtils: void createServletExceptionResponse(javax.servlet.http.HttpServletResponse,int,java.lang.Throwable)>(v, 403, v);
return 0;
label:
v = null;
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler$1: int[] $SwitchMap$org$apache$hadoop$security$token$delegation$web$DelegationTokenAuthenticator$DelegationTokenOperation>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: int ordinal()>();
v = v[v];
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
default: goto label;
};
label:
if v != null goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("request UGI cannot be NULL");
throw v;
label:
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.ServletUtils: java.lang.String getParameter(javax.servlet.http.HttpServletRequest,java.lang.String)>(v, "renewer");
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.ServletUtils: java.lang.String getParameter(javax.servlet.http.HttpServletRequest,java.lang.String)>(v, "service");
label:
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager: oadd.org.apache.hadoop.security.token.Token createToken(oadd.org.apache.hadoop.security.UserGroupInformation,java.lang.String,java.lang.String)>(v, v, v);
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.util.Map delegationTokenToJSON(oadd.org.apache.hadoop.security.token.Token)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new oadd.org.apache.hadoop.security.authentication.client.AuthenticationException;
v = virtualinvoke v.<java.io.IOException: java.lang.String toString()>();
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.client.AuthenticationException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
if v != null goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("request UGI cannot be NULL");
throw v;
label:
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.ServletUtils: java.lang.String getParameter(javax.servlet.http.HttpServletRequest,java.lang.String)>(v, "token");
if v != null goto label;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = "token";
v = staticinvoke <java.text.MessageFormat: java.lang.String format(java.lang.String,java.lang.Object[])>("Operation [{0}] requires the parameter [{1}]", v);
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void sendError(int,java.lang.String)>(400, v);
v = 0;
goto label;
label:
v = new oadd.org.apache.hadoop.security.token.Token;
specialinvoke v.<oadd.org.apache.hadoop.security.token.Token: void <init>()>();
label:
virtualinvoke v.<oadd.org.apache.hadoop.security.token.Token: void decodeFromUrlString(java.lang.String)>(v);
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: java.lang.String getShortUserName()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager: long renewToken(oadd.org.apache.hadoop.security.token.Token,java.lang.String)>(v, v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = v;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("long", v);
label:
goto label;
label:
v := @caughtexception;
v = new oadd.org.apache.hadoop.security.authentication.client.AuthenticationException;
v = virtualinvoke v.<java.io.IOException: java.lang.String toString()>();
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.client.AuthenticationException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.ServletUtils: java.lang.String getParameter(javax.servlet.http.HttpServletRequest,java.lang.String)>(v, "token");
if v != null goto label;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = "token";
v = staticinvoke <java.text.MessageFormat: java.lang.String format(java.lang.String,java.lang.Object[])>("Operation [{0}] requires the parameter [{1}]", v);
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void sendError(int,java.lang.String)>(400, v);
v = 0;
goto label;
label:
v = new oadd.org.apache.hadoop.security.token.Token;
specialinvoke v.<oadd.org.apache.hadoop.security.token.Token: void <init>()>();
label:
virtualinvoke v.<oadd.org.apache.hadoop.security.token.Token: void decodeFromUrlString(java.lang.String)>(v);
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager>;
if v == null goto label;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: java.lang.String getShortUserName()>();
goto label;
label:
v = null;
label:
virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager: void cancelToken(oadd.org.apache.hadoop.security.token.Token,java.lang.String)>(v, v);
label:
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void sendError(int,java.lang.String)>(404, "Invalid delegation token, cannot cancel");
v = 0;
label:
if v == 0 goto label;
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void setStatus(int)>(200);
if v == null goto label;
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void setContentType(java.lang.String)>("application/json");
v = interfaceinvoke v.<javax.servlet.http.HttpServletResponse: java.io.PrintWriter getWriter()>();
v = new oadd.com.fasterxml.jackson.databind.ObjectMapper;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.com.fasterxml.jackson.core.JsonFactory jsonFactory>;
specialinvoke v.<oadd.com.fasterxml.jackson.databind.ObjectMapper: void <init>(oadd.com.fasterxml.jackson.core.JsonFactory)>(v);
virtualinvoke v.<oadd.com.fasterxml.jackson.databind.ObjectMapper: void writeValue(java.io.Writer,java.lang.Object)>(v, v);
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.lang.String ENTER>;
virtualinvoke v.<java.io.Writer: void write(java.lang.String)>(v);
virtualinvoke v.<java.io.Writer: void flush()>();
label:
v = 0;
goto label;
label:
v = newarray (java.lang.Object)[3];
v = interfaceinvoke v.<javax.servlet.http.HttpServletRequest: java.lang.String getMethod()>();
v[0] = v;
v[1] = v;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: java.lang.String getHttpMethod()>();
v[2] = v;
v = staticinvoke <java.text.MessageFormat: java.lang.String format(java.lang.String,java.lang.Object[])>("Wrong HTTP method [{0}] for operation [{1}], it should be [{2}]", v);
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void sendError(int,java.lang.String)>(400, v);
v = 0;
label:
return v;
catch oadd.org.apache.hadoop.security.authorize.AuthorizationException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
}
private static java.util.Map delegationTokenToJSON(oadd.org.apache.hadoop.security.token.Token) throws java.io.IOException
{
java.util.LinkedHashMap v, v;
oadd.org.apache.hadoop.security.token.Token v;
java.lang.String v;
v := @parameter: oadd.org.apache.hadoop.security.token.Token;
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.Token: java.lang.String encodeToUrlString()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("urlString", v);
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("Token", v);
return v;
}
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
{
java.lang.Throwable v;
oadd.org.apache.hadoop.security.authentication.client.AuthenticationException v;
javax.servlet.http.HttpServletRequest v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
java.lang.String v, v, v, v;
oadd.org.apache.hadoop.security.UserGroupInformation v;
org.slf4j.Logger v, v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken v, v;
javax.servlet.http.HttpServletResponse v;
oadd.org.apache.hadoop.security.token.Token v;
oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler v, v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager v;
java.lang.Class v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: javax.servlet.http.HttpServletRequest;
v := @parameter: javax.servlet.http.HttpServletResponse;
v = specialinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.lang.String getDelegationToken(javax.servlet.http.HttpServletRequest)>(v);
if v == null goto label;
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Authenticating with dt param: {}", v);
label:
v = new oadd.org.apache.hadoop.security.token.Token;
specialinvoke v.<oadd.org.apache.hadoop.security.token.Token: void <init>()>();
virtualinvoke v.<oadd.org.apache.hadoop.security.token.Token: void decodeFromUrlString(java.lang.String)>(v);
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager tokenManager>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenManager: oadd.org.apache.hadoop.security.UserGroupInformation verifyToken(oadd.org.apache.hadoop.security.token.Token)>(v);
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: java.lang.String getShortUserName()>();
v = new oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.UserGroupInformation: java.lang.String getUserName()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.lang.String getType()>();
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken: void <init>(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
v = v;
virtualinvoke v.<oadd.org.apache.hadoop.security.authentication.server.AuthenticationToken: void setExpires(long)>(0L);
interfaceinvoke v.<javax.servlet.http.HttpServletRequest: void setAttribute(java.lang.String,java.lang.Object)>("hadoop.security.delegation-token.ugi", v);
label:
goto label;
label:
v := @caughtexception;
v = null;
v = new oadd.org.apache.hadoop.security.authentication.client.AuthenticationException;
specialinvoke v.<oadd.org.apache.hadoop.security.authentication.client.AuthenticationException: void <init>(java.lang.Throwable)>(v);
staticinvoke <oadd.org.apache.hadoop.util.HttpExceptionUtils: void createServletExceptionResponse(javax.servlet.http.HttpServletResponse,int,java.lang.Throwable)>(v, 403, v);
goto label;
label:
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: org.slf4j.Logger LOG>;
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler authHandler>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Falling back to {} (req={})", v, v);
v = v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: oadd.org.apache.hadoop.security.authentication.server.AuthenticationHandler authHandler>;
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);
label:
return v;
catch java.lang.Throwable from label to label with label;
}
private java.lang.String getDelegationToken(javax.servlet.http.HttpServletRequest) throws java.io.IOException
{
javax.servlet.http.HttpServletRequest v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler v;
java.lang.String v;
v := @this: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler;
v := @parameter: javax.servlet.http.HttpServletRequest;
v = interfaceinvoke v.<javax.servlet.http.HttpServletRequest: java.lang.String getHeader(java.lang.String)>("X-Hadoop-Delegation-Token");
if v != null goto label;
v = staticinvoke <oadd.org.apache.hadoop.security.token.delegation.web.ServletUtils: java.lang.String getParameter(javax.servlet.http.HttpServletRequest,java.lang.String)>(v, "delegation");
label:
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
java.util.Set v, v, v;
java.util.HashSet v;
java.lang.String v, v, v, v;
oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation v, v, v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/hadoop/security/token/delegation/web/DelegationTokenAuthenticationHandler;");
<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: org.slf4j.Logger LOG> = v;
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.util.Set DELEGATION_TOKEN_OPS> = v;
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.util.Set DELEGATION_TOKEN_OPS>;
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation GETDELEGATIONTOKEN>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: java.lang.String toString()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.util.Set DELEGATION_TOKEN_OPS>;
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation RENEWDELEGATIONTOKEN>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: java.lang.String toString()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.util.Set DELEGATION_TOKEN_OPS>;
v = <oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation CANCELDELEGATIONTOKEN>;
v = virtualinvoke v.<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticator$DelegationTokenOperation: java.lang.String toString()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("line.separator");
<oadd.org.apache.hadoop.security.token.delegation.web.DelegationTokenAuthenticationHandler: java.lang.String ENTER> = v;
return;
}
}