public class org.apache.hive.http.HttpServer extends java.lang.Object
{
private static final org.slf4j.Logger LOG;
public static final java.lang.String CONF_CONTEXT_ATTRIBUTE;
public static final java.lang.String ADMINS_ACL;
private org.apache.hive.http.HttpServer$XFrameOption xFrameOption;
private boolean xFrameOptionIsEnabled;
private boolean isSSLEnabled;
public static final java.lang.String HTTP_HEADER_PREFIX;
private static final java.lang.String X_FRAME_OPTIONS;
static final java.lang.String X_XSS_PROTECTION;
static final java.lang.String X_CONTENT_TYPE_OPTIONS;
static final java.lang.String STRICT_TRANSPORT_SECURITY;
private static final java.lang.String HTTP_HEADER_REGEX;
private static final java.util.regex.Pattern PATTERN_HTTP_HEADER_REGEX;
private final java.lang.String name;
private java.lang.String appDir;
private org.eclipse.jetty.webapp.WebAppContext webAppContext;
private org.eclipse.jetty.server.Server webServer;
private void <init>(org.apache.hive.http.HttpServer$Builder) throws java.io.IOException
{
org.apache.hive.http.HttpServer v;
org.apache.hive.http.HttpServer$Builder v;
org.apache.hive.http.HttpServer$XFrameOption v;
java.lang.String v;
boolean v, v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
specialinvoke v.<java.lang.Object: void <init>()>();
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String name>;
v.<org.apache.hive.http.HttpServer: java.lang.String name> = v;
v = v.<org.apache.hive.http.HttpServer$Builder: boolean xFrameEnabled>;
v.<org.apache.hive.http.HttpServer: boolean xFrameOptionIsEnabled> = v;
v = v.<org.apache.hive.http.HttpServer$Builder: boolean useSSL>;
v.<org.apache.hive.http.HttpServer: boolean isSSLEnabled> = v;
v = v.<org.apache.hive.http.HttpServer$Builder: org.apache.hive.http.HttpServer$XFrameOption xFrameOption>;
v.<org.apache.hive.http.HttpServer: org.apache.hive.http.HttpServer$XFrameOption xFrameOption> = v;
specialinvoke v.<org.apache.hive.http.HttpServer: void createWebServer(org.apache.hive.http.HttpServer$Builder)>(v);
return;
}
public void start() throws java.lang.Exception
{
org.slf4j.Logger v;
org.apache.hive.http.HttpServer v;
int v;
java.lang.String v;
java.lang.Integer v;
org.eclipse.jetty.server.Server v;
v := @this: org.apache.hive.http.HttpServer;
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
virtualinvoke v.<org.eclipse.jetty.server.Server: void start()>();
v = <org.apache.hive.http.HttpServer: org.slf4j.Logger LOG>;
v = v.<org.apache.hive.http.HttpServer: java.lang.String name>;
v = virtualinvoke v.<org.apache.hive.http.HttpServer: int getPort()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("Started HttpServer[{}] on port {}", v, v);
return;
}
public void stop() throws java.lang.Exception
{
org.eclipse.jetty.server.Server v;
org.apache.hive.http.HttpServer v;
v := @this: org.apache.hive.http.HttpServer;
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
virtualinvoke v.<org.eclipse.jetty.server.Server: void stop()>();
return;
}
public int getPort()
{
org.apache.hive.http.HttpServer v;
int v;
org.eclipse.jetty.server.Connector[] v;
org.eclipse.jetty.server.Connector v;
org.eclipse.jetty.server.Server v;
v := @this: org.apache.hive.http.HttpServer;
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
v = virtualinvoke v.<org.eclipse.jetty.server.Server: org.eclipse.jetty.server.Connector[] getConnectors()>();
v = v[0];
v = virtualinvoke v.<org.eclipse.jetty.server.ServerConnector: int getLocalPort()>();
return v;
}
public static boolean isInstrumentationAccessAllowed(javax.servlet.ServletContext, javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) throws java.io.IOException
{
javax.servlet.http.HttpServletRequest v;
javax.servlet.http.HttpServletResponse v;
java.lang.Object v;
javax.servlet.ServletContext v;
boolean v, v;
v := @parameter: javax.servlet.ServletContext;
v := @parameter: javax.servlet.http.HttpServletRequest;
v := @parameter: javax.servlet.http.HttpServletResponse;
v = interfaceinvoke v.<javax.servlet.ServletContext: java.lang.Object getAttribute(java.lang.String)>("hive.conf");
v = 1;
v = virtualinvoke v.<org.apache.hadoop.conf.Configuration: boolean getBoolean(java.lang.String,boolean)>("hadoop.security.instrumentation.requires.admin", 0);
if v == 0 goto label;
v = staticinvoke <org.apache.hive.http.HttpServer: boolean hasAdministratorAccess(javax.servlet.ServletContext,javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)>(v, v, v);
label:
return v;
}
public static boolean isInstrumentationAccessAllowedStrict(javax.servlet.ServletContext, javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) throws java.io.IOException
{
javax.servlet.http.HttpServletRequest v;
javax.servlet.http.HttpServletResponse v;
java.lang.Object v;
javax.servlet.ServletContext v;
boolean v, v;
v := @parameter: javax.servlet.ServletContext;
v := @parameter: javax.servlet.http.HttpServletRequest;
v := @parameter: javax.servlet.http.HttpServletResponse;
v = interfaceinvoke v.<javax.servlet.ServletContext: java.lang.Object getAttribute(java.lang.String)>("hive.conf");
v = virtualinvoke v.<org.apache.hadoop.conf.Configuration: boolean getBoolean(java.lang.String,boolean)>("hadoop.security.instrumentation.requires.admin", 0);
if v == 0 goto label;
v = staticinvoke <org.apache.hive.http.HttpServer: boolean hasAdministratorAccess(javax.servlet.ServletContext,javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)>(v, v, v);
goto label;
label:
return 0;
label:
return v;
}
public static boolean hasAccess(java.lang.String, java.lang.String, javax.servlet.ServletContext, javax.servlet.http.HttpServletRequest) throws java.io.IOException
{
javax.servlet.http.HttpServletRequest v;
javax.servlet.ServletContext v;
java.lang.String v, v;
boolean v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: javax.servlet.ServletContext;
v := @parameter: javax.servlet.http.HttpServletRequest;
v = staticinvoke <org.apache.commons.lang.StringUtils: boolean equalsIgnoreCase(java.lang.CharSequence,java.lang.CharSequence)>(v, v);
if v != 0 goto label;
v = staticinvoke <org.apache.hive.http.HttpServer: boolean hasAdministratorAccess(javax.servlet.ServletContext,javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)>(v, v, null);
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
static boolean hasAdministratorAccess(javax.servlet.ServletContext, javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) throws java.io.IOException
{
javax.servlet.http.HttpServletResponse v;
javax.servlet.http.HttpServletRequest v;
java.lang.Object v, v;
javax.servlet.ServletContext v;
java.lang.String v, v;
boolean v, v;
v := @parameter: javax.servlet.ServletContext;
v := @parameter: javax.servlet.http.HttpServletRequest;
v := @parameter: javax.servlet.http.HttpServletResponse;
v = interfaceinvoke v.<javax.servlet.ServletContext: java.lang.Object getAttribute(java.lang.String)>("hive.conf");
v = virtualinvoke v.<org.apache.hadoop.conf.Configuration: boolean getBoolean(java.lang.String,boolean)>("hadoop.security.authorization", 0);
if v != 0 goto label;
return 1;
label:
v = interfaceinvoke v.<javax.servlet.http.HttpServletRequest: java.lang.String getRemoteUser()>();
if v != null goto label;
if v == null goto label;
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void sendError(int,java.lang.String)>(401, "Unauthenticated users are not authorized to access this page.");
label:
return 0;
label:
v = interfaceinvoke v.<javax.servlet.ServletContext: java.lang.Object getAttribute(java.lang.String)>("admins.acl");
if v == null goto label;
v = staticinvoke <org.apache.hive.http.HttpServer: boolean userHasAdministratorAccess(javax.servlet.ServletContext,java.lang.String)>(v, v);
if v != 0 goto label;
if v == null goto label;
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[])>("User \u is unauthorized to access this page.");
interfaceinvoke v.<javax.servlet.http.HttpServletResponse: void sendError(int,java.lang.String)>(401, v);
label:
return 0;
label:
return 1;
}
static boolean userHasAdministratorAccess(javax.servlet.ServletContext, java.lang.String)
{
org.apache.hadoop.security.UserGroupInformation v;
java.lang.Object v;
javax.servlet.ServletContext v;
java.lang.String v;
boolean v, v;
v := @parameter: javax.servlet.ServletContext;
v := @parameter: java.lang.String;
v = interfaceinvoke v.<javax.servlet.ServletContext: java.lang.Object getAttribute(java.lang.String)>("admins.acl");
v = staticinvoke <org.apache.hadoop.security.UserGroupInformation: org.apache.hadoop.security.UserGroupInformation createRemoteUser(java.lang.String)>(v);
if v == null goto label;
v = virtualinvoke v.<org.apache.hadoop.security.authorize.AccessControlList: boolean isUserAllowed(org.apache.hadoop.security.UserGroupInformation)>(v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
org.eclipse.jetty.webapp.WebAppContext createWebAppContext(org.apache.hive.http.HttpServer$Builder)
{
org.eclipse.jetty.webapp.WebAppContext v;
javax.servlet.SessionCookieConfig v;
org.apache.hive.http.HttpServer$Builder v;
org.eclipse.jetty.server.handler.ContextHandler$Context v, v;
java.util.Map v;
org.apache.hive.http.HttpServer v;
java.lang.String v, v, v, v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
v = new org.eclipse.jetty.webapp.WebAppContext;
specialinvoke v.<org.eclipse.jetty.webapp.WebAppContext: void <init>()>();
v = virtualinvoke v.<org.eclipse.jetty.webapp.WebAppContext: org.eclipse.jetty.server.handler.ContextHandler$Context getServletContext()>();
v = v.<org.apache.hive.http.HttpServer$Builder: java.util.Map contextAttrs>;
virtualinvoke v.<org.apache.hive.http.HttpServer: void setContextAttributes(org.eclipse.jetty.server.handler.ContextHandler$Context,java.util.Map)>(v, v);
v = virtualinvoke v.<org.eclipse.jetty.webapp.WebAppContext: org.eclipse.jetty.server.handler.ContextHandler$Context getServletContext()>();
v = virtualinvoke v.<org.eclipse.jetty.server.handler.ContextHandler$Context: javax.servlet.SessionCookieConfig getSessionCookieConfig()>();
interfaceinvoke v.<javax.servlet.SessionCookieConfig: void setHttpOnly(boolean)>(1);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String name>;
virtualinvoke v.<org.eclipse.jetty.webapp.WebAppContext: void setDisplayName(java.lang.String)>(v);
virtualinvoke v.<org.eclipse.jetty.webapp.WebAppContext: void setContextPath(java.lang.String)>("/");
v = v.<org.apache.hive.http.HttpServer: java.lang.String appDir>;
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String name>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, 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[])>("\u0001/\u0001");
virtualinvoke v.<org.eclipse.jetty.webapp.WebAppContext: void setWar(java.lang.String)>(v);
return v;
}
void setupSpnegoFilter(org.apache.hive.http.HttpServer$Builder, org.eclipse.jetty.servlet.ServletContextHandler) throws java.io.IOException
{
org.eclipse.jetty.servlet.ServletContextHandler v;
org.eclipse.jetty.servlet.ServletHandler v;
org.apache.hive.http.HttpServer$Builder v;
java.util.HashMap v;
org.eclipse.jetty.servlet.FilterHolder v;
org.apache.hive.http.HttpServer v;
java.lang.Class v;
java.lang.String v, v, v, v, v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
v := @parameter: org.eclipse.jetty.servlet.ServletContextHandler;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String spnegoPrincipal>;
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String host>;
v = staticinvoke <org.apache.hadoop.security.SecurityUtil: java.lang.String getServerPrincipal(java.lang.String,java.lang.String)>(v, v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("kerberos.principal", v);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String spnegoKeytab>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("kerberos.keytab", v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("type", "kerberos");
v = new org.eclipse.jetty.servlet.FilterHolder;
specialinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void <init>()>();
v = class "Lorg/apache/hadoop/security/authentication/server/AuthenticationFilter;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setClassName(java.lang.String)>(v);
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameters(java.util.Map)>(v);
v = virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: org.eclipse.jetty.servlet.ServletHandler getServletHandler()>();
virtualinvoke v.<org.eclipse.jetty.servlet.ServletHandler: void addFilterWithMapping(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,int)>(v, "/*", 31);
return;
}
private void setupCORSFilter(org.apache.hive.http.HttpServer$Builder)
{
org.eclipse.jetty.webapp.WebAppContext v;
org.eclipse.jetty.servlet.ServletHandler v;
org.apache.hive.http.HttpServer$Builder v;
java.util.HashMap v;
org.eclipse.jetty.servlet.FilterHolder v;
org.apache.hive.http.HttpServer v;
java.lang.Class v;
java.lang.String v, v, v, v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
v = new org.eclipse.jetty.servlet.FilterHolder;
specialinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void <init>()>();
v = class "Lorg/apache/hadoop/security/http/CrossOriginFilter;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setClassName(java.lang.String)>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String allowedOrigins>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("allowed-origins", v);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String allowedMethods>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("allowed-methods", v);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String allowedHeaders>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("allowed-headers", v);
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameters(java.util.Map)>(v);
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.webapp.WebAppContext webAppContext>;
v = virtualinvoke v.<org.eclipse.jetty.webapp.WebAppContext: org.eclipse.jetty.servlet.ServletHandler getServletHandler()>();
virtualinvoke v.<org.eclipse.jetty.servlet.ServletHandler: void addFilterWithMapping(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,int)>(v, "/*", 31);
return;
}
org.eclipse.jetty.server.Connector createChannelConnector(int, org.apache.hive.http.HttpServer$Builder)
{
org.apache.hive.http.HttpServer v;
com.google.common.base.Splitter v, v, v, v, v, v;
org.eclipse.jetty.server.Server v, v;
boolean v, v, v, v;
org.apache.hive.http.HttpServer$Builder v;
org.eclipse.jetty.server.HttpConnectionFactory v;
java.lang.Object[] v, v, v, v;
java.lang.String[] v, v;
java.lang.Iterable v, v;
java.util.HashSet v, v;
org.eclipse.jetty.server.HttpConfiguration v;
org.apache.hadoop.hive.conf.HiveConf$ConfVars v;
org.eclipse.jetty.util.ssl.SslContextFactory$Server v;
int v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.hadoop.hive.conf.HiveConf v;
org.eclipse.jetty.server.ServerConnector v, v, v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: int;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
v = new org.eclipse.jetty.server.HttpConfiguration;
specialinvoke v.<org.eclipse.jetty.server.HttpConfiguration: void <init>()>();
virtualinvoke v.<org.eclipse.jetty.server.HttpConfiguration: void setRequestHeaderSize(int)>(65536);
v = new org.eclipse.jetty.server.HttpConnectionFactory;
specialinvoke v.<org.eclipse.jetty.server.HttpConnectionFactory: void <init>(org.eclipse.jetty.server.HttpConfiguration)>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: boolean useSSL>;
if v != 0 goto label;
v = new org.eclipse.jetty.server.ServerConnector;
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
v = newarray (org.eclipse.jetty.server.ConnectionFactory)[1];
v[0] = v;
specialinvoke v.<org.eclipse.jetty.server.ServerConnector: void <init>(org.eclipse.jetty.server.Server,org.eclipse.jetty.server.ConnectionFactory[])>(v, v);
v = v;
goto label;
label:
v = new org.eclipse.jetty.util.ssl.SslContextFactory$Server;
specialinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory$Server: void <init>()>();
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String keyStorePath>;
virtualinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory: void setKeyStorePath(java.lang.String)>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String keyStoreType>;
if v == null goto label;
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String keyStoreType>;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
label:
v = staticinvoke <java.security.KeyStore: java.lang.String getDefaultType()>();
goto label;
label:
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String keyStoreType>;
label:
virtualinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory: void setKeyStoreType(java.lang.String)>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String keyManagerFactoryAlgorithm>;
if v == null goto label;
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String keyManagerFactoryAlgorithm>;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
label:
v = staticinvoke <javax.net.ssl.KeyManagerFactory: java.lang.String getDefaultAlgorithm()>();
goto label;
label:
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String keyManagerFactoryAlgorithm>;
label:
virtualinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory: void setKeyManagerFactoryAlgorithm(java.lang.String)>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String excludeCiphersuites>;
if v == null goto label;
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String excludeCiphersuites>;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = staticinvoke <com.google.common.base.Splitter: com.google.common.base.Splitter on(java.lang.String)>(",");
v = virtualinvoke v.<com.google.common.base.Splitter: com.google.common.base.Splitter trimResults()>();
v = virtualinvoke v.<com.google.common.base.Splitter: com.google.common.base.Splitter omitEmptyStrings()>();
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String excludeCiphersuites>;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<com.google.common.base.Splitter: java.lang.Iterable split(java.lang.CharSequence)>(v);
v = staticinvoke <com.google.common.collect.Sets: java.util.HashSet newHashSet(java.lang.Iterable)>(v);
v = interfaceinvoke v.<java.util.Set: int size()>();
if v <= 0 goto label;
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
virtualinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory: void setExcludeCipherSuites(java.lang.String[])>(v);
label:
v = staticinvoke <com.google.common.base.Splitter: com.google.common.base.Splitter on(java.lang.String)>(",");
v = virtualinvoke v.<com.google.common.base.Splitter: com.google.common.base.Splitter trimResults()>();
v = virtualinvoke v.<com.google.common.base.Splitter: com.google.common.base.Splitter omitEmptyStrings()>();
v = v.<org.apache.hive.http.HttpServer$Builder: org.apache.hadoop.hive.conf.HiveConf conf>;
v = <org.apache.hadoop.hive.conf.HiveConf$ConfVars: org.apache.hadoop.hive.conf.HiveConf$ConfVars HIVE_SSL_PROTOCOL_BLACKLIST>;
v = virtualinvoke v.<org.apache.hadoop.hive.conf.HiveConf: java.lang.String getVar(org.apache.hadoop.hive.conf.HiveConf$ConfVars)>(v);
v = staticinvoke <com.google.common.base.Strings: java.lang.String nullToEmpty(java.lang.String)>(v);
v = virtualinvoke v.<com.google.common.base.Splitter: java.lang.Iterable split(java.lang.CharSequence)>(v);
v = staticinvoke <com.google.common.collect.Sets: java.util.HashSet newHashSet(java.lang.Iterable)>(v);
v = interfaceinvoke v.<java.util.Set: int size()>();
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
virtualinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory: void addExcludeProtocols(java.lang.String[])>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String keyStorePassword>;
virtualinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory: void setKeyStorePassword(java.lang.String)>(v);
v = new org.eclipse.jetty.server.ServerConnector;
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
v = newarray (org.eclipse.jetty.server.ConnectionFactory)[1];
v[0] = v;
specialinvoke v.<org.eclipse.jetty.server.ServerConnector: void <init>(org.eclipse.jetty.server.Server,org.eclipse.jetty.util.ssl.SslContextFactory,org.eclipse.jetty.server.ConnectionFactory[])>(v, v, v);
v = v;
label:
virtualinvoke v.<org.eclipse.jetty.server.ServerConnector: void setAcceptQueueSize(int)>(v);
virtualinvoke v.<org.eclipse.jetty.server.ServerConnector: void setReuseAddress(boolean)>(1);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String host>;
virtualinvoke v.<org.eclipse.jetty.server.ServerConnector: void setHost(java.lang.String)>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: int port>;
virtualinvoke v.<org.eclipse.jetty.server.ServerConnector: void setPort(int)>(v);
return v;
}
void setupPam(org.apache.hive.http.HttpServer$Builder, org.eclipse.jetty.server.Handler)
{
org.eclipse.jetty.server.Handler v;
org.apache.hive.http.HttpServer$Builder v;
org.apache.hive.http.security.PamAuthenticator v;
org.eclipse.jetty.security.ConstraintSecurityHandler v;
java.util.List v;
org.apache.hive.http.security.PamLoginService v;
org.apache.hive.http.HttpServer v;
org.apache.hive.http.security.PamConstraint v;
org.apache.hive.http.security.PamConstraintMapping v;
org.eclipse.jetty.server.Server v, v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
v := @parameter: org.eclipse.jetty.server.Handler;
v = new org.apache.hive.http.security.PamLoginService;
specialinvoke v.<org.apache.hive.http.security.PamLoginService: void <init>()>();
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
virtualinvoke v.<org.eclipse.jetty.server.Server: boolean addBean(java.lang.Object)>(v);
v = new org.eclipse.jetty.security.ConstraintSecurityHandler;
specialinvoke v.<org.eclipse.jetty.security.ConstraintSecurityHandler: void <init>()>();
v = new org.apache.hive.http.security.PamConstraint;
specialinvoke v.<org.apache.hive.http.security.PamConstraint: void <init>()>();
v = new org.apache.hive.http.security.PamConstraintMapping;
specialinvoke v.<org.apache.hive.http.security.PamConstraintMapping: void <init>(org.eclipse.jetty.util.security.Constraint)>(v);
v = staticinvoke <java.util.Collections: java.util.List singletonList(java.lang.Object)>(v);
virtualinvoke v.<org.eclipse.jetty.security.ConstraintSecurityHandler: void setConstraintMappings(java.util.List)>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: org.apache.hive.http.security.PamAuthenticator pamAuthenticator>;
virtualinvoke v.<org.eclipse.jetty.security.ConstraintSecurityHandler: void setAuthenticator(org.eclipse.jetty.security.Authenticator)>(v);
virtualinvoke v.<org.eclipse.jetty.security.ConstraintSecurityHandler: void setLoginService(org.eclipse.jetty.security.LoginService)>(v);
virtualinvoke v.<org.eclipse.jetty.security.ConstraintSecurityHandler: void setHandler(org.eclipse.jetty.server.Handler)>(v);
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
virtualinvoke v.<org.eclipse.jetty.server.Server: void setHandler(org.eclipse.jetty.server.Handler)>(v);
return;
}
void setContextAttributes(org.eclipse.jetty.server.handler.ContextHandler$Context, java.util.Map)
{
java.util.Iterator v;
java.util.Set v;
org.eclipse.jetty.server.handler.ContextHandler$Context v;
java.util.Map v;
org.apache.hive.http.HttpServer v;
java.lang.Object v, v, v;
boolean v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.eclipse.jetty.server.handler.ContextHandler$Context;
v := @parameter: java.util.Map;
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 = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
virtualinvoke v.<org.eclipse.jetty.server.handler.ContextHandler$Context: void setAttribute(java.lang.String,java.lang.Object)>(v, v);
goto label;
label:
return;
}
private void createWebServer(org.apache.hive.http.HttpServer$Builder) throws java.io.IOException
{
org.eclipse.jetty.webapp.WebAppContext v, v, v;
org.eclipse.jetty.util.thread.QueuedThreadPool v;
java.util.Map v;
org.apache.hive.http.HttpServer v;
int v, v, v;
java.lang.String v, v, v, v;
org.eclipse.jetty.server.Server v;
boolean v, v, v, v;
org.apache.hive.http.HttpServer$Builder v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
v = new org.eclipse.jetty.util.thread.QueuedThreadPool;
specialinvoke v.<org.eclipse.jetty.util.thread.QueuedThreadPool: void <init>()>();
v = v.<org.apache.hive.http.HttpServer$Builder: int maxThreads>;
if v <= 0 goto label;
v = v.<org.apache.hive.http.HttpServer$Builder: int maxThreads>;
virtualinvoke v.<org.eclipse.jetty.util.thread.QueuedThreadPool: void setMaxThreads(int)>(v);
label:
virtualinvoke v.<org.eclipse.jetty.util.thread.QueuedThreadPool: void setDaemon(boolean)>(1);
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String name>;
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[])>("\u0001-web");
virtualinvoke v.<org.eclipse.jetty.util.thread.QueuedThreadPool: void setName(java.lang.String)>(v);
v = new org.eclipse.jetty.server.Server;
specialinvoke v.<org.eclipse.jetty.server.Server: void <init>(org.eclipse.jetty.util.thread.ThreadPool)>(v);
v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer> = v;
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String name>;
v = virtualinvoke v.<org.apache.hive.http.HttpServer: java.lang.String getWebAppsPath(java.lang.String)>(v);
v.<org.apache.hive.http.HttpServer: java.lang.String appDir> = v;
v = virtualinvoke v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.webapp.WebAppContext createWebAppContext(org.apache.hive.http.HttpServer$Builder)>(v);
v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.webapp.WebAppContext webAppContext> = v;
v = v.<org.apache.hive.http.HttpServer$Builder: boolean useSPNEGO>;
if v == 0 goto label;
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.webapp.WebAppContext webAppContext>;
virtualinvoke v.<org.apache.hive.http.HttpServer: void setupSpnegoFilter(org.apache.hive.http.HttpServer$Builder,org.eclipse.jetty.servlet.ServletContextHandler)>(v, v);
label:
v = v.<org.apache.hive.http.HttpServer$Builder: boolean enableCORS>;
if v == 0 goto label;
specialinvoke v.<org.apache.hive.http.HttpServer: void setupCORSFilter(org.apache.hive.http.HttpServer$Builder)>(v);
label:
v = specialinvoke v.<org.apache.hive.http.HttpServer: java.util.Map setHeaders()>();
v = v.<org.apache.hive.http.HttpServer$Builder: boolean xFrameEnabled>;
if v == 0 goto label;
specialinvoke v.<org.apache.hive.http.HttpServer: void setupXframeFilter(org.apache.hive.http.HttpServer$Builder,java.util.Map)>(v, v);
label:
v = v.<org.apache.hive.http.HttpServer$Builder: boolean disableDirListing>;
if v == 0 goto label;
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.webapp.WebAppContext webAppContext>;
staticinvoke <org.apache.hive.http.HttpServer: void disableDirectoryListingOnServlet(org.eclipse.jetty.servlet.ServletContextHandler)>(v);
label:
v = virtualinvoke v.<org.eclipse.jetty.util.thread.QueuedThreadPool: int getMaxThreads()>();
specialinvoke v.<org.apache.hive.http.HttpServer: void initializeWebServer(org.apache.hive.http.HttpServer$Builder,int)>(v, v);
return;
}
private void initializeWebServer(org.apache.hive.http.HttpServer$Builder, int) throws java.io.IOException
{
org.eclipse.jetty.servlet.ServletContextHandler v, v, v;
org.eclipse.jetty.webapp.WebAppContext v;
org.eclipse.jetty.server.handler.ContextHandlerCollection v;
org.eclipse.jetty.rewrite.handler.RewriteHandler v;
org.eclipse.jetty.server.LowResourceMonitor v;
java.nio.file.attribute.FileAttribute[] v;
org.eclipse.jetty.server.handler.ContextHandler$Context v, v;
java.util.Map v, v;
org.apache.hive.http.HttpServer v;
java.nio.file.Path v, v;
org.eclipse.jetty.server.Server v, v, v, v;
boolean v, v, v, v, v;
org.eclipse.jetty.rewrite.handler.RewriteRegexRule v;
org.apache.hive.http.HttpServer$Builder v;
java.util.List v;
java.lang.String[] v;
int v;
java.lang.String v, v, v, v, v, v, v, v, v;
org.slf4j.Logger v;
java.nio.file.LinkOption[] v;
java.util.Iterator v;
org.apache.hadoop.hive.conf.HiveConf v;
java.lang.Object v, v, v, v;
org.eclipse.jetty.server.Connector v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
v := @parameter: int;
v = new org.eclipse.jetty.server.LowResourceMonitor;
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
specialinvoke v.<org.eclipse.jetty.server.LowResourceMonitor: void <init>(org.eclipse.jetty.server.Server)>(v);
virtualinvoke v.<org.eclipse.jetty.server.LowResourceMonitor: void setLowResourcesIdleTimeout(int)>(10000);
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
virtualinvoke v.<org.eclipse.jetty.server.Server: boolean addBean(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Connector createChannelConnector(int,org.apache.hive.http.HttpServer$Builder)>(v, v);
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
virtualinvoke v.<org.eclipse.jetty.server.Server: void addConnector(org.eclipse.jetty.server.Connector)>(v);
v = new org.eclipse.jetty.rewrite.handler.RewriteHandler;
specialinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteHandler: void <init>()>();
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteHandler: void setRewriteRequestURI(boolean)>(1);
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteHandler: void setRewritePathInfo(boolean)>(0);
v = new org.eclipse.jetty.rewrite.handler.RewriteRegexRule;
specialinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteRegexRule: void <init>()>();
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteRegexRule: void setRegex(java.lang.String)>("^/$");
v = v.<org.apache.hive.http.HttpServer$Builder: java.lang.String contextRootRewriteTarget>;
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteRegexRule: void setReplacement(java.lang.String)>(v);
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteRegexRule: void setTerminating(boolean)>(1);
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteHandler: void addRule(org.eclipse.jetty.rewrite.handler.Rule)>(v);
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.webapp.WebAppContext webAppContext>;
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteHandler: void setHandler(org.eclipse.jetty.server.Handler)>(v);
v = new org.eclipse.jetty.server.handler.ContextHandlerCollection;
specialinvoke v.<org.eclipse.jetty.server.handler.ContextHandlerCollection: void <init>()>();
virtualinvoke v.<org.eclipse.jetty.server.handler.ContextHandlerCollection: void addHandler(org.eclipse.jetty.server.Handler)>(v);
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.server.Server webServer>;
virtualinvoke v.<org.eclipse.jetty.server.Server: void setHandler(org.eclipse.jetty.server.Handler)>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: boolean usePAM>;
if v == 0 goto label;
virtualinvoke v.<org.apache.hive.http.HttpServer: void setupPam(org.apache.hive.http.HttpServer$Builder,org.eclipse.jetty.server.Handler)>(v, v);
label:
virtualinvoke v.<org.apache.hive.http.HttpServer: void addServlet(java.lang.String,java.lang.String,java.lang.Class)>("jmx", "/jmx", class "Lorg/apache/hive/http/JMXJsonServlet;");
virtualinvoke v.<org.apache.hive.http.HttpServer: void addServlet(java.lang.String,java.lang.String,java.lang.Class)>("conf", "/conf", class "Lorg/apache/hive/http/ConfServlet;");
virtualinvoke v.<org.apache.hive.http.HttpServer: void addServlet(java.lang.String,java.lang.String,java.lang.Class)>("stacks", "/stacks", class "Lorg/apache/hive/http/StackServlet;");
virtualinvoke v.<org.apache.hive.http.HttpServer: void addServlet(java.lang.String,java.lang.String,java.lang.Class)>("conflog", "/conflog", class "Lorg/apache/hive/http/Log4j2ConfiguratorServlet;");
v = staticinvoke <org.apache.hive.http.ProfileServlet: java.lang.String getAsyncProfilerHome()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
virtualinvoke v.<org.apache.hive.http.HttpServer: void addServlet(java.lang.String,java.lang.String,java.lang.Class)>("prof", "/prof", class "Lorg/apache/hive/http/ProfileServlet;");
v = <org.apache.hive.http.ProfileServlet: java.lang.String OUTPUT_DIR>;
v = newarray (java.lang.String)[0];
v = staticinvoke <java.nio.file.Paths: java.nio.file.Path get(java.lang.String,java.lang.String[])>(v, v);
v = newarray (java.nio.file.LinkOption)[0];
v = staticinvoke <java.nio.file.Files: boolean notExists(java.nio.file.Path,java.nio.file.LinkOption[])>(v, v);
if v == 0 goto label;
v = newarray (java.nio.file.attribute.FileAttribute)[0];
staticinvoke <java.nio.file.Files: java.nio.file.Path createDirectories(java.nio.file.Path,java.nio.file.attribute.FileAttribute[])>(v, v);
label:
v = new org.eclipse.jetty.servlet.ServletContextHandler;
specialinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void <init>(org.eclipse.jetty.server.HandlerContainer,java.lang.String)>(v, "/prof-output");
v = virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: org.eclipse.jetty.server.handler.ContextHandler$Context getServletContext()>();
v = v.<org.apache.hive.http.HttpServer$Builder: java.util.Map contextAttrs>;
virtualinvoke v.<org.apache.hive.http.HttpServer: void setContextAttributes(org.eclipse.jetty.server.handler.ContextHandler$Context,java.util.Map)>(v, v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: org.eclipse.jetty.servlet.ServletHolder addServlet(java.lang.Class,java.lang.String)>(class "Lorg/apache/hive/http/ProfileOutputServlet;", "/*");
v = interfaceinvoke v.<java.nio.file.Path: java.nio.file.Path toAbsolutePath()>();
v = interfaceinvoke v.<java.nio.file.Path: java.lang.String toString()>();
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void setResourceBase(java.lang.String)>(v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void setDisplayName(java.lang.String)>("prof-output");
goto label;
label:
v = <org.apache.hive.http.HttpServer: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("ASYNC_PROFILER_HOME env or -Dasync.profiler.home not specified. Disabling /prof endpoint..");
label:
v = v.<org.apache.hive.http.HttpServer$Builder: java.util.List servlets>;
v = interfaceinvoke v.<java.util.List: 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 = virtualinvoke v.<org.apache.commons.math.util.Pair: java.lang.Object getFirst()>();
v = virtualinvoke v.<org.apache.commons.math.util.Pair: java.lang.Object getFirst()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Object)>(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[])>("/\u0001");
v = virtualinvoke v.<org.apache.commons.math.util.Pair: java.lang.Object getSecond()>();
virtualinvoke v.<org.apache.hive.http.HttpServer: void addServlet(java.lang.String,java.lang.String,java.lang.Class)>(v, v, v);
goto label;
label:
v = new org.eclipse.jetty.servlet.ServletContextHandler;
specialinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void <init>(org.eclipse.jetty.server.HandlerContainer,java.lang.String)>(v, "/static");
v = v.<org.apache.hive.http.HttpServer: java.lang.String appDir>;
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[])>("\u0001/static");
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void setResourceBase(java.lang.String)>(v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: org.eclipse.jetty.servlet.ServletHolder addServlet(java.lang.Class,java.lang.String)>(class "Lorg/eclipse/jetty/servlet/DefaultServlet;", "/*");
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void setDisplayName(java.lang.String)>("static");
staticinvoke <org.apache.hive.http.HttpServer: void disableDirectoryListingOnServlet(org.eclipse.jetty.servlet.ServletContextHandler)>(v);
v = v.<org.apache.hive.http.HttpServer$Builder: org.apache.hadoop.hive.conf.HiveConf conf>;
v = virtualinvoke v.<org.apache.hive.http.HttpServer: java.lang.String getLogDir(org.apache.hadoop.conf.Configuration)>(v);
if v == null goto label;
v = new org.eclipse.jetty.servlet.ServletContextHandler;
specialinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void <init>(org.eclipse.jetty.server.HandlerContainer,java.lang.String)>(v, "/logs");
v = virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: org.eclipse.jetty.server.handler.ContextHandler$Context getServletContext()>();
v = v.<org.apache.hive.http.HttpServer$Builder: java.util.Map contextAttrs>;
virtualinvoke v.<org.apache.hive.http.HttpServer: void setContextAttributes(org.eclipse.jetty.server.handler.ContextHandler$Context,java.util.Map)>(v, v);
v = v.<org.apache.hive.http.HttpServer$Builder: boolean useSPNEGO>;
if v == 0 goto label;
virtualinvoke v.<org.apache.hive.http.HttpServer: void setupSpnegoFilter(org.apache.hive.http.HttpServer$Builder,org.eclipse.jetty.servlet.ServletContextHandler)>(v, v);
label:
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: org.eclipse.jetty.servlet.ServletHolder addServlet(java.lang.Class,java.lang.String)>(class "Lorg/apache/hive/http/AdminAuthorizedServlet;", "/*");
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void setResourceBase(java.lang.String)>(v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void setDisplayName(java.lang.String)>("logs");
label:
return;
}
private java.util.Map setHeaders()
{
java.util.Map v;
org.apache.hive.http.HttpServer v;
org.apache.hive.http.HttpServer$XFrameOption v;
java.util.HashMap v;
java.lang.String v;
boolean v;
v := @this: org.apache.hive.http.HttpServer;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = specialinvoke v.<org.apache.hive.http.HttpServer: java.util.Map getDefaultHeaders()>();
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
v = v.<org.apache.hive.http.HttpServer: boolean xFrameOptionIsEnabled>;
if v == 0 goto label;
v = v.<org.apache.hive.http.HttpServer: org.apache.hive.http.HttpServer$XFrameOption xFrameOption>;
v = virtualinvoke v.<org.apache.hive.http.HttpServer$XFrameOption: java.lang.String toString()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>("hadoop.http.header.X-FRAME-OPTIONS", v);
label:
return v;
}
private java.util.Map getDefaultHeaders()
{
java.lang.String[] v, v, v;
java.util.HashMap v;
org.apache.hive.http.HttpServer v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v;
boolean v;
v := @this: org.apache.hive.http.HttpServer;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = "X-Content-Type-Options:nosniff";
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(":");
v = v[0];
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[])>("hadoop.http.header.\u0001");
v = v[1];
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = "X-XSS-Protection:1; mode=block";
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(":");
v = v[0];
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[])>("hadoop.http.header.\u0001");
v = v[1];
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.hive.http.HttpServer: boolean isSSLEnabled>;
if v == 0 goto label;
v = "Strict-Transport-Security:max-age=31536000; includeSubDomains";
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>(":");
v = v[0];
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[])>("hadoop.http.header.\u0001");
v = v[1];
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
return v;
}
private void setupXframeFilter(org.apache.hive.http.HttpServer$Builder, java.util.Map)
{
org.eclipse.jetty.webapp.WebAppContext v;
org.eclipse.jetty.servlet.ServletHandler v;
org.apache.hive.http.HttpServer$Builder v;
org.eclipse.jetty.servlet.FilterHolder v;
java.util.Map v;
org.apache.hive.http.HttpServer v;
java.lang.Class v;
java.lang.String v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hive.http.HttpServer$Builder;
v := @parameter: java.util.Map;
v = new org.eclipse.jetty.servlet.FilterHolder;
specialinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void <init>()>();
v = class "Lorg/apache/hive/http/HttpServer$QuotingInputFilter;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setClassName(java.lang.String)>(v);
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameters(java.util.Map)>(v);
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.webapp.WebAppContext webAppContext>;
v = virtualinvoke v.<org.eclipse.jetty.webapp.WebAppContext: org.eclipse.jetty.servlet.ServletHandler getServletHandler()>();
virtualinvoke v.<org.eclipse.jetty.servlet.ServletHandler: void addFilterWithMapping(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,int)>(v, "/*", 31);
return;
}
java.lang.String getLogDir(org.apache.hadoop.conf.Configuration)
{
org.apache.logging.log4j.core.Appender v;
org.apache.logging.log4j.spi.LoggerContext v;
java.util.Map v;
org.apache.hadoop.conf.Configuration v;
org.apache.hive.http.HttpServer v;
int v;
java.lang.String v, v, v;
boolean v, v, v, v;
java.util.Iterator v, v;
java.util.Collection v, v;
java.lang.Object v, v;
org.apache.logging.log4j.core.appender.OutputStreamManager v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: org.apache.hadoop.conf.Configuration;
v = virtualinvoke v.<org.apache.hadoop.conf.Configuration: java.lang.String get(java.lang.String)>("hive.log.dir");
if v != null goto label;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("hive.log.dir");
label:
if v == null goto label;
return v;
label:
v = staticinvoke <org.apache.logging.log4j.LogManager: org.apache.logging.log4j.spi.LoggerContext getContext(boolean)>(0);
v = virtualinvoke v.<org.apache.logging.log4j.core.LoggerContext: java.util.Collection getLoggers()>();
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()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.Logger: java.util.Map getAppenders()>();
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()>();
v = v instanceof org.apache.logging.log4j.core.appender.AbstractOutputStreamAppender;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.AbstractOutputStreamAppender: org.apache.logging.log4j.core.appender.OutputStreamManager getManager()>();
v = v instanceof org.apache.logging.log4j.core.appender.FileManager;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.FileManager: java.lang.String getFileName()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int lastIndexOf(int)>(47);
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, v);
return v;
label:
return null;
}
java.lang.String getWebAppsPath(java.lang.String) throws java.io.FileNotFoundException
{
java.net.URL v;
java.io.FileNotFoundException v;
org.apache.hive.http.HttpServer v;
int v;
java.lang.Class v;
java.lang.ClassLoader v;
java.lang.String v, v, v, v, v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: java.lang.String;
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[])>("hive-webapps/\u0001");
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = virtualinvoke v.<java.lang.ClassLoader: java.net.URL getResource(java.lang.String)>(v);
if v != null goto label;
v = new java.io.FileNotFoundException;
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[])>("\u not found in CLASSPATH");
specialinvoke v.<java.io.FileNotFoundException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.net.URL: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: int lastIndexOf(int)>(47);
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, v);
return v;
}
public void addServlet(java.lang.String, java.lang.String, java.lang.Class)
{
org.eclipse.jetty.webapp.WebAppContext v;
org.apache.hive.http.HttpServer v;
org.eclipse.jetty.servlet.ServletHolder v;
java.lang.Class v;
java.lang.String v, v;
v := @this: org.apache.hive.http.HttpServer;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class;
v = new org.eclipse.jetty.servlet.ServletHolder;
specialinvoke v.<org.eclipse.jetty.servlet.ServletHolder: void <init>(java.lang.Class)>(v);
if v == null goto label;
virtualinvoke v.<org.eclipse.jetty.servlet.ServletHolder: void setName(java.lang.String)>(v);
label:
v = v.<org.apache.hive.http.HttpServer: org.eclipse.jetty.webapp.WebAppContext webAppContext>;
virtualinvoke v.<org.eclipse.jetty.webapp.WebAppContext: void addServlet(org.eclipse.jetty.servlet.ServletHolder,java.lang.String)>(v, v);
return;
}
private static void disableDirectoryListingOnServlet(org.eclipse.jetty.servlet.ServletContextHandler)
{
org.eclipse.jetty.servlet.ServletContextHandler v;
v := @parameter: org.eclipse.jetty.servlet.ServletContextHandler;
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: java.lang.String setInitParameter(java.lang.String,java.lang.String)>("org.eclipse.jetty.servlet.Default.dirAllowed", "false");
return;
}
static void <clinit>()
{
java.util.regex.Pattern v;
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/hive/http/HttpServer;");
<org.apache.hive.http.HttpServer: org.slf4j.Logger LOG> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>("hadoop\\.http\\.header\\.([a-zA-Z\\-_]+)");
<org.apache.hive.http.HttpServer: java.util.regex.Pattern PATTERN_HTTP_HEADER_REGEX> = v;
return;
}
}