public class org.glassfish.admin.rest.cli.SecurityUtil extends java.lang.Object
{
private static final java.lang.String DAS_CONFIG;
private static java.lang.String ADMIN_REALM;
private static java.lang.String FILE_REALM_CLASSNAME;
private com.sun.enterprise.config.serverbeans.Domain domain;
public void <init>(com.sun.enterprise.config.serverbeans.Domain)
{
org.glassfish.admin.rest.cli.SecurityUtil v;
com.sun.enterprise.config.serverbeans.Domain v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: com.sun.enterprise.config.serverbeans.Domain;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.config.serverbeans.Domain domain> = v;
specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: void _loadRealms()>();
return;
}
public com.sun.enterprise.security.auth.realm.RealmsManager getRealmsManager()
{
java.lang.Object v;
java.lang.'annotation'.Annotation[] v;
org.glassfish.hk.api.ServiceLocator v;
org.glassfish.admin.rest.cli.SecurityUtil v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v = staticinvoke <org.glassfish.internal.api.Globals: org.glassfish.hk.api.ServiceLocator getDefaultHabitat()>();
v = newarray (java.lang.'annotation'.Annotation)[0];
v = interfaceinvoke v.<org.glassfish.hk.api.ServiceLocator: java.lang.Object getService(java.lang.Class,java.lang.'annotation'.Annotation[])>(class "Lcom/sun/enterprise/security/auth/realm/RealmsManager;", v);
return v;
}
private com.sun.enterprise.config.serverbeans.SecurityService getSecurityService()
{
com.sun.enterprise.config.serverbeans.SecurityService v;
com.sun.enterprise.config.serverbeans.Configs v;
java.util.List v;
com.sun.enterprise.config.serverbeans.Domain v;
java.lang.Object v;
org.glassfish.admin.rest.cli.SecurityUtil v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v = v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.config.serverbeans.Domain domain>;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Domain: com.sun.enterprise.config.serverbeans.Configs getConfigs()>();
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Configs: java.util.List getConfig()>();
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Config: com.sun.enterprise.config.serverbeans.SecurityService getSecurityService()>();
return v;
}
private void _loadRealms()
{
java.util.ArrayList v;
java.lang.String v, v, v, v, v, v;
boolean v, v, v;
com.sun.enterprise.config.serverbeans.SecurityService v, v;
java.util.Properties v;
java.util.Iterator v, v, v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v, v;
java.util.List v, v;
java.lang.Object v, v, v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.config.serverbeans.SecurityService getSecurityService()>();
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.SecurityService: java.util.List getAuthRealm()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
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 = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.AuthRealm: java.util.List getProperty()>();
v = new java.util.Properties;
specialinvoke v.<java.util.Properties: void <init>()>();
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 = interfaceinvoke v.<org.jvnet.hk.config.types.Property: java.lang.String getValue()>();
v = interfaceinvoke v.<org.jvnet.hk.config.types.Property: java.lang.String getName()>();
virtualinvoke v.<java.util.Properties: java.lang.Object setProperty(java.lang.String,java.lang.String)>(v, v);
goto label;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.AuthRealm: java.lang.String getName()>();
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.AuthRealm: java.lang.String getClassname()>();
staticinvoke <com.sun.enterprise.security.auth.realm.Realm: com.sun.enterprise.security.auth.realm.Realm instantiate(java.lang.String,java.lang.String,java.util.Properties)>(v, v, v);
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.AuthRealm: java.lang.String getName()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<java.lang.Exception: void printStackTrace()>();
goto label;
label:
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.config.serverbeans.SecurityService getSecurityService()>();
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.SecurityService: java.lang.String getDefaultRealm()>();
staticinvoke <com.sun.enterprise.security.auth.realm.Realm: com.sun.enterprise.security.auth.realm.Realm getInstance(java.lang.String)>(v);
staticinvoke <com.sun.enterprise.security.auth.realm.Realm: void setDefaultRealm(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
staticinvoke <com.sun.enterprise.security.auth.realm.Realm: void setDefaultRealm(java.lang.String)>(v);
virtualinvoke v.<java.lang.Exception: void printStackTrace()>();
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
private java.lang.String[] _getRealmNames()
{
com.sun.enterprise.security.auth.realm.RealmsManager v;
java.lang.Object[] v;
java.util.Enumeration v;
java.lang.String[] v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.util.ArrayList v;
int v;
java.lang.Object v;
boolean v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v = virtualinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.RealmsManager getRealmsManager()>();
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.RealmsManager: java.util.Enumeration getRealmNames()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
public java.lang.String[] getRealmNames()
{
java.lang.String[] v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: java.lang.String[] _getRealmNames()>();
label:
return v;
label:
v := @caughtexception;
virtualinvoke v.<java.lang.Exception: void printStackTrace()>();
return null;
catch java.lang.Exception from label to label with label;
}
public java.lang.String[] getPredefinedAuthRealmClassNames()
{
java.util.List v;
com.sun.enterprise.security.auth.realm.RealmsManager v;
java.lang.Object[] v;
int v;
java.lang.String[] v;
org.glassfish.admin.rest.cli.SecurityUtil v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v = virtualinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.RealmsManager getRealmsManager()>();
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.RealmsManager: java.util.List getPredefinedAuthRealmClassNames()>();
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
public java.lang.String getDefaultRealmName()
{
com.sun.enterprise.security.auth.realm.RealmsManager v;
java.lang.String v;
org.glassfish.admin.rest.cli.SecurityUtil v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v = virtualinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.RealmsManager getRealmsManager()>();
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.RealmsManager: java.lang.String getDefaultRealmName()>();
return v;
}
public void setDefaultRealmName(java.lang.String)
{
com.sun.enterprise.security.auth.realm.RealmsManager v;
java.lang.String v;
org.glassfish.admin.rest.cli.SecurityUtil v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.RealmsManager getRealmsManager()>();
virtualinvoke v.<com.sun.enterprise.security.auth.realm.RealmsManager: void setDefaultRealmName(java.lang.String)>(v);
return;
}
private com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)
{
com.sun.enterprise.security.auth.realm.Realm v;
com.sun.enterprise.security.auth.realm.RealmsManager v;
java.lang.String v, v;
java.lang.IllegalArgumentException v;
org.glassfish.admin.rest.cli.SecurityUtil v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.RealmsManager getRealmsManager()>();
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.RealmsManager: com.sun.enterprise.security.auth.realm.Realm getFromLoadedRealms(java.lang.String)>(v);
if v != null goto label;
v = new java.lang.IllegalArgumentException;
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[])>("No such realm: \u0001");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
}
public void addUser(java.lang.String, java.lang.String, java.lang.String, java.lang.String[])
{
java.lang.String[] v;
java.lang.RuntimeException v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v;
com.sun.enterprise.security.auth.realm.Realm v;
char[] v;
java.lang.String v, v, v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String[];
specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: void checkSupportsUserManagement(java.lang.String)>(v);
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: void addUser(java.lang.String,char[],java.lang.String[])>(v, v, v);
virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: void persist()>();
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
public void updateUser(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String[])
{
java.lang.String[] v;
java.lang.RuntimeException v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v;
com.sun.enterprise.security.auth.realm.Realm v;
char[] v;
java.lang.String v, v, v, v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String[];
specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: void checkSupportsUserManagement(java.lang.String)>(v);
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.String: char[] toCharArray()>();
virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: void updateUser(java.lang.String,java.lang.String,char[],java.lang.String[])>(v, v, v, v);
virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: void persist()>();
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
public void removeUser(java.lang.String, java.lang.String)
{
com.sun.enterprise.security.auth.realm.Realm v;
java.lang.RuntimeException v;
java.lang.String v, v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: void checkSupportsUserManagement(java.lang.String)>(v);
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)>(v);
virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: void removeUser(java.lang.String)>(v);
virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: void persist()>();
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
public boolean supportsUserManagement(java.lang.String)
{
com.sun.enterprise.security.auth.realm.Realm v;
java.lang.String v;
org.glassfish.admin.rest.cli.SecurityUtil v;
boolean v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)>(v);
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: boolean supportsUserManagement()>();
return v;
}
private void checkSupportsUserManagement(java.lang.String)
{
java.lang.IllegalStateException v;
java.lang.String v, v;
org.glassfish.admin.rest.cli.SecurityUtil v;
boolean v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: boolean supportsUserManagement(java.lang.String)>(v);
if v != 0 goto label;
v = new java.lang.IllegalStateException;
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[])>("Realm \u does not support user management");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
}
public java.lang.String[] getUserNames(java.lang.String)
{
java.lang.Object[] v;
java.util.Enumeration v;
java.lang.String[] v;
java.lang.RuntimeException v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v;
java.util.ArrayList v;
com.sun.enterprise.security.auth.realm.Realm v;
int v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)>(v);
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: java.util.Enumeration getUserNames()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
return v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.Exception from label to label with label;
}
public java.lang.String[] getGroupNames(java.lang.String)
{
java.lang.Object[] v;
java.util.Enumeration v;
java.lang.String[] v;
java.lang.RuntimeException v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v;
java.util.ArrayList v;
com.sun.enterprise.security.auth.realm.Realm v;
int v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)>(v);
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: java.util.Enumeration getGroupNames()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
return v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.Exception from label to label with label;
}
public java.lang.String[] getGroupNames(java.lang.String, java.lang.String)
{
java.lang.Object[] v;
java.util.Enumeration v;
java.lang.String[] v;
java.lang.RuntimeException v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v;
java.util.ArrayList v;
com.sun.enterprise.security.auth.realm.Realm v;
int v;
java.lang.Object v;
java.lang.String v, v;
boolean v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)>(v);
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: java.util.Enumeration getGroupNames(java.lang.String)>(v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
return v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.Exception from label to label with label;
}
public java.util.Map getUserAttributes(java.lang.String, java.lang.String)
{
java.util.Enumeration v;
com.sun.enterprise.security.auth.realm.User v;
java.util.HashMap v;
java.util.ArrayList v;
java.lang.String v, v;
boolean v, v;
java.util.Iterator v;
java.lang.RuntimeException v;
org.glassfish.admin.rest.cli.SecurityUtil v;
java.lang.Exception v;
com.sun.enterprise.security.auth.realm.Realm v;
java.lang.Object v, v, v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
label:
v = specialinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.security.auth.realm.Realm getRealm(java.lang.String)>(v);
v = virtualinvoke v.<com.sun.enterprise.security.auth.realm.Realm: com.sun.enterprise.security.auth.realm.User getUser(java.lang.String)>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = interfaceinvoke v.<com.sun.enterprise.security.auth.realm.User: java.util.Enumeration getAttributeNames()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
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 = interfaceinvoke v.<com.sun.enterprise.security.auth.realm.User: java.lang.Object getAttribute(java.lang.String)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
return v;
label:
v := @caughtexception;
v = new java.lang.RuntimeException;
specialinvoke v.<java.lang.RuntimeException: void <init>(java.lang.Throwable)>(v);
throw v;
catch java.lang.Exception from label to label with label;
}
public java.lang.String getAnonymousUser(org.glassfish.hk.api.ServiceLocator)
{
java.lang.IllegalStateException v, v, v;
org.jvnet.hk.config.types.Property v;
boolean v, v, v, v, v;
java.lang.Exception v;
java.util.List v, v;
com.sun.enterprise.config.serverbeans.Domain v;
org.glassfish.hk.api.ServiceLocator v;
java.lang.String[] v;
java.lang.'annotation'.Annotation[] v;
com.sun.enterprise.config.serverbeans.AuthRealm v;
int v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v;
com.sun.enterprise.config.serverbeans.SecurityService v;
java.util.Iterator v, v;
org.glassfish.admin.rest.cli.SecurityUtil v;
char[] v;
java.lang.Object v, v;
com.sun.enterprise.config.serverbeans.Config v;
v := @this: org.glassfish.admin.rest.cli.SecurityUtil;
v := @parameter: org.glassfish.hk.api.ServiceLocator;
v = null;
v = null;
v = v.<org.glassfish.admin.rest.cli.SecurityUtil: com.sun.enterprise.config.serverbeans.Domain domain>;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Domain: com.sun.enterprise.config.serverbeans.Config getConfigNamed(java.lang.String)>("server-config");
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Config: com.sun.enterprise.config.serverbeans.SecurityService getSecurityService()>();
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.SecurityService: java.util.List getAuthRealm()>();
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 = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.AuthRealm: java.lang.String getName()>();
v = <org.glassfish.admin.rest.cli.SecurityUtil: java.lang.String ADMIN_REALM>;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = v;
label:
if v != null goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Cannot find admin realm");
throw v;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.AuthRealm: java.lang.String getClassname()>();
if v == null goto label;
v = <org.glassfish.admin.rest.cli.SecurityUtil: java.lang.String FILE_REALM_CLASSNAME>;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
return null;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.AuthRealm: java.util.List getProperty()>();
v = null;
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 = "file";
v = interfaceinvoke v.<org.jvnet.hk.config.types.Property: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = v;
goto label;
label:
if v != null goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Cannot find property \'file\'");
throw v;
label:
v = interfaceinvoke v.<org.jvnet.hk.config.types.Property: java.lang.String getValue()>();
if v != null goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Cannot find key file");
throw v;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.AuthRealm: java.lang.String getName()>();
v = virtualinvoke v.<org.glassfish.admin.rest.cli.SecurityUtil: java.lang.String[] getUserNames(java.lang.String)>(v);
v = lengthof v;
if v != 1 goto label;
label:
v = newarray (java.lang.'annotation'.Annotation)[0];
interfaceinvoke v.<org.glassfish.hk.api.ServiceLocator: java.lang.Object getService(java.lang.Class,java.lang.'annotation'.Annotation[])>(class "Lcom/sun/enterprise/security/SecurityLifecycle;", v);
v = v[0];
v = newarray (char)[0];
v = <org.glassfish.admin.rest.cli.SecurityUtil: java.lang.String ADMIN_REALM>;
staticinvoke <com.sun.enterprise.security.auth.login.LoginContextDriver: void login(java.lang.String,char[],java.lang.String)>(v, v, v);
v = v[0];
label:
goto label;
label:
v := @caughtexception;
label:
return v;
catch java.lang.Exception from label to label with label;
}
static void <clinit>()
{
<org.glassfish.admin.rest.cli.SecurityUtil: java.lang.String ADMIN_REALM> = "admin-realm";
<org.glassfish.admin.rest.cli.SecurityUtil: java.lang.String FILE_REALM_CLASSNAME> = "com.sun.enterprise.security.auth.realm.file.FileRealm";
return;
}
}