class com.novell.ldapchai.provider.FailOverRotationMachine extends java.lang.Object
{
private static final com.novell.ldapchai.util.internal.ChaiLogger LOGGER;
private java.time.Instant lastFailureTime;
private final java.util.List providerSlots;
private final java.util.concurrent.atomic.AtomicInteger activeSlot;
private final com.novell.ldapchai.provider.FailOverSettings settings;
private final com.novell.ldapchai.provider.ChaiProviderFactory providerFactory;
private final com.novell.ldapchai.provider.ChaiConfiguration originalConfiguration;
private final int urlListHashCode;
private static final java.util.Map LAST_KNOWN_GOOD_CACHE;
private static final int MAX_SIZE_LNG_CACHE;
private static long lngLastPopulateTime;
private java.lang.Exception lastConnectionException;
private volatile com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState;
void <init>(com.novell.ldapchai.provider.ChaiProviderFactory, com.novell.ldapchai.provider.ChaiConfiguration, com.novell.ldapchai.provider.FailOverSettings) throws com.novell.ldapchai.exception.ChaiUnavailableException
{
com.novell.ldapchai.provider.ChaiConfiguration v;
java.time.Instant v;
com.novell.ldapchai.provider.ChaiProviderFactory v;
com.novell.ldapchai.provider.FailOverRotationMachine v;
java.util.List v;
java.util.concurrent.atomic.AtomicInteger v;
int v;
com.novell.ldapchai.provider.FailOverRotationMachine$FailState v;
com.novell.ldapchai.provider.FailOverSettings v;
java.util.concurrent.CopyOnWriteArrayList v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
v := @parameter: com.novell.ldapchai.provider.ChaiProviderFactory;
v := @parameter: com.novell.ldapchai.provider.ChaiConfiguration;
v := @parameter: com.novell.ldapchai.provider.FailOverSettings;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <java.time.Instant: java.time.Instant now()>();
v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.time.Instant lastFailureTime> = v;
v = new java.util.concurrent.CopyOnWriteArrayList;
specialinvoke v.<java.util.concurrent.CopyOnWriteArrayList: void <init>()>();
v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot> = v;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState NEW>;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState> = v;
v = virtualinvoke v.<com.novell.ldapchai.provider.ChaiConfiguration: java.util.List bindURLsAsList()>();
v = interfaceinvoke v.<java.util.List: int hashCode()>();
v.<com.novell.ldapchai.provider.FailOverRotationMachine: int urlListHashCode> = v;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverSettings settings> = v;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.ChaiProviderFactory providerFactory> = v;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.ChaiConfiguration originalConfiguration> = v;
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void configureInitialState(com.novell.ldapchai.provider.ChaiConfiguration)>(v);
return;
}
private void setActiveSlot(int)
{
long v;
java.lang.Integer v, v;
java.util.function.Supplier v;
java.util.concurrent.atomic.AtomicInteger v;
java.util.Map v, v, v;
int v, v, v;
boolean v;
java.util.Iterator v;
com.novell.ldapchai.provider.ChaiConfiguration v;
java.util.Set v;
com.novell.ldapchai.provider.ChaiSetting v;
com.novell.ldapchai.provider.FailOverRotationMachine v;
com.novell.ldapchai.util.internal.ChaiLogger v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
v := @parameter: int;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(v);
if v == 0 goto label;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.ChaiConfiguration originalConfiguration>;
v = <com.novell.ldapchai.provider.ChaiSetting: com.novell.ldapchai.provider.ChaiSetting FAILOVER_USE_LAST_KNOWN_GOOD_HINT>;
v = virtualinvoke v.<com.novell.ldapchai.provider.ChaiConfiguration: boolean getBooleanSetting(com.novell.ldapchai.provider.ChaiSetting)>(v);
if v == 0 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine: java.util.Map LAST_KNOWN_GOOD_CACHE>;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: int urlListHashCode>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
<com.novell.ldapchai.provider.FailOverRotationMachine: long lngLastPopulateTime> = v;
label:
v = <com.novell.ldapchai.provider.FailOverRotationMachine: java.util.Map LAST_KNOWN_GOOD_CACHE>;
v = interfaceinvoke v.<java.util.Map: int size()>();
if v <= 50 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine: java.util.Map LAST_KNOWN_GOOD_CACHE>;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
interfaceinvoke v.<java.util.Iterator: void remove()>();
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_setActiveSlot_0__130: java.util.function.Supplier bootstrap$()>();
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void warn(java.util.function.Supplier)>(v);
goto label;
label:
return;
}
private void configureInitialState(com.novell.ldapchai.provider.ChaiConfiguration)
{
java.lang.Integer v, v;
byte v;
java.util.concurrent.atomic.AtomicInteger v;
java.util.Map v, v, v, v;
boolean v, v, v, v;
com.novell.ldapchai.provider.ChaiConfiguration$ChaiConfigurationBuilder v, v;
com.novell.ldapchai.provider.FailOverRotationMachine v;
java.util.List v, v;
com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot v;
com.novell.ldapchai.util.internal.ChaiLogger v;
long v, v, v;
java.util.function.Supplier v;
int v, v, v, v;
com.novell.ldapchai.provider.FailOverSettings v;
java.util.Iterator v;
com.novell.ldapchai.provider.ChaiConfiguration v, v, v;
com.novell.ldapchai.provider.ChaiSetting v, v;
java.lang.Object v, v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
v := @parameter: com.novell.ldapchai.provider.ChaiConfiguration;
v = virtualinvoke v.<com.novell.ldapchai.provider.ChaiConfiguration: java.util.List bindURLsAsList()>();
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 = staticinvoke <com.novell.ldapchai.provider.ChaiConfiguration: com.novell.ldapchai.provider.ChaiConfiguration$ChaiConfigurationBuilder builder(com.novell.ldapchai.provider.ChaiConfiguration)>(v);
v = <com.novell.ldapchai.provider.ChaiSetting: com.novell.ldapchai.provider.ChaiSetting BIND_URLS>;
v = virtualinvoke v.<com.novell.ldapchai.provider.ChaiConfiguration$ChaiConfigurationBuilder: com.novell.ldapchai.provider.ChaiConfiguration$ChaiConfigurationBuilder setSetting(com.novell.ldapchai.provider.ChaiSetting,java.lang.String)>(v, v);
v = virtualinvoke v.<com.novell.ldapchai.provider.ChaiConfiguration$ChaiConfigurationBuilder: com.novell.ldapchai.provider.ChaiConfiguration build()>();
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = new com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot;
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot: void <init>(com.novell.ldapchai.provider.ChaiConfiguration,java.lang.String)>(v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
goto label;
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.ChaiConfiguration originalConfiguration>;
v = <com.novell.ldapchai.provider.ChaiSetting: com.novell.ldapchai.provider.ChaiSetting FAILOVER_USE_LAST_KNOWN_GOOD_HINT>;
v = virtualinvoke v.<com.novell.ldapchai.provider.ChaiConfiguration: boolean getBooleanSetting(com.novell.ldapchai.provider.ChaiSetting)>(v);
if v == 0 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine: java.util.Map LAST_KNOWN_GOOD_CACHE>;
v = interfaceinvoke v.<java.util.Map: boolean isEmpty()>();
if v != 0 goto label;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = <com.novell.ldapchai.provider.FailOverRotationMachine: long lngLastPopulateTime>;
v = v - v;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverSettings settings>;
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverSettings: int getMinFailBackTime()>();
v = v cmp v;
if v <= 0 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine: java.util.Map LAST_KNOWN_GOOD_CACHE>;
interfaceinvoke v.<java.util.Map: void clear()>();
label:
v = <com.novell.ldapchai.provider.FailOverRotationMachine: java.util.Map LAST_KNOWN_GOOD_CACHE>;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: int urlListHashCode>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = <com.novell.ldapchai.provider.FailOverRotationMachine: java.util.Map LAST_KNOWN_GOOD_CACHE>;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: int urlListHashCode>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: void set(int)>(v);
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_configureInitialState_1__131: java.util.function.Supplier bootstrap$(com.novell.ldapchai.provider.FailOverRotationMachine)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void debug(java.util.function.Supplier)>(v);
label:
return;
}
com.novell.ldapchai.provider.ChaiProvider getCurrentProvider() throws com.novell.ldapchai.exception.ChaiUnavailableException
{
java.util.concurrent.atomic.AtomicInteger v, v, v;
boolean v;
java.lang.Exception v, v, v, v;
com.novell.ldapchai.provider.FailOverRotationMachine v;
java.util.List v, v, v;
com.novell.ldapchai.exception.ChaiUnavailableException v, v, v;
java.lang.StringBuilder v;
com.novell.ldapchai.provider.ChaiProviderImplementor v, v;
int v, v, v, v;
java.lang.String v, v, v;
com.novell.ldapchai.provider.FailOverSettings v;
com.novell.ldapchai.provider.ChaiConfiguration v;
com.novell.ldapchai.exception.ChaiError v;
java.lang.Object v, v;
com.novell.ldapchai.provider.FailOverRotationMachine$FailState v, v, v, v, v, v, v, v, v, v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void failbackCheck()>();
v = null;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState>;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState NEW>;
if v != v goto label;
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void makeNewProvider(int)>(v);
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState OKAY>;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState> = v;
label:
goto label;
label:
v := @caughtexception;
v = v;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverSettings settings>;
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverSettings: boolean errorIsRetryable(java.lang.Exception)>(v);
if v == 0 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState FAILED>;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState> = v;
goto label;
label:
throw v;
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState>;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState OKAY>;
if v != v goto label;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot: com.novell.ldapchai.provider.ChaiProviderImplementor getProvider()>();
return v;
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState>;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState FAILED>;
if v != v goto label;
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void currentServerIsBroken(java.lang.Exception)>(v);
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState>;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState OKAY>;
if v != v goto label;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot: com.novell.ldapchai.provider.ChaiProviderImplementor getProvider()>();
return v;
label:
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.ChaiConfiguration originalConfiguration>;
v = virtualinvoke v.<com.novell.ldapchai.provider.ChaiConfiguration: java.util.List bindURLsAsList()>();
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 1 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("unable to connect to any configured ldap url");
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.lang.Exception lastConnectionException>;
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", last error: ");
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.lang.Exception lastConnectionException>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("unable to connect to ldap url");
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.lang.Exception lastConnectionException>;
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(", error: ");
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.lang.Exception lastConnectionException>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
v = new com.novell.ldapchai.exception.ChaiUnavailableException;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = <com.novell.ldapchai.exception.ChaiError: com.novell.ldapchai.exception.ChaiError COMMUNICATION>;
specialinvoke v.<com.novell.ldapchai.exception.ChaiUnavailableException: void <init>(java.lang.String,com.novell.ldapchai.exception.ChaiError)>(v, v);
throw v;
catch com.novell.ldapchai.exception.ChaiUnavailableException from label to label with label;
}
void reportBrokenProvider(com.novell.ldapchai.provider.ChaiProvider, java.lang.Exception)
{
com.novell.ldapchai.provider.ChaiProviderImplementor v;
java.lang.Exception v;
com.novell.ldapchai.provider.ChaiProvider v;
com.novell.ldapchai.provider.FailOverRotationMachine v;
java.util.List v;
java.util.concurrent.atomic.AtomicInteger v;
int v;
java.lang.Object v;
boolean v;
com.novell.ldapchai.provider.FailOverRotationMachine$FailState v, v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
v := @parameter: com.novell.ldapchai.provider.ChaiProvider;
v := @parameter: java.lang.Exception;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState>;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState OKAY>;
if v == v goto label;
return;
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot: com.novell.ldapchai.provider.ChaiProviderImplementor getProvider()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.Object: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void currentServerIsBroken(java.lang.Exception)>(v);
label:
return;
}
private void failbackCheck()
{
long v;
java.time.Instant v, v;
com.novell.ldapchai.provider.FailOverRotationMachine v;
byte v;
java.util.concurrent.atomic.AtomicInteger v;
java.time.Duration v;
int v, v;
com.novell.ldapchai.provider.FailOverRotationMachine$FailState v, v, v;
com.novell.ldapchai.provider.FailOverSettings v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState>;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState OKAY>;
if v != v goto label;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v == 0 goto label;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.time.Instant lastFailureTime>;
v = staticinvoke <java.time.Instant: java.time.Instant now()>();
v = staticinvoke <java.time.Duration: java.time.Duration between(java.time.temporal.Temporal,java.time.temporal.Temporal)>(v, v);
v = virtualinvoke v.<java.time.Duration: long toMillis()>();
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverSettings settings>;
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverSettings: int getMinFailBackTime()>();
v = v cmp v;
if v <= 0 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState NEW>;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState> = v;
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void setActiveSlot(int)>(0);
label:
return;
}
private void currentServerIsBroken(java.lang.Exception)
{
java.util.concurrent.atomic.AtomicInteger v, v, v;
java.time.Duration v;
boolean v, v;
java.time.Instant v, v, v;
java.lang.Exception v;
com.novell.ldapchai.provider.FailOverRotationMachine v;
java.util.List v, v, v, v;
com.novell.ldapchai.exception.ChaiUnavailableException v;
com.novell.ldapchai.util.internal.ChaiLogger v, v, v, v, v, v;
java.lang.Throwable v;
com.novell.ldapchai.provider.ChaiProviderImplementor v;
java.util.function.Supplier v, v, v, v, v, v;
int v, v, v, v, v, v, v, v, v, v, v, v;
com.novell.ldapchai.provider.FailOverSettings v, v;
com.novell.ldapchai.provider.FailOverRotationMachine$FailState v, v, v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
v := @parameter: java.lang.Exception;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 1 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_currentServerIsBroken_2__135: java.util.function.Supplier bootstrap$(com.novell.ldapchai.provider.FailOverRotationMachine,java.lang.Exception)>(v, v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void warn(java.util.function.Supplier)>(v);
goto label;
label:
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_currentServerIsBroken_3__132: java.util.function.Supplier bootstrap$(com.novell.ldapchai.provider.FailOverRotationMachine,java.lang.Exception)>(v, v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void warn(java.util.function.Supplier)>(v);
label:
v = staticinvoke <java.time.Instant: java.time.Instant now()>();
v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.time.Instant lastFailureTime> = v;
v = 0;
label:
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState SEEKING>;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState> = v;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = 0;
label:
if v != 0 goto label;
if v >= v goto label;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v + 1;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = v - 1;
if v <= v goto label;
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void setActiveSlot(int)>(0);
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverSettings settings>;
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverSettings: int getRotateDelay()>();
staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine: void pause(long)>(v);
goto label;
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v + 1;
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void setActiveSlot(int)>(v);
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 1 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_currentServerIsBroken_4__134: java.util.function.Supplier bootstrap$(com.novell.ldapchai.provider.FailOverRotationMachine)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void debug(java.util.function.Supplier)>(v);
label:
v = staticinvoke <java.time.Instant: java.time.Instant now()>();
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.concurrent.atomic.AtomicInteger activeSlot>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
specialinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void makeNewProvider(int)>(v);
v = 1;
label:
goto label;
label:
v := @caughtexception;
v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.lang.Exception lastConnectionException> = v;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverSettings settings>;
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverSettings: com.novell.ldapchai.provider.ChaiProviderImplementor getFailOverHelper()>();
v = interfaceinvoke v.<com.novell.ldapchai.provider.ChaiProviderImplementor: boolean errorIsRetryable(java.lang.Exception)>(v);
if v == 0 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_currentServerIsBroken_5__137: java.util.function.Supplier bootstrap$(com.novell.ldapchai.exception.ChaiUnavailableException)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void debug(java.util.function.Supplier)>(v);
goto label;
label:
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_currentServerIsBroken_6__136: java.util.function.Supplier bootstrap$(com.novell.ldapchai.exception.ChaiUnavailableException)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void debug(java.util.function.Supplier)>(v);
goto label;
label:
v = staticinvoke <java.time.Instant: java.time.Instant now()>();
v = staticinvoke <java.time.Duration: java.time.Duration between(java.time.temporal.Temporal,java.time.temporal.Temporal)>(v, v);
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_currentServerIsBroken_7__133: java.util.function.Supplier bootstrap$(com.novell.ldapchai.provider.FailOverRotationMachine)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void debug(java.util.function.Supplier,java.time.Duration)>(v, v);
v = v + 1;
goto label;
label:
if v == 0 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState OKAY>;
goto label;
label:
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState FAILED>;
label:
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState> = v;
goto label;
label:
v := @caughtexception;
if v == 0 goto label;
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState OKAY>;
goto label;
label:
v = <com.novell.ldapchai.provider.FailOverRotationMachine$FailState: com.novell.ldapchai.provider.FailOverRotationMachine$FailState FAILED>;
label:
v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.FailOverRotationMachine$FailState failState> = v;
throw v;
label:
return;
catch com.novell.ldapchai.exception.ChaiUnavailableException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void makeNewProvider(int) throws com.novell.ldapchai.exception.ChaiUnavailableException
{
java.lang.IllegalStateException v;
com.novell.ldapchai.provider.ChaiConfiguration v;
com.novell.ldapchai.provider.ChaiProviderImplementor v;
java.util.function.Supplier v;
java.lang.Exception v;
com.novell.ldapchai.provider.ChaiProviderFactory v;
com.novell.ldapchai.provider.FailOverRotationMachine v;
java.util.List v;
int v;
com.novell.ldapchai.exception.ChaiUnavailableException v;
java.lang.Object v;
java.lang.String v, v;
com.novell.ldapchai.util.internal.ChaiLogger v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
v := @parameter: int;
virtualinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine: void destoryAllConnections()>();
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
label:
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.provider.ChaiProviderFactory providerFactory>;
v = virtualinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot: com.novell.ldapchai.provider.ChaiConfiguration getConfig()>();
v = staticinvoke <com.novell.ldapchai.provider.ChaiProviderFactory: com.novell.ldapchai.provider.ChaiProviderImplementor createConcreteProvider(com.novell.ldapchai.provider.ChaiProviderFactory,com.novell.ldapchai.provider.ChaiConfiguration,boolean)>(v, v, 1);
virtualinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot: void setProvider(com.novell.ldapchai.provider.ChaiProviderImplementor)>(v);
label:
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("unexpected error creating new FailOver ChaiProvider: \u0001");
v = <com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER>;
v = staticinvoke <com.novell.ldapchai.provider.FailOverRotationMachine$lambda_makeNewProvider_8__138: java.util.function.Supplier bootstrap$(java.lang.String)>(v);
virtualinvoke v.<com.novell.ldapchai.util.internal.ChaiLogger: void error(java.util.function.Supplier)>(v);
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch com.novell.ldapchai.exception.ChaiUnavailableException from label to label with label;
catch java.lang.Exception from label to label with label;
}
public void destoryAllConnections()
{
com.novell.ldapchai.provider.FailOverRotationMachine v;
java.util.List v;
java.util.Iterator v;
java.lang.Object v;
com.novell.ldapchai.provider.ChaiProviderImplementor v;
boolean v;
v := @this: com.novell.ldapchai.provider.FailOverRotationMachine;
v = v.<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.List providerSlots>;
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 = virtualinvoke v.<com.novell.ldapchai.provider.FailOverRotationMachine$ProviderSlot: com.novell.ldapchai.provider.ChaiProviderImplementor getProvider()>();
if v == null goto label;
interfaceinvoke v.<com.novell.ldapchai.provider.ChaiProvider: void close()>();
goto label;
label:
return;
}
private static void pause(long)
{
long v, v, v, v, v, v, v, v;
byte v, v;
java.lang.InterruptedException v;
v := @parameter: long;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
label:
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
v = v - v;
v = v cmp 0L;
if v <= 0 goto label;
v = v;
goto label;
label:
v = 10L;
label:
staticinvoke <java.lang.Thread: void sleep(long)>(v);
label:
goto label;
label:
v := @caughtexception;
label:
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
v = v cmp v;
if v < 0 goto label;
return;
catch java.lang.InterruptedException from label to label with label;
}
static void <clinit>()
{
java.util.concurrent.ConcurrentHashMap v;
long v;
com.novell.ldapchai.util.internal.ChaiLogger v;
v = staticinvoke <com.novell.ldapchai.util.internal.ChaiLogger: com.novell.ldapchai.util.internal.ChaiLogger getLogger(java.lang.Class)>(class "Lcom/novell/ldapchai/provider/FailOverRotationMachine;");
<com.novell.ldapchai.provider.FailOverRotationMachine: com.novell.ldapchai.util.internal.ChaiLogger LOGGER> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
<com.novell.ldapchai.provider.FailOverRotationMachine: java.util.Map LAST_KNOWN_GOOD_CACHE> = v;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
<com.novell.ldapchai.provider.FailOverRotationMachine: long lngLastPopulateTime> = v;
return;
}
}