public class oadd.org.apache.hadoop.security.NetgroupCache extends java.lang.Object
{
private static java.util.concurrent.ConcurrentHashMap userToNetgroupsMap;
public void <init>()
{
oadd.org.apache.hadoop.security.NetgroupCache v;
v := @this: oadd.org.apache.hadoop.security.NetgroupCache;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static void getNetgroups(java.lang.String, java.util.List)
{
java.util.List v;
java.util.concurrent.ConcurrentHashMap v;
java.lang.Object v;
java.lang.String v;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
v = <oadd.org.apache.hadoop.security.NetgroupCache: java.util.concurrent.ConcurrentHashMap userToNetgroupsMap>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
interfaceinvoke v.<java.util.List: boolean addAll(java.util.Collection)>(v);
label:
return;
}
public static java.util.List getNetgroupNames()
{
java.util.Set v;
java.util.LinkedList v;
v = new java.util.LinkedList;
v = staticinvoke <oadd.org.apache.hadoop.security.NetgroupCache: java.util.Set getGroups()>();
specialinvoke v.<java.util.LinkedList: void <init>(java.util.Collection)>(v);
return v;
}
private static java.util.Set getGroups()
{
java.util.HashSet v;
java.util.Iterator v;
java.util.Collection v;
java.util.concurrent.ConcurrentHashMap v;
java.lang.Object v;
boolean v;
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v = <oadd.org.apache.hadoop.security.NetgroupCache: java.util.concurrent.ConcurrentHashMap userToNetgroupsMap>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: 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()>();
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
goto label;
label:
return v;
}
public static boolean isCached(java.lang.String)
{
java.util.Set v;
java.lang.String v;
boolean v;
v := @parameter: java.lang.String;
v = staticinvoke <oadd.org.apache.hadoop.security.NetgroupCache: java.util.Set getGroups()>();
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
return v;
}
public static void clear()
{
java.util.concurrent.ConcurrentHashMap v;
v = <oadd.org.apache.hadoop.security.NetgroupCache: java.util.concurrent.ConcurrentHashMap userToNetgroupsMap>;
virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: void clear()>();
return;
}
public static void add(java.lang.String, java.util.List)
{
java.util.Iterator v;
java.util.concurrent.ConcurrentHashMap v, v, v;
java.util.List v;
java.lang.Object v, v, v;
java.lang.String v;
boolean v;
v := @parameter: java.lang.String;
v := @parameter: java.util.List;
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 = <oadd.org.apache.hadoop.security.NetgroupCache: java.util.concurrent.ConcurrentHashMap userToNetgroupsMap>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v = staticinvoke <java.util.Collections: java.util.Set newSetFromMap(java.util.Map)>(v);
v = <oadd.org.apache.hadoop.security.NetgroupCache: java.util.concurrent.ConcurrentHashMap userToNetgroupsMap>;
v = virtualinvoke v.<java.util.concurrent.ConcurrentHashMap: java.lang.Object putIfAbsent(java.lang.Object,java.lang.Object)>(v, v);
if v == null goto label;
v = v;
label:
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
return;
}
static void <clinit>()
{
java.util.concurrent.ConcurrentHashMap v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
<oadd.org.apache.hadoop.security.NetgroupCache: java.util.concurrent.ConcurrentHashMap userToNetgroupsMap> = v;
return;
}
}