public class io.vertx.core.impl.HAManager extends java.lang.Object
{
private static final io.vertx.core.impl.logging.Logger log;
private static final long QUORUM_CHECK_PERIOD;
private final io.vertx.core.impl.VertxInternal vertx;
private final io.vertx.core.impl.DeploymentManager deploymentManager;
private final io.vertx.core.impl.VerticleManager verticleFactoryManager;
private final io.vertx.core.spi.cluster.ClusterManager clusterManager;
private final int quorumSize;
private final java.lang.String group;
private final io.vertx.core.json.JsonObject haInfo;
private final java.util.Map clusterMap;
private final java.lang.String nodeID;
private final java.util.Queue toDeployOnQuorum;
private long quorumTimerID;
private long checkQuorumTimerID;
private volatile boolean attainedQuorum;
private volatile io.vertx.core.impl.FailoverCompleteHandler failoverCompleteHandler;
private volatile boolean failDuringFailover;
private volatile boolean stopped;
private volatile boolean killed;
public void <init>(io.vertx.core.impl.VertxInternal, io.vertx.core.impl.DeploymentManager, io.vertx.core.impl.VerticleManager, io.vertx.core.spi.cluster.ClusterManager, java.util.Map, int, java.lang.String)
{
io.vertx.core.impl.VertxInternal v;
io.vertx.core.spi.cluster.ClusterManager v;
io.vertx.core.json.JsonArray v;
io.vertx.core.impl.VerticleManager v;
io.vertx.core.impl.DeploymentManager v;
java.util.Map v;
int v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v, v, v;
java.lang.String v, v, v;
java.util.concurrent.ConcurrentLinkedQueue v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: io.vertx.core.impl.VertxInternal;
v := @parameter: io.vertx.core.impl.DeploymentManager;
v := @parameter: io.vertx.core.impl.VerticleManager;
v := @parameter: io.vertx.core.spi.cluster.ClusterManager;
v := @parameter: java.util.Map;
v := @parameter: int;
v := @parameter: java.lang.String;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.ConcurrentLinkedQueue;
specialinvoke v.<java.util.concurrent.ConcurrentLinkedQueue: void <init>()>();
v.<io.vertx.core.impl.HAManager: java.util.Queue toDeployOnQuorum> = v;
v.<io.vertx.core.impl.HAManager: long checkQuorumTimerID> = -1L;
v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx> = v;
v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.DeploymentManager deploymentManager> = v;
v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VerticleManager verticleFactoryManager> = v;
v.<io.vertx.core.impl.HAManager: io.vertx.core.spi.cluster.ClusterManager clusterManager> = v;
v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap> = v;
v.<io.vertx.core.impl.HAManager: int quorumSize> = v;
v.<io.vertx.core.impl.HAManager: java.lang.String group> = v;
v = new io.vertx.core.json.JsonObject;
specialinvoke v.<io.vertx.core.json.JsonObject: void <init>()>();
v = new io.vertx.core.json.JsonArray;
specialinvoke v.<io.vertx.core.json.JsonArray: void <init>()>();
v = virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonObject put(java.lang.String,java.lang.Object)>("verticles", v);
v = v.<io.vertx.core.impl.HAManager: java.lang.String group>;
v = virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonObject put(java.lang.String,java.lang.Object)>("group", v);
v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo> = v;
v = interfaceinvoke v.<io.vertx.core.spi.cluster.ClusterManager: java.lang.String getNodeId()>();
v.<io.vertx.core.impl.HAManager: java.lang.String nodeID> = v;
return;
}
void init()
{
java.lang.Throwable v, v;
io.vertx.core.impl.VertxInternal v;
io.vertx.core.spi.cluster.ClusterManager v;
long v;
java.util.Map v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v, v;
java.lang.String v, v;
io.vertx.core.Handler v;
io.vertx.core.impl.HAManager$1 v;
v := @this: io.vertx.core.impl.HAManager;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
entermonitor v;
label:
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String encode()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.spi.cluster.ClusterManager clusterManager>;
v = new io.vertx.core.impl.HAManager$1;
specialinvoke v.<io.vertx.core.impl.HAManager$1: void <init>(io.vertx.core.impl.HAManager)>(v);
interfaceinvoke v.<io.vertx.core.spi.cluster.ClusterManager: void nodeListener(io.vertx.core.spi.cluster.NodeListener)>(v);
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_init_0__1511: io.vertx.core.Handler bootstrap$(io.vertx.core.impl.HAManager)>(v);
v = interfaceinvoke v.<io.vertx.core.impl.VertxInternal: long setPeriodic(long,io.vertx.core.Handler)>(1000L, v);
v.<io.vertx.core.impl.HAManager: long quorumTimerID> = v;
entermonitor v;
label:
specialinvoke v.<io.vertx.core.impl.HAManager: void checkQuorum()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void removeFromHA(java.lang.String)
{
java.lang.Throwable v;
io.vertx.core.impl.DeploymentManager v;
java.util.Map v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v, v, v;
java.lang.String v, v, v, v;
boolean v, v, v;
java.util.Iterator v;
io.vertx.core.json.JsonArray v;
io.vertx.core.impl.Deployment v;
io.vertx.core.DeploymentOptions v;
java.lang.Object v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.DeploymentManager deploymentManager>;
v = virtualinvoke v.<io.vertx.core.impl.DeploymentManager: io.vertx.core.impl.Deployment getDeployment(java.lang.String)>(v);
if v == null goto label;
v = interfaceinvoke v.<io.vertx.core.impl.Deployment: io.vertx.core.DeploymentOptions deploymentOptions()>();
v = virtualinvoke v.<io.vertx.core.DeploymentOptions: boolean isHa()>();
if v != 0 goto label;
label:
return;
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
entermonitor v;
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
v = virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonArray getJsonArray(java.lang.String)>("verticles");
v = virtualinvoke v.<io.vertx.core.json.JsonArray: 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 = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String getString(java.lang.String)>("dep_id");
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: void remove()>();
goto label;
label:
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String encode()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void addDataToAHAInfo(java.lang.String, io.vertx.core.json.JsonObject)
{
java.lang.Throwable v;
java.util.Map v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v, v, v, v;
java.lang.String v, v, v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v := @parameter: io.vertx.core.json.JsonObject;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
entermonitor v;
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonObject put(java.lang.String,java.lang.Object)>(v, v);
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String encode()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public void deployVerticle(java.lang.String, io.vertx.core.DeploymentOptions, io.vertx.core.Handler)
{
io.vertx.core.impl.logging.Logger v;
io.vertx.core.DeploymentOptions v;
io.vertx.core.impl.HAManager v;
java.lang.String v;
io.vertx.core.Handler v;
boolean v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v := @parameter: io.vertx.core.DeploymentOptions;
v := @parameter: io.vertx.core.Handler;
v = v.<io.vertx.core.impl.HAManager: boolean attainedQuorum>;
if v == 0 goto label;
specialinvoke v.<io.vertx.core.impl.HAManager: void doDeployVerticle(java.lang.String,io.vertx.core.DeploymentOptions,io.vertx.core.Handler)>(v, v, v);
goto label;
label:
v = <io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.Logger log>;
interfaceinvoke v.<io.vertx.core.impl.logging.Logger: void info(java.lang.Object)>("Quorum not attained. Deployment of verticle will be delayed until there\'s a quorum.");
specialinvoke v.<io.vertx.core.impl.HAManager: void addToHADeployList(java.lang.String,io.vertx.core.DeploymentOptions,io.vertx.core.Handler)>(v, v, v);
label:
return;
}
public void stop()
{
io.vertx.core.impl.VertxInternal v, v;
io.vertx.core.spi.cluster.ClusterManager v;
long v, v;
byte v;
java.util.Map v;
io.vertx.core.impl.HAManager v;
java.lang.String v;
boolean v, v;
v := @this: io.vertx.core.impl.HAManager;
v = v.<io.vertx.core.impl.HAManager: boolean stopped>;
if v != 0 goto label;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.spi.cluster.ClusterManager clusterManager>;
v = interfaceinvoke v.<io.vertx.core.spi.cluster.ClusterManager: boolean isActive()>();
if v == 0 goto label;
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
label:
v = v.<io.vertx.core.impl.HAManager: long checkQuorumTimerID>;
v = v cmp 0L;
if v < 0 goto label;
v.<io.vertx.core.impl.HAManager: long checkQuorumTimerID> = -1L;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
interfaceinvoke v.<io.vertx.core.impl.VertxInternal: boolean cancelTimer(long)>(v);
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
v = v.<io.vertx.core.impl.HAManager: long quorumTimerID>;
interfaceinvoke v.<io.vertx.core.impl.VertxInternal: boolean cancelTimer(long)>(v);
v.<io.vertx.core.impl.HAManager: boolean stopped> = 1;
label:
return;
}
public void simulateKill()
{
java.lang.Throwable v;
long v, v, v, v, v, v;
byte v;
java.lang.Thread v, v;
io.vertx.core.impl.HAManager v;
boolean v, v;
io.vertx.core.impl.VertxInternal v, v;
io.vertx.core.spi.cluster.ClusterManager v;
io.vertx.core.Promise v;
io.vertx.core.Future v, v;
java.util.concurrent.TimeUnit v, v;
java.util.concurrent.CountDownLatch v;
java.lang.InterruptedException v;
io.vertx.core.Handler v, v;
v := @this: io.vertx.core.impl.HAManager;
v = v.<io.vertx.core.impl.HAManager: boolean stopped>;
if v != 0 goto label;
v.<io.vertx.core.impl.HAManager: boolean killed> = 1;
v = new java.util.concurrent.CountDownLatch;
specialinvoke v.<java.util.concurrent.CountDownLatch: void <init>(int)>(1);
v = staticinvoke <io.vertx.core.Promise: io.vertx.core.Promise promise()>();
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.spi.cluster.ClusterManager clusterManager>;
interfaceinvoke v.<io.vertx.core.spi.cluster.ClusterManager: void leave(io.vertx.core.Promise)>(v);
v = interfaceinvoke v.<io.vertx.core.Promise: io.vertx.core.Future future()>();
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_simulateKill_1__1512: io.vertx.core.Handler bootstrap$()>();
v = interfaceinvoke v.<io.vertx.core.Future: io.vertx.core.Future onFailure(io.vertx.core.Handler)>(v);
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_simulateKill_2__1513: io.vertx.core.Handler bootstrap$(java.util.concurrent.CountDownLatch)>(v);
interfaceinvoke v.<io.vertx.core.Future: io.vertx.core.Future onComplete(io.vertx.core.Handler)>(v);
v = v.<io.vertx.core.impl.HAManager: long checkQuorumTimerID>;
v = v cmp 0L;
if v < 0 goto label;
v.<io.vertx.core.impl.HAManager: long checkQuorumTimerID> = -1L;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
interfaceinvoke v.<io.vertx.core.impl.VertxInternal: boolean cancelTimer(long)>(v);
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
v = v.<io.vertx.core.impl.HAManager: long quorumTimerID>;
interfaceinvoke v.<io.vertx.core.impl.VertxInternal: boolean cancelTimer(long)>(v);
v = 0;
label:
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MINUTES>;
v = virtualinvoke v.<java.util.concurrent.TimeUnit: long toNanos(long)>(1L);
v = staticinvoke <java.lang.System: long nanoTime()>();
v = v + v;
label:
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit NANOSECONDS>;
virtualinvoke v.<java.util.concurrent.CountDownLatch: boolean await(long,java.util.concurrent.TimeUnit)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = 1;
v = staticinvoke <java.lang.System: long nanoTime()>();
v = v - v;
goto label;
label:
if v == 0 goto label;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
goto label;
label:
v := @caughtexception;
if v == 0 goto label;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
label:
throw v;
label:
v.<io.vertx.core.impl.HAManager: boolean stopped> = 1;
label:
return;
catch java.lang.InterruptedException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void setFailoverCompleteHandler(io.vertx.core.impl.FailoverCompleteHandler)
{
io.vertx.core.impl.HAManager v;
io.vertx.core.impl.FailoverCompleteHandler v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: io.vertx.core.impl.FailoverCompleteHandler;
v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.FailoverCompleteHandler failoverCompleteHandler> = v;
return;
}
public boolean isKilled()
{
io.vertx.core.impl.HAManager v;
boolean v;
v := @this: io.vertx.core.impl.HAManager;
v = v.<io.vertx.core.impl.HAManager: boolean killed>;
return v;
}
public void failDuringFailover(boolean)
{
io.vertx.core.impl.HAManager v;
boolean v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: boolean;
v.<io.vertx.core.impl.HAManager: boolean failDuringFailover> = v;
return;
}
private void doDeployVerticle(java.lang.String, io.vertx.core.DeploymentOptions, io.vertx.core.Handler)
{
io.vertx.core.Future v, v;
java.util.function.Function v;
io.vertx.core.impl.VerticleManager v;
io.vertx.core.DeploymentOptions v;
io.vertx.core.impl.HAManager v;
java.lang.String v;
io.vertx.core.Handler v, v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v := @parameter: io.vertx.core.DeploymentOptions;
v := @parameter: io.vertx.core.Handler;
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_doDeployVerticle_5__1514: io.vertx.core.Handler bootstrap$(io.vertx.core.impl.HAManager,java.lang.String,io.vertx.core.DeploymentOptions,io.vertx.core.Handler)>(v, v, v, v);
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VerticleManager verticleFactoryManager>;
v = virtualinvoke v.<io.vertx.core.impl.VerticleManager: io.vertx.core.Future deployVerticle(java.lang.String,io.vertx.core.DeploymentOptions)>(v, v);
v = staticinvoke <io.vertx.core.impl.HAManager$deploymentID__1515: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<io.vertx.core.Future: io.vertx.core.Future map(java.util.function.Function)>(v);
interfaceinvoke v.<io.vertx.core.Future: io.vertx.core.Future onComplete(io.vertx.core.Handler)>(v);
return;
}
private synchronized void nodeAdded(java.lang.String)
{
io.vertx.core.impl.HAManager v;
long v;
java.lang.String v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
specialinvoke v.<io.vertx.core.impl.HAManager: void addHaInfoIfLost()>();
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
specialinvoke v.<io.vertx.core.impl.HAManager: void checkQuorumWhenAdded(java.lang.String,long)>(v, v);
return;
}
private synchronized void nodeLeft(java.lang.String)
{
java.util.Map v, v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v, v;
java.lang.String v;
boolean v, v, v, v;
java.util.Iterator v;
io.vertx.core.spi.cluster.ClusterManager v;
java.util.Set v;
java.util.List v;
java.lang.Object v, v, v, v, v, v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
specialinvoke v.<io.vertx.core.impl.HAManager: void addHaInfoIfLost()>();
specialinvoke v.<io.vertx.core.impl.HAManager: void checkQuorum()>();
v = v.<io.vertx.core.impl.HAManager: boolean attainedQuorum>;
if v == 0 goto label;
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = new io.vertx.core.json.JsonObject;
specialinvoke v.<io.vertx.core.json.JsonObject: void <init>(java.lang.String)>(v);
specialinvoke v.<io.vertx.core.impl.HAManager: void checkFailover(java.lang.String,io.vertx.core.json.JsonObject)>(v, v);
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.spi.cluster.ClusterManager clusterManager>;
v = interfaceinvoke v.<io.vertx.core.spi.cluster.ClusterManager: java.util.List getNodes()>();
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: 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.<java.util.Map$Entry: java.lang.Object getKey()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = new io.vertx.core.json.JsonObject;
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
specialinvoke v.<io.vertx.core.json.JsonObject: void <init>(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
specialinvoke v.<io.vertx.core.impl.HAManager: void checkFailover(java.lang.String,io.vertx.core.json.JsonObject)>(v, v);
goto label;
label:
return;
}
private void addHaInfoIfLost()
{
java.lang.Throwable v;
io.vertx.core.spi.cluster.ClusterManager v;
java.util.List v;
java.util.Map v, v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v, v;
java.lang.String v, v, v, v;
boolean v, v;
v := @this: io.vertx.core.impl.HAManager;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.spi.cluster.ClusterManager clusterManager>;
v = interfaceinvoke v.<io.vertx.core.spi.cluster.ClusterManager: java.util.List getNodes()>();
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
v = interfaceinvoke v.<java.util.List: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
entermonitor v;
label:
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String encode()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private synchronized void checkQuorumWhenAdded(java.lang.String, long)
{
io.vertx.core.impl.VertxInternal v;
long v, v;
java.util.Map v;
io.vertx.core.impl.HAManager v;
java.lang.String v;
io.vertx.core.Handler v;
boolean v, v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v := @parameter: long;
v = v.<io.vertx.core.impl.HAManager: boolean stopped>;
if v != 0 goto label;
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
specialinvoke v.<io.vertx.core.impl.HAManager: void checkQuorum()>();
goto label;
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_checkQuorumWhenAdded_8__1516: io.vertx.core.Handler bootstrap$(io.vertx.core.impl.HAManager,long,java.lang.String)>(v, v, v);
v = interfaceinvoke v.<io.vertx.core.impl.VertxInternal: long setTimer(long,io.vertx.core.Handler)>(200L, v);
v.<io.vertx.core.impl.HAManager: long checkQuorumTimerID> = v;
label:
return;
}
private void checkQuorum()
{
java.util.Map v;
int v, v, v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v;
java.lang.String v, v;
boolean v, v, v, v, v, v;
io.vertx.core.impl.logging.Logger v, v;
java.util.Iterator v;
io.vertx.core.spi.cluster.ClusterManager v;
java.util.List v;
java.lang.Object v, v;
v := @this: io.vertx.core.impl.HAManager;
v = v.<io.vertx.core.impl.HAManager: int quorumSize>;
if v != 0 goto label;
v.<io.vertx.core.impl.HAManager: boolean attainedQuorum> = 1;
goto label;
label:
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.spi.cluster.ClusterManager clusterManager>;
v = interfaceinvoke v.<io.vertx.core.spi.cluster.ClusterManager: java.util.List getNodes()>();
v = 0;
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 = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = new io.vertx.core.json.JsonObject;
specialinvoke v.<io.vertx.core.json.JsonObject: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String getString(java.lang.String)>("group");
v = v.<io.vertx.core.impl.HAManager: java.lang.String group>;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = v + 1;
goto label;
label:
v = v.<io.vertx.core.impl.HAManager: int quorumSize>;
if v < v goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
v = v.<io.vertx.core.impl.HAManager: boolean attainedQuorum>;
if v != 0 goto label;
if v == 0 goto label;
v = <io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.Logger log>;
interfaceinvoke v.<io.vertx.core.impl.logging.Logger: void info(java.lang.Object)>("A quorum has been obtained. Any deploymentIDs waiting on a quorum will now be deployed");
v.<io.vertx.core.impl.HAManager: boolean attainedQuorum> = 1;
goto label;
label:
v = v.<io.vertx.core.impl.HAManager: boolean attainedQuorum>;
if v == 0 goto label;
if v != 0 goto label;
v = <io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.Logger log>;
interfaceinvoke v.<io.vertx.core.impl.logging.Logger: void info(java.lang.Object)>("There is no longer a quorum. Any HA deploymentIDs will be undeployed until a quorum is re-attained");
v.<io.vertx.core.impl.HAManager: boolean attainedQuorum> = 0;
label:
return;
}
private void addToHA(java.lang.String, java.lang.String, io.vertx.core.DeploymentOptions)
{
java.lang.Throwable v;
io.vertx.core.json.JsonArray v;
io.vertx.core.DeploymentOptions v;
java.util.Map v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v, v, v, v, v, v;
java.lang.String v, v, v, v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: io.vertx.core.DeploymentOptions;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
entermonitor v;
label:
v = new io.vertx.core.json.JsonObject;
specialinvoke v.<io.vertx.core.json.JsonObject: void <init>()>();
v = virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonObject put(java.lang.String,java.lang.Object)>("dep_id", v);
virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonObject put(java.lang.String,java.lang.Object)>("verticle_name", v);
v = virtualinvoke v.<io.vertx.core.DeploymentOptions: io.vertx.core.json.JsonObject toJson()>();
virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonObject put(java.lang.String,java.lang.Object)>("options", v);
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
v = virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonArray getJsonArray(java.lang.String)>("verticles");
virtualinvoke v.<io.vertx.core.json.JsonArray: io.vertx.core.json.JsonArray add(java.lang.Object)>(v);
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.json.JsonObject haInfo>;
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String encode()>();
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void addToHADeployList(java.lang.String, io.vertx.core.DeploymentOptions, io.vertx.core.Handler)
{
io.vertx.core.DeploymentOptions v;
io.vertx.core.impl.HAManager v;
java.lang.String v;
java.util.Queue v;
io.vertx.core.Handler v;
java.lang.Runnable v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v := @parameter: io.vertx.core.DeploymentOptions;
v := @parameter: io.vertx.core.Handler;
v = v.<io.vertx.core.impl.HAManager: java.util.Queue toDeployOnQuorum>;
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_addToHADeployList_10__1517: java.lang.Runnable bootstrap$(io.vertx.core.impl.HAManager,java.lang.String,io.vertx.core.DeploymentOptions,io.vertx.core.Handler)>(v, v, v, v);
interfaceinvoke v.<java.util.Queue: boolean add(java.lang.Object)>(v);
return;
}
private void checkHADeployments()
{
io.vertx.core.impl.logging.Logger v;
java.lang.Throwable v;
io.vertx.core.impl.HAManager v;
boolean v;
v := @this: io.vertx.core.impl.HAManager;
label:
v = v.<io.vertx.core.impl.HAManager: boolean attainedQuorum>;
if v == 0 goto label;
specialinvoke v.<io.vertx.core.impl.HAManager: void deployHADeployments()>();
goto label;
label:
specialinvoke v.<io.vertx.core.impl.HAManager: void undeployHADeployments()>();
label:
goto label;
label:
v := @caughtexception;
v = <io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.Logger log>;
interfaceinvoke v.<io.vertx.core.impl.logging.Logger: void error(java.lang.Object,java.lang.Throwable)>("Failed when checking HA deploymentIDs", v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void undeployHADeployments()
{
io.vertx.core.impl.VertxInternal v;
java.util.Iterator v;
java.util.Set v;
io.vertx.core.impl.Deployment v;
io.vertx.core.DeploymentOptions v;
io.vertx.core.impl.DeploymentManager v, v;
io.vertx.core.impl.HAManager v;
java.lang.Object v;
io.vertx.core.Handler v;
boolean v, v;
v := @this: io.vertx.core.impl.HAManager;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.DeploymentManager deploymentManager>;
v = virtualinvoke v.<io.vertx.core.impl.DeploymentManager: java.util.Set deployments()>();
v = interfaceinvoke v.<java.util.Set: 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 = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.DeploymentManager deploymentManager>;
v = virtualinvoke v.<io.vertx.core.impl.DeploymentManager: io.vertx.core.impl.Deployment getDeployment(java.lang.String)>(v);
if v == null goto label;
v = interfaceinvoke v.<io.vertx.core.impl.Deployment: io.vertx.core.DeploymentOptions deploymentOptions()>();
v = virtualinvoke v.<io.vertx.core.DeploymentOptions: boolean isHa()>();
if v == 0 goto label;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_undeployHADeployments_13__1518: io.vertx.core.Handler bootstrap$(io.vertx.core.impl.HAManager,java.lang.String,io.vertx.core.impl.Deployment)>(v, v, v);
virtualinvoke v.<io.vertx.core.impl.VertxImpl: void executeIsolated(io.vertx.core.Handler)>(v);
goto label;
label:
return;
}
private void deployHADeployments()
{
io.vertx.core.impl.logging.Logger v, v;
java.lang.Throwable v;
int v;
io.vertx.core.impl.HAManager v;
java.lang.Object v;
java.lang.String v;
java.util.Queue v, v;
v := @this: io.vertx.core.impl.HAManager;
v = v.<io.vertx.core.impl.HAManager: java.util.Queue toDeployOnQuorum>;
v = interfaceinvoke v.<java.util.Queue: int size()>();
if v == 0 goto label;
v = <io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.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[])>("There are \u HA deploymentIDs waiting on a quorum. These will now be deployed");
interfaceinvoke v.<io.vertx.core.impl.logging.Logger: void info(java.lang.Object)>(v);
label:
v = v.<io.vertx.core.impl.HAManager: java.util.Queue toDeployOnQuorum>;
v = interfaceinvoke v.<java.util.Queue: java.lang.Object poll()>();
if v == null goto label;
label:
interfaceinvoke v.<java.lang.Runnable: void run()>();
label:
goto label;
label:
v := @caughtexception;
v = <io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.Logger log>;
interfaceinvoke v.<io.vertx.core.impl.logging.Logger: void error(java.lang.Object,java.lang.Throwable)>("Failed to run redeployment task", v);
goto label;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void checkFailover(java.lang.String, io.vertx.core.json.JsonObject)
{
java.lang.Throwable v;
java.lang.Runnable v, v;
java.util.Map v;
int v, v, v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v;
java.lang.String v, v, v, v, v, v;
boolean v, v;
io.vertx.core.impl.logging.Logger v, v;
java.util.Iterator v;
io.vertx.core.json.JsonArray v;
java.lang.Object v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v := @parameter: io.vertx.core.json.JsonObject;
label:
v = virtualinvoke v.<io.vertx.core.json.JsonObject: io.vertx.core.json.JsonArray getJsonArray(java.lang.String)>("verticles");
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String getString(java.lang.String)>("group");
v = virtualinvoke v.<java.lang.String: int hashCode()>();
v = specialinvoke v.<io.vertx.core.impl.HAManager: java.lang.String chooseHashedNode(java.lang.String,int)>(v, v);
if v == null goto label;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
if v == null goto label;
v = virtualinvoke v.<io.vertx.core.json.JsonArray: int size()>();
if v == 0 goto label;
v = <io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.Logger log>;
v = v.<io.vertx.core.impl.HAManager: java.lang.String nodeID>;
v = virtualinvoke v.<io.vertx.core.json.JsonArray: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,int)>(v, 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[])>("node\u says: Node \u has failed. This node will deploy \u deploymentIDs from that node.");
interfaceinvoke v.<io.vertx.core.impl.logging.Logger: void info(java.lang.Object)>(v);
v = virtualinvoke v.<io.vertx.core.json.JsonArray: 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.<io.vertx.core.impl.HAManager: void processFailover(io.vertx.core.json.JsonObject)>(v);
goto label;
label:
v = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_checkFailover_14__1519: java.lang.Runnable bootstrap$(io.vertx.core.impl.HAManager,java.lang.String,io.vertx.core.json.JsonObject)>(v, v, v);
specialinvoke v.<io.vertx.core.impl.HAManager: void runOnContextAndWait(java.lang.Runnable)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.Logger log>;
interfaceinvoke v.<io.vertx.core.impl.logging.Logger: void error(java.lang.Object,java.lang.Throwable)>("Failed to handle failover", v);
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_checkFailover_15__1520: java.lang.Runnable bootstrap$(io.vertx.core.impl.HAManager,java.lang.String,io.vertx.core.json.JsonObject)>(v, v, v);
specialinvoke v.<io.vertx.core.impl.HAManager: void runOnContextAndWait(java.lang.Runnable)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void runOnContextAndWait(java.lang.Runnable)
{
java.util.concurrent.TimeUnit v;
java.util.concurrent.CountDownLatch v;
io.vertx.core.impl.VertxInternal v;
java.lang.InterruptedException v;
io.vertx.core.impl.HAManager v;
io.vertx.core.Handler v;
java.lang.Runnable v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.Runnable;
v = new java.util.concurrent.CountDownLatch;
specialinvoke v.<java.util.concurrent.CountDownLatch: void <init>(int)>(1);
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_runOnContextAndWait_16__1521: io.vertx.core.Handler bootstrap$(java.lang.Runnable,java.util.concurrent.CountDownLatch)>(v, v);
interfaceinvoke v.<io.vertx.core.impl.VertxInternal: void runOnContext(io.vertx.core.Handler)>(v);
label:
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
virtualinvoke v.<java.util.concurrent.CountDownLatch: boolean await(long,java.util.concurrent.TimeUnit)>(30L, v);
label:
goto label;
label:
v := @caughtexception;
label:
return;
catch java.lang.InterruptedException from label to label with label;
}
private void processFailover(io.vertx.core.json.JsonObject)
{
io.vertx.core.VertxException v, v;
java.lang.IllegalStateException v;
io.vertx.core.impl.VertxInternal v;
java.util.concurrent.atomic.AtomicReference v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.CountDownLatch v;
java.lang.InterruptedException v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v;
java.lang.String v;
io.vertx.core.Handler v;
boolean v, v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: io.vertx.core.json.JsonObject;
v = v.<io.vertx.core.impl.HAManager: boolean failDuringFailover>;
if v == 0 goto label;
v = new io.vertx.core.VertxException;
specialinvoke v.<io.vertx.core.VertxException: void <init>(java.lang.String)>("Oops!");
throw v;
label:
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String getString(java.lang.String)>("verticle_name");
v = new java.util.concurrent.CountDownLatch;
specialinvoke v.<java.util.concurrent.CountDownLatch: void <init>(int)>(1);
v = new java.util.concurrent.atomic.AtomicReference;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>()>();
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.impl.VertxInternal vertx>;
v = staticinvoke <io.vertx.core.impl.HAManager$lambda_processFailover_18__1522: io.vertx.core.Handler bootstrap$(io.vertx.core.impl.HAManager,io.vertx.core.json.JsonObject,java.lang.String,java.util.concurrent.atomic.AtomicReference,java.util.concurrent.CountDownLatch)>(v, v, v, v, v);
virtualinvoke v.<io.vertx.core.impl.VertxImpl: void executeIsolated(io.vertx.core.Handler)>(v);
label:
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
v = virtualinvoke v.<java.util.concurrent.CountDownLatch: boolean await(long,java.util.concurrent.TimeUnit)>(120L, v);
if v != 0 goto label;
v = new io.vertx.core.VertxException;
specialinvoke v.<io.vertx.core.VertxException: void <init>(java.lang.String)>("Timed out waiting for redeploy on failover");
throw v;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
return;
catch java.lang.InterruptedException from label to label with label;
}
private java.lang.String chooseHashedNode(java.lang.String, int)
{
long v, v;
java.util.ArrayList v;
java.util.Map v;
int v, v;
io.vertx.core.impl.HAManager v;
io.vertx.core.json.JsonObject v;
java.lang.String v, v;
boolean v, v, v;
java.util.Iterator v;
io.vertx.core.spi.cluster.ClusterManager v;
java.util.List v;
java.lang.Object v, v, v;
v := @this: io.vertx.core.impl.HAManager;
v := @parameter: java.lang.String;
v := @parameter: int;
v = v.<io.vertx.core.impl.HAManager: io.vertx.core.spi.cluster.ClusterManager clusterManager>;
v = interfaceinvoke v.<io.vertx.core.spi.cluster.ClusterManager: java.util.List getNodes()>();
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 = v.<io.vertx.core.impl.HAManager: java.util.Map clusterMap>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = new io.vertx.core.json.JsonObject;
specialinvoke v.<io.vertx.core.json.JsonObject: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<io.vertx.core.json.JsonObject: java.lang.String getString(java.lang.String)>("group");
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
virtualinvoke v.<java.util.ArrayList: boolean add(java.lang.Object)>(v);
goto label;
label:
v = virtualinvoke v.<java.util.ArrayList: boolean isEmpty()>();
if v != 0 goto label;
v = v + 2147483647L;
v = virtualinvoke v.<java.util.ArrayList: int size()>();
v = v % v;
v = virtualinvoke v.<java.util.ArrayList: java.lang.Object get(int)>(v);
return v;
label:
return null;
}
static void <clinit>()
{
io.vertx.core.impl.logging.Logger v;
v = staticinvoke <io.vertx.core.impl.logging.LoggerFactory: io.vertx.core.impl.logging.Logger getLogger(java.lang.Class)>(class "Lio/vertx/core/impl/HAManager;");
<io.vertx.core.impl.HAManager: io.vertx.core.impl.logging.Logger log> = v;
return;
}
}