public class org.apache.hive.hcatalog.templeton.Main extends java.lang.Object
{
public static final java.lang.String SERVLET_PATH;
private static final org.slf4j.Logger LOG;
public static final int DEFAULT_PORT;
public static final java.lang.String DEFAULT_HOST;
public static final java.lang.String DEFAULT_KEY_STORE_PATH;
public static final java.lang.String DEFAULT_KEY_STORE_PASSWORD;
public static final java.lang.String DEFAULT_SSL_PROTOCOL_BLACKLIST;
private org.eclipse.jetty.server.Server server;
private static volatile org.apache.hive.hcatalog.templeton.AppConfig conf;
public static synchronized org.apache.hive.hcatalog.templeton.AppConfig getAppConfigInstance()
{
org.slf4j.Logger v;
org.apache.hive.hcatalog.templeton.AppConfig v, v;
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
if v != null goto label;
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>("Bug: configuration not yet loaded");
label:
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
return v;
}
void <init>(java.lang.String[])
{
java.lang.String[] v;
org.apache.hive.hcatalog.templeton.Main v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v := @parameter: java.lang.String[];
specialinvoke v.<java.lang.Object: void <init>()>();
virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: void init(java.lang.String[])>(v);
return;
}
public void init(java.lang.String[])
{
org.slf4j.Logger v;
org.apache.hive.hcatalog.templeton.Main v;
org.apache.hive.hcatalog.templeton.AppConfig v, v, v;
java.lang.String[] v;
java.lang.String v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v := @parameter: java.lang.String[];
specialinvoke v.<org.apache.hive.hcatalog.templeton.Main: void initLogger()>();
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig loadConfig(java.lang.String[])>(v);
<org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf> = v;
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: void startCleanup()>();
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.hive.hcatalog.templeton.AppConfig)>(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[])>("Loaded conf \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
return;
}
private void initLogger()
{
org.apache.hive.hcatalog.templeton.Main v;
java.util.logging.LogManager v;
int v, v;
java.util.logging.Handler[] v;
java.util.logging.Handler v;
java.util.logging.Logger v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = staticinvoke <java.util.logging.LogManager: java.util.logging.LogManager getLogManager()>();
v = virtualinvoke v.<java.util.logging.LogManager: java.util.logging.Logger getLogger(java.lang.String)>("");
v = virtualinvoke v.<java.util.logging.Logger: java.util.logging.Handler[] getHandlers()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
virtualinvoke v.<java.util.logging.Logger: void removeHandler(java.util.logging.Handler)>(v);
v = v + 1;
goto label;
label:
staticinvoke <org.slf4j.bridge.SLF4JBridgeHandler: void install()>();
return;
}
public org.apache.hive.hcatalog.templeton.AppConfig loadConfig(java.lang.String[])
{
org.slf4j.Logger v;
java.io.IOException v;
java.lang.String[] v, v;
org.apache.hadoop.util.GenericOptionsParser v;
org.apache.hive.hcatalog.templeton.Main v;
org.apache.hive.hcatalog.templeton.AppConfig v;
int v;
java.lang.String v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v := @parameter: java.lang.String[];
v = new org.apache.hive.hcatalog.templeton.AppConfig;
specialinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: void <init>()>();
label:
v = new org.apache.hadoop.util.GenericOptionsParser;
specialinvoke v.<org.apache.hadoop.util.GenericOptionsParser: void <init>(org.apache.hadoop.conf.Configuration,java.lang.String[])>(v, v);
v = virtualinvoke v.<org.apache.hadoop.util.GenericOptionsParser: java.lang.String[] getRemainingArgs()>();
v = lengthof v;
if v <= 0 goto label;
virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: void usage()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.IOException)>(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[])>("Unable to parse options: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: void usage()>();
label:
return v;
catch java.io.IOException from label to label with label;
}
public void usage()
{
java.io.PrintStream v;
org.apache.hive.hcatalog.templeton.Main v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = <java.lang.System: java.io.PrintStream err>;
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>("usage: templeton [-Dtempleton.port=N] [-D...]");
staticinvoke <java.lang.System: void exit(int)>(1);
return;
}
public void run()
{
int v, v, v;
java.lang.String v, v, v, v;
org.eclipse.jetty.server.Server v, v;
boolean v;
java.io.PrintStream v, v;
org.slf4j.Logger v, v;
org.eclipse.jetty.server.Connector[] v, v;
java.lang.Exception v;
org.apache.hive.hcatalog.templeton.Main v;
org.apache.hive.hcatalog.templeton.AppConfig v;
org.eclipse.jetty.server.Connector v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: int getInt(java.lang.String,int)>("templeton.port", 8080);
label:
specialinvoke v.<org.apache.hive.hcatalog.templeton.Main: void checkEnv()>();
virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.server.Server runServer(int)>(v);
v = v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.server.Server server>;
v = virtualinvoke v.<org.eclipse.jetty.server.Server: org.eclipse.jetty.server.Connector[] getConnectors()>();
v = staticinvoke <org.apache.commons.lang.ArrayUtils: boolean isEmpty(java.lang.Object[])>(v);
if v == 0 goto label;
v = (int) -1;
v = v;
goto label;
label:
v = v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.server.Server server>;
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()>();
label:
v = <java.lang.System: java.io.PrintStream out>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("templeton: listening on port \u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("Templeton listening on port \u0001");
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <java.lang.System: java.io.PrintStream err>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
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[])>("templeton: Server failed to start: \u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Server failed to start: ", v);
staticinvoke <java.lang.System: void exit(int)>(1);
label:
return;
catch java.lang.Exception from label to label with label;
}
void stop()
{
org.slf4j.Logger v;
org.apache.hive.hcatalog.templeton.Main v;
org.eclipse.jetty.server.Server v, v;
java.lang.Exception v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.server.Server server>;
if v == null goto label;
label:
v = v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.server.Server server>;
virtualinvoke v.<org.eclipse.jetty.server.Server: void stop()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Failed to stop jetty.Server", v);
label:
return;
catch java.lang.Exception from label to label with label;
}
private void checkEnv()
{
org.apache.hive.hcatalog.templeton.Main v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
specialinvoke v.<org.apache.hive.hcatalog.templeton.Main: void checkCurrentDirPermissions()>();
return;
}
private void checkCurrentDirPermissions()
{
java.io.PrintStream v;
org.slf4j.Logger v;
org.apache.hive.hcatalog.templeton.Main v;
java.io.File v;
boolean v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(".");
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
v = <java.lang.System: java.io.PrintStream err>;
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>("Server failed to start: templeton: Current working directory \'.\' does not exist!");
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>("Server failed to start: templeton: Current working directory \'.\' does not exist!");
staticinvoke <java.lang.System: void exit(int)>(1);
label:
return;
}
public org.eclipse.jetty.server.Server runServer(int) throws java.lang.Exception
{
org.eclipse.jetty.servlet.ServletContextHandler v;
org.eclipse.jetty.server.LowResourceMonitor v;
org.eclipse.jetty.servlet.FilterHolder v, v, v;
org.eclipse.jetty.server.Server v;
org.eclipse.jetty.xml.XmlConfiguration v;
java.util.EnumSet v;
boolean v, v, v;
org.eclipse.jetty.servlet.ServletHolder v;
org.apache.hive.hcatalog.templeton.Main v;
org.apache.hive.hcatalog.templeton.AppConfig v, v, v, v, v;
com.sun.jersey.api.core.PackagesResourceConfig v;
com.sun.jersey.spi.container.servlet.ServletContainer v;
int v;
java.lang.String v, v, v, v, v;
org.slf4j.Logger v, v;
org.eclipse.jetty.server.Connector[] v;
java.io.FileInputStream v;
javax.servlet.DispatcherType v;
java.lang.Object v;
org.eclipse.jetty.server.Connector v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v := @parameter: int;
v = staticinvoke <org.apache.hadoop.security.UserGroupInformation: boolean isSecurityEnabled()>();
if v == 0 goto label;
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String kerberosPrincipal()>();
v = staticinvoke <org.apache.hadoop.security.SecurityUtil: java.lang.String getServerPrincipal(java.lang.String,java.lang.String)>(v, "0.0.0.0");
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String kerberosKeytab()>();
staticinvoke <org.apache.hadoop.security.UserGroupInformation: void loginUserFromKeytab(java.lang.String,java.lang.String)>(v, v);
label:
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String jettyConfiguration()>();
v = staticinvoke <org.apache.commons.lang.StringUtils: boolean isEmpty(java.lang.CharSequence)>(v);
if v == 0 goto label;
v = new org.eclipse.jetty.server.Server;
specialinvoke v.<org.eclipse.jetty.server.Server: void <init>(int)>(v);
goto label;
label:
v = new java.io.FileInputStream;
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String jettyConfiguration()>();
specialinvoke v.<java.io.FileInputStream: void <init>(java.lang.String)>(v);
v = new org.eclipse.jetty.xml.XmlConfiguration;
specialinvoke v.<org.eclipse.jetty.xml.XmlConfiguration: void <init>(java.io.InputStream)>(v);
v = virtualinvoke v.<org.eclipse.jetty.xml.XmlConfiguration: java.lang.Object configure()>();
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, "/");
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.servlet.FilterHolder makeAuthFilter()>();
v = <javax.servlet.DispatcherType: javax.servlet.DispatcherType REQUEST>;
v = staticinvoke <java.util.EnumSet: java.util.EnumSet of(java.lang.Enum)>(v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/ddl/*", v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/pig/*", v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/hive/*", v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/sqoop/*", v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/queue/*", v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/jobs/*", v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/mapreduce/*", v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/status/*", v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/v1/version/*", v);
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: boolean getBoolean(java.lang.String,boolean)>("templeton.xsrf.filter.enabled", 0);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.servlet.FilterHolder makeXSRFFilter()>();
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/*", v);
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("XSRF filter enabled");
goto label;
label:
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>("XSRF filter disabled");
label:
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.servlet.FilterHolder makeFrameOptionFilter()>();
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addFilter(org.eclipse.jetty.servlet.FilterHolder,java.lang.String,java.util.EnumSet)>(v, "/templeton/*", v);
v = new org.eclipse.jetty.servlet.ServletHolder;
v = new com.sun.jersey.spi.container.servlet.ServletContainer;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: com.sun.jersey.api.core.PackagesResourceConfig makeJerseyConfig()>();
specialinvoke v.<com.sun.jersey.spi.container.servlet.ServletContainer: void <init>(javax.ws.rs.core.Application)>(v);
specialinvoke v.<org.eclipse.jetty.servlet.ServletHolder: void <init>(javax.servlet.Servlet)>(v);
virtualinvoke v.<org.eclipse.jetty.servlet.ServletContextHandler: void addServlet(org.eclipse.jetty.servlet.ServletHolder,java.lang.String)>(v, "/templeton/*");
virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: void addRedirects(org.eclipse.jetty.server.Server)>(v);
v = new org.eclipse.jetty.server.LowResourceMonitor;
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);
virtualinvoke v.<org.eclipse.jetty.server.Server: boolean addBean(java.lang.Object)>(v);
v = newarray (org.eclipse.jetty.server.Connector)[1];
v = specialinvoke v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.server.Connector createChannelConnector(org.eclipse.jetty.server.Server)>(v);
v[0] = v;
virtualinvoke v.<org.eclipse.jetty.server.Server: void setConnectors(org.eclipse.jetty.server.Connector[])>(v);
virtualinvoke v.<org.eclipse.jetty.server.Server: void start()>();
v.<org.apache.hive.hcatalog.templeton.Main: org.eclipse.jetty.server.Server server> = v;
return v;
}
public org.eclipse.jetty.servlet.FilterHolder makeXSRFFilter()
{
javax.servlet.Filter v;
org.apache.hive.hcatalog.templeton.Main v;
org.eclipse.jetty.servlet.FilterHolder v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = new org.eclipse.jetty.servlet.FilterHolder;
v = staticinvoke <org.apache.hadoop.hive.shims.Utils: javax.servlet.Filter getXSRFFilter()>();
specialinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void <init>(javax.servlet.Filter)>(v);
return v;
}
private org.eclipse.jetty.server.Connector createChannelConnector(org.eclipse.jetty.server.Server)
{
com.google.common.base.Splitter v, v, v;
org.eclipse.jetty.server.Server v;
boolean v;
org.apache.hive.hcatalog.templeton.Main v;
org.apache.hive.hcatalog.templeton.AppConfig v, v, v, v, v, v;
org.eclipse.jetty.server.HttpConnectionFactory v;
java.lang.Object[] v, v, v;
java.lang.String[] v;
java.lang.Iterable v;
java.util.HashSet v;
org.eclipse.jetty.server.HttpConfiguration v;
org.eclipse.jetty.util.ssl.SslContextFactory$Server v;
int v, v;
java.lang.String v, v, v, v, v;
org.slf4j.Logger v;
org.eclipse.jetty.server.ServerConnector v, v, v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v := @parameter: org.eclipse.jetty.server.Server;
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 = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: boolean getBoolean(java.lang.String,boolean)>("templeton.use.ssl", 0);
if v == 0 goto label;
v = <org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("Using SSL for templeton.");
v = new org.eclipse.jetty.util.ssl.SslContextFactory$Server;
specialinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory$Server: void <init>()>();
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String get(java.lang.String,java.lang.String)>("templeton.keystore.path", "");
virtualinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory: void setKeyStorePath(java.lang.String)>(v);
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String get(java.lang.String,java.lang.String)>("templeton.keystore.password", "");
virtualinvoke v.<org.eclipse.jetty.util.ssl.SslContextFactory: void setKeyStorePassword(java.lang.String)>(v);
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 = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String get(java.lang.String,java.lang.String)>("templeton.ssl.protocol.blacklist", "SSLv,SSLv3");
v = staticinvoke <java.util.Objects: java.lang.String toString(java.lang.Object,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 = new org.eclipse.jetty.server.ServerConnector;
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;
goto label;
label:
v = new org.eclipse.jetty.server.ServerConnector;
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;
label:
virtualinvoke v.<org.eclipse.jetty.server.ServerConnector: void setReuseAddress(boolean)>(1);
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String get(java.lang.String,java.lang.String)>("templeton.host", "0.0.0.0");
virtualinvoke v.<org.eclipse.jetty.server.ServerConnector: void setHost(java.lang.String)>(v);
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: int getInt(java.lang.String,int)>("templeton.port", 8080);
virtualinvoke v.<org.eclipse.jetty.server.ServerConnector: void setPort(int)>(v);
return v;
}
public org.eclipse.jetty.servlet.FilterHolder makeAuthFilter() throws java.io.IOException
{
org.eclipse.jetty.servlet.FilterHolder v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v;
boolean v;
org.apache.hive.hcatalog.templeton.Main v;
org.apache.hive.hcatalog.templeton.AppConfig v, v, v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = new org.eclipse.jetty.servlet.FilterHolder;
specialinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void <init>(java.lang.Class)>(class "Lorg/apache/hadoop/hdfs/web/AuthFilter;");
staticinvoke <org.apache.hive.hcatalog.templeton.Main$UserNameHandler: void allowAnonymous(org.eclipse.jetty.servlet.FilterHolder)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>("dfs.web.authentication") <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.");
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameter(java.lang.String,java.lang.String)>("config.prefix", "dfs.web.authentication");
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[])>("\u0001cookie.path");
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameter(java.lang.String,java.lang.String)>(v, "/");
v = staticinvoke <org.apache.hadoop.security.UserGroupInformation: boolean isSecurityEnabled()>();
if v == 0 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[])>("\u0001type");
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameter(java.lang.String,java.lang.String)>(v, "kerberos");
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String kerberosPrincipal()>();
v = staticinvoke <org.apache.hadoop.security.SecurityUtil: java.lang.String getServerPrincipal(java.lang.String,java.lang.String)>(v, "0.0.0.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[])>("\u0001kerberos.principal");
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameter(java.lang.String,java.lang.String)>(v, v);
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[])>("\u0001kerberos.keytab");
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String kerberosKeytab()>();
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameter(java.lang.String,java.lang.String)>(v, v);
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[])>("\u0001signature.secret");
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String kerberosSecret()>();
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameter(java.lang.String,java.lang.String)>(v, v);
goto label;
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[])>("\u0001type");
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameter(java.lang.String,java.lang.String)>(v, "simple");
label:
return v;
}
public org.eclipse.jetty.servlet.FilterHolder makeFrameOptionFilter()
{
org.apache.hive.hcatalog.templeton.Main v;
org.eclipse.jetty.servlet.FilterHolder v;
org.apache.hive.hcatalog.templeton.AppConfig v;
java.lang.String v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = new org.eclipse.jetty.servlet.FilterHolder;
specialinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void <init>(java.lang.Class)>(class "Lorg/apache/hive/hcatalog/templeton/Main$XFrameOptionsFilter;");
v = <org.apache.hive.hcatalog.templeton.Main: org.apache.hive.hcatalog.templeton.AppConfig conf>;
v = virtualinvoke v.<org.apache.hive.hcatalog.templeton.AppConfig: java.lang.String get(java.lang.String)>("templeton.frame.options.filter");
virtualinvoke v.<org.eclipse.jetty.servlet.FilterHolder: void setInitParameter(java.lang.String,java.lang.String)>("templeton.frame.options.filter", v);
return v;
}
public com.sun.jersey.api.core.PackagesResourceConfig makeJerseyConfig()
{
com.sun.jersey.api.core.PackagesResourceConfig v;
org.apache.hive.hcatalog.templeton.Main v;
java.lang.String[] v;
java.util.HashMap v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v = new com.sun.jersey.api.core.PackagesResourceConfig;
v = newarray (java.lang.String)[1];
v[0] = "org.apache.hive.hcatalog.templeton";
specialinvoke v.<com.sun.jersey.api.core.PackagesResourceConfig: void <init>(java.lang.String[])>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
virtualinvoke v.<java.util.HashMap: java.lang.Object put(java.lang.Object,java.lang.Object)>("com.sun.jersey.api.json.POJOMappingFeature", "true");
virtualinvoke v.<java.util.HashMap: java.lang.Object put(java.lang.Object,java.lang.Object)>("com.sun.jersey.config.property.WadlGeneratorConfig", "org.apache.hive.hcatalog.templeton.WadlConfig");
virtualinvoke v.<com.sun.jersey.api.core.PackagesResourceConfig: void setPropertiesAndFeatures(java.util.Map)>(v);
return v;
}
public void addRedirects(org.eclipse.jetty.server.Server)
{
org.eclipse.jetty.server.Handler v;
java.lang.Object[] v;
org.eclipse.jetty.rewrite.handler.RedirectPatternRule v;
org.eclipse.jetty.server.handler.HandlerList v;
org.eclipse.jetty.rewrite.handler.RewriteHandler v;
org.eclipse.jetty.server.Handler[] v, v;
java.util.ArrayList v;
org.apache.hive.hcatalog.templeton.Main v;
int v, v, v;
org.eclipse.jetty.server.Server v;
v := @this: org.apache.hive.hcatalog.templeton.Main;
v := @parameter: org.eclipse.jetty.server.Server;
v = new org.eclipse.jetty.rewrite.handler.RewriteHandler;
specialinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteHandler: void <init>()>();
v = new org.eclipse.jetty.rewrite.handler.RedirectPatternRule;
specialinvoke v.<org.eclipse.jetty.rewrite.handler.RedirectPatternRule: void <init>()>();
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RedirectPatternRule: void setPattern(java.lang.String)>("/templeton/v1/application.wadl");
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RedirectPatternRule: void setLocation(java.lang.String)>("/templeton/application.wadl");
virtualinvoke v.<org.eclipse.jetty.rewrite.handler.RewriteHandler: void addRule(org.eclipse.jetty.rewrite.handler.Rule)>(v);
v = new org.eclipse.jetty.server.handler.HandlerList;
specialinvoke v.<org.eclipse.jetty.server.handler.HandlerList: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
v = virtualinvoke v.<org.eclipse.jetty.server.Server: org.eclipse.jetty.server.Handler[] getHandlers()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.util.ArrayList: int size()>();
v = newarray (org.eclipse.jetty.server.Handler)[v];
v = virtualinvoke v.<java.util.ArrayList: java.lang.Object[] toArray(java.lang.Object[])>(v);
virtualinvoke v.<org.eclipse.jetty.server.handler.HandlerList: void setHandlers(org.eclipse.jetty.server.Handler[])>(v);
virtualinvoke v.<org.eclipse.jetty.server.Server: void setHandler(org.eclipse.jetty.server.Handler)>(v);
return;
}
public static void main(java.lang.String[])
{
java.lang.String[] v;
org.apache.hive.hcatalog.templeton.Main v;
v := @parameter: java.lang.String[];
v = new org.apache.hive.hcatalog.templeton.Main;
specialinvoke v.<org.apache.hive.hcatalog.templeton.Main: void <init>(java.lang.String[])>(v);
virtualinvoke v.<org.apache.hive.hcatalog.templeton.Main: void run()>();
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/hive/hcatalog/templeton/Main;");
<org.apache.hive.hcatalog.templeton.Main: org.slf4j.Logger LOG> = v;
return;
}
}