public class io.fabric.kubernetes.client.extended.leaderelection.LeaderElector extends java.lang.Object
{
private static final org.slf4j.Logger LOGGER;
protected static final java.lang.Double JITTER_FACTOR;
private io.fabric.kubernetes.client.KubernetesClient kubernetesClient;
private io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig;
private final java.util.concurrent.atomic.AtomicReference observedRecord;
private final java.util.concurrent.atomic.AtomicReference observedTime;
private final java.util.concurrent.Executor executor;
public void <init>(io.fabric.kubernetes.client.KubernetesClient, io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig, java.util.concurrent.Executor)
{
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.util.concurrent.Executor v;
io.fabric.kubernetes.client.KubernetesClient v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v;
java.util.concurrent.atomic.AtomicReference v, v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v := @parameter: io.fabric.kubernetes.client.KubernetesClient;
v := @parameter: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig;
v := @parameter: java.util.concurrent.Executor;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.atomic.AtomicReference;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>()>();
v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.atomic.AtomicReference observedRecord> = v;
v = new java.util.concurrent.atomic.AtomicReference;
specialinvoke v.<java.util.concurrent.atomic.AtomicReference: void <init>()>();
v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.atomic.AtomicReference observedTime> = v;
v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.KubernetesClient kubernetesClient> = v;
v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig> = v;
v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.Executor executor> = v;
return;
}
public void run()
{
java.util.concurrent.ExecutionException v;
org.slf4j.Logger v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.lang.InterruptedException v;
java.lang.Thread v;
java.util.concurrent.CompletableFuture v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.CompletableFuture start()>();
label:
virtualinvoke v.<java.util.concurrent.CompletableFuture: java.lang.Object get()>();
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<java.util.concurrent.CompletableFuture: boolean cancel(boolean)>(1);
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
goto label;
label:
v := @caughtexception;
v = <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Exception during leader election", v);
label:
return;
catch java.lang.InterruptedException from label to label with label;
catch java.util.concurrent.ExecutionException from label to label with label;
}
public java.util.concurrent.CompletableFuture start()
{
org.slf4j.Logger v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.util.function.BiConsumer v, v;
java.util.concurrent.CompletableFuture v, v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v = <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Leader election started");
v = new java.util.concurrent.CompletableFuture;
specialinvoke v.<java.util.concurrent.CompletableFuture: void <init>()>();
v = specialinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.CompletableFuture acquire()>();
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector$lambda_start_2__10: java.util.function.BiConsumer bootstrap$(io.fabric.kubernetes.client.extended.leaderelection.LeaderElector,java.util.concurrent.CompletableFuture)>(v, v);
virtualinvoke v.<java.util.concurrent.CompletableFuture: java.util.concurrent.CompletableFuture whenComplete(java.util.function.BiConsumer)>(v);
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector$lambda_start_3__11: java.util.function.BiConsumer bootstrap$(java.util.concurrent.CompletableFuture)>(v);
virtualinvoke v.<java.util.concurrent.CompletableFuture: java.util.concurrent.CompletableFuture whenComplete(java.util.function.BiConsumer)>(v);
return v;
}
private void stopLeading()
{
java.lang.Throwable v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v, v, v;
java.util.concurrent.atomic.AtomicReference v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks v, v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.lang.Object v;
boolean v, v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.atomic.AtomicReference observedRecord>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object get()>();
if v == null goto label;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: boolean isLeader(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v);
if v != 0 goto label;
label:
return;
label:
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: boolean isReleaseOnCancel()>();
if v == 0 goto label;
specialinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: void release(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v);
label:
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks getLeaderCallbacks()>();
virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks: void onStopLeading()>();
goto label;
label:
v := @caughtexception;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks getLeaderCallbacks()>();
virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks: void onStopLeading()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void release(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)
{
org.slf4j.Logger v;
java.time.ZonedDateTime v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v, v;
java.lang.Exception v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock v, v;
java.io.Serializable v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord v, v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.time.Duration v;
int v;
io.fabric.kubernetes.client.KubernetesClient v;
java.lang.String v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v := @parameter: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord;
label:
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.time.ZonedDateTime now()>();
v = new io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord;
v = staticinvoke <java.time.Duration: java.time.Duration ofSeconds(long)>(1L);
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: int getLeaderTransitions()>();
specialinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: void <init>(java.lang.String,java.time.Duration,java.time.ZonedDateTime,java.time.ZonedDateTime,int)>(null, v, v, v, v);
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.io.Serializable getVersion()>();
virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: void setVersion(java.io.Serializable)>(v);
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.KubernetesClient kubernetesClient>;
interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: void update(io.fabric.kubernetes.client.KubernetesClient,io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String describe()>();
v = <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("Exception occurred while releasing lock \'{}\'", v, v);
label:
return;
catch io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LockException from label to label with label;
catch io.fabric.kubernetes.client.KubernetesClientException from label to label with label;
}
private java.util.concurrent.CompletableFuture acquire()
{
org.slf4j.Logger v;
java.util.concurrent.Executor v;
java.util.concurrent.CompletableFuture v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v;
java.util.function.Supplier v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock v;
java.util.function.Consumer v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.lang.String v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String describe()>();
v = <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Attempting to acquire leader lease \'{}\'...", v);
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector$lambda_acquire_4__12: java.util.function.Consumer bootstrap$(io.fabric.kubernetes.client.extended.leaderelection.LeaderElector,java.lang.String)>(v, v);
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector$lambda_acquire_5__13: java.util.function.Supplier bootstrap$(io.fabric.kubernetes.client.extended.leaderelection.LeaderElector)>(v);
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.Executor executor>;
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.CompletableFuture loop(java.util.function.Consumer,java.util.function.Supplier,java.util.concurrent.Executor)>(v, v, v);
return v;
}
private java.util.concurrent.CompletableFuture renewWithTimeout()
{
org.slf4j.Logger v;
java.util.concurrent.Executor v;
java.util.concurrent.CompletableFuture v;
long v, v, v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v, v;
java.util.function.Supplier v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock v;
java.util.function.Consumer v;
java.util.concurrent.atomic.AtomicLong v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.time.Duration v;
java.lang.String v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String describe()>();
v = <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Attempting to renew leader lease \'{}\'...", v);
v = new java.util.concurrent.atomic.AtomicLong;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: java.time.Duration getRenewDeadline()>();
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
v = v + v;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>(long)>(v);
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector$lambda_renewWithTimeout_6__14: java.util.function.Consumer bootstrap$(io.fabric.kubernetes.client.extended.leaderelection.LeaderElector,java.util.concurrent.atomic.AtomicLong,java.lang.String)>(v, v, v);
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector$lambda_renewWithTimeout_7__15: java.util.function.Supplier bootstrap$(io.fabric.kubernetes.client.extended.leaderelection.LeaderElector)>(v);
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.Executor executor>;
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.CompletableFuture loop(java.util.function.Consumer,java.util.function.Supplier,java.util.concurrent.Executor)>(v, v, v);
return v;
}
boolean tryAcquireOrRenew() throws io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LockException
{
java.time.ZonedDateTime v, v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v, v, v, v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord v, v, v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.time.Duration v, v;
int v, v;
java.lang.String v, v, v;
boolean v, v, v;
org.slf4j.Logger v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock v, v;
java.io.Serializable v;
io.fabric.kubernetes.client.KubernetesClient v, v, v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.time.ZonedDateTime now()>();
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.KubernetesClient kubernetesClient>;
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord get(io.fabric.kubernetes.client.KubernetesClient)>(v);
if v != null goto label;
v = new io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord;
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String identity()>();
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: java.time.Duration getLeaseDuration()>();
specialinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: void <init>(java.lang.String,java.time.Duration,java.time.ZonedDateTime,java.time.ZonedDateTime,int)>(v, v, v, v, 0);
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.KubernetesClient kubernetesClient>;
interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: void create(io.fabric.kubernetes.client.KubernetesClient,io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v, v);
specialinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: void updateObserved(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v);
return 1;
label:
specialinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: void updateObserved(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v);
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: boolean isLeader(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v);
if v != 0 goto label;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: boolean canBecomeLeader(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v);
if v != 0 goto label;
v = <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.lang.String getHolderIdentity()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Lock is held by {} and has not yet expired", v);
return 0;
label:
v = new io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord;
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String identity()>();
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: java.time.Duration getLeaseDuration()>();
if v == 0 goto label;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.time.ZonedDateTime getAcquireTime()>();
goto label;
label:
v = v;
label:
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: int getLeaderTransitions()>();
if v == 0 goto label;
v = 0;
goto label;
label:
v = 1;
label:
v = v + v;
specialinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: void <init>(java.lang.String,java.time.Duration,java.time.ZonedDateTime,java.time.ZonedDateTime,int)>(v, v, v, v, v);
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.io.Serializable getVersion()>();
virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: void setVersion(java.io.Serializable)>(v);
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.KubernetesClient kubernetesClient>;
interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: void update(io.fabric.kubernetes.client.KubernetesClient,io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v, v);
specialinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: void updateObserved(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)>(v);
return 1;
}
private void updateObserved(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)
{
java.time.LocalDateTime v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v, v, v, v, v, v;
java.util.concurrent.atomic.AtomicReference v, v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks v, v, v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.lang.String v, v, v, v, v;
boolean v, v, v, v;
org.slf4j.Logger v, v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock v, v, v;
java.lang.Object v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v := @parameter: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.atomic.AtomicReference observedRecord>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: java.lang.Object getAndSet(java.lang.Object)>(v);
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v != 0 goto label;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.util.concurrent.atomic.AtomicReference observedTime>;
v = staticinvoke <java.time.LocalDateTime: java.time.LocalDateTime now()>();
virtualinvoke v.<java.util.concurrent.atomic.AtomicReference: void set(java.lang.Object)>(v);
if v != null goto label;
v = null;
goto label;
label:
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.lang.String getHolderIdentity()>();
label:
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.lang.String getHolderIdentity()>();
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v != 0 goto label;
v = <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Leader changed from {} to {}", v, v);
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks getLeaderCallbacks()>();
virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks: void onNewLeader(java.lang.String)>(v);
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String identity()>();
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks getLeaderCallbacks()>();
virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks: void onStopLeading()>();
goto label;
label:
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String identity()>();
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER>;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String describe()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("Successfully Acquired leader lease \'{}\'", v);
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks getLeaderCallbacks()>();
virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderCallbacks: void onStartLeading()>();
label:
return;
}
protected final boolean isLeader(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)
{
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.lang.String v, v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v;
boolean v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v := @parameter: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord;
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock getLock()>();
v = interfaceinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.Lock: java.lang.String identity()>();
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.lang.String getHolderIdentity()>();
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
return v;
}
protected final boolean canBecomeLeader(io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord)
{
java.time.ZonedDateTime v, v, v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig v;
io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord v;
io.fabric.kubernetes.client.extended.leaderelection.LeaderElector v;
java.time.Duration v;
java.lang.String v;
boolean v, v, v;
v := @this: io.fabric.kubernetes.client.extended.leaderelection.LeaderElector;
v := @parameter: io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.lang.String getHolderIdentity()>();
v = staticinvoke <io.fabric.kubernetes.client.utils.Utils: boolean isNullOrEmpty(java.lang.String)>(v);
if v != 0 goto label;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.resourcelock.LeaderElectionRecord: java.time.ZonedDateTime getRenewTime()>();
v = v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig leaderElectionConfig>;
v = virtualinvoke v.<io.fabric.kubernetes.client.extended.leaderelection.LeaderElectionConfig: java.time.Duration getLeaseDuration()>();
v = virtualinvoke v.<java.time.ZonedDateTime: java.time.ZonedDateTime plus(java.time.temporal.TemporalAmount)>(v);
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.time.ZonedDateTime now()>();
v = virtualinvoke v.<java.time.ZonedDateTime: boolean isAfter(java.time.chrono.ChronoZonedDateTime)>(v);
if v != 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
protected static java.util.concurrent.CompletableFuture loop(java.util.function.Consumer, java.util.function.Supplier, java.util.concurrent.Executor)
{
java.util.concurrent.TimeUnit v;
java.util.function.Consumer v;
java.util.concurrent.Executor v;
java.util.concurrent.CompletableFuture v;
java.lang.Runnable v;
java.util.function.Supplier v;
v := @parameter: java.util.function.Consumer;
v := @parameter: java.util.function.Supplier;
v := @parameter: java.util.concurrent.Executor;
v = new java.util.concurrent.CompletableFuture;
specialinvoke v.<java.util.concurrent.CompletableFuture: void <init>()>();
v = staticinvoke <io.fabric.kubernetes.client.extended.leaderelection.LeaderElector$lambda_loop_8__16: java.lang.Runnable bootstrap$(java.util.function.Consumer,java.util.concurrent.CompletableFuture)>(v, v);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
staticinvoke <io.fabric.kubernetes.client.utils.Utils: void scheduleWithVariableRate(java.util.concurrent.CompletableFuture,java.util.concurrent.Executor,java.lang.Runnable,long,java.util.function.Supplier,java.util.concurrent.TimeUnit)>(v, v, v, 0L, v, v);
return v;
}
protected static java.time.ZonedDateTime now()
{
java.time.ZoneOffset v;
java.time.ZonedDateTime v;
v = <java.time.ZoneOffset: java.time.ZoneOffset UTC>;
v = staticinvoke <java.time.ZonedDateTime: java.time.ZonedDateTime now(java.time.ZoneId)>(v);
return v;
}
protected static java.time.Duration jitter(java.time.Duration, double)
{
java.lang.Double v;
long v, v;
byte v;
java.time.Duration v, v;
double v, v, v, v, v;
v := @parameter: java.time.Duration;
v := @parameter: double;
v = v cmpl 0.0;
if v <= 0 goto label;
v = v;
goto label;
label:
v = 1.0;
label:
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
v = staticinvoke <java.lang.Math: double random()>();
v = v * v;
v = v * v;
v = staticinvoke <java.lang.Double: java.lang.Double valueOf(double)>(v);
v = virtualinvoke v.<java.lang.Double: long longValue()>();
v = virtualinvoke v.<java.time.Duration: java.time.Duration plusMillis(long)>(v);
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
java.lang.Double v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lio/fabric8/kubernetes/client/extended/leaderelection/LeaderElector;");
<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: org.slf4j.Logger LOGGER> = v;
v = staticinvoke <java.lang.Double: java.lang.Double valueOf(double)>(1.2);
<io.fabric.kubernetes.client.extended.leaderelection.LeaderElector: java.lang.Double JITTER_FACTOR> = v;
return;
}
}