public class org.glassfish.gms.bootstrap.GMSAdapterService extends java.lang.Object implements org.glassfish.hk.api.PostConstruct, org.jvnet.hk.config.ConfigListener
{
private static final java.lang.String GMSBS_LOGGER_NAME;
private static final java.lang.String LOG_MESSAGES_RB;
static final java.util.logging.Logger GMSBS_LOGGER;
private static final java.lang.String GMSBS_GMSADAPTER_NOT_AVAILABLE;
private static final com.sun.enterprise.util.i18n.StringManager strings;
com.sun.enterprise.config.serverbeans.Clusters clusters;
com.sun.enterprise.config.serverbeans.Server server;
org.glassfish.api.admin.ServerEnvironment env;
private org.glassfish.hk.api.ServiceLocator habitat;
com.sun.enterprise.module.bootstrap.StartupContext startupContext;
private jakarta.inject.Provider gmsAdapterProvider;
private static final java.lang.Object lock;
java.util.List gmsAdapters;
private static final java.util.logging.Level TRACE_LEVEL;
public void <init>()
{
org.glassfish.gms.bootstrap.GMSAdapterService v;
java.util.LinkedList v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.LinkedList;
specialinvoke v.<java.util.LinkedList: void <init>()>();
v.<org.glassfish.gms.bootstrap.GMSAdapterService: java.util.List gmsAdapters> = v;
return;
}
public void postConstruct()
{
java.util.Properties v;
com.sun.enterprise.config.serverbeans.Clusters v, v;
org.glassfish.gms.bootstrap.GMSAdapterService v;
org.glassfish.api.admin.ServerEnvironment v;
com.sun.enterprise.module.bootstrap.StartupContext v, v;
java.lang.Boolean v;
com.sun.enterprise.config.serverbeans.Server v;
java.lang.String v;
boolean v, v;
com.sun.enterprise.config.serverbeans.Cluster v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: com.sun.enterprise.module.bootstrap.StartupContext startupContext>;
if v == null goto label;
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: com.sun.enterprise.module.bootstrap.StartupContext startupContext>;
v = virtualinvoke v.<com.sun.enterprise.module.bootstrap.StartupContext: java.util.Properties getArguments()>();
if v == null goto label;
v = virtualinvoke v.<java.util.Properties: java.lang.String getProperty(java.lang.String)>("-upgrade");
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
return;
label:
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: com.sun.enterprise.config.serverbeans.Clusters clusters>;
if v == null goto label;
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: org.glassfish.api.admin.ServerEnvironment env>;
v = interfaceinvoke v.<org.glassfish.api.admin.ServerEnvironment: boolean isDas()>();
if v == 0 goto label;
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: com.sun.enterprise.config.serverbeans.Clusters clusters>;
specialinvoke v.<org.glassfish.gms.bootstrap.GMSAdapterService: void checkAllClusters(com.sun.enterprise.config.serverbeans.Clusters)>(v);
goto label;
label:
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: com.sun.enterprise.config.serverbeans.Server server>;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Server: com.sun.enterprise.config.serverbeans.Cluster getCluster()>();
if v == null goto label;
specialinvoke v.<org.glassfish.gms.bootstrap.GMSAdapterService: org.glassfish.gms.bootstrap.GMSAdapter checkCluster(com.sun.enterprise.config.serverbeans.Cluster)>(v);
label:
return;
}
public java.lang.String toString()
{
org.glassfish.gms.bootstrap.GMSAdapterService v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
return "GMS Loader";
}
public org.glassfish.gms.bootstrap.GMSAdapter getGMSAdapter()
{
java.lang.Throwable v;
java.lang.IllegalStateException v;
com.sun.enterprise.util.i18n.StringManager v;
java.util.List v, v, v;
org.glassfish.gms.bootstrap.GMSAdapterService v;
int v, v;
java.lang.Object v, v;
java.lang.String v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.lang.Object lock>;
entermonitor v;
label:
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: java.util.List gmsAdapters>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 1 goto label;
v = new java.lang.IllegalStateException;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: com.sun.enterprise.util.i18n.StringManager strings>;
v = virtualinvoke v.<com.sun.enterprise.util.i18n.StringManager: java.lang.String getString(java.lang.String)>("use.getByName");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: java.util.List gmsAdapters>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v != 1 goto label;
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: java.util.List gmsAdapters>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
exitmonitor v;
label:
return v;
label:
exitmonitor v;
label:
return null;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public boolean isGmsEnabled()
{
java.util.List v;
org.glassfish.gms.bootstrap.GMSAdapterService v;
int v;
boolean v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: java.util.List gmsAdapters>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public org.glassfish.gms.bootstrap.GMSAdapter getGMSAdapterByName(java.lang.String)
{
java.lang.Throwable v;
org.glassfish.gms.bootstrap.GMSAdapterService v;
java.lang.Object v, v;
java.lang.String v;
java.lang.'annotation'.Annotation[] v;
org.glassfish.hk.api.ServiceLocator v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
v := @parameter: java.lang.String;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.lang.Object lock>;
entermonitor v;
label:
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: org.glassfish.hk.api.ServiceLocator habitat>;
v = newarray (java.lang.'annotation'.Annotation)[0];
v = interfaceinvoke v.<org.glassfish.hk.api.ServiceLocator: java.lang.Object getService(java.lang.Class,java.lang.String,java.lang.'annotation'.Annotation[])>(class "Lorg/glassfish/gms/bootstrap/GMSAdapter;", v, v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
private void checkAllClusters(com.sun.enterprise.config.serverbeans.Clusters)
{
java.util.Iterator v;
com.sun.enterprise.config.serverbeans.Clusters v;
java.util.logging.Logger v, v;
java.util.logging.Level v, v;
java.util.List v;
org.glassfish.gms.bootstrap.GMSAdapterService v;
java.lang.Object v;
boolean v, v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
v := @parameter: com.sun.enterprise.config.serverbeans.Clusters;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, "In DAS. Checking all clusters.");
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Clusters: java.util.List getCluster()>();
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()>();
specialinvoke v.<org.glassfish.gms.bootstrap.GMSAdapterService: org.glassfish.gms.bootstrap.GMSAdapter checkCluster(com.sun.enterprise.config.serverbeans.Cluster)>(v);
goto label;
label:
return;
}
private org.glassfish.gms.bootstrap.GMSAdapter checkCluster(com.sun.enterprise.config.serverbeans.Cluster)
{
java.lang.Object[] v;
java.util.logging.Logger v, v;
java.util.logging.Level v, v;
org.glassfish.gms.bootstrap.GMSAdapterService v;
java.lang.String v, v, v;
org.glassfish.gms.bootstrap.GMSAdapter v;
boolean v, v;
com.sun.enterprise.config.serverbeans.Cluster v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
v := @parameter: com.sun.enterprise.config.serverbeans.Cluster;
v = null;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getGmsEnabled()>();
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = newarray (java.lang.Object)[2];
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getName()>();
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("cluster %s found with gms-enabled=\'%s\'", v);
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
if v == null goto label;
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
if v == 0 goto label;
v = specialinvoke v.<org.glassfish.gms.bootstrap.GMSAdapterService: org.glassfish.gms.bootstrap.GMSAdapter loadModule(com.sun.enterprise.config.serverbeans.Cluster)>(v);
label:
return v;
}
private org.glassfish.gms.bootstrap.GMSAdapter loadModule(com.sun.enterprise.config.serverbeans.Cluster)
{
org.glassfish.gms.bootstrap.GMSAdapterService v;
boolean v, v, v, v;
com.sun.enterprise.config.serverbeans.Cluster v;
java.util.logging.Logger v, v, v, v, v, v, v;
java.util.List v;
java.lang.reflect.Type[] v;
org.glassfish.gms.bootstrap.GMSAdapter v;
org.glassfish.hk.api.ServiceLocator v;
java.lang.Throwable v;
java.util.logging.Level v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
jakarta.inject.Provider v;
java.lang.Object v, v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
v := @parameter: com.sun.enterprise.config.serverbeans.Cluster;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.lang.Object lock>;
entermonitor v;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getName()>();
v = virtualinvoke v.<org.glassfish.gms.bootstrap.GMSAdapterService: org.glassfish.gms.bootstrap.GMSAdapter getGMSAdapterByName(java.lang.String)>(v);
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,org.glassfish.gms.bootstrap.GMSAdapter)>(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[])>("lookup GMSAdapter by clusterName=\u returned \u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
if v != null goto label;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getName()>();
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getName()>();
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[])>("creating gms-adapter for clustername \u since no gms adapter found for clustername \u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: jakarta.inject.Provider gmsAdapterProvider>;
v = interfaceinvoke v.<jakarta.inject.Provider: java.lang.Object get()>();
if v != null goto label;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.api.logging.LogLevel: java.util.logging.Level WARNING>;
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, "NCLS-CLSTR-10001");
exitmonitor v;
label:
return null;
label:
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getName()>();
v = interfaceinvoke v.<org.glassfish.gms.bootstrap.GMSAdapter: boolean initialize(java.lang.String)>(v);
if v != 0 goto label;
exitmonitor v;
label:
return null;
label:
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: org.glassfish.hk.api.ServiceLocator habitat>;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getName()>();
v = newarray (java.lang.reflect.Type)[1];
v[0] = class "Lorg/glassfish/gms/bootstrap/GMSAdapter;";
staticinvoke <org.glassfish.hk.utilities.ServiceLocatorUtilities: org.glassfish.hk.api.ActiveDescriptor addOneConstant(org.glassfish.hk.api.ServiceLocator,java.lang.Object,java.lang.String,java.lang.reflect.Type[])>(v, v, v, v);
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = virtualinvoke v.<java.util.logging.Logger: boolean isLoggable(java.util.logging.Level)>(v);
if v == 0 goto label;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL>;
v = interfaceinvoke v.<com.sun.enterprise.config.serverbeans.Cluster: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,boolean)>(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[])>("loadModule: registered created gmsadapter for cluster \u initialized result=\u0001");
virtualinvoke v.<java.util.logging.Logger: void log(java.util.logging.Level,java.lang.String)>(v, v);
label:
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: java.util.List gmsAdapters>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public org.jvnet.hk.config.UnprocessedChangeEvents changed(java.beans.PropertyChangeEvent[])
{
java.beans.PropertyChangeEvent[] v;
org.glassfish.gms.bootstrap.GMSAdapterService v;
org.glassfish.gms.bootstrap.GMSAdapterService$1 v;
org.jvnet.hk.config.UnprocessedChangeEvents v;
org.glassfish.api.admin.ServerEnvironment v;
java.util.logging.Logger v;
boolean v;
v := @this: org.glassfish.gms.bootstrap.GMSAdapterService;
v := @parameter: java.beans.PropertyChangeEvent[];
v = v.<org.glassfish.gms.bootstrap.GMSAdapterService: org.glassfish.api.admin.ServerEnvironment env>;
v = interfaceinvoke v.<org.glassfish.api.admin.ServerEnvironment: boolean isDas()>();
if v == 0 goto label;
v = new org.glassfish.gms.bootstrap.GMSAdapterService$1;
specialinvoke v.<org.glassfish.gms.bootstrap.GMSAdapterService$1: void <init>(org.glassfish.gms.bootstrap.GMSAdapterService)>(v);
v = <org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER>;
v = staticinvoke <org.jvnet.hk.config.ConfigSupport: org.jvnet.hk.config.UnprocessedChangeEvents sortAndDispatch(java.beans.PropertyChangeEvent[],org.jvnet.hk.config.Changed,java.util.logging.Logger)>(v, v, v);
return v;
label:
return null;
}
static void <clinit>()
{
com.sun.enterprise.util.i18n.StringManager v;
java.lang.Object v;
java.util.logging.Logger v;
java.util.logging.Level v;
v = staticinvoke <java.util.logging.Logger: java.util.logging.Logger getLogger(java.lang.String,java.lang.String)>("jakarta.enterprise.cluster.gms.bootstrap", "org.glassfish.cluster.gms.bootstrap.LogMessages");
<org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Logger GMSBS_LOGGER> = v;
v = staticinvoke <com.sun.enterprise.util.i18n.StringManager: com.sun.enterprise.util.i18n.StringManager getManager(java.lang.Class)>(class "Lorg/glassfish/gms/bootstrap/GMSAdapterService;");
<org.glassfish.gms.bootstrap.GMSAdapterService: com.sun.enterprise.util.i18n.StringManager strings> = v;
v = new java.lang.Object;
specialinvoke v.<java.lang.Object: void <init>()>();
<org.glassfish.gms.bootstrap.GMSAdapterService: java.lang.Object lock> = v;
v = <org.glassfish.api.logging.LogLevel: java.util.logging.Level FINE>;
<org.glassfish.gms.bootstrap.GMSAdapterService: java.util.logging.Level TRACE_LEVEL> = v;
return;
}
}