public class org.apache.hive.hcatalog.templeton.UgiFactory extends java.lang.Object
{
private static java.util.concurrent.ConcurrentHashMap userUgiMap;
public void <init>()
{
org.apache.hive.hcatalog.templeton.UgiFactory v;
v := @this: org.apache.hive.hcatalog.templeton.UgiFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static org.apache.hadoop.security.UserGroupInformation getUgi(java.lang.String) throws java.io.IOException
{
java.util.concurrent.ConcurrentHashMap v, v, v;
org.apache.hadoop.security.UserGroupInformation v, v;
java.lang.Object v, v;
java.lang.String v;
v := @parameter: java.lang.String;
v = <org.apache.hive.hcatalog.templeton.UgiFactory: java.util.concurrent.ConcurrentHashMap userUgiMap>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = staticinvoke <org.apache.hadoop.security.UserGroupInformation: org.apache.hadoop.security.UserGroupInformation getLoginUser()>();
v = staticinvoke <org.apache.hadoop.security.UserGroupInformation: org.apache.hadoop.security.UserGroupInformation createProxyUser(java.lang.String,org.apache.hadoop.security.UserGroupInformation)>(v, v);
v = <org.apache.hive.hcatalog.templeton.UgiFactory: java.util.concurrent.ConcurrentHashMap userUgiMap>;
virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: java.lang.Object putIfAbsent(java.lang.Object,java.lang.Object)>(v, v);
v = <org.apache.hive.hcatalog.templeton.UgiFactory: java.util.concurrent.ConcurrentHashMap userUgiMap>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: java.lang.Object get(java.lang.Object)>(v);
return v;
label:
return v;
}
static void <clinit>()
{
java.util.concurrent.ConcurrentHashMap v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
<org.apache.hive.hcatalog.templeton.UgiFactory: java.util.concurrent.ConcurrentHashMap userUgiMap> = v;
return;
}
}